/* ============================================
 * マイページ専用ブラッシュアップ CSS
 * 既存の layout.css の .mypage__* を上書きする想定。
 * （読み込み順序: layout.css → mypage.css）
 * ============================================ */

/* -------- ユーティリティ -------- */

.u-visually-hidden {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* -------- アバター xl サイズ -------- */

.avatar.avatar--xl {
	width: 112px;
	height: 112px;
	border-radius: var(--radius-full);
	overflow: hidden;
	background: var(--color-base-2);
	box-shadow: 0 6px 18px rgba(15, 32, 39, 0.08);
	border: 4px solid var(--color-base-1);
	flex: 0 0 auto;
}

.avatar.avatar--xl .avatar__img,
.avatar.avatar--xl img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* -------- プロフィールヘッダー -------- */

/* SP: 縦積み中央寄せ。横 padding は container に任せて幅を揃える */
.mypage__profile-header {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-3);
	padding: var(--space-8) 0 var(--space-6);
	margin-bottom: var(--space-6);
	background: linear-gradient(180deg, color-mix(in srgb, var(--color-main) 6%, transparent) 0%, transparent 100%);
	border-radius: var(--radius-lg);
	position: relative;
}

/* PC: 中央揃えコンパクトレイアウト（最大幅720pxで両端に余白を作る） */
@media (min-width: 769px) {
	.mypage__profile-header {
		display: grid;
		grid-template-columns: 120px 1fr;
		column-gap: var(--space-6);
		row-gap: var(--space-5);
		align-items: center;
		text-align: center;
		max-width: 720px;
		margin-inline: auto;
		padding: var(--space-8) var(--space-5) var(--space-6);
	}

	/* アバター: 左列、1行目 */
	.mypage__profile-header > .avatar {
		grid-column: 1;
		grid-row: 1;
		margin: 0 auto;
	}

	/* プロフ情報: 右列、1行目（テキストは左寄せでアバターと並ぶ） */
	.mypage__profile-header > .mypage__profile-info {
		grid-column: 2;
		grid-row: 1;
		align-items: flex-start;
		text-align: left;
		max-width: none;
	}

	/* スタッツ: 全幅、2行目 */
	.mypage__profile-header > .mypage__stats {
		grid-column: 1 / -1;
		grid-row: 2;
		justify-content: center;
	}

	/* アクション: 全幅、3行目（中央揃え） */
	.mypage__profile-header > .mypage__header-actions {
		grid-column: 1 / -1;
		grid-row: 3;
		justify-content: center;
	}
}

.mypage__profile-info {
	flex: 0 1 auto;
	width: 100%;
	max-width: 600px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-2);
}

.mypage__nickname {
	margin: 0 0 0;
	font-size: var(--font-size-xl);
	font-weight: 700;
	color: var(--color-text-primary);
	line-height: 1.3;
}

.mypage__profile-prefecture {
	margin: 0;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: var(--font-size-sm);
	color: var(--color-text-secondary);
}

.mypage__profile-prefecture::before {
	content: "";
	display: inline-block;
	width: 14px;
	height: 14px;
	background: currentColor;
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='currentColor' d='M12 2a7 7 0 0 0-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 0 0-7-7zm0 9.5A2.5 2.5 0 1 1 12 6.5a2.5 2.5 0 0 1 0 5z'/></svg>") center / contain no-repeat;
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='currentColor' d='M12 2a7 7 0 0 0-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 0 0-7-7zm0 9.5A2.5 2.5 0 1 1 12 6.5a2.5 2.5 0 0 1 0 5z'/></svg>") center / contain no-repeat;
}

.mypage__meta {
	margin: 0;
	color: var(--color-text-secondary);
	font-size: var(--font-size-sm);
}

.mypage__bio {
	margin: var(--space-2) 0 0;
	width: 100%;
	max-width: 600px;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text-secondary);
	text-align: center;
}

/* -------- bio アコーディオン -------- */

.bio-accordion {
	width: 100%;
	margin: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.bio-accordion__text {
	margin: 0;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text-secondary);
	text-align: left;
	white-space: pre-line;
	width: 100%;
	max-width: 600px;
}

/* オーバーフローしているときのみ折りたたみ。
   オーバーしないなら -webkit-line-clamp は付けないので全文表示される。 */
