:root {
	--media-bg: #f3f0ea;
	--media-surface: #fffdfa;
	--media-panel: #f6ddd2;
	--media-text: #241d18;
	--media-muted: #6f675f;
	--media-line: #d8cdc2;
	--media-stroke: #2d241d;
	--media-accent: #e4cf88;
	--media-accent-strong: #b7744e;
	--media-shadow: 0 16px 34px rgba(64, 40, 22, 0.06);
	--media-radius-xl: 30px;
	--media-radius-lg: 24px;
	--media-radius-md: 18px;
	--media-radius-pill: 999px;
	--media-shell: min(1380px, calc(100% - 48px));
}

.post-type-archive-media #content.l-content,
.single-media #content.l-content,
.post-type-archive-media #content.l-content.l-container,
.single-media #content.l-content.l-container,
.post-type-archive-media .l-mainContent,
.post-type-archive-media .l-mainContent__inner,
.single-media .l-mainContent,
.single-media .l-mainContent__inner {
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
}

.media-archive,
.media-single {
	background: var(--media-bg);
	color: var(--media-text);
	padding: 28px 0 96px;
}

.media-archive {
	background:
		linear-gradient(rgba(243, 240, 234, 0.78), rgba(243, 240, 234, 0.78)),
		url("https://futofura.com/wp-content/uploads/2026/04/bg_media.png") center top / cover fixed no-repeat;
}

.media-single {
	background:
		linear-gradient(rgba(243, 240, 234, 0.93), rgba(243, 240, 234, 0.93)),
		url("https://futofura.com/wp-content/uploads/2026/04/bg_media.png") center top / cover fixed no-repeat;
}

.media-mobile-return {
	display: none;
}

.media-shell {
	width: min(1120px, calc(100% - 48px));
	margin: 0 auto;
}

.media-shell-wide {
	width: var(--media-shell);
}

.media-layout {
	display: grid;
	grid-template-columns: clamp(250px, 25vw, 340px) minmax(0, 1fr);
	gap: 42px;
	align-items: start;
}

.media-intro-panel {
	position: sticky;
	top: 28px;
}

.media-intro-card {
	position: relative;
	padding: 34px 30px 30px;
	border-radius: var(--media-radius-xl);
	background:
		radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.35) 0 10%, transparent 28%),
		radial-gradient(circle at 80% 15%, rgba(255, 255, 255, 0.18) 0 8%, transparent 24%),
		linear-gradient(315deg, #f2efe9 0%, #f4e8de 42%, #f6ddd2 72%, #f8e8df 100%);
	box-shadow:
		18px 18px 0 rgba(99, 76, 73, 0.18),
		var(--media-shadow);
	overflow: hidden;
	min-height: min(760px, calc(100vh - 120px));
}

.media-intro-card::before,
.media-intro-card::after {
	position: absolute;
	font-size: 30px;
	line-height: 1;
	opacity: 0.28;
}

.media-intro-card::before {
	content: "✦";
	top: 18px;
	left: 24px;
}

.media-intro-card::after {
	content: "◌";
	right: 24px;
	bottom: 140px;
	font-size: 42px;
}

.media-intro-kicker,
.media-eyebrow,
.media-section-kicker {
	margin: 0 0 16px;
	color: var(--media-accent-strong);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.2em;
}

.media-intro-title {
	margin: 0;
	font-size: clamp(24px, 2.8vw, 48px);
	line-height: 1.18;
	letter-spacing: 0.02em;
	writing-mode: vertical-rl;
	text-orientation: mixed;
	height: clamp(280px, 46vw, 420px);
	max-height: 46vh;
	overflow: hidden;
}

.media-intro-count {
	margin: 28px 0 0;
	color: #f4e3b9;
	font-size: clamp(56px, 7vw, 102px);
	line-height: 0.95;
	-webkit-text-stroke: 1.5px rgba(45, 36, 29, 0.45);
	text-shadow: 2px 2px 0 rgba(255, 255, 255, 0.45);
}

.media-intro-count-label {
	margin: 8px 0 0;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.28em;
}

.media-intro-text {
	margin: 28px 0 0;
	color: var(--media-muted);
	font-size: clamp(13px, 1vw, 15px);
	line-height: 1.9;
}

.media-intro-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	margin-top: 28px;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: none;
	color: transparent;
	font-size: 0;
	text-decoration: none;
	isolation: isolate;
}

.media-intro-link::before {
	content: "検索ページへ →";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 46px;
	padding: 0 18px;
	border-radius: 999px;
	background:
		radial-gradient(circle at 23px 23px, rgba(255, 255, 255, 0.97) 0 22px, transparent 22.5px) 0 0 / 35px 46px repeat-x;
	color: #4e3d35;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.18em;
	white-space: nowrap;
	box-shadow: 0 4px 10px rgba(151, 124, 105, 0.08);
	transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.media-intro-link:hover::before {
	transform: translateY(-2px);
	box-shadow: 0 7px 14px rgba(151, 124, 105, 0.12);
}

.media-intro-link,
.media-intro-link-bubbles {
	display: none;
}

.media-intro-link-bubbles-fixed {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	margin-top: 28px;
	text-decoration: none;
}

.media-intro-link-bubbles-fixed span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	margin-left: -7px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.96);
	color: #4e3d35;
	font-size: 16px;
	font-weight: 700;
	line-height: 1;
	box-shadow: 0 4px 10px rgba(151, 124, 105, 0.08);
	transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
}

.media-intro-link-bubbles-fixed span:first-child {
	margin-left: 0;
}

.media-intro-link-bubbles-fixed__arrow {
	font-size: 18px;
	font-weight: 700;
}

.media-intro-link-bubbles-fixed:hover span {
	transform: translateY(-2px);
	box-shadow: 0 7px 14px rgba(151, 124, 105, 0.12);
	background: rgba(255, 255, 255, 1);
}

.media-intro-card::after {
	display: none;
}

.media-intro-card > .media-intro-title,
.media-intro-card > .media-intro-count,
.media-intro-card > .media-intro-count-label,
.media-intro-card > .media-intro-text {
	display: none;
}

.media-intro-content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.media-intro-heading-wrap {
	display: grid;
	grid-template-columns: auto auto;
	align-items: start;
	justify-content: center;
	column-gap: clamp(18px, 2.4vw, 34px);
	width: 100%;
}

.media-intro-title-new {
	position: relative;
	align-self: start;
	grid-column: 2;
	margin: 0;
	font-size: clamp(55px, 6.6vw, 108px);
	line-height: 1.18;
	letter-spacing: 0.02em;
	writing-mode: vertical-rl;
	text-orientation: mixed;
	height: clamp(280px, 46vw, 420px);
	max-height: 46vh;
	overflow: hidden;
	color: transparent;
	filter: drop-shadow(16px 16px 0 rgba(99, 76, 73, 0.22));
}

