/* ============================================================
 * slorisu — Dark & Gorgeous theme
 * ベース: 深い黒 (#0e0e12) + ゴールド (#d4af37) アクセント
 * テキスト: クリームホワイト (#ece6d2) を基調
 * ============================================================ */

:root {
	--bg:           #0c0c10;   /* ページ最背面 */
	--bg-elev-1:    #16161d;   /* カード等の表面 */
	--bg-elev-2:    #1d1d26;   /* hover / 一段持ち上げ */
	--bg-input:     #11111a;
	--text:         #ece6d2;   /* 本文（クリーム） */
	--text-mute:    #b8a98a;   /* 補助テキスト（くすみゴールド） */
	--text-dim:     #7a7158;   /* 更にくすませた補助 */
	--gold:         #d4af37;   /* メインのゴールド */
	--gold-2:       #f0d77b;   /* ハイライトゴールド */
	--gold-deep:    #8a6d1c;   /* ダーク寄りゴールド（罫線・ホバー） */
	--accent:       var(--gold);
	--border:       rgba(212, 175, 55, 0.18);
	--border-soft:  rgba(255, 255, 255, 0.06);
	--shadow-1:     0 1px 3px rgba(0, 0, 0, .55);
	--shadow-2:     0 6px 24px rgba(0, 0, 0, .55);
}

* { box-sizing: border-box; }
html { background: var(--bg); }
body {
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
	color: var(--text);
	background:
		radial-gradient(1200px 600px at 50% -200px, rgba(212,175,55,0.07), transparent 60%),
		var(--bg);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--gold-2); text-decoration: none; }
a:hover { color: var(--gold); text-decoration: underline; }
hr { border: 0; border-top: 1px solid var(--border); margin: 24px 0; }
::selection { background: rgba(212,175,55,0.35); color: #fff; }

.container { max-width: 1080px; margin: 0 auto; padding: 24px 16px; }

/* ===== header ===== */
.site-header {
	background: linear-gradient(180deg, #07070b 0%, #11111a 100%);
	color: var(--text);
	border-bottom: 1px solid var(--border);
}
.site-header--front-hidden {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 20;
	transform: translateY(-100%);
	transition: transform .24s ease, box-shadow .24s ease;
	box-shadow: 0 10px 28px rgba(0,0,0,0.42);
}
body.is-header-visible .site-header--front-hidden { transform: translateY(0); }
.site-header__inner { max-width: 1080px; margin: 0 auto; padding: 12px 16px; display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.site-header--front-hidden .site-header__inner {
	min-height: 96px;
	padding-top: 12px;
	padding-bottom: 12px;
	flex-wrap: nowrap;
	align-items: center;
}
.site-header__logo { color: var(--gold-2); font-weight: 700; font-size: 18px; display: inline-flex; align-items: center; }
.site-header__logo-img { height: 96px; width: auto; display: block; filter: drop-shadow(0 0 12px rgba(212,175,55,0.32)); }
.site-header--front-hidden .site-header__logo {
	flex: 0 0 auto;
	align-self: center;
	line-height: 0;
}
.site-header--front-hidden .site-header__logo-img { height: 80px; }
.site-header__search { display: flex; gap: 6px; flex: 1 1 auto; }
.site-header--front-hidden .site-header__search { display: none; }
.site-header__search input[type="search"],
.site-header__search input[type="date"] {
	padding: 7px 10px;
	border-radius: 6px;
	border: 1px solid var(--border);
	background: var(--bg-input);
	color: var(--text);
}
.site-header__search input::placeholder { color: var(--text-dim); }
.site-header__search button {
	padding: 7px 16px;
	border-radius: 6px;
	border: 1px solid var(--gold-deep);
	background: linear-gradient(180deg, var(--gold-2) 0%, var(--gold) 100%);
	color: #1a1305;
	font-weight: 700;
	cursor: pointer;
}
.site-header__search button:hover { filter: brightness(1.06); }
.site-header__nav ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 12px; }
.site-header__nav a { color: var(--text); }
.site-header__nav a:hover { color: var(--gold); }

/* ===== front hero ===== */
.front-hero {
	min-height: 72vh;
	background-color: #06060a;
	background-position: center;
	background-size: cover;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 72px 20px;
	border-bottom: 1px solid var(--border);
	position: relative;
}
.front-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0.24), rgba(0,0,0,0.72));
}
.front-hero__logo {
	position: relative;
	width: min(520px, 82vw);
	height: auto;
	display: block;
	filter: drop-shadow(0 10px 28px rgba(0,0,0,0.65));
}
.front-search { padding-top: 18px; padding-bottom: 8px; }

/* ===== sections ===== */
.section-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 16px; gap: 8px; flex-wrap: wrap; }
.section-header__title {
	font-size: 22px;
	margin: 0;
	color: var(--gold-2);
	border-left: 4px solid var(--gold);
	padding-left: 10px;
	letter-spacing: 0.04em;
	text-shadow: 0 0 14px rgba(212,175,55,0.18);
}
.section-header__lead { color: var(--text-mute); margin: 0; font-size: 13px; }
.section-header__more { font-size: 13px; color: var(--gold-2); }