.bio-accordion.is-overflow:not(.is-expanded) .bio-accordion__text {
	display: -webkit-box;
	-webkit-line-clamp: var(--bio-collapsed-lines, 2);
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.bio-accordion__toggle {
	margin-top: var(--space-2);
	background: transparent;
	border: none;
	color: var(--color-main);
	font-size: var(--font-size-xs);
	font-weight: 600;
	cursor: pointer;
	padding: 4px 8px;
	border-radius: var(--radius-sm);
	transition: background-color 0.15s ease;
}

.bio-accordion__toggle:hover,
.bio-accordion__toggle:focus-visible {
	background: color-mix(in srgb, var(--color-main) 10%, transparent);
	outline: none;
}

.bio-accordion__toggle::after {
	content: "▾";
	margin-left: 4px;
	display: inline-block;
	transition: transform 0.2s ease;
}

.bio-accordion.is-expanded .bio-accordion__toggle::after {
	transform: rotate(180deg);
}

@media (prefers-reduced-motion: reduce) {
	.bio-accordion__toggle,
	.bio-accordion__toggle::after {
		transition: none;
	}
}

/* -------- SNS アイコンリンク -------- */

.mypage__sns {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-3);
	margin-top: var(--space-2);
}

@media (min-width: 769px) {
	.mypage__sns {
		justify-content: center;
	}
}

.sns-link.sns-link--icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	padding: 0;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-full);
	background: var(--color-base-1);
	color: var(--color-text-secondary);
	transition:
		transform 0.18s ease,
		box-shadow 0.18s ease,
		border-color 0.18s ease,
		background-color 0.18s ease;
	text-decoration: none;
}

.sns-link.sns-link--icon:hover,
.sns-link.sns-link--icon:focus-visible {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	border-color: var(--color-main);
	color: var(--color-main);
	outline: none;
}

.sns-link__icon-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
}

.sns-link__icon--brand {
	width: 24px;
	height: 24px;
	object-fit: contain;
}

.sns-link__icon--globe {
	width: 22px;
	height: 22px;
}

@media (prefers-reduced-motion: reduce) {
	.sns-link.sns-link--icon {
		transition: none;
	}
	.sns-link.sns-link--icon:hover,
	.sns-link.sns-link--icon:focus-visible {
		transform: none;
	}
}

/* -------- stats リッチタイル（リンク化） -------- */

.mypage__stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-3);
	width: 100%;
	max-width: 600px;
	margin: var(--space-4) 0 0;
	padding: 0;
	list-style: none;
}

@media (min-width: 769px) {
	.mypage__stats {
		max-width: none;
		margin-top: 0;
	}
}

.mypage__stats-item {
	margin: 0;
	padding: 0;
	min-width: 0;
	border: none;
	background: transparent;
	border-radius: 0;
}

.mypage__stat-tile {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 4px;
	padding: var(--space-3) var(--space-2);
	background: var(--color-base-1);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	color: var(--color-text-primary);
	text-decoration: none;
	transition:
		transform 0.18s ease,
		box-shadow 0.18s ease,
		border-color 0.18s ease;
	position: relative;
	overflow: hidden;
}

.mypage__stat-tile::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: var(--color-main);
	opacity: 0;
	transition: opacity 0.18s ease;
}

.mypage__stat-tile:hover,
.mypage__stat-tile:focus-visible {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	border-color: color-mix(in srgb, var(--color-main) 35%, var(--color-border));
	outline: none;
}

.mypage__stat-tile:hover::before,
.mypage__stat-tile:focus-visible::before {
	opacity: 1;
}

.mypage__stat-tile-value {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	color: var(--color-accent-2);
	line-height: 1;
}

.mypage__stat-tile-label {
	font-size: var(--font-size-xs);
	color: var(--color-text-secondary);
}

@media (prefers-reduced-motion: reduce) {
	.mypage__stat-tile,
	.mypage__stat-tile::before {
		transition: none;
	}
	.mypage__stat-tile:hover,
	.mypage__stat-tile:focus-visible {
		transform: none;
	}
}

/* -------- ヘッダーアクション -------- */

.mypage__header-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-2);
	margin-top: var(--space-4);
}

@media (min-width: 769px) {
	.mypage__header-actions {
		justify-content: center;
		margin-top: var(--space-2);
	}
}