.media-intro-title-new::before,
.media-intro-title-new::after {
	content: "ふとふら手帳";
	position: absolute;
	inset: 0;
	display: block;
	font: inherit;
	letter-spacing: inherit;
	line-height: inherit;
	writing-mode: inherit;
	text-orientation: inherit;
	white-space: nowrap;
}

.media-intro-title-new::before {
	color: transparent;
	-webkit-text-stroke: 2px var(--media-text);
}

.media-intro-title-new::after {
	color: var(--media-text);
	-webkit-text-stroke: 1px var(--media-text);
	animation: media-intro-title-wave 4.2s ease-in-out infinite;
}

.media-intro-text-new {
	margin: 28px 0 0;
	color: var(--media-muted);
	font-size: clamp(13px, 1vw, 15px);
	line-height: 1.9;
}

.media-intro-title-new::before,
.media-intro-title-new::after {
	content: "ふとふら手帖";
}

@keyframes media-intro-title-wave {
	0%,
	100% {
		clip-path: polygon(
			0% 50%,
			15% 46%,
			33% 51%,
			51% 61%,
			68% 63%,
			84% 58%,
			100% 50%,
			100% 100%,
			0% 100%
		);
	}

	50% {
		clip-path: polygon(
			0% 63%,
			15% 67%,
			33% 66%,
			51% 58%,
			68% 48%,
			84% 43%,
			100% 46%,
			100% 100%,
			0% 100%
		);
	}
}

@keyframes media-intro-title-wave {
	0%,
	100% {
		clip-path: polygon(
			0% 0%,
			48% 0%,
			44% 16%,
			49% 34%,
			59% 52%,
			61% 70%,
			56% 86%,
			48% 100%,
			0% 100%
		);
	}

	50% {
		clip-path: polygon(
			0% 0%,
			60% 0%,
			64% 15%,
			61% 34%,
			53% 52%,
			43% 69%,
			38% 85%,
			41% 100%,
			0% 100%
		);
	}
}

.media-intro-kicker {
	display: none;
}

.media-intro-title-new {
	font-size: clamp(25px, 3vw, 51px);
}

.media-intro-title-new::before,
.media-intro-title-new::after {
	content: "ふとふら手帖";
}

.media-intro-title-new::after {
	animation-name: media-intro-title-wave-side;
}

@keyframes media-intro-title-wave-side {
	0%,
	100% {
		clip-path: polygon(
			0% 0%,
			48% 0%,
			44% 16%,
			49% 34%,
			59% 52%,
			61% 70%,
			56% 86%,
			48% 100%,
			0% 100%
		);
	}

	50% {
		clip-path: polygon(
			0% 0%,
			60% 0%,
			64% 15%,
			61% 34%,
			53% 52%,
			43% 69%,
			38% 85%,
			41% 100%,
			0% 100%
		);
	}
}

@keyframes media-intro-title-wave-bottom {
	0%,
	100% {
		clip-path: polygon(
			0% 50%,
			15% 46%,
			33% 51%,
			51% 61%,
			68% 63%,
			84% 58%,
			100% 50%,
			100% 100%,
			0% 100%
		);
	}

	50% {
		clip-path: polygon(
			0% 63%,
			15% 67%,
			33% 66%,
			51% 58%,
			68% 48%,
			84% 43%,
			100% 46%,
			100% 100%,
			0% 100%
		);
	}
}

.media-intro-card {
	background:
		radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.35) 0 10%, transparent 28%),
		radial-gradient(circle at 80% 15%, rgba(255, 255, 255, 0.18) 0 8%, transparent 24%),
		linear-gradient(315deg, #f2efe9 0%, #f4e8de 42%, #f6ddd2 72%, #f8e8df 100%);
}

/* PCラッコ */
.media-intro-card::before {
	content: "";
	position: absolute;
	left: 18px;
	bottom: -190px;
	width: 134px;
	height: 134px;
	background: url("https://futofura.com/wp-content/uploads/2026/03/korakko_left.png") center / contain no-repeat;
	opacity: 0.98;
	transform-origin: center bottom;
	animation: media-intro-otter-float 5s ease-in-out infinite;
	pointer-events: none;
	z-index: 2;
}

.media-intro-content {
	position: relative;
	z-index: 3;
}

.media-intro-card::before {
	content: none !important;
	display: none !important;
}

.media-intro-otter {
	position: absolute;
	right: 18px;
	bottom: 300px;
	width: 134px;
	height: 134px;
	background: url("https://futofura.com/wp-content/uploads/2026/03/korakko_left.png") center / contain no-repeat;
	opacity: 0.98;
	transform-origin: center bottom;
	transform: scaleX(-1);
	animation: media-intro-otter-float-flip 5s ease-in-out infinite;
	pointer-events: none;
	z-index: 2;
}

.media-intro-link::before {
	content: "検 索 ペ ー ジ へ →";
	padding: 0 16px 0 18px;
	background:
		radial-gradient(circle at 23px 23px, rgba(255, 255, 255, 0.97) 0 20px, transparent 20.5px) 0 0 / 38px 46px repeat-x;
	letter-spacing: 0.08em;
}

@keyframes media-intro-otter-float {
	0% {
		transform: translateY(0) rotate(0deg);
	}

	25% {
		transform: translateY(-7px) rotate(-1.1deg);
	}

	50% {
		transform: translateY(1px) rotate(0.7deg);
	}

	75% {
		transform: translateY(-5px) rotate(-0.7deg);
	}

	100% {
		transform: translateY(0) rotate(0deg);
	}
}

@keyframes media-intro-otter-float-flip {
	0% {
		transform: scaleX(-1) translateY(0) rotate(0deg);
	}

	25% {
		transform: scaleX(-1) translateY(-7px) rotate(-1.1deg);
	}

	50% {
		transform: scaleX(-1) translateY(1px) rotate(0.7deg);
	}

	75% {
		transform: scaleX(-1) translateY(-5px) rotate(-0.7deg);
	}

	100% {
		transform: scaleX(-1) translateY(0) rotate(0deg);
	}
}

.media-main-column {
	min-width: 0;
}

.media-search-panel,
.media-single-thumbnail,
.media-side-card,
.media-empty {
	border-radius: var(--media-radius-xl);
	background: var(--media-surface);
	box-shadow: var(--media-shadow);
}

.media-brand-hero__inner {
	max-width: 100%;
	text-align: left;
}