/* ===== media / event tile grid ===== */
.media-grid,
.event-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 600px) {
	.media-grid,
	.event-grid { grid-template-columns: repeat(2, 1fr); }
}
.media-tile,
.event-tile {
	display: block;
	color: var(--text);
	background: linear-gradient(180deg, var(--bg-elev-1) 0%, #12121a 100%);
	border: 1px solid var(--border);
	border-radius: 10px;
	overflow: hidden;
	box-shadow: var(--shadow-1);
	transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.media-tile:hover,
.event-tile:hover {
	text-decoration: none;
	transform: translateY(-2px);
	box-shadow: var(--shadow-2);
	border-color: rgba(212,175,55,0.5);
}
.media-tile__image,
.event-tile__poster {
	aspect-ratio: 1 / 1;
	background-size: cover;
	background-position: center;
	background-color: #0a0a10;
	display: flex; align-items: center; justify-content: center;
	border-bottom: 1px solid var(--border);
}
.media-tile__image { border-bottom: 1px solid var(--border); }
.media-tile__placeholder,
.event-tile__placeholder { color: var(--text-dim); font-size: 12px; }
.event-tile__title { font-size: 13px; padding: 9px 12px; margin: 0; line-height: 1.4; color: var(--text); }

/* ===== result list ===== */
.result-list { display: grid; gap: 12px; }
@media (min-width: 720px) { .result-list { grid-template-columns: repeat(2, 1fr); } }
.result-card {
	background: linear-gradient(180deg, var(--bg-elev-1) 0%, #12121a 100%);
	border: 1px solid var(--border);
	border-radius: 10px;
	overflow: hidden;
	box-shadow: var(--shadow-1);
	transition: transform .2s ease, border-color .2s ease;
}
.result-card:hover { border-color: rgba(212,175,55,0.45); transform: translateY(-1px); }
.result-card__link { display: flex; gap: 12px; color: var(--text); padding: 10px; }
.result-card__link:hover { text-decoration: none; }
.result-card__thumb { flex: 0 0 96px; width: 96px; height: 96px; overflow: hidden; border-radius: 6px; background: #0a0a10; border: 1px solid var(--border-soft); }
.result-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.result-card__body { flex: 1 1 auto; min-width: 0; }
.result-card__meta { font-size: 12px; color: var(--text-mute); margin: 0 0 4px; display: flex; gap: 8px; flex-wrap: wrap; }
.result-card__title { font-size: 15px; margin: 0 0 4px; color: var(--text); }
.result-card__event { font-size: 12px; color: var(--gold); margin: 0; }
.front-latest .result-list { grid-template-columns: 1fr; }
.front-latest .result-card {
	background: rgba(22,22,29,0.72);
	border-color: rgba(255,255,255,0.18);
	border-radius: 8px;
}
.front-latest .result-card__link {
	align-items: center;
	padding: 16px;
	gap: 16px;
}
.front-latest .result-card__thumb {
	flex-basis: 104px;
	width: 104px;
	height: 104px;
	border-radius: 6px;
}
.front-latest .result-card__meta {
	color: #d6d6d6;
	font-size: 13px;
	font-weight: 700;
}
.front-latest .result-card__title {
	color: #fff;
	font-size: 20px;
	line-height: 1.35;
}
.front-latest .result-card__event {
	color: var(--gold-2);
	font-size: 16px;
	font-weight: 700;
}

/* ===== result detail ===== */
.result-detail {
	max-width: 672px;
	background: #000;
	padding: 28px 18px 0;
}
.result-detail__header { margin-bottom: 16px; }
.result-detail__headline {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 128px;
	gap: 20px;
	align-items: start;
}
.result-detail__headline--text-only { grid-template-columns: 1fr; }
.result-detail__intro { min-width: 0; }
.result-detail__date,
.result-detail__shop {
	margin: 0 0 4px;
	color: #fff;
	font-size: 20px;
	line-height: 1.35;
	font-weight: 500;
}
.result-detail__title {
	margin: 4px 0 0;
	color: #fff;
	font-size: 20px;
	line-height: 1.35;
	font-weight: 500;
	letter-spacing: 0;
}
.result-detail__thumb {
	width: 128px;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: #111;
	border: 1px solid #2f2f2f;
}
.result-detail__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.result-detail__tags {
	display: flex;
	gap: 5px;
	flex-wrap: wrap;
	margin-top: 8px;
}
.result-detail__tags span,
.result-detail__tags a {
	display: inline-flex;
	align-items: center;
	min-height: 20px;
	max-width: 100%;
	padding: 2px 8px;
	border: 1px solid #e15364;
	border-radius: 999px;
	background: #080808;
	color: #fff;
	font-size: 12px;
	line-height: 1.2;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.result-detail__tags a:hover {
	color: #fff;
	text-decoration: none;
	border-color: #ff7b8b;
}
.result-detail__stats {
	display: flex;
	gap: 0;
	padding: 0;
	background: #040404;
	border: 2px solid #efefef;
	border-radius: 0;
	margin: 16px 0 22px;
	box-shadow: none;
}
.result-detail__stats div {
	flex: 1 1 0;
	padding: 8px 10px 9px;
	border-right: 1px solid #efefef;
	text-align: center;
	min-width: 0;
}
.result-detail__stats div:last-child { border-right: 0; }
.result-detail__stats dt {
	color: #fff;
	font-size: 12px;
	line-height: 1.35;
	font-weight: 700;
}
.result-detail__stats dd {
	margin: 2px 0 0;
	color: #cf4f5f;
	font-size: 18px;
	line-height: 1.15;
	font-weight: 700;
}
.result-detail__body {
	margin: 16px 0;
	background: transparent;
	border: 0;
	padding: 0;
	border-radius: 0;
	box-shadow: none;
}
.result-detail__body > *:first-child { margin-top: 0; }
.result-detail__body > *:last-child { margin-bottom: 0; }
.result-detail__body p { margin: 0 0 10px; }
.result-detail__body img {
	width: 100%;
	height: auto;
	border-radius: 0;
}
.result-detail__body--poster {
	aspect-ratio: 3 / 1;
	overflow: hidden;
	background: #111;
}
.result-detail__body--poster img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.result-detail__giveaways {
	margin-top: 28px;
	padding: 0;
	background: transparent;
	border: 0;
	border-radius: 0;
}
.result-detail__giveaways-title {
	position: static;
	transform: none;
	margin: 0 0 14px;
	padding: 0;
	background: transparent;
	color: #fff16d;
	font-size: 20px;
	line-height: 1.2;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-align: center;
	white-space: nowrap;
}
.result-detail__footer { margin-top: 24px; display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.result-detail__more { color: var(--text-mute); font-size: 13px; margin: 0; }
.result-detail__more a { color: var(--gold-2); }
.result-detail__tweet {
	background: #1d9bf0;
	color: #fff !important;
	padding: 10px 18px;
	border-radius: 999px;
	box-shadow: 0 0 0 1px rgba(255,255,255,0.06), 0 6px 18px rgba(29,155,240,0.35);
}
.result-detail__tweet:hover { filter: brightness(1.08); text-decoration: none; }

/* ===== giveaway accordion ===== */
.giveaway {
	display: block;
	background: #050505;
	border: 1px solid #efefef;
	border-radius: 8px;
	margin: 0 0 14px;
	overflow: hidden;
}
.giveaway:last-child { margin-bottom: 0; }
.giveaway[open] {
	border-color: #efe96e;
	box-shadow: 0 0 0 1px rgba(239, 233, 110, 0.35);
}
.giveaway__summary-row {
	list-style: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	color: #fff;
	user-select: none;
	min-height: 44px;
	background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(0,0,0,0.2) 100%);
}
.giveaway__summary-row::-webkit-details-marker { display: none; }
.giveaway__summary-row:hover {
	background: linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(0,0,0,0.2) 100%);
}
.giveaway__index {
	flex: 0 0 auto;
	display: inline-block;
	color: #efe96e;
	font-weight: 700;
	font-size: 16px;
	letter-spacing: 0.04em;
}
.giveaway__heading {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.giveaway__name {
	font-size: 15px;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.02em;
	line-height: 1.3;
}
.giveaway__stats-text {
	color: #fff16d;
	font-size: 13px;
	line-height: 1.4;
	font-weight: 500;
	letter-spacing: 0.01em;
	word-break: break-word;
}
.giveaway__summary-mini {
	flex: 1 1 auto;
	min-width: 0;
	color: #d9d9d9;
	font-size: 12px;
	line-height: 1.4;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	text-align: right;
}
.giveaway__chevron {
	flex: 0 0 auto;
	width: 0; height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 7px solid #efe96e;
	transition: transform 0.2s ease;
}
.giveaway[open] .giveaway__chevron { transform: rotate(180deg); }
.giveaway__body {
	padding: 14px;
	border-top: 1px solid #2a2a2a;
}
.giveaway__stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: 0;
	margin: 0 0 12px;
	border: 1px solid #2a2a2a;
	border-radius: 6px;
	overflow: hidden;
	background: rgba(0,0,0,0.3);
}
.giveaway__stats > div {
	padding: 8px 10px;
	border-right: 1px solid #2a2a2a;
	border-bottom: 1px solid #2a2a2a;
	text-align: center;
}
.giveaway__stats > div:last-child { border-right: 0; }
.giveaway__stats dt {
	color: #bdbdbd;
	font-size: 11px;
	line-height: 1.3;
	letter-spacing: 0.02em;
}
.giveaway__stats dd {
	margin: 2px 0 0;
	color: #fff;
	font-size: 14px;
	line-height: 1.3;
	font-weight: 700;
}
.giveaway__images {
	display: grid;
	gap: 8px;
	margin: 0;
}
.giveaway__images img {
	width: 100%;
	height: auto;
	border-radius: 4px;
}

/* 媒体詳細セクション間の余白 */
.media-detail__search { margin-bottom: 72px; }
.media-detail__results { margin-top: 24px; }
@media (max-width: 600px) {
	.media-detail__search { margin-bottom: 48px; }
	.media-detail__results { margin-top: 16px; }
}

/* ===== media / event detail ===== */
.media-detail__header,
.event-detail__header { text-align: center; margin-bottom: 24px; }
.media-detail__image {
	display: inline-block;
	width: min(320px, 80vw);
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 10px;
	border: 1px solid var(--border);
	box-shadow: var(--shadow-2);
}
.media-detail__banner,
.event-detail__banner {
	display: inline-block;
	width: 100%;
	max-width: 960px;
	aspect-ratio: 3 / 1;
	object-fit: cover;
	border-radius: 8px;
	border: 1px solid var(--border);
	box-shadow: var(--shadow-2);
}
.media-detail__title,
.event-detail__title { font-size: 22px; margin: 12px 0 6px; color: var(--gold-2); letter-spacing: 0.04em; }
.media-detail__official { margin: 4px 0 0; }
.media-detail__official-link {
	display: inline-block;
	padding: 6px 14px;
	border: 1px solid var(--gold-deep);
	border-radius: 999px;
	background: rgba(212,175,55,0.08);
	color: var(--gold-2);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
}
.media-detail__official-link:hover {
	background: rgba(212,175,55,0.18);
	text-decoration: none;
}
.event-detail__media { margin: 0 0 8px; color: var(--text-mute); font-size: 13px; }
.event-detail__body { color: var(--text); }

/* ===== legacy search.php ===== */
.search-form {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 16px;
	padding: 12px;
	background: var(--bg-elev-1);
	border: 1px solid var(--border);
	border-radius: 10px;
	color: var(--text);
}
.search-form label { display: flex; gap: 6px; align-items: center; font-size: 13px; color: var(--text-mute); }
.search-form input {
	padding: 7px 10px;
	border-radius: 6px;
	border: 1px solid var(--border);
	background: var(--bg-input);
	color: var(--text);
}
.search-form button {
	padding: 7px 18px;
	background: linear-gradient(180deg, var(--gold-2) 0%, var(--gold) 100%);
	color: #1a1305;
	font-weight: 700;
	border: 1px solid var(--gold-deep);
	border-radius: 6px;
	cursor: pointer;
}

/* ===== slorisu-search (front + single-event) ===== */
.slorisu-search {
	background: linear-gradient(180deg, var(--bg-elev-1) 0%, #12121a 100%);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 16px;
	box-shadow: var(--shadow-1);
}
.slorisu-search__row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; margin-bottom: 10px; }
.slorisu-search__field { display: flex; flex-direction: column; gap: 4px; font-size: 12px; color: var(--text-mute); }
.slorisu-search__label { font-weight: 700; color: var(--gold-2); letter-spacing: 0.02em; }
.slorisu-search__field input,
.slorisu-search__field select {
	padding: 9px 11px;
	border: 1px solid var(--border);
	border-radius: 8px;
	font-size: 14px;
	background: var(--bg-input);
	color: var(--text);
}
.slorisu-search__field input::placeholder { color: var(--text-dim); }
.slorisu-search__field input:focus,
.slorisu-search__field select:focus {
	outline: none;
	border-color: var(--gold);
	box-shadow: 0 0 0 3px rgba(212,175,55,0.15);
}
.slorisu-search__field select {
	appearance: none; -webkit-appearance: none;
	background-image:
		linear-gradient(45deg, transparent 50%, var(--gold) 50%),
		linear-gradient(135deg, var(--gold) 50%, transparent 50%);
	background-position: calc(100% - 14px) 50%, calc(100% - 9px) 50%;
	background-size: 5px 5px;
	background-repeat: no-repeat;
	padding-right: 28px;
}
/* 媒体名（optgroup 見出し）を目立たせる。※ネイティブ select の見出し色は
   PC ブラウザでは効くが、スマホの標準ピッカーでは無視される場合がある。
   そのため「■」プレフィックス（search-form.php 側）と併用している。 */
.slorisu-search__field optgroup {
	color: var(--gold-2);
	background: var(--bg-elev-2);
	font-weight: 800;
	font-style: normal;
	font-size: 13px;
	letter-spacing: 0.04em;
}
.slorisu-search__field optgroup option {
	color: var(--text);
	background: var(--bg-input);
	font-weight: 400;
}
input[type="date"] { color-scheme: dark; }
.slorisu-search__actions { text-align: center; margin-top: 4px; }
.slorisu-search__submit {
	background: linear-gradient(180deg, var(--gold-2) 0%, var(--gold) 100%);
	color: #1a1305;
	border: 1px solid var(--gold-deep);
	padding: 11px 32px;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	letter-spacing: 0.05em;
	box-shadow: 0 6px 18px rgba(212,175,55,0.18);
}
.slorisu-search__submit:hover { filter: brightness(1.08); }
.slorisu-search--compact {
	padding: 8px;
	border-radius: 8px;
	background: rgba(8,8,12,0.82);
	border-color: rgba(255,255,255,0.16);
	box-shadow: none;
}
.slorisu-search--compact .slorisu-search__row {
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 164px auto;
	gap: 8px;
	margin: 0;
	align-items: stretch;
}
.slorisu-search--compact .slorisu-search__field { gap: 0; }
.slorisu-search--compact .slorisu-search__label {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
.slorisu-search--compact .slorisu-search__field input,
.slorisu-search--compact .slorisu-search__field select {
	width: 100%;
	min-height: 42px;
	padding: 8px 34px 8px 12px;
	border-color: rgba(255,255,255,0.22);
	border-radius: 6px;
	background-color: #f4f4f4;
	color: #242424;
	font-size: 15px;
	font-weight: 700;
}
.slorisu-search--compact .slorisu-search__field select {
	background-image:
		linear-gradient(45deg, transparent 50%, #2a2a2a 50%),
		linear-gradient(135deg, #2a2a2a 50%, transparent 50%);
	background-position: calc(100% - 17px) 50%, calc(100% - 10px) 50%;
	background-size: 7px 7px;
}
.slorisu-search--compact .slorisu-search__actions {
	margin: 0;
	display: flex;
}
.slorisu-search--compact .slorisu-search__submit {
	min-height: 42px;
	padding: 8px 18px;
	border-radius: 6px;
	font-size: 14px;
	letter-spacing: 0;
	box-shadow: none;
}

/* ===== date-group ===== */
.date-group { margin-bottom: 24px; }
.date-group__heading {
	font-size: 18px;
	margin: 0 0 12px;
	padding: 8px 14px;
	background: linear-gradient(180deg, #1c1c25 0%, #0e0e15 100%);
	color: var(--gold-2);
	border: 1px solid var(--border);
	border-left: 3px solid var(--gold);
	border-radius: 6px;
	display: inline-block;
	letter-spacing: 0.04em;
	box-shadow: var(--shadow-1);
}

/* ===== pagination ===== */
.page-numbers,
.pagination a, .pagination span {
	color: var(--text);
}
.nav-links { display: flex; gap: 6px; flex-wrap: wrap; justify-content: center; margin-top: 16px; }
.nav-links a, .nav-links span {
	padding: 6px 12px;
	border: 1px solid var(--border);
	border-radius: 6px;
	background: var(--bg-elev-1);
	color: var(--text);
	font-size: 13px;
}
.nav-links .current {
	background: linear-gradient(180deg, var(--gold-2) 0%, var(--gold) 100%);
	color: #1a1305;
	border-color: var(--gold-deep);
	font-weight: 700;
}

/* ===== footer ===== */
.site-footer {
	background: linear-gradient(180deg, #07070b 0%, #11111a 100%);
	color: var(--text-mute);
	margin-top: 48px;
	border-top: 1px solid var(--border);
}
.site-footer__inner { max-width: 1080px; margin: 0 auto; padding: 28px 16px; }
.site-footer__brand { margin-bottom: 16px; }
.site-footer__brand-link { display: inline-block; }
.site-footer__logo { height: 104px; width: auto; display: block; filter: drop-shadow(0 0 12px rgba(212,175,55,0.32)); }
.site-footer__nav ul { list-style: none; padding: 0; margin: 0 0 12px; display: flex; gap: 16px; flex-wrap: wrap; }
.site-footer__nav a { color: var(--text); }
.site-footer__nav a:hover { color: var(--gold); }
.site-footer__notice {
	background: var(--bg-elev-1);
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 14px 16px;
	margin: 12px 0;
	font-size: 12px;
	line-height: 1.7;
}
.site-footer__notice-title { font-size: 13px; color: var(--gold-2); margin: 0 0 6px; border-left: 3px solid var(--gold); padding-left: 8px; letter-spacing: 0.04em; }
.site-footer__notice-body p { margin: 0 0 6px; color: var(--text-mute); }
.site-footer__copyright { font-size: 12px; color: var(--text-dim); margin: 12px 0 0; }

/* ===== misc / page title ===== */
.page-title { color: var(--gold-2); border-left: 4px solid var(--gold); padding-left: 10px; margin: 0 0 16px; }

/* ============================================================
 * SP（スマホ）対応 — ほとんどのユーザーがSP閲覧。最優先
 * ============================================================ */
@media (max-width: 600px) {
	.container { padding: 16px 12px; }

	/* front hero */
	.front-hero {
		min-height: 38vh;
		padding: 36px 16px;
	}
	.front-hero__logo { width: min(280px, 72vw); }

	/* ヘッダ: ロゴ中央 / インライン検索フォームはSPでは非表示 */
	.site-header__inner { justify-content: center; gap: 8px; padding: 10px 12px; }
	.site-header__logo { margin: 0 auto; }
	.site-header__logo-img { height: 48px; }
	.site-header--front-hidden .site-header__inner {
		min-height: 72px;
		justify-content: space-between;
		padding: 10px 12px;
		flex-wrap: nowrap;
	}
	.site-header--front-hidden .site-header__logo { margin: 0; }
	.site-header--front-hidden .site-header__logo-img { height: 56px; }
	.site-header__search { display: none; }
	.site-header__nav ul { justify-content: center; gap: 10px; font-size: 13px; }

	/* セクション見出し */
	.section-header { gap: 4px; }
	.section-header__title { font-size: 18px; }
	.section-header__lead { font-size: 12px; }

	/* 取材カテゴリタイル */
	.media-grid { grid-template-columns: repeat(4, 1fr); gap: 6px; }
	.event-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.event-tile__title { font-size: 12px; padding: 7px 9px; }
	.media-tile { border-radius: 6px; }

	/* 取材カード */
	.result-card__link { padding: 8px; gap: 8px; }
	.result-card__thumb { flex: 0 0 80px; width: 80px; height: 80px; }
	.result-card__title { font-size: 14px; }
	.result-card__meta { font-size: 11px; gap: 6px; }
	.front-latest .result-card__link { padding: 10px; gap: 10px; }
	.front-latest .result-card__thumb {
		flex-basis: 86px;
		width: 86px;
		height: 86px;
	}
	.front-latest .result-card__title { font-size: 16px; }
	.front-latest .result-card__event { font-size: 13px; }

	/* 検索フォーム */
	.search-form {
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
		padding: 10px;
	}
	.search-form label {
		flex-wrap: wrap;
		gap: 4px 8px;
	}
	.search-form input[type="search"],
	.search-form input[type="date"] {
		flex: 1 1 auto;
		min-width: 0;
		width: 100%;
		font-size: 16px; /* iOS のズーム抑止 */
	}
	.search-form button {
		width: 100%;
		padding: 10px 18px;
	}
	.slorisu-search { padding: 12px; }
	.slorisu-search__row { grid-template-columns: 1fr; gap: 8px; margin-bottom: 8px; }
	.slorisu-search__field input,
	.slorisu-search__field select { font-size: 16px; /* iOS のズーム抑止 */ }
	.slorisu-search__submit { width: 100%; padding: 12px 24px; }
	.slorisu-search--compact {
		padding: 8px;
		overflow: hidden;
	}
	.slorisu-search--compact .slorisu-search__row {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 6px;
		margin: 0;
	}
	.slorisu-search--compact .slorisu-search__field {
		min-width: 0;
		max-width: 100%;
	}
	.slorisu-search--compact .slorisu-search__field input,
	.slorisu-search--compact .slorisu-search__field select {
		min-height: 40px;
		padding: 6px 18px 6px 6px;
		font-size: 12px;
		font-weight: 600;
		width: 100%;
		min-width: 0;
		max-width: 100%;
		box-sizing: border-box;
	}
	.slorisu-search--compact .slorisu-search__field input[type="date"] {
		padding-right: 4px;
		padding-left: 4px;
		font-size: 11px;
		-webkit-appearance: none;
	}
	.slorisu-search--compact .slorisu-search__field input[type="date"]::-webkit-calendar-picker-indicator {
		padding: 0;
		margin-left: 2px;
	}
	.slorisu-search--compact .slorisu-search__field select {
		background-position: calc(100% - 9px) 50%, calc(100% - 5px) 50%;
		padding-right: 18px;
	}
	.slorisu-search--compact .slorisu-search__actions {
		grid-column: 1 / -1;
		margin-top: 6px;
	}
	.slorisu-search--compact .slorisu-search__submit {
		width: 100%;
		min-height: 40px;
	}

	/* 取材詳細ヘッダ */
	.media-detail__image { max-width: 80vw; }
	.media-detail__banner,
	.event-detail__banner { border-radius: 6px; }
	.media-detail__title,
	.event-detail__title { font-size: 18px; }

	/* 結果(取材)詳細 */
	.result-detail { padding: 16px 10px 0; }
	.result-detail__headline {
		grid-template-columns: minmax(0, 1fr) 96px;
		gap: 12px;
	}
	.result-detail__headline--text-only { grid-template-columns: 1fr; }
	.result-detail__date,
	.result-detail__shop,
	.result-detail__title { font-size: 16px; }
	.result-detail__thumb { width: 96px; }
	.result-detail__tags { gap: 4px; }
	.result-detail__tags span,
	.result-detail__tags a {
		min-height: 18px;
		padding: 1px 6px;
		font-size: 10px;
	}
	.result-detail__stats {
		padding: 0;
	}
	.result-detail__stats div { padding: 6px 4px; }
	.result-detail__stats dt { font-size: 10px; }
	.result-detail__stats dd { font-size: 14px; }
	.result-detail__body { padding: 0; }
	.result-detail__giveaways {
		padding: 18px 8px 10px;
		border-radius: 20px;
	}
	.result-detail__giveaways-title { font-size: 16px; top: -15px; }
	.result-detail__footer { gap: 8px; }
	.result-detail__tweet { width: 100%; text-align: center; }

	/* 仕掛けアコーディオン (SP) */
	.giveaway { margin-bottom: 12px; }
	.giveaway__summary-row {
		padding: 8px 10px;
		gap: 8px;
		min-height: 38px;
	}
	.giveaway__index { font-size: 14px; }
	.giveaway__name { font-size: 13px; }
	.giveaway__stats-text { font-size: 11px; }
	.giveaway__body { padding: 10px; }

	/* 日付ヘッダ */
	.date-group__heading { font-size: 15px; padding: 6px 12px; }

	/* フッター */
	.site-footer__inner { padding: 20px 12px; }
	.site-footer__logo { height: 56px; }
	.site-footer__nav ul { gap: 12px; font-size: 13px; }
}

/* ============================================================
 * Neon premium redesign
 * ============================================================ */
:root {
	--bg: #030306;
	--bg-elev-1: rgba(12, 10, 18, 0.92);
	--bg-elev-2: rgba(22, 13, 31, 0.94);
	--bg-input: rgba(5, 5, 10, 0.88);
	--text: #fff8e8;
	--text-mute: #d9c7a6;
	--text-dim: #897b68;
	--gold: #d7a935;
	--gold-2: #ffe39a;
	--gold-deep: #805b18;
	--neon: #a64dff;
	--neon-2: #f04dff;
	--cyan: #45d9ff;
	--border: rgba(255, 214, 128, 0.3);
	--border-soft: rgba(255, 255, 255, 0.08);
	--shadow-1: 0 12px 36px rgba(0, 0, 0, 0.55);
	--shadow-2: 0 22px 70px rgba(0, 0, 0, 0.72);
}

html { scroll-padding-top: 96px; }
body {
	padding-top: 92px;
	background:
		radial-gradient(900px 520px at 18% 0%, rgba(166, 77, 255, 0.2), transparent 60%),
		radial-gradient(760px 480px at 88% 16%, rgba(215, 169, 53, 0.16), transparent 62%),
		linear-gradient(180deg, #050509 0%, #000 46%, #06030a 100%);
	color: var(--text);
}
body::before {
	content: "";
	position: fixed;
	inset: 0;
	pointer-events: none;
	background:
		linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px),
		linear-gradient(180deg, rgba(255,255,255,0.012) 1px, transparent 1px);
	background-size: 42px 42px;
	mask-image: linear-gradient(180deg, rgba(0,0,0,0.8), transparent 70%);
	z-index: -1;
}

.container { max-width: 1120px; }

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background:
		linear-gradient(180deg, rgba(4, 4, 8, 0.96) 0%, rgba(3, 3, 6, 0.84) 100%);
	border-bottom: 1px solid rgba(255, 225, 148, 0.24);
	box-shadow: 0 1px 0 rgba(166,77,255,0.22), 0 16px 50px rgba(0,0,0,0.38);
	backdrop-filter: blur(18px);
}
.admin-bar .site-header { top: 32px; }
body.is-header-scrolled .site-header {
	box-shadow: 0 1px 0 rgba(255, 225, 148, 0.34), 0 18px 52px rgba(0,0,0,0.7), 0 0 34px rgba(166,77,255,0.14);
}
.site-header__inner {
	max-width: 1180px;
	min-height: 92px;
	padding: 8px 20px;
	flex-wrap: nowrap;
	gap: 20px;
}
.site-header__logo {
	line-height: 0;
	flex: 0 0 auto;
}
.site-header__logo-img {
	height: 66px;
	filter:
		drop-shadow(0 0 10px rgba(166, 77, 255, 0.58))
		drop-shadow(0 0 12px rgba(215, 169, 53, 0.34));
}
.site-header__search { display: none; }
.site-header__nav {
	margin-left: auto;
}
.site-header__nav ul {
	align-items: center;
	gap: 22px;
}
.site-header__nav a {
	color: rgba(255, 248, 232, 0.9);
	font-size: 14px;
	font-weight: 700;
	text-shadow: 0 0 12px rgba(255,227,154,0.18);
}
.site-header__nav a:hover {
	color: var(--gold-2);
	text-decoration: none;
}
.site-header__menu {
	flex: 0 0 auto;
	width: 44px;
	height: 44px;
	display: inline-flex;
	flex-direction: column;
	justify-content: center;
	gap: 6px;
	border: 1px solid rgba(255, 225, 148, 0.4);
	border-radius: 8px;
	background: linear-gradient(180deg, rgba(255,227,154,0.12), rgba(166,77,255,0.08));
	box-shadow: inset 0 0 18px rgba(255,227,154,0.08), 0 0 18px rgba(166,77,255,0.18);
	cursor: pointer;
}
.site-header__menu span {
	width: 20px;
	height: 2px;
	margin: 0 auto;
	border-radius: 999px;
	background: var(--gold-2);
	box-shadow: 0 0 10px rgba(255, 227, 154, 0.62);
}

.section-header {
	align-items: center;
	margin-bottom: 18px;
}
.section-header__title {
	border-left: 4px solid var(--gold);
	color: var(--gold-2);
	font-size: 24px;
	text-shadow: 0 0 18px rgba(255, 227, 154, 0.26), 0 0 26px rgba(166, 77, 255, 0.18);
}
.section-header__more {
	color: var(--gold-2);
	font-weight: 700;
}

.front-hero {
	min-height: auto;
	display: block;
	padding: 28px 16px 18px;
	background:
		radial-gradient(680px 320px at 50% 0%, rgba(166,77,255,0.22), transparent 64%),
		#020205;
	border-bottom: 1px solid rgba(255, 225, 148, 0.22);
}
.front-hero::before { content: none; }
.front-hero__stage {
	position: relative;
	max-width: 1180px;
	margin: 0 auto;
}
.front-hero__panel {
	position: relative;
	min-height: 430px;
	overflow: hidden;
	border: 1px solid rgba(255, 225, 148, 0.62);
	border-radius: 10px;
	background: #050508;
	box-shadow:
		0 0 0 1px rgba(166,77,255,0.22),
		0 0 36px rgba(215,169,53,0.18),
		0 26px 78px rgba(0,0,0,0.72);
}
.front-hero__panel::after {
	content: none;
}
.front-hero__slide {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.74) 34%, rgba(0,0,0,0.16) 68%),
		linear-gradient(115deg, rgba(255, 227, 154, 0.14), transparent 22%, transparent 74%, rgba(166,77,255,0.24)),
		radial-gradient(260px 160px at 70% 52%, rgba(255,227,154,0.28), transparent 68%),
		var(--hero-image) center center / contain no-repeat,
		#050508;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.34s ease;
}
.front-hero__slide.is-active {
	opacity: 1;
	pointer-events: auto;
}
.front-hero__shine {
	position: absolute;
	inset: 0;
	background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.12) 42%, transparent 52%);
	transform: translateX(-60%);
	opacity: 0.45;
	z-index: 2;
	pointer-events: none;
}
.front-hero__copy {
	position: relative;
	z-index: 3;
	width: min(520px, 100%);
	padding: 42px 44px;
}
.front-hero__badge {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 4px 13px;
	border-radius: 999px;
	background: linear-gradient(180deg, var(--neon-2), var(--neon));
	color: #fff;
	font-size: 13px;
	font-weight: 800;
	box-shadow: 0 0 18px rgba(166,77,255,0.58);
}
.front-hero__logo {
	position: static;
	width: 230px;
	margin: 18px 0 22px;
	filter:
		drop-shadow(0 0 16px rgba(166,77,255,0.62))
		drop-shadow(0 0 12px rgba(255,227,154,0.26));
}
.front-hero__meta {
	margin: 0 0 8px;
	display: flex;
	gap: 12px;
	color: var(--gold-2);
	font-size: 15px;
	font-weight: 700;
}
.front-hero__title {
	margin: 0 0 14px;
	color: #fff;
	font-size: 40px;
	line-height: 1.22;
	text-shadow: 0 0 24px rgba(255,227,154,0.24);
}
.front-hero__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 22px;
}
.front-hero__tags span,
.result-card__tags span,
.result-detail__tags span,
.result-detail__tags a {
	display: inline-flex;
	align-items: center;
	max-width: 100%;
	padding: 4px 12px;
	border: 1px solid rgba(255, 225, 148, 0.44);
	border-radius: 999px;
	background: rgba(5, 5, 10, 0.68);
	color: var(--gold-2);
	font-size: 12px;
	font-weight: 800;
	line-height: 1.2;
	box-shadow: inset 0 0 14px rgba(166,77,255,0.14), 0 0 12px rgba(166,77,255,0.14);
}
.front-hero__cta {
	display: inline-flex;
	align-items: center;
	min-height: 42px;
	padding: 8px 22px;
	border: 1px solid rgba(255, 225, 148, 0.68);
	border-radius: 7px;
	background: linear-gradient(180deg, rgba(255,227,154,0.22), rgba(128,91,24,0.18));
	color: var(--gold-2);
	font-weight: 800;
	box-shadow: inset 0 0 18px rgba(255,227,154,0.1), 0 0 20px rgba(215,169,53,0.18);
}
.front-hero__cta:hover {
	color: #fff;
	text-decoration: none;
	border-color: var(--gold-2);
}
.front-hero__arrow {
	position: absolute;
	top: 50%;
	z-index: 2;
	width: 46px;
	height: 46px;
	border: 1px solid rgba(255, 225, 148, 0.78);
	border-radius: 50%;
	background: rgba(0,0,0,0.46);
	box-shadow: 0 0 20px rgba(255,227,154,0.2);
}
.front-hero__arrow--prev { left: -8px; }
.front-hero__arrow--next { right: -8px; }
.front-hero__arrow::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 12px;
	height: 12px;
	border-top: 2px solid var(--gold-2);
	border-right: 2px solid var(--gold-2);
}
.front-hero__arrow--prev::before { transform: translate(-38%, -50%) rotate(-135deg); }
.front-hero__arrow--next::before { transform: translate(-62%, -50%) rotate(45deg); }
.front-hero__arrow:disabled {
	opacity: 0.35;
	cursor: default;
}
.front-hero__dots {
	display: flex;
	justify-content: center;
	gap: 10px;
	margin-top: 14px;
}
.front-hero__dots span,
.front-hero__dots button {
	width: 10px;
	height: 10px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: rgba(255,255,255,0.28);
	cursor: pointer;
}
.front-hero__dots .is-active {
	background: var(--gold);
	box-shadow: 0 0 14px rgba(255,227,154,0.72);
}

.front-search {
	padding-top: 28px;
	padding-bottom: 12px;
}
.slorisu-search--compact {
	max-width: 980px;
	margin: 0 auto;
	padding: 18px;
	border: 1px solid rgba(255, 225, 148, 0.52);
	border-radius: 10px;
	background:
		linear-gradient(180deg, rgba(16, 10, 24, 0.92), rgba(3, 3, 8, 0.94));
	box-shadow: inset 0 0 28px rgba(166,77,255,0.08), 0 0 28px rgba(215,169,53,0.12), var(--shadow-1);
}
.slorisu-search--compact .slorisu-search__row {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 12px;
}
.slorisu-search--compact .slorisu-search__field input,
.slorisu-search--compact .slorisu-search__field select {
	min-height: 48px;
	border: 1px solid rgba(255, 225, 148, 0.42);
	border-radius: 7px;
	background-color: rgba(2, 2, 6, 0.9);
	color: var(--text);
	font-size: 14px;
	font-weight: 800;
	box-shadow: inset 0 0 18px rgba(255,227,154,0.05), 0 0 18px rgba(166,77,255,0.1);
}
.slorisu-search--compact .slorisu-search__field select {
	background-image:
		linear-gradient(45deg, transparent 50%, var(--gold-2) 50%),
		linear-gradient(135deg, var(--gold-2) 50%, transparent 50%);
}
.slorisu-search--compact .slorisu-search__actions {
	grid-column: 1 / -1;
	justify-content: center;
	margin-top: 2px;
}
.slorisu-search--compact .slorisu-search__submit {
	width: min(540px, 100%);
	min-height: 52px;
	border-radius: 8px;
	border-color: rgba(255, 236, 172, 0.76);
	background: linear-gradient(180deg, #fff0af 0%, #d7a935 42%, #8f641a 100%);
	color: #120b02;
	font-size: 18px;
	font-weight: 900;
	box-shadow: inset 0 2px 0 rgba(255,255,255,0.32), 0 0 26px rgba(215,169,53,0.3);
}

.front-media,
.front-latest {
	padding-top: 26px;
	padding-bottom: 20px;
}
.front-media .media-grid {
	display: flex;
	grid-template-columns: none;
	gap: 14px;
	overflow-x: auto;
	padding: 2px 2px 14px;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
}
.front-media .media-grid::-webkit-scrollbar { height: 6px; }
.front-media .media-grid::-webkit-scrollbar-thumb {
	background: linear-gradient(90deg, var(--gold), var(--neon));
	border-radius: 999px;
}
.front-media .media-tile {
	flex: 0 0 170px;
	scroll-snap-align: start;
	border-color: rgba(255,225,148,0.42);
	border-radius: 9px;
	background: linear-gradient(180deg, rgba(14,10,22,0.96), rgba(4,4,8,0.98));
	box-shadow: inset 0 0 20px rgba(166,77,255,0.08), 0 0 22px rgba(166,77,255,0.1);
}
.media-tile__image {
	border-bottom-color: rgba(255,225,148,0.24);
}
.media-tile__title {
	margin: 0;
	padding: 10px 8px 12px;
	color: #fff;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.35;
	text-align: center;
}

.result-card {
	position: relative;
	border-color: rgba(255,225,148,0.3);
	border-radius: 10px;
	background:
		linear-gradient(120deg, rgba(16,10,24,0.98), rgba(3,3,8,0.96) 68%, rgba(70,17,94,0.42));
	box-shadow: inset 0 0 24px rgba(255,227,154,0.04), 0 0 22px rgba(166,77,255,0.1);
}
.result-card:hover {
	border-color: rgba(255,225,148,0.72);
	box-shadow: inset 0 0 24px rgba(255,227,154,0.08), 0 0 28px rgba(166,77,255,0.24);
}
.front-latest .result-list { gap: 16px; }
.result-card__link {
	position: relative;
	align-items: center;
	padding: 14px;
	gap: 16px;
}
.result-card__thumb {
	flex: 0 0 132px;
	width: 132px;
	height: 132px;
	border-radius: 8px;
	border-color: rgba(255,225,148,0.36);
	box-shadow: 0 0 20px rgba(166,77,255,0.2);
}
.result-card__meta {
	margin-bottom: 6px;
	color: rgba(255, 248, 232, 0.76);
	font-weight: 700;
}
.result-card__shop-name {
	margin: 0 0 8px;
	color: #fff;
	font-size: 24px;
	font-weight: 900;
	line-height: 1.3;
	text-shadow: 0 0 20px rgba(255,227,154,0.16);
}
.result-card__title {
	color: rgba(255,248,232,0.74);
	font-size: 14px;
	font-weight: 700;
}
.front-latest .result-card__title,
.search-result .result-card__title { display: none; }
.result-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0;
}
.result-card__arrow {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	margin-left: auto;
	border-top: 3px solid var(--gold-2);
	border-right: 3px solid var(--gold-2);
	transform: rotate(45deg);
	filter: drop-shadow(0 0 8px rgba(255,227,154,0.48));
}

.media-detail__header {
	position: relative;
	padding: 18px;
	border: 1px solid rgba(255,225,148,0.38);
	border-radius: 10px;
	background: linear-gradient(180deg, rgba(14,10,22,0.92), rgba(3,3,8,0.96));
	box-shadow: inset 0 0 28px rgba(166,77,255,0.08), var(--shadow-1);
}
.media-detail__banner,
.event-detail__banner {
	border-color: rgba(255,225,148,0.5);
	box-shadow: 0 0 26px rgba(215,169,53,0.16), 0 0 32px rgba(166,77,255,0.12);
}
.media-detail__title,
.event-detail__title {
	color: var(--gold-2);
	text-shadow: 0 0 22px rgba(255,227,154,0.2);
}
.media-official-card {
	width: min(560px, 100%);
	margin: 20px auto 0;
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px;
	border: 1px solid rgba(166, 77, 255, 0.72);
	border-radius: 10px;
	background: linear-gradient(120deg, rgba(30, 12, 43, 0.92), rgba(5, 5, 10, 0.96));
	color: #fff;
	box-shadow: inset 0 0 24px rgba(166,77,255,0.14), 0 0 28px rgba(166,77,255,0.2);
	text-align: left;
}
.media-official-card:hover {
	color: #fff;
	text-decoration: none;
	border-color: var(--gold-2);
}
.media-official-card__icon {
	flex: 0 0 auto;
	width: 58px;
	height: 58px;
	border: 1px solid rgba(255,225,148,0.5);
	border-radius: 10px;
	background:
		radial-gradient(circle at 50% 50%, rgba(255,255,255,0.16), transparent 58%),
		linear-gradient(180deg, rgba(166,77,255,0.42), rgba(15,7,24,0.92));
	box-shadow: inset 0 0 18px rgba(255,255,255,0.08), 0 0 20px rgba(166,77,255,0.38);
	position: relative;
}
.media-official-card__icon::before,
.media-official-card__icon::after {
	content: "";
	position: absolute;
	border: 1px solid rgba(255,255,255,0.86);
	border-radius: 50%;
}
.media-official-card__icon::before {
	inset: 16px 12px;
}
.media-official-card__icon::after {
	inset: 12px 18px;
}
.media-official-card__body {
	display: grid;
	gap: 2px;
	min-width: 0;
}
.media-official-card__eyebrow {
	color: var(--text-mute);
	font-size: 12px;
	font-weight: 700;
}
.media-official-card__title {
	color: #fff;
	font-size: 17px;
	line-height: 1.35;
}
.media-official-card__text {
	color: var(--gold-2);
	font-size: 13px;
}
.media-official-card__arrow {
	flex: 0 0 auto;
	width: 16px;
	height: 16px;
	margin-left: auto;
	border-top: 2px solid var(--gold-2);
	border-right: 2px solid var(--gold-2);
	transform: rotate(45deg);
}

.result-detail {
	max-width: 980px;
	padding: 24px 16px 0;
	background: transparent;
}
.result-detail__header {
	margin-bottom: 22px;
	padding: 24px;
	border: 1px solid rgba(255,225,148,0.38);
	border-radius: 10px;
	background:
		radial-gradient(520px 260px at 88% 42%, rgba(215,169,53,0.13), transparent 68%),
		linear-gradient(180deg, rgba(9, 8, 14, 0.96), rgba(0,0,0,0.96));
	box-shadow: inset 0 0 32px rgba(166,77,255,0.06), 0 0 32px rgba(215,169,53,0.12), var(--shadow-1);
}
.result-detail__headline {
	grid-template-columns: minmax(0, 1fr) 150px;
	align-items: start;
}
.result-detail__date,
.result-detail__shop,
.result-detail__event-name {
	margin: 0 0 8px;
	color: #fff;
	font-weight: 800;
	text-shadow: 0 0 16px rgba(255,227,154,0.15);
}
.result-detail__date {
	color: var(--gold-2);
	font-size: 21px;
}
.result-detail__shop {
	font-size: 30px;
	line-height: 1.25;
}
.result-detail__event-name {
	font-size: 20px;
	color: rgba(255,248,232,0.9);
}
.result-detail__thumb {
	width: 150px;
	border-radius: 8px;
	border-color: rgba(255,225,148,0.45);
	box-shadow: 0 0 24px rgba(166,77,255,0.18);
}
.result-detail__tags {
	margin-top: 12px;
	gap: 7px;
}
.result-detail__stats {
	margin: 18px 0 0;
	border: 1px solid rgba(255,225,148,0.42);
	border-radius: 8px;
	background: rgba(0,0,0,0.58);
	overflow: hidden;
	box-shadow: inset 0 0 18px rgba(255,227,154,0.05);
}
.result-detail__stats div {
	border-right: 1px solid rgba(255,225,148,0.28);
	padding: 12px 10px;
}
.result-detail__stats dt {
	color: #fff;
	font-size: 13px;
}
.result-detail__stats dd {
	color: #ff5d78;
	font-size: 26px;
	text-shadow: 0 0 18px rgba(255,93,120,0.24);
}
.result-detail__body--poster {
	margin: 22px 0 34px;
	border: 1px solid rgba(255,225,148,0.5);
	border-radius: 10px;
	box-shadow: 0 0 28px rgba(215,169,53,0.14), 0 0 34px rgba(166,77,255,0.12);
}
.result-detail__body--poster img {
	border-radius: 10px;
}
.result-detail__giveaways {
	margin-top: 32px;
	padding: 0;
	border: 0;
	background: transparent;
}
.result-detail__giveaways-title {
	margin: 0 0 20px;
	color: var(--gold-2);
	font-size: 24px;
	text-shadow: 0 0 20px rgba(255,227,154,0.22);
}
.result-detail__giveaways-title::before,
.result-detail__giveaways-title::after {
	content: "";
	display: inline-block;
	width: 72px;
	height: 1px;
	margin: 0 14px 6px;
	background: linear-gradient(90deg, transparent, rgba(255,225,148,0.66));
}
.result-detail__giveaways-title::after {
	background: linear-gradient(90deg, rgba(255,225,148,0.66), transparent);
}

.giveaway {
	border: 1px solid rgba(255,225,148,0.44);
	border-radius: 10px;
	background: linear-gradient(180deg, rgba(8,8,12,0.94), rgba(0,0,0,0.96));
	box-shadow: inset 0 0 22px rgba(166,77,255,0.07), 0 0 22px rgba(0,0,0,0.44);
}
.giveaway[open] {
	border-color: rgba(255,225,148,0.82);
	box-shadow: inset 0 0 24px rgba(255,227,154,0.06), 0 0 28px rgba(215,169,53,0.18), 0 0 28px rgba(166,77,255,0.12);
}
.giveaway__summary-row {
	min-height: 78px;
	padding: 16px 20px;
	gap: 18px;
	background: linear-gradient(90deg, rgba(255,227,154,0.08), rgba(166,77,255,0.08), transparent);
}
.giveaway__index {
	min-width: 72px;
	color: var(--gold-2);
	font-size: 38px;
	font-style: italic;
	line-height: 1;
	text-shadow: 0 0 20px rgba(255,227,154,0.35);
}
.giveaway__heading {
	border-left: 1px solid rgba(255,225,148,0.42);
	padding-left: 18px;
}
.giveaway__name {
	font-size: 24px;
	line-height: 1.28;
}
.giveaway__stats-text {
	color: var(--text-mute);
	font-size: 14px;
}
.giveaway__chevron {
	width: 34px;
	height: 34px;
	border: 1px solid rgba(255,225,148,0.7);
	border-radius: 50%;
	background: rgba(0,0,0,0.42);
	position: relative;
	transform: none;
	box-shadow: 0 0 16px rgba(255,227,154,0.16);
}
.giveaway__chevron::before {
	content: "+";
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	color: var(--gold-2);
	font-size: 24px;
	line-height: 1;
}
.giveaway[open] .giveaway__chevron { transform: none; }
.giveaway[open] .giveaway__chevron::before { content: "-"; }
.giveaway__body {
	padding: 18px 20px 20px;
	border-top: 1px solid rgba(255,225,148,0.24);
}
.giveaway__detail-stats {
	margin: 0 0 14px;
	padding: 12px 14px;
	border: 1px solid rgba(255,225,148,0.28);
	border-radius: 7px;
	background: rgba(255,227,154,0.05);
	color: var(--gold-2);
	font-weight: 800;
	text-align: right;
}
.giveaway__images {
	gap: 12px;
}
.giveaway__images img {
	border: 1px solid rgba(255,225,148,0.34);
	border-radius: 8px;
	box-shadow: 0 0 22px rgba(0,0,0,0.55);
}

.site-footer {
	background: linear-gradient(180deg, rgba(4,4,8,0.92), #000);
	border-top-color: rgba(255,225,148,0.24);
}
.site-footer__logo {
	filter: drop-shadow(0 0 14px rgba(166,77,255,0.48));
}

@media (max-width: 782px) {
	.admin-bar .site-header { top: 46px; }
}

@media (max-width: 760px) {
	html { scroll-padding-top: 78px; }
	body { padding-top: 74px; }
	.container { padding: 18px 12px; }

	.site-header__inner {
		min-height: 74px;
		padding: 8px 12px;
		gap: 10px;
		justify-content: space-between;
	}
	.site-header__logo {
		margin: 0;
	}
	.site-header__logo-img {
		height: 52px;
	}
	.site-header__nav {
		display: none;
		position: absolute;
		top: calc(100% + 1px);
		left: 12px;
		right: 12px;
		margin: 0;
		padding: 12px;
		border: 1px solid rgba(255,225,148,0.36);
		border-radius: 8px;
		background: rgba(5,5,10,0.96);
		box-shadow: 0 18px 42px rgba(0,0,0,0.66);
	}
	.site-header.is-menu-open .site-header__nav { display: block; }
	.site-header__nav ul {
		display: grid;
		gap: 8px;
	}
	.site-header__nav a {
		display: block;
		padding: 10px 12px;
		border-radius: 6px;
		background: rgba(255,255,255,0.04);
	}
	.site-header__menu {
		width: 42px;
		height: 42px;
	}

	.front-hero {
		padding: 14px 10px 14px;
	}
	.front-hero__panel {
		min-height: 360px;
		background: #050508;
	}
	.front-hero__slide {
		background:
			linear-gradient(180deg, rgba(0,0,0,0.28), rgba(0,0,0,0.92) 72%),
			var(--hero-image) center center / contain no-repeat,
			#050508;
	}
	.front-hero__copy {
		width: 100%;
		padding: 24px 18px;
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
	}
	.front-hero__badge {
		min-height: 24px;
		padding: 3px 10px;
		font-size: 12px;
	}
	.front-hero__logo {
		width: 164px;
		margin: 12px 0 14px;
	}
	.front-hero__meta {
		font-size: 12px;
		gap: 8px;
	}
	.front-hero__title {
		font-size: 26px;
		line-height: 1.25;
	}
	.front-hero__tags span {
		font-size: 11px;
		padding: 4px 9px;
	}
	.front-hero__arrow {
		display: none;
	}

	.slorisu-search--compact {
		padding: 10px;
	}
	.slorisu-search--compact .slorisu-search__row {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 7px;
	}
	.slorisu-search--compact .slorisu-search__field input,
	.slorisu-search--compact .slorisu-search__field select {
		min-height: 42px;
		padding: 6px 18px 6px 7px;
		font-size: 11px;
	}
	.slorisu-search--compact .slorisu-search__field input[type="date"] {
		font-size: 10px;
		padding-left: 5px;
		padding-right: 2px;
	}
	.slorisu-search--compact .slorisu-search__field select {
		background-position: calc(100% - 10px) 50%, calc(100% - 6px) 50%;
		background-size: 5px 5px;
	}
	.slorisu-search--compact .slorisu-search__submit {
		min-height: 46px;
		font-size: 16px;
	}

	.front-media .media-tile {
		flex-basis: 138px;
	}
	.media-tile__title {
		font-size: 12px;
	}

	.front-latest .result-card__link,
	.result-card__link {
		padding: 10px;
		gap: 12px;
	}
	.front-latest .result-card__thumb,
	.result-card__thumb {
		flex-basis: 104px;
		width: 104px;
		height: 104px;
	}
	.result-card__shop-name {
		font-size: 20px;
	}
	.result-card__arrow {
		width: 14px;
		height: 14px;
		border-width: 2px;
	}
	.result-card__tags span {
		font-size: 11px;
		padding: 4px 8px;
	}

	.media-official-card {
		padding: 13px;
		gap: 10px;
	}
	.media-official-card__icon {
		width: 48px;
		height: 48px;
	}
	.media-official-card__title {
		font-size: 15px;
	}

	.result-detail {
		padding: 14px 10px 0;
	}
	.result-detail__header {
		padding: 16px;
	}
	.result-detail__headline {
		grid-template-columns: minmax(0, 1fr) 92px;
		gap: 12px;
	}
	.result-detail__headline--text-only { grid-template-columns: 1fr; }
	.result-detail__date {
		font-size: 18px;
	}
	.result-detail__shop {
		font-size: 23px;
	}
	.result-detail__event-name {
		font-size: 16px;
	}
	.result-detail__thumb {
		width: 92px;
	}
	.result-detail__stats div {
		padding: 9px 4px;
	}
	.result-detail__stats dt {
		font-size: 10px;
	}
	.result-detail__stats dd {
		font-size: 17px;
	}
	.result-detail__body--poster {
		aspect-ratio: 3 / 1;
		margin: 18px 0 28px;
	}
	.result-detail__giveaways-title {
		font-size: 20px;
	}
	.result-detail__giveaways-title::before,
	.result-detail__giveaways-title::after {
		width: 34px;
		margin-left: 8px;
		margin-right: 8px;
	}
	.giveaway__summary-row {
		min-height: 68px;
		padding: 13px 12px;
		gap: 12px;
	}
	.giveaway__index {
		min-width: 48px;
		font-size: 32px;
	}
	.giveaway__heading {
		padding-left: 12px;
	}
	.giveaway__name {
		font-size: 18px;
	}
	.giveaway__stats-text {
		font-size: 12px;
	}
	.giveaway__chevron {
		width: 30px;
		height: 30px;
	}
	.giveaway__body {
		padding: 12px;
	}
	.giveaway__detail-stats {
		text-align: left;
		font-size: 12px;
	}
}

/* Header menu behavior fix */
.site-header__inner {
	position: relative;
}
.site-header__nav {
	display: block;
	position: absolute;
	top: calc(100% + 10px);
	right: 20px;
	width: min(340px, calc(100vw - 32px));
	margin: 0;
	padding: 12px;
	border: 1px solid rgba(255, 225, 148, 0.45);
	border-radius: 10px;
	background:
		linear-gradient(180deg, rgba(14, 10, 22, 0.98), rgba(3, 3, 8, 0.98));
	box-shadow: 0 20px 56px rgba(0,0,0,0.72), 0 0 28px rgba(166,77,255,0.18);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(-8px);
	transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
}
.site-header.is-menu-open .site-header__nav {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
}
.site-header__nav ul {
	display: grid;
	gap: 8px;
}
.site-header__nav a {
	display: flex;
	align-items: center;
	min-height: 42px;
	padding: 10px 12px;
	border: 1px solid rgba(255, 225, 148, 0.18);
	border-radius: 8px;
	background: rgba(255,255,255,0.04);
	color: #fff;
}
.site-header__nav a:hover {
	border-color: rgba(255, 225, 148, 0.5);
	background: rgba(255, 227, 154, 0.08);
	color: var(--gold-2);
}
.site-header__menu[aria-expanded="true"] {
	border-color: rgba(255, 225, 148, 0.78);
	box-shadow: inset 0 0 18px rgba(255,227,154,0.1), 0 0 24px rgba(166,77,255,0.34);
}
.site-header__menu[aria-expanded="true"] span:nth-child(1) {
	transform: translateY(8px) rotate(45deg);
}
.site-header__menu[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
}
.site-header__menu[aria-expanded="true"] span:nth-child(3) {
	transform: translateY(-8px) rotate(-45deg);
}
.site-header__menu span {
	transition: transform 0.18s ease, opacity 0.18s ease;
}
.site-header__menu {
	margin-left: auto;
}
@media (max-width: 760px) {
	.site-header__nav {
		top: calc(100% + 8px);
		left: 12px;
		right: 12px;
		width: auto;
	}
}

/* Keep hero CTA inside the carousel frame. */
.front-hero__panel {
	min-height: clamp(470px, 42vw, 560px);
}
.front-hero__slide {
	display: flex;
	align-items: flex-end;
}
.front-hero__copy {
	padding-bottom: 52px;
}
@media (max-width: 760px) {
	.front-hero__panel {
		min-height: clamp(500px, 132vw, 640px);
	}
	.front-hero__copy {
		position: relative;
		left: auto;
		right: auto;
		bottom: auto;
		margin-top: auto;
		padding: 22px 18px 30px;
	}
	.front-hero__logo {
		width: 144px;
		margin: 10px 0 12px;
	}
	.front-hero__title {
		font-size: 24px;
	}
	.front-hero__tags {
		margin-bottom: 16px;
	}
	.front-hero__cta {
		min-height: 40px;
		padding: 8px 18px;
	}
}

/* Responsive hero frame: keep every control inside the banner on PC/SP. */
.front-hero__panel {
	min-height: 0;
	overflow: hidden;
}
.front-hero__slide {
	display: none;
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(0,0,0,0.94) 0%, rgba(0,0,0,0.78) 34%, rgba(0,0,0,0.24) 70%),
		linear-gradient(115deg, rgba(255, 227, 154, 0.13), transparent 24%, transparent 76%, rgba(166,77,255,0.22)),
		radial-gradient(260px 160px at 72% 52%, rgba(255,227,154,0.22), transparent 70%),
		var(--hero-image) center right / contain no-repeat,
		#050508;
}
.front-hero__slide.is-active {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: clamp(420px, 40vw, 540px);
	opacity: 1;
	pointer-events: auto;
}
.front-hero__copy {
	position: relative;
	left: auto;
	right: auto;
	bottom: auto;
	width: min(540px, 100%);
	max-width: 100%;
	min-width: 0;
	padding: clamp(22px, 3.8vw, 44px);
	padding-bottom: clamp(28px, 4vw, 52px);
}
.front-hero__badge,
.front-hero__cta {
	max-width: 100%;
	white-space: normal;
	text-align: center;
}
.front-hero__meta,
.front-hero__tags {
	flex-wrap: wrap;
	min-width: 0;
}
.front-hero__meta span,
.front-hero__tags span {
	min-width: 0;
	overflow-wrap: anywhere;
}
.front-hero__title {
	font-size: clamp(25px, 3.4vw, 40px);
	overflow-wrap: anywhere;
}
.front-hero__cta {
	justify-content: center;
}
@media (max-width: 760px) {
	.front-hero__panel {
		min-height: 0;
	}
	.front-hero__slide {
		background:
			linear-gradient(180deg, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0.5) 44%, rgba(0,0,0,0.94) 100%),
			var(--hero-image) center top / cover no-repeat,
			#050508;
	}
	.front-hero__slide.is-active {
		min-height: clamp(440px, 126vw, 600px);
	}
	.front-hero__copy {
		width: 100%;
		padding: clamp(16px, 4vw, 20px);
		padding-bottom: clamp(22px, 6vw, 34px);
	}
	.front-hero__badge {
		min-height: 22px;
		padding: 3px 9px;
		font-size: 11px;
	}
	.front-hero__logo {
		width: clamp(118px, 36vw, 150px);
		margin: 8px 0 10px;
	}
	.front-hero__meta {
		gap: 6px 10px;
		font-size: 11px;
		margin-bottom: 6px;
	}
	.front-hero__title {
		font-size: clamp(20px, 6.1vw, 25px);
		line-height: 1.24;
		margin-bottom: 10px;
	}
	.front-hero__tags {
		gap: 6px;
		margin-bottom: 14px;
	}
	.front-hero__tags span {
		padding: 3px 8px;
		font-size: 10px;
	}
	.front-hero__cta {
		min-height: 38px;
		padding: 7px 14px;
		font-size: 13px;
	}
}

/* Final polish request */
.site-header__logo-img {
	height: 76px;
}
.site-header__nav a.is-disabled {
	opacity: 0.58;
	cursor: default;
	pointer-events: none;
}

.front-hero__panel {
	aspect-ratio: 15 / 8;
	min-height: 0;
	touch-action: pan-y;
	cursor: grab;
	user-select: none;
	-webkit-user-select: none;
}
.front-hero__panel:active {
	cursor: grabbing;
}
.front-hero__slide,
.front-hero__slide.is-active {
	position: absolute;
	inset: 0;
	display: block;
	min-height: 0;
	background:
		linear-gradient(90deg, rgba(0,0,0,0.16), rgba(0,0,0,0.04) 54%, rgba(0,0,0,0.1)),
		var(--hero-image) center center / contain no-repeat,
		#050508;
}
.front-hero__banner-link {
	position: absolute;
	inset: 0;
	display: block;
	color: inherit;
}
.front-hero__banner-link:hover {
	text-decoration: none;
}
.front-hero__badge {
	position: absolute;
	top: 14px;
	left: 14px;
	z-index: 2;
}
.front-hero__shine {
	z-index: 1;
}

.media-detail__header .media-detail__search {
	margin: 22px 0 0;
	padding: 18px;
	border: 1px solid rgba(255,225,148,0.34);
	border-radius: 10px;
	background: rgba(0,0,0,0.26);
}
.media-detail__header .media-detail__search .section-header {
	margin-bottom: 12px;
}
.media-detail__header .media-detail__search .section-header__title {
	font-size: 20px;
}
.media-official-card {
	width: auto;
	margin: 14px auto 0;
	display: inline-flex;
	gap: 8px;
	padding: 7px 14px;
	border-color: rgba(255,225,148,0.42);
	border-radius: 999px;
	background: rgba(0,0,0,0.38);
	box-shadow: none;
}
.media-official-card__text {
	color: var(--gold-2);
	font-weight: 800;
}
.media-official-card__arrow {
	width: 10px;
	height: 10px;
}

.giveaway__detail-stats {
	display: none;
}

@media (max-width: 760px) {
	body {
		padding-top: 82px;
	}
	.site-header__inner {
		min-height: 82px;
	}
	.site-header__logo-img {
		height: 60px;
	}
	.front-hero__panel {
		aspect-ratio: 15 / 8;
	}
	.front-hero__slide,
	.front-hero__slide.is-active {
		background:
			linear-gradient(180deg, rgba(0,0,0,0.04), rgba(0,0,0,0.24)),
			var(--hero-image) center center / cover no-repeat,
			#050508;
	}
	.front-hero__badge {
		top: 8px;
		left: 8px;
		min-height: 20px;
		padding: 2px 8px;
		font-size: 10px;
	}
	.front-media .media-tile {
		flex-basis: 112px;
	}
	.front-media .media-tile__image {
		aspect-ratio: 1 / 1;
	}
	.media-detail__header .media-detail__search {
		padding: 12px;
	}
	.media-detail__header .media-detail__search .section-header__title {
		font-size: 17px;
	}
}

/* Media search rail: always one horizontal row. */
.front-media .media-rail {
	position: relative;
	margin-top: 8px;
}
.front-media .media-grid {
	display: flex !important;
	grid-template-columns: none !important;
	flex-wrap: nowrap;
	gap: 14px;
	overflow-x: auto;
	overflow-y: hidden;
	padding: 2px 2px 16px;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
}
.front-media .media-tile {
	flex: 0 0 150px;
	scroll-snap-align: start;
}
/* Scroll affordance: fade gradient on the right edge */
.front-media .media-rail::before,
.front-media .media-rail::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 16px;
	width: 56px;
	pointer-events: none;
	z-index: 2;
	transition: opacity 0.25s ease;
}
.front-media .media-rail::before {
	left: 0;
	background: linear-gradient(90deg, var(--bg) 0%, rgba(12,12,16,0) 100%);
	opacity: 0;
}
.front-media .media-rail::after {
	right: 0;
	background: linear-gradient(90deg, rgba(12,12,16,0) 0%, var(--bg) 85%);
}
.front-media .media-rail.is-rail-scrolled::before { opacity: 1; }
.front-media .media-rail.is-rail-end::after { opacity: 0; }