/* 公開プロフィールリンク（控えめ） */
.mypage__view-public {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 6px 10px;
	font-size: var(--font-size-xs);
	color: var(--color-text-secondary);
	text-decoration: none;
	border-radius: var(--radius-full);
	border: 1px solid var(--color-border);
	background: color-mix(in srgb, var(--color-base-1) 70%, transparent);
	transition:
		color 0.18s ease,
		border-color 0.18s ease,
		background-color 0.18s ease;
}

.mypage__view-public:hover,
.mypage__view-public:focus-visible {
	color: var(--color-main);
	border-color: var(--color-main);
	background: var(--color-base-1);
	outline: none;
}

.mypage__view-public svg {
	flex: 0 0 auto;
	opacity: 0.7;
}

/* 編集 FAB（右上絶対配置） */
.mypage__edit-fab {
	position: absolute;
	top: var(--space-3);
	right: var(--space-3);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--radius-full);
	border: 1px solid var(--color-border);
	background: var(--color-base-1);
	color: var(--color-text-secondary);
	box-shadow: var(--shadow-sm);
	z-index: 2;
	transition:
		transform 0.18s ease,
		box-shadow 0.18s ease,
		color 0.18s ease,
		border-color 0.18s ease;
}

.mypage__edit-fab:hover,
.mypage__edit-fab:focus-visible {
	transform: translateY(-1px);
	color: var(--color-main);
	border-color: var(--color-main);
	box-shadow: var(--shadow-md);
	outline: none;
}

@media (prefers-reduced-motion: reduce) {
	.mypage__edit-fab,
	.mypage__view-public {
		transition: none;
	}
	.mypage__edit-fab:hover {
		transform: none;
	}
}

/* -------- 自分の相談タブ：TOP と同じ home-feed-rail カード -------- */

/*
 * TOP の home-feed-rail は横スクロールだが、マイページでは折り返しさせる。
 * カード幅は --home-feed-card-width (380px) を維持して TOP と同じ見た目にする。
 * SP は 1列、PC は auto-fit で2列以上に折り返し。
 */
.tab-my-threads__grid.home-feed-rail {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
}

@media (min-width: 769px) {
	.tab-my-threads__grid.home-feed-rail {
		grid-template-columns: repeat(auto-fill, minmax(min(var(--home-feed-card-width), 100%), 1fr));
		gap: var(--space-5);
	}
}

.tab-my-threads__grid.home-feed-rail .home-feed-item {
	display: flex;
	width: 100%;
	min-width: 0;
}

/* front-page.css の固定幅(flex 0 0 380px)を上書きして grid セルに収める */
.tab-my-threads__grid.home-feed-rail .home-feed-item .thread-card--home-rail {
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: none;
	flex: 1 1 auto;
	scroll-snap-align: none;
}

.tab-my-threads__grid.home-feed-rail .home-feed-item .thread-card--home-rail .thread-card__footer {
	margin-top: auto;
}

/* empty-state は1行目をぶち抜いて中央に */
.tab-my-threads__grid.home-feed-rail > .empty-state {
	grid-column: 1 / -1;
}

/* -------- レスポンシブ調整 -------- */

@media (max-width: 480px) {
	.mypage__profile-header {
		padding: var(--space-6) 0 var(--space-5);
	}
	.avatar.avatar--xl {
		width: 96px;
		height: 96px;
	}
	.mypage__stat-tile-value {
		font-size: var(--font-size-xl);
	}
}

/* ============================================================
 * サブナビ（タブ内のセグメント切替）
 * ============================================================ */

.subnav {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
	margin: 0 0 var(--space-5);
	padding: 4px;
	border-radius: var(--radius-full);
	background: color-mix(in srgb, var(--color-main) 5%, var(--color-base-2));
	border: 1px solid var(--color-border);
}

.subnav__item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	font-size: var(--font-size-sm);
	font-weight: 600;
	line-height: 1.2;
	color: var(--color-text-secondary);
	text-decoration: none;
	border-radius: var(--radius-full);
	transition:
		background-color 0.15s ease,
		color 0.15s ease;
}

.subnav__item:hover,
.subnav__item:focus-visible {
	color: var(--color-text-primary);
	background: color-mix(in srgb, var(--color-base-1) 70%, transparent);
	outline: none;
}

.subnav__item.is-active {
	color: var(--color-base-1);
	background: var(--color-main);
}

.subnav__item.is-active .subnav__count {
	color: var(--color-base-1);
	background: color-mix(in srgb, var(--color-base-1) 25%, transparent);
}