.media-brand-hero {
	align-self: start;
	grid-column: 1;
	margin: 10px 0 0;
	padding: 0;
	background: transparent;
	box-shadow: none;
}

.media-brand-hero__title {
	margin: 0;
	color: var(--media-text);
	font-size: clamp(16px, 1.45vw, 22px);
	font-weight: 800;
	line-height: 1.55;
	letter-spacing: 0.08em;
	writing-mode: vertical-rl;
	text-orientation: mixed;
	white-space: nowrap;
}

.media-brand-hero__static {
	display: inline-block;
	vertical-align: top;
}

.media-brand-hero__rotator {
	--media-brand-hero-slot: 1.34em;
	display: inline-flex;
	position: relative;
	vertical-align: top;
	justify-content: flex-start;
	width: var(--media-brand-hero-slot);
	height: 5.5em;
	min-width: var(--media-brand-hero-slot);
	margin: 0 0.02em;
	overflow: hidden;
	writing-mode: horizontal-tb;
}

.media-brand-hero__track {
	display: flex;
	width: calc(var(--media-brand-hero-slot) * 7);
	height: 100%;
	animation: media-brand-hero-slide-desktop 14s cubic-bezier(0.76, 0, 0.24, 1) infinite;
	writing-mode: horizontal-tb;
}

.media-brand-hero__word {
	display: flex;
	flex: 0 0 var(--media-brand-hero-slot);
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: var(--media-brand-hero-slot);
	min-width: var(--media-brand-hero-slot);
	height: 100%;
	padding: 0.18em 0.42em 0.22em;
	color: var(--media-text);
	font-size: 1em;
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
	writing-mode: vertical-rl;
	text-orientation: mixed;
	border-radius: 6px;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.55),
		0 6px 16px rgba(96, 74, 57, 0.06);
}

.media-brand-hero__tail,
.media-brand-hero__static {
	display: inline-block;
}

