/*
Theme Name: S2RJ Hub
Template: s2rj-base
Version: 1.0.0
Description: S2RJ コーポレート+EC ハブサイト子テーマ。デスクトップ1200px/モバイル対応（モック s2rj-hub-mock.png 準拠）。
*/

body.s2rj-hub { font-size: 14px; }
body.s2rj-hub .site-main { padding-top: 0; }
.hub-inner { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* ─── HERO ─── */
/* セクション枠のみ保持。演出本体(canvas/overlay/preloader/gate)のスタイルは assets/css/s2rj-hero.css。
   高さは既定 72svh（フォールバック）。WebGL稼働時のみ s2rj-hero.css が 100svh に拡張する。 */
.hub-hero { position: relative; height: 72svh; min-height: 480px; overflow: hidden; border-bottom: 1px solid rgba(196,240,0,.2); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ─── セクション ─── */
body.s2rj-hub section.hub-section { padding: 70px 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.hub-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 28px; }
.hub-title { font-family: 'Bebas Neue', sans-serif; font-size: 38px; letter-spacing: 2px; margin: 0; border-left: 3px solid var(--s2rj-lime); padding-left: 14px; font-weight: 400; }
.hub-title small { display: block; font-family: 'Noto Sans JP', sans-serif; font-size: 10px; letter-spacing: 3px; color: var(--s2rj-lime); }
.hub-more { font-size: 11px; letter-spacing: 2px; color: var(--s2rj-lime); text-decoration: none; }

/* ─── NEWS ─── */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.news-card { background: var(--s2rj-surface); border: 1px solid rgba(255,255,255,.07); text-decoration: none; color: #fff; display: block; transition: border-color .2s; }
.news-card:hover { border-color: var(--s2rj-lime); }
.news-thumb { aspect-ratio: 16/9; overflow: hidden; background: var(--s2rj-field); }
.news-thumb img { width: 100%; height: 100%; object-fit: cover; }
.news-body { padding: 14px 16px 16px; }
.news-date { font-family: 'Bebas Neue', sans-serif; font-size: 12px; letter-spacing: 2px; color: var(--s2rj-lime); }
.news-cat { font-size: 9px; letter-spacing: 1px; border: 1px solid var(--s2rj-red); color: var(--s2rj-red); padding: 1px 7px; margin-left: 8px; }
.news-title { font-size: 13px; font-weight: 700; line-height: 1.6; margin-top: 6px; }

/* ─── ARTISTS ─── */
.artist-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; }
.artist-card { position: relative; aspect-ratio: 3/4; overflow: hidden; background: var(--s2rj-surface); text-decoration: none; }
.artist-card img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); transition: filter .25s; }
.artist-card:hover img { filter: grayscale(0); }
.artist-card .artist-meta { position: absolute; left: 0; right: 0; bottom: 0; padding: 20px 10px 8px; background: linear-gradient(transparent, rgba(13,13,16,.95)); }
.artist-name { color: #fff; font-size: 12px; font-weight: 700; letter-spacing: 1px; }
.artist-genre { color: var(--s2rj-lime); font-size: 9px; letter-spacing: 1px; }

/* ─── GATE ONE / G.BOX バナー ─── */
.promo-banner { display: flex; align-items: center; justify-content: space-between; gap: 24px; background: var(--s2rj-surface); border: 1px solid rgba(196,240,0,.25); padding: 28px 32px; margin-bottom: 16px; }
.promo-banner.is-red { border-color: rgba(220,30,50,.4); }
.promo-logo { font-family: 'Bebas Neue', sans-serif; font-size: 44px; letter-spacing: 2px; color: var(--s2rj-lime); line-height: .9; transform: rotate(-2deg); }
.promo-logo.gbox { color: #fff; transform: none; }
.promo-logo.gbox span { color: var(--s2rj-lime); }
.promo-info .promo-date { font-family: 'Bebas Neue', sans-serif; font-size: 30px; letter-spacing: 2px; }
.promo-info .promo-meta { font-size: 11px; color: var(--s2rj-gray); letter-spacing: 1px; margin-top: 4px; }

/* ─── ABOUT ─── */
.about-flex { display: flex; gap: 36px; align-items: center; }
.about-flex .about-text { flex: 1; }
.about-flex .about-photo { flex: 1; aspect-ratio: 16/10; overflow: hidden; }
.about-flex .about-photo img { width: 100%; height: 100%; object-fit: cover; }

/* ─── CONTACT / SNS ─── */
.contact-cta { text-align: center; }
.sns-icons { display: flex; gap: 14px; justify-content: center; margin-top: 24px; }
.sns-icons a { width: 52px; height: 52px; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: 20px; color: #fff; text-decoration: none; transition: border-color .2s; }
.sns-icons a:hover { border-color: var(--s2rj-lime); }

/* ─── アーカイブ・個別 共通 ─── */
.hub-archive { padding: 60px 0; }
.entry-content { max-width: 760px; }
.release-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.release-card { background: var(--s2rj-surface); border: 1px solid rgba(255,255,255,.07); text-decoration: none; color: #fff; display: block; }
.release-card:hover { border-color: var(--s2rj-lime); }
.release-cover { aspect-ratio: 1; overflow: hidden; }
.release-cover img { width: 100%; height: 100%; object-fit: cover; }
.release-body { padding: 12px 14px; }
.release-title { font-size: 13px; font-weight: 700; line-height: 1.5; }
.release-price { font-family: 'Bebas Neue', sans-serif; font-size: 16px; color: var(--s2rj-lime); margin-top: 4px; }
.release-type { font-size: 9px; letter-spacing: 1px; color: var(--s2rj-gray); }

/* ─── JOURNEY 5ステップ ─── */
.journey-steps { display: flex; flex-direction: column; gap: 0; max-width: 760px; }
.journey-step { display: flex; gap: 20px; padding: 24px 0; border-bottom: 1px solid rgba(255,255,255,.08); }
.journey-no { font-family: 'Bebas Neue', sans-serif; font-size: 44px; color: var(--s2rj-lime); line-height: 1; min-width: 64px; }
.journey-title { font-size: 16px; font-weight: 900; margin-bottom: 4px; }
.journey-desc { font-size: 12px; color: rgba(255,255,255,.7); line-height: 1.8; }

/* ─── レスポンシブ ─── */
@media (max-width: 1023px) {
	.news-grid { grid-template-columns: 1fr; }
	.artist-grid { grid-template-columns: repeat(3, 1fr); }
	.release-grid { grid-template-columns: repeat(2, 1fr); }
	.promo-banner { flex-direction: column; align-items: flex-start; gap: 14px; padding: 22px 20px; }
	.about-flex { flex-direction: column; }
	.hub-hero { height: 88svh; }
}