.subnav__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	padding: 0 6px;
	height: 18px;
	font-size: var(--font-size-xs);
	font-weight: 600;
	color: var(--color-text-secondary);
	background: color-mix(in srgb, var(--color-base-1) 80%, transparent);
	border-radius: var(--radius-full);
}

/* underline 派生（保留：将来用） */
.subnav--underline {
	background: transparent;
	border: none;
	border-bottom: 1px solid var(--color-border);
	border-radius: 0;
	padding: 0;
	gap: 0;
}

.subnav--underline .subnav__item {
	border-radius: 0;
	border-bottom: 2px solid transparent;
	padding: 8px 16px;
}

.subnav--underline .subnav__item.is-active {
	color: var(--color-main);
	background: transparent;
	border-bottom-color: var(--color-main);
}

@media (prefers-reduced-motion: reduce) {
	.subnav__item {
		transition: none;
	}
}

/* ============================================================
 * ブックマークタブ
 * ============================================================ */

.tab-bookmarks__panel {
	margin-top: 0;
}

/* ============================================================
 * フォロー中タブ ＆ user-card
 * ============================================================ */

.tab-following__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
}

@media (min-width: 600px) {
	.tab-following__grid {
		grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
		gap: var(--space-4);
	}
}

.user-card {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	padding: var(--space-4);
	background: var(--color-base-1);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	transition:
		transform 0.18s ease,
		box-shadow 0.18s ease,
		border-color 0.18s ease;
}

.user-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	border-color: color-mix(in srgb, var(--color-main) 35%, var(--color-border));
}

.user-card__link {
	display: flex;
	gap: var(--space-3);
	color: inherit;
	text-decoration: none;
}

.user-card__avatar {
	flex: 0 0 auto;
}

.user-card__body {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.user-card__name {
	margin: 0;
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text-primary);
	line-height: 1.3;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.user-card__meta {
	margin: 0;
	font-size: var(--font-size-xs);
	color: var(--color-text-secondary);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.user-card__pref {
	margin: 0;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: var(--font-size-xs);
	color: var(--color-text-secondary);
}

.user-card__bio {
	margin: 4px 0 0;
	font-size: var(--font-size-sm);
	line-height: 1.5;
	color: var(--color-text-secondary);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.user-card__actions {
	display: flex;
	justify-content: flex-end;
	margin-top: auto;
}

/* フォロー中ボタン: ホバーで「フォロー解除」風の表示に */
.user-card__follow-btn[data-following="1"]:hover,
.user-card__follow-btn[data-following="1"]:focus-visible {
	color: var(--color-base-1);
	background: var(--color-text-secondary);
	border-color: var(--color-text-secondary);
}

@media (prefers-reduced-motion: reduce) {
	.user-card {
		transition: none;
	}
	.user-card:hover {
		transform: none;
	}
}

/* ============================================================
 * 通知タブ
 * ============================================================ */

.notifications-header {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-2);
	margin-bottom: var(--space-3);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--color-border);
}

.notifications-header__count {
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-secondary);
}

.notifications-header__count .js-unread-total {
	font-weight: 700;
	color: var(--color-text-primary);
	font-variant-numeric: tabular-nums;
}

.notifications-header--zero .notifications-header__count .js-unread-total {
	color: var(--color-text-secondary);
	font-weight: 600;
}

.notification-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.notification-list > li {
	margin: 0;
}

.notification-card {
	display: grid;
	grid-template-columns: 40px 1fr auto;
	grid-template-areas:
		"icon title meta"
		"icon text  meta";
	column-gap: var(--space-3);
	row-gap: 2px;
	align-items: start;
	padding: var(--space-3) var(--space-4);
	background: var(--color-base-1);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	color: inherit;
	text-decoration: none;
	transition:
		transform 0.18s ease,
		box-shadow 0.18s ease,
		border-color 0.18s ease,
		background-color 0.18s ease;
}

button.notification-card {
	width: 100%;
	max-width: none;
	font: inherit;
	text-align: left;
	cursor: pointer;
	appearance: none;
}

a.notification-card:hover,
a.notification-card:focus-visible,
button.notification-card:hover,
button.notification-card:focus-visible {
	transform: translateY(-1px);
	box-shadow: var(--shadow-sm);
	border-color: color-mix(in srgb, var(--color-main) 30%, var(--color-border));
	outline: none;
}