.media-brand-hero__word--vision {
	background: linear-gradient(135deg, #f3d3ca 0%, #edc1b4 100%);
}

.media-brand-hero__word--idea {
	background: linear-gradient(135deg, #efd7bf 0%, #e8c39e 100%);
}

.media-brand-hero__word--fun {
	background: linear-gradient(135deg, #f2cfd5 0%, #ebb8c1 100%);
}

.media-brand-hero__word--relief {
	background: linear-gradient(135deg, #d9e6cb 0%, #c7daad 100%);
}

.media-brand-hero__word--choice {
	background: linear-gradient(135deg, #e8d3c7 0%, #ddbead 100%);
}

.media-brand-hero__word--style {
	background: linear-gradient(135deg, #f0dfbc 0%, #e7c990 100%);
}

@keyframes media-brand-hero-slide-desktop {
	0%,
	10% {
		transform: translateX(0);
	}

	14%,
	24% {
		transform: translateX(calc(-1 * var(--media-brand-hero-slot)));
	}

	28%,
	38% {
		transform: translateX(calc(-2 * var(--media-brand-hero-slot)));
	}

	42%,
	52% {
		transform: translateX(calc(-3 * var(--media-brand-hero-slot)));
	}

	56%,
	66% {
		transform: translateX(calc(-4 * var(--media-brand-hero-slot)));
	}

	70%,
	80% {
		transform: translateX(calc(-5 * var(--media-brand-hero-slot)));
	}

	84%,
	94% {
		transform: translateX(calc(-5 * var(--media-brand-hero-slot)));
	}

	100% {
		transform: translateX(calc(-6 * var(--media-brand-hero-slot)));
	}
}

@keyframes media-brand-hero-slide-mobile {
	0%,
	10% {
		transform: translateY(0);
	}

	14%,
	24% {
		transform: translateY(-14.285714%);
	}

	28%,
	38% {
		transform: translateY(-28.571429%);
	}

	42%,
	52% {
		transform: translateY(-42.857143%);
	}

	56%,
	66% {
		transform: translateY(-57.142857%);
	}

	70%,
	80% {
		transform: translateY(-71.428571%);
	}

	84%,
	94% {
		transform: translateY(-71.428571%);
	}

	100% {
		transform: translateY(-85.714286%);
	}
}

.media-search-panel {
	padding: 20px 24px 24px;
}

.media-search-form--stacked {
	display: grid;
	gap: 18px;
}

.media-search-header,
.media-search-row,
.media-section-head,
.media-card-meta,
.media-single-meta,
.media-single-layout {
	display: flex;
	gap: 16px;
}

.media-search-header,
.media-search-row,
.media-section-head {
	align-items: center;
	justify-content: space-between;
}

.media-search-label {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.media-search-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: auto;
	height: auto;
	border: 0;
	border-radius: 0;
	font-size: 14px;
	line-height: 1;
}

.media-chip-group,
.media-term-list,
.media-card-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.media-chip-group-large {
	gap: 10px 12px;
}

.media-chip,
.media-term-list a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	padding: 0 16px;
	border: 1px solid rgba(45, 36, 29, 0.72);
	border-radius: var(--media-radius-pill);
	background: #fff;
	color: var(--media-text);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.media-chip:hover,
.media-chip.is-active,
.media-term-list a:hover {
	background: #fff8ec;
	color: var(--media-text);
	transform: translateY(-1px);
	border-color: rgba(45, 36, 29, 0.82);
}

.media-chip.is-static {
	border-color: transparent;
	background: #fff4df;
	color: var(--media-accent-strong);
}

.media-chip.is-active {
	background: #fff;
	box-shadow: inset 0 0 0 1px rgba(45, 36, 29, 0.08);
}

.media-input,
.media-select,
.media-sort-wrap select {
	width: 100%;
	min-height: 54px;
	padding: 0 18px;
	border: 1px solid rgba(45, 36, 29, 0.14);
	border-radius: 18px;
	background: #fff;
	color: var(--media-text);
	font-size: 15px;
}

.media-sort-wrap {
	display: grid;
	gap: 8px;
	color: var(--media-muted);
	font-size: 13px;
}

.media-button {
	min-width: 132px;
	min-height: 54px;
	padding: 0 22px;
	border: 0;
	border-radius: 18px;
	background: #3a312a;
	color: #fff;
	font-size: 15px;
	font-weight: 700;
	cursor: pointer;
}

.media-search-row {
	align-items: center;
}

.media-search-row .media-input {
	flex: 1 1 320px;
}

.media-search-row .media-select {
	flex: 1 1 280px;
}

.media-search-row .media-button {
	flex: 0 0 180px;
}

.media-archive-tools {
	display: flex;
	align-items: end;
	gap: 20px;
	flex-wrap: wrap;
}

.media-sort-form {
	margin: 0;
}

.media-sort-wrap-inline {
	min-width: 180px;
}

.media-sort-wrap-inline select {
	min-width: 180px;
}

.media-pickup-strip,
.media-list-section,
.media-related {
	padding-top: 30px;
}

.media-brand-banner {
	position: relative;
	left: 50%;
	width: 100vw;
	margin-top: 72px;
	margin-bottom: -96px;
	margin-left: -50vw;
	margin-right: -50vw;
	padding: 52px 0 58px;
	background:
		radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.35) 0 10%, transparent 28%),
		radial-gradient(circle at 80% 15%, rgba(255, 255, 255, 0.18) 0 8%, transparent 24%),
		linear-gradient(315deg, #f2efe9 0%, #f4e8de 42%, #f6ddd2 72%, #f8e8df 100%);
}

.media-brand-banner__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	max-width: 980px;
	margin: 0 auto;
	text-align: center;
}

.media-brand-banner__name {
	position: relative;
	display: inline-block;
	margin: 0;
	font-size: clamp(24px, 3vw, 42px);
	font-weight: 800;
	line-height: 1.12;
	letter-spacing: 0.02em;
	color: transparent;
	filter: drop-shadow(10px 10px 0 rgba(99, 76, 73, 0.18));
}

.media-brand-banner__name::before,
.media-brand-banner__name::after {
	content: "ふとふら手帖";
	position: absolute;
	inset: 0;
	display: block;
	font: inherit;
	letter-spacing: inherit;
	line-height: inherit;
	white-space: nowrap;
}

.media-brand-banner__name::before {
	color: transparent;
	-webkit-text-stroke: 1.6px var(--media-text);
}

.media-brand-banner__name::after {
	color: var(--media-text);
	-webkit-text-stroke: 0.8px var(--media-text);
	animation: media-intro-title-wave-bottom 4.2s ease-in-out infinite;
}

.media-brand-banner__title {
	display: block;
	margin: 0;
	color: var(--media-text);
	font-size: clamp(15px, 1.55vw, 22px);
	font-weight: 800;
	line-height: 1.45;
	letter-spacing: 0.05em;
	text-align: center;
	white-space: nowrap;
}

.media-brand-banner__static,
.media-brand-banner__tail {
	display: inline-block;
	vertical-align: top;
}

.media-brand-banner__rotator {
	display: inline-flex;
	vertical-align: top;
	width: auto;
	height: 1.34em;
	min-width: 5.1em;
	margin: 0 0.03em;
	overflow: hidden;
	writing-mode: horizontal-tb;
}

.media-brand-banner__track {
	display: flex;
	flex-direction: column;
	width: 100%;
	height: 700%;
	animation: media-brand-hero-slide-mobile 14s cubic-bezier(0.76, 0, 0.24, 1) infinite;
}

.media-brand-banner__word {
	display: flex;
	flex: 0 0 calc(100% / 7);
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: auto;
	height: calc(100% / 7);
	padding: 0.16em 0.5em 0.18em;
	color: var(--media-text);
	font-size: 1em;
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
	border-radius: 6px;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.55),
		0 6px 16px rgba(96, 74, 57, 0.06);
}

.media-brand-banner__word--vision {
	background: linear-gradient(135deg, #f3d3ca 0%, #edc1b4 100%);
}

.media-brand-banner__word--idea {
	background: linear-gradient(135deg, #efd7bf 0%, #e8c39e 100%);
}

.media-brand-banner__word--fun {
	background: linear-gradient(135deg, #f2cfd5 0%, #ebb8c1 100%);
}

.media-brand-banner__word--relief {
	background: linear-gradient(135deg, #d9e6cb 0%, #c7daad 100%);
}

.media-brand-banner__word--choice {
	background: linear-gradient(135deg, #e8d3c7 0%, #ddbead 100%);
}

.media-brand-banner__word--style {
	background: linear-gradient(135deg, #f0dfbc 0%, #e7c990 100%);
}

.media-brand-banner__tail-line {
	display: inline;
}

.media-section-head {
	margin-bottom: 32px;
}

.media-section-head-compact {
	margin-bottom: 18px;
}

.media-section-title,
.media-page-title,
.media-single-title {
	margin: 0;
	font-size: clamp(28px, 4vw, 46px);
	line-height: 1.2;
}

.media-page-lead {
	max-width: 760px;
	margin: 24px 0 0;
	color: var(--media-muted);
	font-size: 16px;
	line-height: 1.9;
}

.media-result-count {
	margin: 0;
	font-size: 14px;
	color: var(--media-muted);
}

.media-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 36px 30px;
}

.media-grid-magazine {
	align-items: start;
}

.media-card {
	position: relative;
	margin: 0;
}

.media-card-link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.media-card-number {
	position: absolute;
	top: -18px;
	left: 0;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 0 16px;
	border-radius: 10px;
	background: rgba(99, 76, 73, 0.42);
	color: #ffffff;
	font-size: 26px;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0.04em;
	-webkit-text-stroke: 0;
	text-shadow: none;
	white-space: nowrap;
}

.media-card-image {
	position: relative;
	overflow: visible;
	aspect-ratio: 4 / 5;
	background: linear-gradient(135deg, #efe2cd 0%, #dfcfb6 100%);
}

.media-card-magazine .media-card-image::after,
.media-card-featured .media-card-image::after {
	content: "";
	position: absolute;
	right: -10px;
	top: 10px;
	width: 100%;
	height: 100%;
	background: rgba(228, 207, 136, 0.68);
	z-index: -1;
}

.media-card-image img,
.media-single-thumbnail img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.media-card-placeholder {
	display: grid;
	place-items: center;
	height: 100%;
	color: var(--media-muted);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.18em;
}

.media-card-body {
	padding-top: 16px;
}

.media-card-title {
	margin: 0 0 12px;
	font-size: 22px;
	line-height: 1.42;
}

.media-card-title-bubble {
	display: inline;
	padding: 0.08em 0.45em 0.14em;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.88);
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}

.media-card-excerpt {
	margin: 16px 0 0;
	color: var(--media-text);
	font-size: 14px;
	line-height: 1.95;
}

.media-card-tags {
	margin-top: 14px;
	color: var(--media-muted);
	font-size: 13px;
	font-weight: 700;
}

.media-card-meta,
.media-single-meta {
	flex-wrap: wrap;
	color: var(--media-muted);
	font-size: 13px;
}

.media-card-more {
	display: inline-block;
	margin-top: 18px;
	color: var(--media-accent-strong);
	font-size: 13px;
	font-weight: 700;
}

.media-pagination {
	margin-top: 36px;
}

.media-pagination ul {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	list-style: none;
	padding: 0;
}

.media-pagination a,
.media-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	min-height: 42px;
	padding: 0 14px;
	border: 1px solid var(--media-line);
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.95);
	color: var(--media-text);
	text-decoration: none;
}

.media-pagination .current {
	background: var(--media-text);
	border-color: var(--media-text);
	color: #fff;
}

.media-single-thumbnail {
	margin-top: 30px;
	overflow: hidden;
}

.media-single-hero {
	padding: 36px 0 24px;
}

.media-single-hero-grid {
	display: grid;
	grid-template-columns: minmax(340px, 470px) minmax(420px, 620px);
	justify-content: center;
	gap: 20px;
	align-items: start;
}

.media-single-hero-visual {
	position: relative;
}

.media-single-number {
	position: absolute;
	top: -26px;
	left: 12px;
	z-index: 2;
	color: #efe3ba;
	font-size: 44px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.08em;
	-webkit-text-stroke: 1.1px rgba(45, 36, 29, 0.72);
	text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.72);
}

.media-single-thumbnail-hero {
	position: relative;
	margin-top: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	overflow: visible;
}

.media-single-thumbnail-hero::after {
	content: "";
	position: absolute;
	right: -12px;
	bottom: -12px;
	width: 100%;
	height: 100%;
	background: rgba(212, 237, 220, 0.72);
	z-index: -1;
}

.media-single-thumbnail-hero img,
.media-single-thumbnail-hero .media-card-placeholder {
	aspect-ratio: 4 / 5;
	min-height: auto;
	background: #fff;
	max-height: 560px;
}

.media-single-hero-copy {
	position: relative;
	padding-top: 86px;
	max-width: 680px;
}

.media-single-date {
	margin-bottom: 28px;
	color: rgba(36, 29, 24, 0.72);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.04em;
}

.media-single-hero-copy .media-eyebrow {
	margin-bottom: 16px;
	color: var(--media-accent-strong);
	font-size: 12px;
	letter-spacing: 0.12em;
}

.media-single-title-bubble,
.media-subtitle-bubble,
.media-intro-text-bubble {
	display: inline;
	padding: 0.08em 0.38em 0.14em;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.88);
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}

.media-single-title-bubble {
	font-size: clamp(24px, 2.7vw, 40px);
	line-height: 1.32;
	background: #fff;
	padding: 0.1em 0.42em 0.16em;
}

.media-subtitle-bubble {
	margin-top: 14px;
}

.media-intro-text-bubble {
	margin-top: 14px;
	font-size: clamp(17px, 2vw, 24px);
	line-height: 1.8;
	color: var(--media-text);
}

.media-single-info {
	margin-top: 28px;
	padding-top: 0;
}

.media-single-info-label {
	margin-bottom: 12px;
	color: rgba(36, 29, 24, 0.62);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.18em;
}

.media-single-info-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 18px;
}

.media-single-info-links a {
	color: var(--media-text);
	font-size: 15px;
	font-weight: 600;
	line-height: 1.8;
	text-decoration: none;
}

.media-single-info-links a:hover {
	color: var(--media-accent-strong);
}

.media-single-layout {
	align-items: flex-start;
	gap: 40px;
}

.media-single-layout--simple {
	display: block;
}

.media-single-main {
	flex: 1 1 auto;
	min-width: 0;
}

.media-single-main--full {
	max-width: 100%;
}

.media-single-side {
	flex: 0 0 290px;
	position: sticky;
	top: 24px;
}

.media-content-block {
	margin-bottom: 44px;
}

.media-entry-content {
	max-width: 760px;
	margin: 0 auto;
	font-size: 16px;
	line-height: 2.05;
}

.media-entry-content h2,
.media-entry-content h3,
.media-entry-content h4 {
	color: var(--media-text);
	font-weight: 700;
	letter-spacing: 0.01em;
	line-height: 1.5;
}

.media-entry-content h2 {
	position: relative;
	margin-top: 2.8em;
	margin-bottom: 1em;
	padding: 0 0 0.28em 40px;
	border-bottom: 2px solid rgba(63, 54, 46, 0.24);
	border-left: 0;
	border-radius: 0;
	background: none;
	font-size: 30px;
	line-height: 1.45;
}

.media-entry-content h2::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(63, 54, 46, 0.24);
	border-radius: 5px;
	background:
		radial-gradient(circle, rgba(63, 54, 46, 0.24) 0 2px, transparent 2.5px) 50% 50% / 100% 100% no-repeat,
		rgba(255, 255, 255, 0.72);
	box-sizing: border-box;
	transform: translateY(-58%) rotate(45deg);
}

.media-entry-content h3 {
	margin-top: 2.3em;
	margin-bottom: 0.95em;
	display: inline-block;
	padding: 0 0 0.18em;
	border-bottom: 2px solid rgba(63, 54, 46, 0.24);
	border-radius: 0;
	background: none;
	font-size: 24px;
	line-height: 1.5;
}

.media-entry-content h3 + * {
	margin-top: 0.2em;
}

.media-entry-content h4 {
	position: relative;
	margin-top: 2em;
	margin-bottom: 0.85em;
	padding-left: 18px;
	color: rgba(45, 36, 29, 0.82);
	font-size: 19px;
	line-height: 1.6;
}

.media-entry-content h4::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.72em;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(205, 133, 74, 0.72);
	transform: translateY(-50%);
}

.media-entry-content p,
.media-entry-content ul,
.media-entry-content ol,
.media-entry-content table {
	margin-bottom: 1.35em;
}

.media-entry-content ul,
.media-entry-content ol {
	padding-left: 1.4em;
}

.media-entry-content li + li {
	margin-top: 0.45em;
}

.media-entry-content > :first-child {
	margin-top: 0;
}

.media-entry-content h2 + *,
.media-entry-content h4 + * {
	margin-top: 0.2em;
}

.media-entry-content img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 0;
	box-shadow: 10px 10px 0 rgba(212, 237, 220, 0.62);
}