/* Swipe hint (SP only) */
.media-rail__hint { display: none; }
@media (max-width: 760px) {
	.front-media .media-grid {
		gap: 10px;
		padding-bottom: 12px;
	}
	.front-media .media-tile {
		flex-basis: 112px;
	}
	.front-media .media-rail::before,
	.front-media .media-rail::after {
		bottom: 12px;
		width: 44px;
	}
	.media-rail__hint {
		display: flex;
		align-items: center;
		justify-content: flex-end;
		gap: 8px;
		margin: 6px 2px 0;
		font-size: 11px;
		font-weight: 700;
		letter-spacing: 0.06em;
		color: var(--text-mute);
		transition: opacity 0.3s ease;
	}
	.media-rail.is-rail-end .media-rail__hint { opacity: 0; }
	.media-rail__hint-arrow {
		display: inline-block;
		color: var(--gold-2);
		font-size: 14px;
		font-weight: 900;
		letter-spacing: -0.1em;
		text-shadow: 0 0 8px rgba(255,225,148,0.4);
		animation: media-rail-hint-arrow 1.4s ease-in-out infinite;
	}
}

.site-header__logo {
	filter: none !important;
	text-shadow: none !important;
	box-shadow: none !important;
}
.site-header__logo-img {
	height: 148px !important;
	filter: none !important;
	text-shadow: none !important;
	box-shadow: none !important;
}
.site-header__inner {
	min-height: 164px;
}
body {
	padding-top: 164px;
}
@media (max-width: 760px) {
	body {
		padding-top: 88px;
	}
	.site-header__inner {
		min-height: 88px;
	}
	.site-header__logo-img {
		height: 72px !important;
	}
}
@keyframes media-rail-hint-arrow {
	0%, 100% { transform: translateX(0); opacity: 0.55; }
	50% { transform: translateX(6px); opacity: 1; }
}