.notification-card.is-unread {
	background: color-mix(in srgb, var(--color-main) 4%, var(--color-base-1));
	border-color: color-mix(in srgb, var(--color-main) 25%, var(--color-border));
}

.notification-card__icon {
	grid-area: icon;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--radius-full);
	color: var(--color-base-1);
	background: var(--color-text-secondary);
	flex: 0 0 auto;
	align-self: start;
}

.notification-card--main .notification-card__icon {
	background: var(--color-main);
}
.notification-card--accent1 .notification-card__icon {
	background: var(--color-accent-1);
}
.notification-card--accent2 .notification-card__icon {
	background: var(--color-accent-2);
}
.notification-card--success .notification-card__icon {
	background: var(--color-accent-1);
}
.notification-card--warning .notification-card__icon {
	background: #c2410c;
}
.notification-card--gold .notification-card__icon {
	background: #d4a017;
}
.notification-card--neutral .notification-card__icon {
	background: var(--color-text-secondary);
}

.notification-card__title {
	grid-area: title;
	margin: 0;
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-text-primary);
	line-height: 1.4;
	align-self: center;
	min-width: 0;
}

.notification-card__text {
	grid-area: text;
	margin: 0;
	padding: 0;
	text-indent: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-secondary);
	line-height: 1.5;
	text-align: left;
	overflow-wrap: anywhere;
	word-break: break-word;
	min-width: 0;
	/* PC: 最大 2 行クランプ（new_answer の誘導文 2 行目まで見せる）。 */
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	/* \n 改行を尊重しつつ 2 行目の左端を揃える（インデントなし）。 */
	white-space: pre-wrap;
}

/* プレースホルダーは非表示（grid-area: text の空セルとして機能するだけ）。 */
.notification-card__text-placeholder {
	grid-area: text;
	display: none;
}

.notification-card__meta {
	grid-area: meta;
	display: inline-flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 6px;
	flex: 0 0 auto;
	align-self: start;
}

.notification-card__time {
	font-size: var(--font-size-xs);
	color: var(--color-text-secondary);
	white-space: nowrap;
}

.notification-card__unread-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: var(--radius-full);
	background: var(--color-main);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-main) 20%, transparent);
}

@media (max-width: 480px) {
	.notification-card {
		grid-template-columns: 32px 1fr;
		grid-template-areas:
			"icon title"
			"text text"
			"meta meta";
		column-gap: var(--space-2);
		row-gap: 6px;
		padding: var(--space-3);
	}
	.notification-card__icon {
		width: 32px;
		height: 32px;
	}
	.notification-card__title {
		align-self: center;
	}
	/* SP: 高さ可変・全文表示（クランプ解除）。 */
	.notification-card__text {
		display: block;
		-webkit-line-clamp: unset;
		-webkit-box-orient: initial;
		overflow: visible;
	}
	.notification-card__meta {
		flex-direction: row;
		align-items: center;
		justify-content: flex-end;
		gap: 8px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.notification-card {
		transition: none;
	}
	a.notification-card:hover,
	button.notification-card:hover {
		transform: none;
	}
}

/* ============================================================
 * 設定タブ
 * ============================================================ */

.tab-settings {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.settings-card {
	padding: var(--space-5);
	background: var(--color-base-1);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
}

.settings-card__head {
	margin-bottom: var(--space-3);
}

.settings-card__title {
	margin: 0 0 4px;
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-text-primary);
	line-height: 1.3;
}

.settings-card__desc {
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-secondary);
	line-height: 1.5;
}

.settings-card__body {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-2);
}

.settings-card--danger {
	border-color: color-mix(in srgb, #d97706 30%, var(--color-border));
}

.settings-card--danger .settings-card__title {
	color: var(--color-rank-gold-dark);
}

/* メール通知の受信設定。
 * 初期は fieldset[disabled] で出力し、notification.js が GET /notification-prefs 成功後に
 * disabled を外して有効化する。淡色＋操作不可カーソルは disabled の間だけ適用する。 */
.settings-prefs {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-2);
	margin: 0;
	padding: 0;
	border: none;
}

.settings-prefs[disabled] {
	opacity: 0.65;
}

@media (min-width: 600px) {
	.settings-prefs {
		grid-template-columns: repeat(2, 1fr);
		column-gap: var(--space-4);
	}
}

