/*
Theme Name: MBTI-SVAF
Theme URI:
Author: MBTI-SVAF Team
Description: 愛着MBTI（MBTI × SVAF）心理診断サイト — 進化したMBTI診断
Version: 3.0.0
Text Domain: mbti-svaf
*/

/* ==========================================================================
   Variables
   ========================================================================== */
:root {
	--color-primary: #8b6cc1;
	--color-primary-dark: #7558ab;
	--color-secondary: #d65c9a;
	--color-secondary-dark: #c04888;
	--color-accent: #f0c040;
	--color-analysts: #8b6cc1;
	--color-diplomats: #43b88c;
	--color-sentinels: #5ba3c9;
	--color-explorers: #e4ae3a;
	--color-bg: #f5f0fa;
	--color-bg-white: #ffffff;
	--color-bg-dark: #2d2055;
	--color-text: #3a3040;
	--color-text-secondary: #6b5f7d;
	--color-text-muted: #a093b5;
	--color-text-white: #ffffff;
	--color-border: #e4daf0;
	--shadow-soft: 0 2px 12px rgba(80,40,120,0.06);
	--shadow-card: 0 4px 16px rgba(80,40,120,0.08);
	--shadow-hover: 0 8px 32px rgba(80,40,120,0.12);
	--radius-sm: 6px;
	--radius-md: 12px;
	--radius-lg: 20px;
	--radius-full: 9999px;
	--font-main: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, sans-serif;
	--font-heading: 'Poppins', var(--font-main);
	--max-width: 1200px;
	--header-height: 80px;
}

/* ==========================================================================
   Reset
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: var(--font-main); color: var(--color-text); background: var(--color-bg); line-height: 1.75; -webkit-font-smoothing: antialiased; }
a { color: var(--color-primary); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--color-primary-dark); }
img { max-width: 100%; height: auto; display: block; }
ul, ol { list-style: none; }

.ms-container { max-width: var(--max-width); margin: 0 auto; padding: 0 16px; }
.ms-sp-only { display: none; }

/* ==========================================================================
   Header — スマホファースト
   ========================================================================== */