.media-entry-content figure {
	margin: 3.2em 0;
}

.media-entry-content .wp-block-image figcaption,
.media-entry-content figcaption {
	margin-top: 14px;
	color: var(--media-muted);
	font-size: 13px;
	text-align: center;
}

.media-entry-content a {
	color: var(--media-accent-strong);
	font-weight: 700;
	text-decoration: none;
	background-image: linear-gradient(rgba(228, 207, 136, 0.28), rgba(228, 207, 136, 0.28));
	background-position: 0 88%;
	background-repeat: no-repeat;
	background-size: 100% 0.34em;
	transition: background-size 0.2s ease, color 0.2s ease;
}

.media-entry-content a:hover {
	color: var(--media-text);
	background-size: 100% 100%;
}

.media-entry-content blockquote {
	position: relative;
	margin: 2.8em 0;
	padding: 26px 28px;
	border: 1px solid rgba(45, 36, 29, 0.18);
	border-radius: 24px;
	background: rgba(255, 255, 255, 0.9);
}

.media-entry-content blockquote::after {
	content: "";
	position: absolute;
	left: 42px;
	bottom: -11px;
	width: 18px;
	height: 18px;
	border-right: 1px solid rgba(45, 36, 29, 0.18);
	border-bottom: 1px solid rgba(45, 36, 29, 0.18);
	background: rgba(255, 255, 255, 0.9);
	transform: rotate(45deg);
}