/* 保存ボタンの行を選択肢グリッドから明確に離す（行と被らないように上余白を確保）。 */
.settings-prefs + .settings-card__body {
	margin-top: var(--space-4);
}

.settings-prefs__item {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--font-size-sm);
	color: var(--color-text-primary);
	cursor: pointer;
}

.settings-prefs[disabled] .settings-prefs__item {
	cursor: not-allowed;
}

.settings-prefs__item input[type="checkbox"] {
	width: 16px;
	height: 16px;
	accent-color: var(--color-main);
	cursor: pointer;
}

.settings-prefs[disabled] .settings-prefs__item input[type="checkbox"] {
	cursor: not-allowed;
}

/* ============================================================
 * 空状態（マイページ用モディファイア）
 * ============================================================ */

.empty-state--mypage {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--space-3);
	padding: var(--space-8) var(--space-4);
	background: linear-gradient(180deg, color-mix(in srgb, var(--color-main) 4%, transparent) 0%, transparent 80%);
	border: 1px dashed var(--color-border);
	border-radius: var(--radius-lg);
	color: var(--color-text-secondary);
	text-align: center;
}

.empty-state--mypage .empty-state__illust {
	width: 96px;
	height: 96px;
	color: color-mix(in srgb, var(--color-main) 60%, var(--color-text-secondary));
}

.empty-state--mypage .empty-state__message {
	margin: 0;
	font-size: var(--font-size-base);
	font-weight: 600;
	color: var(--color-text-primary);
}

.empty-state--mypage .empty-state__sub {
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-secondary);
	max-width: 480px;
	line-height: 1.5;
}

/* ============================================================
   公開プロフィール（/u/:id ・ author.php）
   ============================================================ */

/* container 外側の縦余白 */
.profile-page {
	padding-block: var(--space-8);
}

/* ヘッダー全体: SP は縦積み中央寄せ。マイページと同じトーン。 */
.profile-header {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-3);
	padding: var(--space-8) 0 var(--space-6);
	margin-bottom: var(--space-6);
	background: linear-gradient(
		180deg,
		color-mix(in srgb, var(--color-main) 6%, transparent) 0%,
		transparent 100%
	);
	border-radius: var(--radius-lg);
	position: relative;
}

/* PC: 中央寄せコンパクト 2列グリッド（マイページと同じ構造） */
@media (min-width: 769px) {
	.profile-header {
		display: grid;
		grid-template-columns: 120px 1fr;
		column-gap: var(--space-6);
		row-gap: var(--space-5);
		align-items: center;
		text-align: center;
		max-width: 720px;
		margin-inline: auto;
		padding: var(--space-8) var(--space-5) var(--space-6);
	}

	.profile-header > .avatar {
		grid-column: 1;
		grid-row: 1;
		margin: 0 auto;
	}

	.profile-header > .profile-header__info {
		grid-column: 2;
		grid-row: 1;
		text-align: left;
		align-items: flex-start;
	}

	.profile-header > .profile-cta {
		grid-column: 1 / -1;
		grid-row: 2;
		justify-content: center;
	}

}

/* 情報ブロック */
.profile-header__info {
	flex: 0 1 auto;
	width: 100%;
	max-width: 600px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-2);
}

.profile-header__name {
	margin: 0;
	font-size: var(--font-size-xl);
	font-weight: 700;
	color: var(--color-text-primary);
	line-height: 1.3;
}

.profile-header__pref {
	margin: 0;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: var(--font-size-sm);
	color: var(--color-text-secondary);
}

.profile-header__pref::before {
	content: "";
	display: inline-block;
	width: 14px;
	height: 14px;
	background: currentColor;
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='currentColor' d='M12 2a7 7 0 0 0-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 0 0-7-7zm0 9.5A2.5 2.5 0 1 1 12 6.5a2.5 2.5 0 0 1 0 5z'/></svg>") center / contain no-repeat;
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='currentColor' d='M12 2a7 7 0 0 0-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 0 0-7-7zm0 9.5A2.5 2.5 0 1 1 12 6.5a2.5 2.5 0 0 1 0 5z'/></svg>") center / contain no-repeat;
}

.profile-header__meta {
	margin: 0;
	color: var(--color-text-secondary);
	font-size: var(--font-size-sm);
}

/* SNSリンク列（アイコンスタイルは .sns-link.sns-link--icon を共用） */
.profile-header__sns {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-3);
	margin-top: var(--space-2);
}