/* SP media detail layout */
.media-detail__visual {
	position: relative;
}
.media-detail__visual .media-official-card {
	position: absolute;
	right: 12px;
	bottom: 12px;
	margin: 0;
	z-index: 2;
}
@media (max-width: 760px) {
	.media-detail {
		padding: 12px 10px 18px;
	}
	.media-detail__header {
		margin: 0;
		padding: 0 0 16px;
		border: 0;
		background: transparent;
		box-shadow: none;
		text-align: left;
	}
	.media-detail__visual {
		margin: 0 0 22px;
	}
	.media-detail__banner {
		width: 100%;
		max-width: none;
		aspect-ratio: 3 / 1;
		border-radius: 8px;
		object-fit: cover;
		border-color: rgba(255,225,148,0.46);
		box-shadow: 0 0 22px rgba(215,169,53,0.14);
	}
	.media-detail__visual .media-official-card {
		right: 8px;
		bottom: 8px;
		min-height: 28px;
		padding: 5px 10px;
		border-radius: 999px;
		background: rgba(0,0,0,0.56);
		border-color: rgba(255,225,148,0.42);
		backdrop-filter: blur(8px);
	}
	.media-official-card__text {
		font-size: 10px;
		line-height: 1.2;
	}
	.media-official-card__arrow {
		width: 8px;
		height: 8px;
	}
	.media-detail__title {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 14px;
		margin: 0 0 20px;
		color: var(--gold-2);
		font-size: 21px;
		line-height: 1.35;
		text-align: center;
		letter-spacing: 0.03em;
	}
	.media-detail__title::before,
	.media-detail__title::after {
		content: "";
		flex: 1 1 40px;
		max-width: 84px;
		height: 1px;
		background: linear-gradient(90deg, transparent, rgba(255,225,148,0.62));
	}
	.media-detail__title::after {
		background: linear-gradient(90deg, rgba(255,225,148,0.62), transparent);
	}
	.media-detail__header .media-detail__search {
		margin: 0;
		padding: 14px;
		border: 1px solid rgba(255,225,148,0.38);
		border-radius: 10px;
		background: linear-gradient(180deg, rgba(10,8,14,0.94), rgba(2,2,5,0.96));
		box-shadow: inset 0 0 22px rgba(255,227,154,0.04);
	}
	.media-detail__header .media-detail__search .section-header {
		margin: 0 0 12px;
	}
	.media-detail__header .media-detail__search .section-header__title {
		font-size: 18px;
		border-left-width: 4px;
		padding-left: 10px;
	}
	.media-detail .slorisu-search--compact {
		padding: 0;
		border: 0;
		background: transparent;
		box-shadow: none;
	}
	.media-detail .slorisu-search--compact .slorisu-search__row {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
	}
	.media-detail .slorisu-search--compact .slorisu-search__field input,
	.media-detail .slorisu-search--compact .slorisu-search__field select {
		min-height: 44px;
		border-color: rgba(255,225,148,0.38);
		background-color: rgba(0,0,0,0.72);
		color: #fff;
		font-size: 13px;
	}
	.media-detail .slorisu-search--compact .slorisu-search__field:nth-of-type(3) {
		grid-column: 1 / -1;
	}
	.media-detail .slorisu-search--compact .slorisu-search__actions {
		grid-column: 1 / -1;
		margin-top: 0;
	}
	.media-detail .slorisu-search--compact .slorisu-search__submit {
		width: 100%;
		min-height: 46px;
		border-radius: 7px;
		font-size: 15px;
	}
}