.media-empty {
	padding: 40px;
}

@media (max-width: 1180px) {
	.media-archive {
		padding-top: 0;
		background:
			linear-gradient(rgba(243, 240, 234, 0.82), rgba(243, 240, 234, 0.82)),
			url("https://futofura.com/wp-content/uploads/2026/04/bg_media.png") left top / auto 100vh no-repeat fixed;
	}

	.media-single {
		background: var(--media-bg);
	}

	.media-layout {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.media-intro-panel {
		position: static;
		position: relative;
		left: 50%;
		width: 100vw;
		margin-left: -50vw;
		margin-right: -50vw;
		margin-top: -28px;
		padding: 28px 0 0;
		background:
			radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.35) 0 10%, transparent 28%),
			radial-gradient(circle at 80% 15%, rgba(255, 255, 255, 0.18) 0 8%, transparent 24%),
			linear-gradient(315deg, #f2efe9 0%, #f4e8de 42%, #f6ddd2 72%, #f8e8df 100%);
	}

	.media-shell-wide {
		width: min(100% - 48px, 100%);
		margin-left: auto;
		margin-right: auto;
		position: static;
		left: auto;
	}

	.media-intro-card {
		min-height: auto;
		max-width: 720px;
		margin: 0 auto;
		padding: 28px 24px 30px;
		border-radius: 0;
		background: transparent;
		box-shadow: none;
	}

	.media-intro-card::after {
		display: none;
	}

	.media-intro-content {
		width: 100%;
		max-width: 640px;
		margin: 0 auto;
	}

	.media-intro-heading-wrap {
		display: flex;
		flex-direction: column;
	}

	/* タブレットラッコ */
	.media-brand-hero {
		align-self: flex-start;
		order: 2;
		margin-top: 12px;
	}

	.media-brand-hero__inner {
		text-align: left;
	}

	.media-brand-hero__title {
		font-size: clamp(18px, 3.2vw, 24px);
		line-height: 1.42;
		letter-spacing: 0.04em;
		writing-mode: horizontal-tb;
		text-orientation: mixed;
	}

	.media-brand-hero__rotator {
		display: inline-flex;
		width: auto;
		height: 1.34em;
		min-width: 5.1em;
		writing-mode: horizontal-tb;
	}

	.media-brand-hero__track {
		display: flex;
		flex-direction: column;
		width: 100%;
		height: 700%;
		animation-name: media-brand-hero-slide-mobile;
		writing-mode: horizontal-tb;
	}

	.media-brand-hero__word {
		position: static;
		flex: 0 0 calc(100% / 7);
		width: auto;
		height: calc(100% / 7);
		padding-left: 0.46em;
		padding-right: 0.46em;
		border-radius: 6px;
		writing-mode: horizontal-tb;
		text-orientation: mixed;
	}

	.media-brand-hero__tail {
		display: inline;
	}

	.media-brand-hero__tail-line {
		display: block;
	}

	.media-intro-title-new {
		order: 1;
	}

	.media-brand-banner {
		margin-top: 44px;
		padding: 34px 0 38px;
	}

	.media-brand-banner__inner {
		gap: 10px;
	}

	.media-brand-banner__name {
		font-size: clamp(20px, 7.6vw, 28px);
	}

	.media-brand-banner__title {
		font-size: clamp(13px, 4.6vw, 17px);
		line-height: 1.55;
	}

	.media-brand-banner__rotator {
		min-width: 4.8em;
	}

	.media-brand-banner__tail-line {
		display: inline;
	}

	.media-intro-otter {
		left: auto;
		right: 16px;
		bottom: -5px;
		width: 176px;
		height: 176px;
		animation-name: media-intro-otter-float-flip;
	}

	.media-intro-title-new {
		font-size: clamp(39px, 7.5vw, 57px);
		line-height: 1.35;
		writing-mode: horizontal-tb;
		text-orientation: mixed;
		height: auto;
		max-height: none;
		align-self: flex-start;
	}

	.media-intro-title-new::after {
		animation-name: media-intro-title-wave-bottom;
	}

	.media-intro-text-new {
		margin-top: 14px;
		font-size: 14px;
		line-height: 1.85;
		white-space: normal;
		text-align: left;
	}

	.media-brand-banner {
		margin-top: 56px;
		padding: 42px 0 46px;
	}

	.media-brand-banner__inner {
		gap: 12px;
	}

	.media-brand-banner__name {
		font-size: clamp(22px, 4.6vw, 34px);
	}

	.media-brand-banner__title {
		font-size: clamp(14px, 2.9vw, 20px);
		line-height: 1.5;
	}

	.media-intro-text-new br {
		display: inline;
	}

	.media-intro-link-bubbles-fixed {
		justify-content: flex-end;
	}

	.media-intro-title {
		writing-mode: horizontal-tb;
		height: auto;
		max-height: none;
		font-size: clamp(34px, 6vw, 56px);
	}

	.media-intro-count {
		margin-top: 18px;
	}

	.media-intro-text {
		margin-top: 18px;
	}

	.media-grid,
	.media-grid-featured,
	.media-grid-magazine,
	.media-grid-related {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.media-single-hero-grid {
		grid-template-columns: minmax(280px, 420px) minmax(320px, 1fr);
		gap: 24px;
		align-items: start;
	}

	.media-single-hero-copy {
		padding-top: 20px;
		max-width: 100%;
	}
}

@media (max-width: 820px) {
	.media-search-header,
	.media-search-row,
	.media-section-head {
		flex-direction: column;
		align-items: stretch;
	}

	.media-button {
		width: 100%;
	}

	.media-search-row .media-button {
		min-width: 0;
		flex-basis: auto;
	}

	.media-archive-tools,
	.media-sort-wrap-inline {
		width: 100%;
	}

	.media-sort-wrap-inline select {
		min-width: 0;
		width: 100%;
	}

	.media-card-number {
		top: -14px;
	}

	.media-grid,
	.media-grid-featured,
	.media-grid-magazine,
	.media-grid-related {
		gap: 34px;
	}
}

@media (max-width: 640px) {
	:root {
		--media-shell: min(100% - 24px, 100%);
	}

	.media-archive,
	.media-single {
		padding: 0 0 72px;
	}

	.media-archive {
		background:
			linear-gradient(rgba(243, 240, 234, 0.84), rgba(243, 240, 234, 0.84)),
			url("https://futofura.com/wp-content/uploads/2026/04/bg_media.png") left top / auto 100vh no-repeat fixed;
	}

	.media-single {
		background: var(--media-bg);
	}

	.media-mobile-return {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		z-index: 200;
		display: block;
		padding: 0;
		pointer-events: none;
		opacity: 0;
		transform: translateY(-8px);
		transition: opacity 0.18s ease, transform 0.18s ease;
	}

	.media-mobile-return.is-visible {
		opacity: 1;
		transform: translateY(0);
		pointer-events: auto;
	}

	.media-mobile-return__link {
		display: grid;
		grid-template-columns: auto auto 1fr auto;
		align-items: center;
		gap: 12px;
		width: 100%;
		padding: 6px 14px;
		border-top: 0;
		border-bottom: 1px solid rgba(45, 36, 29, 0.12);
		background:
			radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.35) 0 10%, transparent 28%),
			radial-gradient(circle at 80% 15%, rgba(255, 255, 255, 0.18) 0 8%, transparent 24%),
			linear-gradient(315deg, #f2efe9 0%, #f4e8de 42%, #f6ddd2 72%, #f8e8df 100%);
		color: var(--media-text);
		text-decoration: none;
	}

	.media-mobile-return__icon {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 28px;
		height: 28px;
		border: 1px solid rgba(45, 36, 29, 0.14);
		border-radius: 6px;
		background: rgba(255, 255, 255, 0.52);
		color: var(--media-accent-strong);
		font-size: 14px;
		font-weight: 700;
		line-height: 1;
	}

	.media-mobile-return__eyebrow {
		color: var(--media-accent-strong);
		font-size: 10px;
		font-weight: 700;
		letter-spacing: 0.14em;
		white-space: nowrap;
	}

	.media-mobile-return__title {
		min-width: 0;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
		font-size: 15px;
		font-weight: 700;
		line-height: 1.3;
	}

	.media-archive .media-mobile-return__title {
		position: relative;
		color: transparent;
	}

	.media-archive .media-mobile-return__title::after {
		content: "ふとふら手帖";
		position: absolute;
		inset: 0;
		color: var(--media-text);
	}

	.media-mobile-return__arrow {
		display: none;
	}

	.media-shell,
	.media-shell-wide {
		width: min(100% - 24px, 100%);
	}

	.media-shell-wide {
		width: min(100% - 24px, 100%);
		margin-left: auto;
		margin-right: auto;
		position: static;
		left: auto;
	}

	.media-search-panel,
	.media-intro-card,
	.media-single-thumbnail,
	.media-side-card,
	.media-empty {
		border-radius: 22px;
	}

	.media-intro-card {
		min-height: auto;
		margin: 0 auto;
		padding: 0 20px 26px;
		border-radius: 0;
		background: transparent;
		box-shadow: none;
	}

	.media-intro-card::before,
	.media-intro-card::after {
		display: none;
	}

	.media-intro-kicker {
		margin-bottom: 12px;
	}

	.media-intro-panel {
		left: 50%;
		width: 100vw;
		margin-left: -50vw;
		margin-right: -50vw;
		margin-top: -24px;
		padding-top: 24px;
		background:
			radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.35) 0 10%, transparent 28%),
			radial-gradient(circle at 80% 15%, rgba(255, 255, 255, 0.18) 0 8%, transparent 24%),
			linear-gradient(315deg, #f2efe9 0%, #f4e8de 42%, #f6ddd2 72%, #f8e8df 100%);
	}

	.media-intro-title-new {
		font-size: 47px;
		line-height: 1.45;
		writing-mode: horizontal-tb;
		text-orientation: mixed;
		height: auto;
		max-height: none;
	}

	.media-intro-title-new::before {
		-webkit-text-stroke: 0.9px var(--media-text);
	}

	.media-intro-title-new::after {
		animation-name: media-intro-title-wave-bottom;
		-webkit-text-stroke: 0.35px var(--media-text);
	}

	.media-intro-heading-wrap {
		display: flex;
		flex-direction: column;
	}

	.media-brand-hero {
		align-self: flex-start;
		order: 2;
		margin-top: 12px;
	}

	.media-brand-hero__inner {
		text-align: left;
	}

	.media-brand-hero__title {
		font-size: clamp(18px, 7vw, 24px);
		line-height: 1.5;
		letter-spacing: 0.04em;
		writing-mode: horizontal-tb;
		text-orientation: mixed;
	}

	.media-brand-hero__rotator {
		display: inline-flex;
		width: auto;
		height: 1.34em;
		min-width: 5.1em;
		writing-mode: horizontal-tb;
	}

	.media-brand-hero__track {
		display: flex;
		flex-direction: column;
		width: 100%;
		height: 700%;
		animation-name: media-brand-hero-slide-mobile;
		writing-mode: horizontal-tb;
	}

	.media-brand-hero__word {
		position: static;
		flex: 0 0 calc(100% / 7);
		width: auto;
		height: calc(100% / 7);
		padding-left: 0.46em;
		padding-right: 0.46em;
		border-radius: 6px;
		writing-mode: horizontal-tb;
		text-orientation: mixed;
	}

	.media-brand-hero__tail {
		display: inline;
	}

	.media-brand-hero__tail-line {
		display: block;
	}

	.media-intro-title-new {
		order: 1;
	}

	.media-intro-text-new {
		margin-top: 16px;
		font-size: 14px;
		line-height: 1.95;
		white-space: normal;
		text-align: left;
	}

	/* スマホラッコ */
	.media-intro-otter {
		left: auto;
		right: 12px;
		bottom: -5px;
		width: 111px;
		height: 111px;
		animation-name: media-intro-otter-float-flip;
	}

	.media-intro-link::before {
		height: 42px;
		padding: 0 16px;
		background:
			radial-gradient(circle at 21px 21px, rgba(255, 255, 255, 0.97) 0 18px, transparent 18.5px) 0 0 / 34px 42px repeat-x;
		font-size: 14px;
		letter-spacing: 0.06em;
	}

	.media-intro-link-bubbles-fixed span {
		width: 36px;
		height: 36px;
		margin-left: -7px;
		font-size: 14px;
	}

	.media-intro-link-bubbles-fixed__arrow {
		font-size: 16px;
	}

	.media-intro-title {
		font-size: 22px;
		line-height: 1.45;
	}

	.media-intro-count {
		margin-top: 20px;
		font-size: 60px;
	}

	.media-intro-count-label {
		font-size: 12px;
		letter-spacing: 0.2em;
	}

	.media-intro-text {
		margin-top: 16px;
		font-size: 14px;
		line-height: 1.95;
	}

	.media-grid,
	.media-grid-featured,
	.media-grid-magazine,
	.media-grid-related {
		grid-template-columns: 1fr;
		gap: 48px;
	}

	.media-card-image {
		aspect-ratio: 4 / 5;
	}

	.media-card-title {
		font-size: 20px;
	}

	.media-page-lead,
	.media-intro-text,
	.media-entry-content {
		font-size: 15px;
	}

	.media-entry-content {
		max-width: 100%;
	}

	.media-search-panel {
		padding: 18px 16px 18px;
	}

	.media-brand-hero__title {
		font-size: clamp(18px, 7vw, 24px);
		line-height: 1.42;
		letter-spacing: 0.04em;
		writing-mode: horizontal-tb;
		text-orientation: mixed;
	}

	.media-brand-hero__rotator {
		min-width: 5.1em;
	}

	.media-brand-hero__word {
		padding-left: 0.46em;
		padding-right: 0.46em;
		border-radius: 6px;
	}

	.media-search-form--stacked {
		gap: 14px;
	}

	.media-chip-group-large {
		gap: 10px;
	}

	.media-chip {
		min-height: 38px;
		padding: 0 14px;
		font-size: 13px;
	}

	.media-input,
	.media-select,
	.media-sort-wrap select {
		min-height: 52px;
		padding: 0 16px;
		font-size: 14px;
	}

	.media-search-row {
		gap: 12px;
	}

	.media-search-row .media-input,
	.media-search-row .media-select,
	.media-search-row .media-button {
		flex: none;
		width: 100%;
	}

	.media-entry-content h2 {
		padding-left: 34px;
		padding-bottom: 0.24em;
		font-size: 24px;
	}

	.media-entry-content h2::before {
		top: 50%;
		width: 16px;
		height: 16px;
		border-radius: 4px;
		background:
			radial-gradient(circle, rgba(63, 54, 46, 0.24) 0 2px, transparent 2.5px) 50% 50% / 100% 100% no-repeat,
			rgba(255, 255, 255, 0.72);
		transform: translateY(-58%) rotate(45deg);
	}

	.media-entry-content h3 {
		padding-bottom: 0.16em;
		font-size: 20px;
	}

	.media-entry-content h4 {
		padding-left: 16px;
		font-size: 17px;
	}

	.media-single-layout {
		flex-direction: column;
	}

	.media-single-side {
		position: static;
		width: 100%;
		flex-basis: auto;
	}

	.media-single-number {
		top: -18px;
		left: 4px;
		font-size: 34px;
	}

	.media-single-hero-grid {
		grid-template-columns: 1fr;
		gap: 18px;
	}

	.media-single-hero-copy {
		padding-top: 0;
		max-width: 100%;
	}

	.media-single-thumbnail-hero img,
	.media-single-thumbnail-hero .media-card-placeholder {
		aspect-ratio: 4 / 5;
		min-height: auto;
	}

	.media-single-thumbnail-hero::after {
		right: -10px;
		bottom: -10px;
	}

	.media-intro-text-bubble {
		font-size: 16px;
	}

	.media-entry-content img {
		box-shadow: 8px 8px 0 rgba(212, 237, 220, 0.58);
	}
}

