/**
 * コンポーネントスタイル（design-rules準拠）
 */

/* ========================================
   ボタン（ピル型）
   ======================================== */
.ao-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-family: var(--font-body);
	font-size: var(--text-body);
	font-weight: var(--weight-medium);
	line-height: 1.18;
	color: var(--color-white);
	background-color: var(--color-primary);
	border: 2px solid transparent;
	border-radius: var(--radius-btn);
	padding: 12px 28px;
	cursor: pointer;
	text-decoration: none;
	transition: all var(--transition-normal);
}

.ao-btn:hover {
	background-color: var(--color-primary-light);
	color: var(--color-white);
}

.ao-btn--large {
	font-size: var(--text-body-large);
	padding: 16px 40px;
}

.ao-btn--white {
	background-color: var(--color-white);
	color: var(--color-primary);
}

.ao-btn--white:hover {
	background-color: var(--color-bg-alt);
	color: var(--color-primary);
}

.ao-btn--outline {
	background-color: transparent;
	color: var(--color-white);
	border-color: var(--color-white);
}

.ao-btn--outline:hover {
	background-color: var(--color-white);
	color: var(--color-primary);
}

.ao-btn--header {
	font-size: var(--text-caption);
	padding: 8px 20px;
}

.ao-btn__icon {
	font-size: 1.2em;
}

/* ========================================
   カード
   ======================================== */
.ao-card {
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-card);
	padding: var(--spacing-lg) var(--spacing-md);
	overflow: hidden;
	transition: box-shadow var(--transition-normal);
}

.ao-card:hover {
	box-shadow: var(--shadow-md);
}

/* カード画像付きバリアント */
.ao-card--has-image {
	padding: 0;
	display: flex;
	flex-direction: column;
}

.ao-card__image {
	width: 100%;
	aspect-ratio: 16 / 9;
	max-height: 200px;
	overflow: hidden;
	border-radius: var(--radius-card) var(--radius-card) 0 0;
}

.ao-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.ao-card--has-image:hover .ao-card__image img {
	transform: scale(1.05);
}

.ao-card__body {
	padding: var(--spacing-md);
	flex: 1;
}

.ao-card__icon {
	color: var(--color-primary);
	margin-bottom: var(--spacing-md);
}

.ao-card__title {
	font-size: var(--text-callout);
	font-weight: var(--weight-semibold);
	margin-bottom: var(--spacing-sm);
	color: var(--color-text);
}

.ao-card__text {
	font-size: var(--text-body);
	line-height: var(--leading-relaxed);
	color: var(--color-text-secondary);
}

/* カードグリッド */
.ao-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--spacing-sm);
}

/* ========================================
   チェックリスト
   ======================================== */
.ao-checklist {
	max-width: 720px;
	margin: 0 auto;
}

.ao-checklist__item {
	position: relative;
	padding: var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) 48px;
	font-size: var(--text-body-large);
	line-height: var(--leading-relaxed);
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.ao-checklist__item:last-child {
	border-bottom: none;
}

.ao-checklist__item::before {
	content: '\2611';
	position: absolute;
	left: var(--spacing-sm);
	top: var(--spacing-sm);
	font-size: 24px;
	color: var(--color-primary);
}

/* ========================================
   プロフィール
   ======================================== */
.ao-profile {
	display: flex;
	gap: var(--spacing-lg);
	align-items: center;
	margin-top: var(--spacing-xl);
	padding: var(--spacing-lg);
	background-color: var(--color-bg);
	border-radius: var(--radius-card);
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.ao-profile__image {
	flex-shrink: 0;
}

.ao-profile__placeholder {
	width: 200px;
	height: 200px;
	border-radius: 50%;
	background-color: var(--color-bg-alt);
	border: 3px solid var(--color-accent);
}

.ao-profile__photo {
	width: 200px;
	height: 200px;
	border-radius: 50%;
	object-fit: cover;
	border: 3px solid var(--color-accent);
}

.ao-profile__label {
	font-size: var(--text-caption);
	font-weight: var(--weight-medium);
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: var(--spacing-xs);
}

.ao-profile__name {
	font-size: var(--text-subtitle);
	font-weight: var(--weight-bold);
	margin-bottom: var(--spacing-sm);
}

.ao-profile__bio {
	font-size: var(--text-body);
	line-height: var(--leading-relaxed);
	color: var(--color-text-secondary);
}

/* 実績セクション */
.ao-proof__achievements {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--spacing-sm);
	max-width: 800px;
	margin: 0 auto;
}