@media (min-width: 769px) {
	.profile-header__sns {
		justify-content: flex-start;
	}
}

/* CTA エリア */
.profile-cta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-2);
	width: 100%;
	margin-top: var(--space-2);
}

@media (min-width: 769px) {
	.profile-cta {
		flex-direction: row;
	}
}

/* 自分のプロフ用の控えめリンク */
.profile-cta__self-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 6px 12px;
	font-size: var(--font-size-xs);
	font-weight: 500;
	color: var(--color-text-secondary);
	background: color-mix(in srgb, var(--color-base-1) 70%, transparent);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-full);
	text-decoration: none;
	transition:
		background-color 0.15s ease,
		border-color 0.15s ease,
		color 0.15s ease;
}

.profile-cta__self-link:hover,
.profile-cta__self-link:focus-visible {
	color: var(--color-main);
	border-color: var(--color-main);
	background: color-mix(in srgb, var(--color-main) 8%, var(--color-base-1));
	outline: none;
}

.profile-cta__self-link svg {
	flex: 0 0 auto;
}

/* メインCTA（btn--lg を引き伸ばしてヒーロー化） */
.profile-cta__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	min-height: 52px;
	padding-inline: var(--space-6);
	width: 100%;
	max-width: 360px;
	font-size: var(--font-size-base);
	font-weight: 700;
	letter-spacing: 0.02em;
	border-radius: var(--radius-full);
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transition:
		transform 0.18s ease,
		box-shadow 0.18s ease,
		background-color 0.18s ease,
		color 0.18s ease,
		border-color 0.18s ease;
}

.profile-cta__btn:hover,
.profile-cta__btn:focus-visible {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
	outline: none;
}

/* フォロー中（ghost）はホバーで「フォロー解除」を示唆するグレー塗りに */
.profile-cta__btn.btn--ghost {
	box-shadow: none;
	background: var(--color-base-1);
}

.profile-cta__btn.btn--ghost:hover,
.profile-cta__btn.btn--ghost:focus-visible {
	background: color-mix(in srgb, var(--color-text-secondary) 12%, var(--color-base-1));
	border-color: color-mix(in srgb, var(--color-text-secondary) 30%, var(--color-border));
	color: var(--color-text-primary);
}

.profile-cta__btn-icon {
	flex: 0 0 auto;
}

.profile-cta__btn-label {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

@media (prefers-reduced-motion: reduce) {
	.profile-cta__btn {
		transition: none;
	}
	.profile-cta__btn:hover,
	.profile-cta__btn:focus-visible {
		transform: none;
	}
}

/* 体験談セクション */
.profile-body {
	margin-top: var(--space-6);
}

.profile-body__title {
	margin: 0 0 var(--space-4);
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-text-primary);
}

/* ============================================
 * マイページ ページネーション (6-19)
 * paginate_links( type=list ) 出力をスタイル
 * ============================================ */
.mypage-pagination {
	margin-top: var(--space-8);
	display: flex;
	justify-content: center;
}

.mypage-pagination .page-numbers {
	list-style: none;
	margin: 0;
	padding: 0;
	display: inline-flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	align-items: center;
}

.mypage-pagination .page-numbers li {
	display: inline-flex;
}

.mypage-pagination .page-numbers a,
.mypage-pagination .page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 var(--space-3);
	border-radius: var(--radius-md);
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-text-primary);
	background: var(--color-base-1);
	border: 1px solid var(--color-border);
	text-decoration: none;
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.mypage-pagination .page-numbers a:hover {
	background: var(--color-base-2);
	border-color: var(--color-main);
	color: var(--color-main);
}

.mypage-pagination .page-numbers .current {
	background: var(--color-main);
	border-color: var(--color-main);
	color: var(--color-base-1);
	font-weight: 700;
}

.mypage-pagination .page-numbers .dots {
	border: none;
	background: transparent;
	color: var(--color-text-secondary);
}

.mypage-pagination .page-numbers .prev,
.mypage-pagination .page-numbers .next {
	font-weight: 500;
}

@media (max-width: 600px) {
	.mypage-pagination .page-numbers {
		gap: var(--space-1);
	}
	.mypage-pagination .page-numbers a,
	.mypage-pagination .page-numbers span {
		min-width: 32px;
		height: 32px;
		padding: 0 var(--space-2);
		font-size: var(--font-size-xs);
	}
}