.ff-share-panel--media {
	--share-text: var(--media-text);
	--share-muted: var(--media-muted);
	--share-border: rgba(45, 36, 29, 0.12);
	--share-bg:
		radial-gradient(circle at top right, rgba(255, 255, 255, 0.44), transparent 34%),
		linear-gradient(135deg, rgba(255, 253, 250, 0.96), rgba(246, 221, 210, 0.92));
	--share-shadow: 0 16px 34px rgba(64, 40, 22, 0.08);
	--share-chip-bg: rgba(255, 255, 255, 0.92);
	--share-accent: var(--media-accent-strong);
}

.ff-share-panel--media.ff-share-panel--header {
	margin-top: 34px;
}

.ff-share-panel--media.ff-share-panel--header .ff-share-panel__inner {
	width: min(100%, 100%);
}

.ff-share-panel--media.ff-share-panel--footer {
	margin-top: 38px;
}

.ff-share-panel--media.ff-share-panel--footer .ff-share-panel__inner {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
}

.ff-share-panel--media .ff-share-panel__inner {
	border-radius: 0;
	padding: 0;
	background: transparent;
	border: 0;
	box-shadow: none;
}

.ff-share-panel--media .ff-share-panel__label {
	margin-bottom: 12px;
	color: rgba(36, 29, 24, 0.62);
	font-size: 12px;
	letter-spacing: 0.18em;
}