/* Media rail final responsive override */
.media-rail {
	position: relative;
	margin-top: 8px;
}
.media-rail .media-grid {
	display: flex !important;
	grid-template-columns: none !important;
	flex-flow: row nowrap !important;
	gap: 14px;
	overflow-x: auto;
	overflow-y: hidden;
	padding: 2px 2px 16px;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
	touch-action: pan-x;
}
.media-rail .media-grid::-webkit-scrollbar { height: 6px; }
.media-rail .media-grid::-webkit-scrollbar-thumb {
	background: linear-gradient(90deg, var(--gold), var(--neon));
	border-radius: 999px;
}
.media-rail .media-tile {
	flex: 0 0 150px !important;
	min-width: 150px;
	max-width: 150px;
	scroll-snap-align: start;
	border-color: rgba(255,225,148,0.42);
	border-radius: 9px;
	background: linear-gradient(180deg, rgba(14,10,22,0.96), rgba(4,4,8,0.98));
	box-shadow: inset 0 0 20px rgba(166,77,255,0.08), 0 0 22px rgba(166,77,255,0.1);
}
.media-rail .media-tile__image {
	width: 100%;
	aspect-ratio: 1 / 1;
	background-size: cover;
	background-position: center;
	border-bottom-color: rgba(255,225,148,0.24);
}
.media-rail .media-tile__title {
	margin: 0;
	padding: 10px 8px 12px;
	color: #fff;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.35;
	text-align: center;
}
.media-rail::before,
.media-rail::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 16px;
	width: 56px;
	pointer-events: none;
	z-index: 2;
	transition: opacity 0.25s ease;
}
.media-rail::before {
	left: 0;
	background: linear-gradient(90deg, var(--bg) 0%, rgba(12,12,16,0) 100%);
	opacity: 0;
}
.media-rail::after {
	right: 0;
	background: linear-gradient(90deg, rgba(12,12,16,0) 0%, var(--bg) 85%);
}
.media-rail.is-rail-scrolled::before { opacity: 1; }
.media-rail.is-rail-end::after { opacity: 0; }