.ms-header {
	background: linear-gradient(135deg, #f3ecfb, #fdf0f6, #f0ecfb);
	height: var(--header-height);
	border-bottom: 2px solid #ddd0ef;
	position: sticky;
	top: 0;
	z-index: 1000;
	overflow: visible;
}
.ms-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 100%;
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 16px;
}
.ms-header__logo {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	position: relative;
	z-index: 10;
}
.ms-header__logo-img {
	height: 200px;
	width: auto;
	max-width: none;
	display: block;
	object-fit: contain;
	margin: -20px 0 -100px -40px;
	filter: drop-shadow(0 2px 8px rgba(0,0,0,0.1));
	position: relative;
	z-index: 10;
}
.ms-header__nav {
	display: none;
	position: fixed;
	top: var(--header-height);
	left: 0;
	right: 0;
	background: var(--color-bg-white);
	flex-direction: column;
	padding: 16px;
	border-bottom: 1px solid var(--color-border);
	box-shadow: var(--shadow-card);
	z-index: 999;
}
.ms-header__nav--open {
	display: flex;
}
.ms-header__nav a {
	color: #5a3d7a;
	font-size: 0.85rem;
	font-weight: 500;
	padding: 10px 14px;
	border-radius: var(--radius-full);
	transition: all 0.2s;
}
.ms-header__nav a:hover {
	background: rgba(139,108,193,0.1);
	color: var(--color-primary);
}
.ms-header__cta {
	background: linear-gradient(135deg, #8b6cc1, #d65c9a) !important;
	color: var(--color-text-white) !important;
	text-align: center;
	border-radius: var(--radius-full) !important;
	font-weight: 700 !important;
	margin-top: 8px;
	box-shadow: 0 2px 12px rgba(139,108,193,0.3);
}
.ms-header__hamburger {
	display: flex;
	background: none;
	border: none;
	width: 32px;
	height: 32px;
	cursor: pointer;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
}
.ms-header__hamburger span {
	display: block;
	width: 20px;
	height: 2px;
	background: var(--color-text);
	border-radius: 2px;
}

/* ==========================================================================
   Hero v2 — バナー画像フル表示 + CTA下部バー
   ========================================================================== */
.ms-hero2 {
	background: #e0d4f0;
}
.ms-hero2__image {
	width: 100%;
	line-height: 0;
}
.ms-hero2__image img {
	width: 100%;
	height: auto;
	display: block;
}
.ms-hero2__img-sp { display: none !important; }
.ms-hero2__img-pc { display: block !important; }
@media (max-width: 767px) {
	.ms-hero2__img-sp { display: block !important; line-height: 0; }
	.ms-hero2__img-pc { display: none !important; }
	.ms-hero2 { background: var(--color-bg); }
	.ms-hero2__cta-bar { display: none; }

	.ms-section { padding: 32px 0; }
	.ms-section__header { margin-bottom: 24px; }
	.ms-section__title { font-size: 1.25rem; }
	.ms-section__desc { font-size: 0.82rem; }

	.ms-authority__card { padding: 18px 16px; }
	.ms-authority__content h3 { font-size: 0.88rem; }
	.ms-authority__content p { font-size: 0.78rem; }

	.ms-svaf-card { padding: 18px 16px; }
	.ms-svaf-card__desc { font-size: 0.8rem; }
	.ms-svaf-card__traits li { font-size: 0.78rem; }

	.ms-dance__visual { padding: 16px 10px; gap: 8px; margin-bottom: 20px; }
	.ms-dance__person strong { font-size: 0.8rem; }
	.ms-dance__step h4 { font-size: 0.85rem; }
	.ms-dance__step p { font-size: 0.8rem; }
	.ms-dance__cta { padding: 18px 14px; }
	.ms-dance__cta p { font-size: 0.88rem; }

	.ms-group__header { padding: 12px 16px; }
	.ms-group__header h3 { font-size: 0.9rem; }
	.ms-group__header p { font-size: 0.72rem; }
	.ms-type-card { padding: 14px 8px; }
	.ms-type-card__img { width: 64px; height: 64px; }
	.ms-type-card__mbti { font-size: 0.78rem; }
	.ms-type-card__animal { font-size: 0.7rem; }
	.ms-type-card__title { font-size: 0.6rem; }

	.ms-cta-section { padding: 32px 16px; }
	.ms-cta-section__title { font-size: 1.15rem; }
	.ms-cta-section__desc { font-size: 0.82rem; }
	.ms-cta-section__btn-link { max-width: 320px; }

	.ms-header__logo-img { height: 180px; margin: -20px 0 -80px -40px; }
}
.ms-hero2__cta-bar {
	background: var(--color-bg);
	padding: 24px 16px;
	text-align: center;
}
.ms-hero2__cta-inner {
	display: flex;
	justify-content: center;
	align-items: center;
}
.ms-hero2__cta-link {
	display: inline-block;
	max-width: 520px;
	transition: transform 0.2s;
}
.ms-hero2__cta-link:hover {
	transform: scale(1.05);
}
.ms-hero2__cta-img {
	width: 100%;
	height: auto;
	display: block;
}

/* 旧ヒーロー非表示 */
.ms-hero { display: none; }
.ms-hero__bg-shapes { display: none; }
.ms-hero__shape { display: none; }
.ms-hero__layout { display: none; }
.ms-hero__text { display: none; }
.ms-hero__eyecatch { display: none; }
.ms-hero__title { display: none; }
.ms-hero__subtitle { display: none; }
.ms-hero__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--color-accent);
	color: var(--color-bg-dark);
	font-size: 1rem;
	font-weight: 700;
	padding: 14px 36px;
	border-radius: var(--radius-full);
	box-shadow: 0 4px 20px rgba(228,174,58,0.3);
	transition: all 0.25s;
}
.ms-hero__cta:hover {
	background: #f0c040;
	color: var(--color-bg-dark);
	transform: translateY(-2px);
}
.ms-hero__stats {
	display: flex;
	justify-content: center;
	gap: 28px;
	margin-top: 28px;
}
.ms-hero__stat { text-align: center; }
.ms-hero__stat-num {
	font-family: var(--font-heading);
	font-size: 1.3rem;
	font-weight: 800;
	display: block;
}
.ms-hero__stat-label { font-size: 0.7rem; opacity: 0.7; }