/* ========================================
   サービス
   ======================================== */
.ao-services {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--spacing-sm);
	margin-bottom: var(--spacing-lg);
}

.ao-area {
	text-align: center;
	padding: var(--spacing-lg);
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-card);
}

.ao-area__title {
	font-size: var(--text-callout);
	font-weight: var(--weight-semibold);
	margin-bottom: var(--spacing-md);
}

.ao-area__list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
	font-size: var(--text-body);
}

/* ========================================
   FAQ（アコーディオン）
   ======================================== */
.ao-faq {
	max-width: 800px;
	margin: 0 auto;
}

.ao-faq__item {
	background-color: var(--color-bg);
	border-radius: var(--radius-sm);
	margin-bottom: var(--spacing-sm);
	overflow: hidden;
	transition: box-shadow var(--transition-normal);
}

.ao-faq__item:hover {
	box-shadow: var(--shadow-sm);
}

.ao-faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--spacing-md) var(--spacing-md);
	font-size: var(--text-body-large);
	font-weight: var(--weight-semibold);
	cursor: pointer;
	list-style: none;
	transition: color var(--transition-fast);
}

.ao-faq__question::-webkit-details-marker {
	display: none;
}

.ao-faq__question::after {
	content: '+';
	font-size: 24px;
	font-weight: var(--weight-regular);
	color: var(--color-primary);
	flex-shrink: 0;
	margin-left: var(--spacing-sm);
	transition: transform var(--transition-normal);
}

.ao-faq__item[open] .ao-faq__question::after {
	content: '\2212';
	transform: rotate(180deg);
}

.ao-faq__item[open] .ao-faq__question {
	color: var(--color-primary);
}

.ao-faq__answer {
	padding: 0 var(--spacing-md) var(--spacing-md);
	font-size: var(--text-body);
	line-height: var(--leading-relaxed);
	color: var(--color-text-secondary);
}

/* ========================================
   Hero
   ======================================== */
.ao-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-color: var(--color-primary-dark);
	background-size: cover;
	background-position: center;
	overflow: hidden;
	padding-top: 64px;
}

.ao-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		180deg,
		rgba(21, 67, 96, 0.7) 0%,
		rgba(27, 79, 114, 0.85) 100%
	);
}

.ao-hero__content {
	position: relative;
	z-index: 1;
}

.ao-hero__title {
	font-size: var(--text-hero);
	font-weight: var(--weight-bold);
	line-height: var(--leading-tight);
	color: var(--color-white);
	margin-bottom: var(--spacing-md);
	letter-spacing: var(--tracking-heading);
}

.ao-hero__subtitle {
	font-size: var(--text-body-large);
	font-weight: var(--weight-regular);
	color: var(--color-text-on-dark);
	max-width: 640px;
	margin: 0 auto var(--spacing-lg);
	line-height: var(--leading-relaxed);
	opacity: 0.9;
}

/* ========================================
   CTA（クロージング）
   ======================================== */
.ao-cta {
	background-color: var(--color-primary-dark);
	color: var(--color-white);
	text-align: center;
}

.ao-cta__title {
	font-size: var(--text-section-title);
	color: var(--color-white);
	margin-bottom: var(--spacing-md);
}

.ao-cta__message {
	font-size: var(--text-body-large);
	color: var(--color-text-on-dark);
	max-width: 640px;
	margin: 0 auto var(--spacing-lg);
	line-height: var(--leading-relaxed);
	opacity: 0.9;
}

.ao-cta__actions {
	display: flex;
	justify-content: center;
	gap: var(--spacing-sm);
	flex-wrap: wrap;
	margin-bottom: var(--spacing-md);
}

.ao-cta__note {
	font-size: var(--text-caption);
	color: var(--color-text-on-dark);
	opacity: 0.7;
}

/* ========================================
   お悩みセクション（画像+リスト横並び）
   ======================================== */
.ao-problem__layout {
	display: flex;
	gap: var(--spacing-lg);
	align-items: center;
	margin-bottom: var(--spacing-md);
}

.ao-problem__image {
	flex: 0 0 360px;
	border-radius: var(--radius-card);
	overflow: hidden;
}

.ao-problem__image img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: var(--radius-card);
}

.ao-problem__content {
	flex: 1;
}

/* ========================================
   サービスセクション ビジュアル
   ======================================== */
.ao-service__visual {
	margin-bottom: var(--spacing-lg);
	border-radius: var(--radius-card);
	overflow: hidden;
	max-height: 280px;
}

.ao-service__hero-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: var(--radius-card);
}