@media (max-width: 760px) {
	.media-rail .media-grid {
		gap: 10px;
		padding: 2px 2px 12px;
	}
	.media-rail .media-tile {
		flex-basis: 112px !important;
		min-width: 112px;
		max-width: 112px;
	}
	.media-rail .media-tile__title {
		padding: 8px 7px 10px;
		font-size: 11px;
		line-height: 1.3;
	}
	.media-rail::before,
	.media-rail::after {
		bottom: 12px;
		width: 44px;
	}
	.media-rail__hint {
		display: flex;
		align-items: center;
		justify-content: flex-end;
		gap: 8px;
		margin: 6px 2px 0;
		font-size: 11px;
		font-weight: 700;
		letter-spacing: 0.06em;
		color: var(--text-mute);
		transition: opacity 0.3s ease;
	}
	.media-rail.is-rail-end .media-rail__hint { opacity: 0; }
	.media-rail__hint-arrow {
		display: inline-block;
		color: var(--gold-2);
		font-size: 14px;
		font-weight: 900;
		letter-spacing: -0.1em;
		text-shadow: 0 0 8px rgba(255,225,148,0.4);
		animation: media-rail-hint-arrow 1.4s ease-in-out infinite;
	}
}

/* Media official link: below banner, right aligned */
.media-detail__visual {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 10px;
	max-width: 960px;
	margin-left: auto;
	margin-right: auto;
}
.media-detail__visual .media-official-card {
	position: static !important;
	right: auto !important;
	bottom: auto !important;
	align-self: flex-end;
	width: auto;
	max-width: 100%;
	margin: 0;
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	padding: 7px 12px;
	border-color: rgba(255,225,148,0.42);
	border-radius: 999px;
	background: rgba(0,0,0,0.38);
	box-shadow: none;
}
.media-detail__visual .media-official-card__text {
	color: var(--gold-2);
	font-size: 12px;
	font-weight: 800;
	line-height: 1.35;
	text-align: right;
}
.media-detail__visual .media-official-card__arrow {
	position: relative;
	width: 14px;
	height: 14px;
	margin-left: 0;
	border: 1px solid currentColor;
	border-radius: 2px;
	transform: none;
	color: var(--gold-2);
}
.media-detail__visual .media-official-card__arrow::before {
	content: "";
	position: absolute;
	top: 2px;
	right: 2px;
	width: 6px;
	height: 6px;
	border-top: 2px solid currentColor;
	border-right: 2px solid currentColor;
}
.media-detail__visual .media-official-card__arrow::after {
	content: "";
	position: absolute;
	top: 6px;
	right: 2px;
	width: 7px;
	height: 2px;
	background: currentColor;
	transform: rotate(-45deg);
	transform-origin: right center;
}
@media (max-width: 760px) {
	.media-detail__visual {
		gap: 8px;
		margin-bottom: 20px;
	}
	.media-detail__visual .media-official-card {
		max-width: calc(100% - 4px);
		min-height: 30px;
		padding: 6px 10px;
		background: rgba(0,0,0,0.32);
		backdrop-filter: none;
	}
	.media-detail__visual .media-official-card__text {
		font-size: 10px;
	}
	.media-detail__visual .media-official-card__arrow {
		width: 12px;
		height: 12px;
	}
}