.ms-hero__visual { display: none; }
.ms-hero__banner { display: none; }

.ms-hero__card {
	position: absolute;
	width: 140px;
	background: white;
	border-radius: 14px;
	padding: 6px;
	box-shadow: 0 8px 32px rgba(0,0,0,0.2);
	transition: transform 0.3s;
}
.ms-hero__card:hover { transform: scale(1.06) !important; }
.ms-hero__card img { width: 100%; border-radius: 10px; }
.ms-hero__card-label {
	text-align: center;
	font-size: 0.65rem;
	font-weight: 600;
	color: #555;
	margin-top: 4px;
	display: block;
}
.ms-hero__card--1 { top: 8%; left: 3%; transform: rotate(-5deg); }
.ms-hero__card--2 { top: 4%; left: 42%; transform: rotate(4deg); }
.ms-hero__card--3 { top: 32%; left: 18%; transform: rotate(-2deg); }
.ms-hero__card--4 { top: 28%; left: 58%; transform: rotate(5deg); }
.ms-hero__card--5 { top: 58%; left: 5%; transform: rotate(3deg); }
.ms-hero__card--6 { top: 54%; left: 48%; transform: rotate(-4deg); }

/* ==========================================================================
   Section
   ========================================================================== */
.ms-section { padding: 48px 0; }
.ms-section--white { background: var(--color-bg-white); }
.ms-section--decorated {
	position: relative;
	background: url('images/bg-pastel.png') center / cover no-repeat;
	background-color: var(--color-bg);
}
.ms-section__header {
	text-align: center;
	max-width: 640px;
	margin: 0 auto 36px;
	padding: 0 16px;
}
.ms-section__label {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin-bottom: 6px;
}
.ms-section__title {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1.35;
	margin-bottom: 10px;
	color: var(--color-bg-dark);
}
.ms-section__desc {
	font-size: 0.9rem;
	color: var(--color-text-secondary);
	line-height: 1.7;
}

/* ==========================================================================
   仕組み解説(.ms-explain)
   ========================================================================== */