.ff-share-panel--media .ff-share-panel__buttons {
	justify-content: flex-start;
	gap: 10px;
}

.ff-share-panel--media.ff-share-panel--footer .ff-share-panel__buttons {
	justify-content: flex-end;
}

.ff-share-panel--media.ff-share-panel--footer .ff-share-panel__status {
	text-align: right;
}

.ff-share-panel--media .ff-share-button {
	width: 52px;
	height: 52px;
	border-color: rgba(45, 36, 29, 0.08);
	background: rgba(255, 255, 255, 0.88);
}

.ff-share-panel--media .ff-share-button:hover {
	border-color: rgba(183, 116, 78, 0.34);
	box-shadow: 0 12px 24px rgba(183, 116, 78, 0.12);
}

@media (max-width: 640px) {
	.ff-share-panel--media.ff-share-panel--header .ff-share-panel__inner {
		width: 100%;
	}

	.ff-share-panel--media.ff-share-panel--footer .ff-share-panel__inner {
		align-items: flex-start;
	}

	.ff-share-panel--media.ff-share-panel--footer .ff-share-panel__buttons {
		justify-content: flex-start;
	}

	.ff-share-panel--media.ff-share-panel--footer .ff-share-panel__status {
		text-align: left;
	}
}
	.media-card-number {
		top: -14px;
		min-height: 28px;
		padding: 0 12px;
		border-radius: 8px;
		font-size: 14px;
		letter-spacing: 0.02em;
	}