.ms-explain {
	max-width: 680px;
	margin: 0 auto;
}
.ms-explain__item {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	background: white;
	padding: 24px;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-soft);
}
.ms-explain__item--highlight {
	border: 2px solid var(--color-primary);
	background: #f8f3ff;
}
.ms-explain__icon {
	font-size: 1.8rem;
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.ms-explain__content h3 {
	font-size: 1rem;
	font-weight: 700;
	margin-bottom: 4px;
	color: var(--color-bg-dark);
}
.ms-explain__content p {
	font-size: 0.85rem;
	color: var(--color-text-secondary);
	line-height: 1.7;
}
.ms-explain__icon-plus {
	text-align: center;
	font-size: 1.3rem;
	font-weight: 800;
	color: var(--color-secondary);
	padding: 10px 0;
}

/* ==========================================================================
   SVAF カード
   ========================================================================== */
.ms-svaf-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}
.ms-svaf-card {
	background: white;
	border-radius: var(--radius-lg);
	padding: 24px;
	box-shadow: var(--shadow-soft);
	border-top: 4px solid;
	transition: transform 0.2s;
}
.ms-svaf-card:hover { transform: translateY(-3px); }
.ms-svaf-card--s { border-color: #33a474; }
.ms-svaf-card--v { border-color: #4298b4; }
.ms-svaf-card--a { border-color: #e4ae3a; }
.ms-svaf-card--f { border-color: #8b6cc1; }

.ms-svaf-card__header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
}
.ms-svaf-card__letter {
	width: 36px;
	height: 36px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	font-size: 1rem;
	flex-shrink: 0;
}
.ms-svaf-card--s .ms-svaf-card__letter { background: #e8f5e9; color: #33a474; }
.ms-svaf-card--v .ms-svaf-card__letter { background: #e3f2fd; color: #4298b4; }
.ms-svaf-card--a .ms-svaf-card__letter { background: #fff8e1; color: #e4ae3a; }
.ms-svaf-card--f .ms-svaf-card__letter { background: #ede7f6; color: #8b6cc1; }

.ms-svaf-card__header h3 {
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.2;
}
.ms-svaf-card__header h3 small {
	display: block;
	font-size: 0.7rem;
	color: var(--color-text-muted);
	font-weight: 400;
}
.ms-svaf-card__desc {
	font-size: 0.85rem;
	color: var(--color-text-secondary);
	margin-bottom: 12px;
}
.ms-svaf-card__traits li {
	font-size: 0.82rem;
	line-height: 1.8;
	padding-left: 20px;
	position: relative;
}
.ms-svaf-card__traits li::before {
	content: "✓";
	position: absolute;
	left: 0;
	font-weight: 700;
}
.ms-svaf-card--s .ms-svaf-card__traits li::before { color: #33a474; }
.ms-svaf-card--v .ms-svaf-card__traits li::before { color: #4298b4; }
.ms-svaf-card--a .ms-svaf-card__traits li::before { color: #e4ae3a; }
.ms-svaf-card--f .ms-svaf-card__traits li::before { color: #8b6cc1; }

.ms-svaf-card__pct {
	display: inline-block;
	margin-top: 10px;
	font-size: 0.7rem;
	background: #f5f5f5;
	padding: 3px 10px;
	border-radius: var(--radius-full);
	color: var(--color-text-muted);
}

/* ==========================================================================
   愛着のダンス
   ========================================================================== */
.ms-dance { max-width: 700px; margin: 0 auto; }
.ms-dance__visual {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	margin-bottom: 28px;
	padding: 24px 16px;
	background: linear-gradient(135deg, #f8f3ff, #fff0f6);
	border-radius: var(--radius-lg);
}
.ms-dance__person {
	text-align: center;
	flex: 1;
	max-width: 140px;
}
.ms-dance__letter {
	display: flex;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	font-size: 1.2rem;
	margin: 0 auto 6px;
}
.ms-dance__person--anxious .ms-dance__letter {
	background: #fef5e0;
	color: #d4a030;
}
.ms-dance__person--avoidant .ms-dance__letter {
	background: #e8f4fb;
	color: #5ba3c9;
}
.ms-dance__person strong {
	display: block;
	font-size: 0.85rem;
	color: var(--color-bg-dark);
	margin-bottom: 2px;
}
.ms-dance__person p {
	font-size: 0.72rem;
	color: var(--color-text-muted);
	font-style: italic;
}
.ms-dance__arrows {
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex-shrink: 0;
}
.ms-dance__arrow {
	font-size: 0.7rem;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: var(--radius-full);
	white-space: nowrap;
}
.ms-dance__arrow--push {
	background: #fce4f0;
	color: #d65c9a;
}
.ms-dance__arrow--pull {
	background: #e8f4fb;
	color: #5ba3c9;
}
.ms-dance__explanation {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-bottom: 28px;
}
.ms-dance__step {
	display: flex;
	gap: 14px;
	align-items: flex-start;
}
.ms-dance__step-num {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: linear-gradient(135deg, #8b6cc1, #d65c9a);
	color: white;
	font-weight: 800;
	font-size: 0.85rem;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.ms-dance__step h4 {
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--color-bg-dark);
	margin-bottom: 4px;
}
.ms-dance__step p {
	font-size: 0.84rem;
	color: var(--color-text-secondary);
	line-height: 1.75;
}
.ms-dance__cta {
	text-align: center;
	background: linear-gradient(135deg, #f3ecfb, #fff0f6);
	border-radius: var(--radius-lg);
	padding: 24px 20px;
	border: 1px solid #e4d5f5;
}
.ms-dance__cta p {
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--color-bg-dark);
	margin-bottom: 4px;
}
.ms-dance__cta-sub {
	font-size: 0.8rem !important;
	font-weight: 400 !important;
	color: var(--color-text-secondary) !important;
	margin-bottom: 16px !important;
}

/* ==========================================================================
   タイプ一覧(.ms-group)
   ========================================================================== */
.ms-group { margin-bottom: 32px; }
.ms-group__header {
	padding: 16px 20px;
	border-radius: var(--radius-lg) var(--radius-lg) 0 0;
	color: white;
}
.ms-group__header--analysts { background: linear-gradient(135deg, #8b6cc1, #a88dd8); }
.ms-group__header--diplomats { background: linear-gradient(135deg, #33a474, #4fc08d); }
.ms-group__header--sentinels { background: linear-gradient(135deg, #4298b4, #68b8d0); }
.ms-group__header--explorers { background: linear-gradient(135deg, #d4a030, #e8c547); color: var(--color-bg-dark); }

.ms-group__header h3 { font-size: 1rem; font-weight: 700; }
.ms-group__header h3 small { font-weight: 400; opacity: 0.8; margin-left: 6px; font-size: 0.8rem; }
.ms-group__header p { font-size: 0.78rem; opacity: 0.8; margin-top: 2px; }

.ms-group__types {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	background: white;
	border-radius: 0 0 var(--radius-lg) var(--radius-lg);
	box-shadow: var(--shadow-soft);
	overflow: hidden;
}
.ms-type-card {
	padding: 20px 12px;
	text-align: center;
	border-bottom: 1px solid #f0f0f0;
	transition: background 0.2s;
}
.ms-type-card:hover { background: #f8f3ff; }
.ms-type-card__img {
	width: 80px;
	height: 80px;
	margin: 0 auto 8px;
	overflow: hidden;
	border-radius: var(--radius-md);
}
.ms-type-card__img img { width: 100%; height: 100%; object-fit: cover; }
.ms-type-card__mbti {
	display: block;
	font-weight: 800;
	font-size: 0.85rem;
	color: var(--color-bg-dark);
	letter-spacing: 0.04em;
}
.ms-type-card__animal {
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--color-text-secondary);
}
.ms-type-card__title {
	display: block;
	font-size: 0.65rem;
	color: var(--color-text-muted);
}

/* ==========================================================================
   CTA
   ========================================================================== */
.ms-cta-section {
	background: linear-gradient(135deg, #8b6cc1, #d65c9a);
	padding: 48px 16px;
	text-align: center;
	color: var(--color-text-white);
}
.ms-cta-section__title {
	font-family: var(--font-heading);
	font-size: 1.4rem;
	font-weight: 800;
	margin-bottom: 10px;
}
.ms-cta-section__desc { opacity: 0.85; margin-bottom: 24px; font-size: 0.9rem; }
.ms-cta-section__btn-link {
	display: inline-block;
	max-width: 480px;
	transition: transform 0.2s;
}
.ms-cta-section__btn-link:hover { transform: scale(1.05); }
.ms-cta-section__btn-img {
	width: 100%;
	height: auto;
	display: block;
	filter: drop-shadow(0 4px 16px rgba(0,0,0,0.2));
}

/* ==========================================================================
   Footer
   ========================================================================== */
.ms-footer {
	background: var(--color-bg-dark);
	color: var(--color-text-white);
	padding: 36px 16px 24px;
}
.ms-footer__inner {
	max-width: var(--max-width);
	margin: 0 auto;
	text-align: center;
}
.ms-footer__logo {
	font-family: var(--font-heading);
	font-size: 0.9rem;
	font-weight: 700;
	opacity: 0.9;
	margin-bottom: 16px;
}
.ms-footer__links { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-bottom: 16px; }
.ms-footer__links a { color: var(--color-text-muted); font-size: 0.75rem; }
.ms-footer__links a:hover { color: var(--color-text-white); }
.ms-footer__copy { font-size: 0.7rem; color: var(--color-text-muted); padding-top: 16px; border-top: 1px solid rgba(255,255,255,0.1); }

/* ==========================================================================
   Buttons
   ========================================================================== */
.ms-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-family: var(--font-main);
	font-weight: 600;
	border: none;
	cursor: pointer;
	transition: all 0.2s;
	border-radius: var(--radius-full);
	text-decoration: none;
}
.ms-btn--primary { background: var(--color-primary); color: white; padding: 12px 28px; font-size: 0.95rem; }
.ms-btn--primary:hover { background: var(--color-primary-dark); color: white; }
.ms-btn--accent { background: var(--color-accent); color: var(--color-bg-dark); padding: 12px 28px; font-size: 0.95rem; font-weight: 700; }
.ms-btn--accent:hover { background: #f0c040; color: var(--color-bg-dark); }
.ms-btn--outline { background: transparent; color: var(--color-text-secondary); border: 2px solid var(--color-border); padding: 10px 24px; font-size: 0.85rem; }
.ms-btn--outline:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ==========================================================================
   権威付けセクション
   ========================================================================== */
.ms-authority {
	max-width: 900px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}
.ms-authority__card {
	background: white;
	border-radius: var(--radius-lg);
	padding: 24px 20px;
	box-shadow: var(--shadow-soft);
}
.ms-authority__icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.3rem;
	flex-shrink: 0;
	margin-bottom: 12px;
}
.ms-authority__icon--jung { background: #ede7f6; }
.ms-authority__icon--bowlby { background: #e3f2fd; }
.ms-authority__icon--fusion { background: #fff3e0; }
.ms-authority__content h3 { font-size: 0.95rem; font-weight: 700; margin-bottom: 6px; color: var(--color-bg-dark); }
.ms-authority__content p { font-size: 0.82rem; color: var(--color-text-secondary); line-height: 1.7; }

/* ==========================================================================
   PC (min-width: 768px)
   ========================================================================== */
@media (min-width: 768px) {
	:root { --header-height: 90px; }
	.ms-container { padding: 0 24px; }
	.ms-sp-only { display: none !important; }

	.ms-header__logo-img { height: 240px; margin: -20px 0 -130px -40px; }
	.ms-header__hamburger { display: none; }
	.ms-header__nav {
		display: flex !important;
		position: static;
		flex-direction: row;
		padding: 0;
		border-bottom: none;
		box-shadow: none;
		gap: 4px;
		align-items: center;
	}
	.ms-header__nav a { font-size: 0.8rem; padding: 8px 14px; }
	.ms-header__cta { margin-top: 0 !important; }
	.ms-hero2__cta-link { max-width: 500px; }

	.ms-hero { min-height: 480px; max-height: 700px; }
	.ms-hero__overlay { padding: 40px 24px 32px; }

	.ms-section { padding: 72px 0; }
	.ms-section__title { font-size: 1.8rem; }

	.ms-svaf-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
	.ms-group__types { grid-template-columns: repeat(4, 1fr); }
	.ms-type-card { border-bottom: none; border-right: 1px solid #f0f0f0; }
	.ms-type-card:nth-child(4n) { border-right: none; }
	.ms-type-card__img { width: 100px; height: 100px; }

	.ms-authority { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1024px) {
	.ms-hero__title { font-size: 3rem; }
	.ms-hero__card { width: 160px; }
}

/* ==========================================================================
   64タイプ一覧ページ
   ========================================================================== */
.ms-group--detail { margin-bottom: 40px; }
.ms-type-detail {
	background: white;
	padding: 20px;
	border-bottom: 1px solid #f0e8f8;
}
.ms-type-detail:last-child { border-bottom: none; border-radius: 0 0 var(--radius-lg) var(--radius-lg); }
.ms-type-detail__header {
	display: flex;
	align-items: baseline;
	gap: 10px;
	margin-bottom: 12px;
}
.ms-type-detail__mbti {
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 900;
	color: var(--color-bg-dark);
}
.ms-type-detail__animal {
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--color-primary);
}
.ms-type-detail__title {
	font-size: 0.8rem;
	color: var(--color-text-muted);
}
.ms-type-detail__variants {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
}
.ms-variant-card {
	display: flex;
	align-items: center;
	gap: 10px;
	background: var(--color-bg);
	border-radius: var(--radius-md);
	padding: 8px 10px;
	transition: transform 0.2s;
}
.ms-variant-card:hover { transform: translateY(-2px); }
.ms-variant-card__img {
	width: 56px;
	height: 56px;
	border-radius: 10px;
	overflow: hidden;
	flex-shrink: 0;
}
.ms-variant-card__img img { width: 100%; height: 100%; object-fit: cover; }
.ms-variant-card__info {
	display: flex;
	flex-direction: column;
	gap: 1px;
}
.ms-variant-card__type {
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	color: var(--color-bg-dark);
}
.ms-variant-card__svaf {
	font-size: 0.68rem;
	color: var(--color-text-muted);
}
.ms-types-cta {
	text-align: center;
	padding: 40px 0;
}
.ms-types-cta p {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-bg-dark);
	margin-bottom: 16px;
}
@media (min-width: 768px) {
	.ms-type-detail__variants { grid-template-columns: repeat(4, 1fr); }
	.ms-variant-card__img { width: 64px; height: 64px; }
}

/* ==========================================================================
   Aboutページ
   ========================================================================== */
.ms-about-block {
	max-width: 760px;
	margin: 0 auto 40px;
	padding: 0 8px;
}
.ms-about-block__icon {
	font-size: 2rem;
	margin-bottom: 8px;
}
.ms-about-block h2 {
	font-size: 1.2rem;
	font-weight: 800;
	color: var(--color-bg-dark);
	margin-bottom: 12px;
}
.ms-about-block p {
	font-size: 0.9rem;
	color: var(--color-text-secondary);
	line-height: 1.85;
	margin-bottom: 12px;
}
.ms-about-axes {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	margin: 16px 0;
}
.ms-about-axis {
	background: white;
	padding: 14px 16px;
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-soft);
}
.ms-about-axis__pair {
	display: block;
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--color-bg-dark);
	margin-bottom: 2px;
}
.ms-about-axis__desc {
	font-size: 0.78rem;
	color: var(--color-text-muted);
}
.ms-about-svaf {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	margin: 16px 0;
}
.ms-about-svaf__item {
	padding: 14px 16px;
	border-radius: var(--radius-md);
	border-left: 4px solid;
}
.ms-about-svaf__item--s { border-color: #43b88c; background: #f0faf5; }
.ms-about-svaf__item--v { border-color: #5ba3c9; background: #f0f7fc; }
.ms-about-svaf__item--a { border-color: #e4ae3a; background: #fef9f0; }
.ms-about-svaf__item--f { border-color: #8b6cc1; background: #f5f0fa; }
.ms-about-svaf__item strong {
	display: block;
	font-size: 0.88rem;
	color: var(--color-bg-dark);
	margin-bottom: 4px;
}
.ms-about-svaf__item p {
	font-size: 0.82rem;
	color: var(--color-text-secondary);
	margin-bottom: 0;
}
.ms-about-example {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	margin: 16px 0;
}
.ms-about-example__item {
	background: linear-gradient(135deg, #f8f3ff, #fff0f6);
	padding: 16px;
	border-radius: var(--radius-md);
}
.ms-about-example__item strong {
	display: block;
	font-size: 0.88rem;
	color: var(--color-bg-dark);
	margin-bottom: 4px;
}
.ms-about-example__item p {
	font-size: 0.82rem;
	margin-bottom: 0;
}
.ms-about-list {
	margin: 8px 0;
}
.ms-about-list li {
	font-size: 0.85rem;
	color: var(--color-text-secondary);
	line-height: 1.8;
	padding-left: 20px;
	position: relative;
}
.ms-about-list li::before {
	content: '•';
	position: absolute;
	left: 4px;
	color: var(--color-primary);
	font-weight: 700;
}
@media (min-width: 768px) {
	.ms-about-axes { grid-template-columns: repeat(2, 1fr); }
	.ms-about-svaf { grid-template-columns: repeat(2, 1fr); }
	.ms-about-example { grid-template-columns: repeat(2, 1fr); }
}

/* ==========================================================================
   法務ページ（特定商取引法・プライバシーポリシー）
   ========================================================================== */
.ms-tokushoho-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 16px;
	font-size: 0.9rem;
}
.ms-tokushoho-table th {
	background-color: var(--color-primary);
	color: var(--color-bg-white);
	padding: 12px 16px;
	text-align: left;
	font-weight: 600;
	width: 30%;
	border: 1px solid var(--color-primary);
}
.ms-tokushoho-table td {
	padding: 12px 16px;
	border: 1px solid #e0e0e0;
	color: var(--color-text-secondary);
	line-height: 1.6;
}
.ms-tokushoho-table a {
	color: var(--color-primary);
	text-decoration: none;
}
.ms-tokushoho-table a:hover {
	text-decoration: underline;
}
