/**
 * ベーススタイル + リセット + Elementor上書き
 */

/* ========================================
   リセット
   ======================================== */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: var(--font-body);
	font-size: var(--text-body);
	font-weight: var(--weight-regular);
	line-height: var(--leading-normal);
	color: var(--color-text);
	background-color: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

a:hover {
	color: var(--color-primary-light);
}

ul, ol {
	list-style: none;
}

/* ========================================
   タイポグラフィ
   ======================================== */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	font-weight: var(--weight-semibold);
	color: var(--color-text);
	letter-spacing: var(--tracking-heading);
	line-height: var(--leading-snug);
}

h1 { font-size: var(--text-hero); }
h2 { font-size: var(--text-section-title); }
h3 { font-size: var(--text-callout); }

p {
	margin-bottom: 1em;
}

p:last-child {
	margin-bottom: 0;
}

/* ========================================
   コンテナ
   ======================================== */
.ao-container {
	max-width: var(--container-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--container-padding);
	padding-right: var(--container-padding);
}

/* ========================================
   セクション
   ======================================== */
.ao-section {
	padding-top: var(--section-padding);
	padding-bottom: var(--section-padding);
}

.ao-section--alt {
	background-color: var(--color-bg-alt);
}

.ao-section__title {
	text-align: center;
	margin-bottom: var(--spacing-lg);
}

.ao-section__message {
	text-align: center;
	font-size: var(--text-body-large);
	font-weight: var(--weight-semibold);
	color: var(--color-primary);
	margin-top: var(--spacing-lg);
}

/* ========================================
   ヘッダー
   ======================================== */
.ao-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background-color: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	transition: background-color var(--transition-normal);
}

.ao-header__inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 64px;
}

.ao-header__logo a,
.ao-header__site-name {
	font-size: 20px;
	font-weight: var(--weight-bold);
	color: var(--color-primary);
	text-decoration: none;
}

.ao-header__nav {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
}

.ao-header__menu {
	display: flex;
	gap: var(--spacing-md);
}

.ao-header__menu li a {
	font-size: var(--text-caption);
	font-weight: var(--weight-medium);
	color: var(--color-text);
	transition: color var(--transition-fast);
}

.ao-header__menu li a:hover {
	color: var(--color-primary);
}

/* ハンバーガーメニュー */
.ao-header__menu-toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
}

.ao-header__menu-bar {
	display: block;
	width: 24px;
	height: 2px;
	background-color: var(--color-text);
	border-radius: 2px;
	transition: transform var(--transition-normal), opacity var(--transition-normal);
}

/* ========================================
   フッター
   ======================================== */
.ao-footer {
	background-color: var(--color-bg-dark);
	color: var(--color-text-on-dark);
	padding-top: var(--spacing-xl);
	padding-bottom: var(--spacing-md);
}

.ao-footer__inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap: var(--spacing-lg);
}

.ao-footer__site-name {
	font-size: 20px;
	font-weight: var(--weight-bold);
}

.ao-footer__description {
	margin-top: var(--spacing-sm);
	font-size: var(--text-caption);
	opacity: 0.8;
}

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

.ao-footer__list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.ao-footer__link {
	color: var(--color-text-on-dark);
	font-size: var(--text-caption);
	opacity: 0.8;
	transition: opacity var(--transition-fast);
}

.ao-footer__link:hover {
	opacity: 1;
	color: var(--color-white);
}

.ao-footer__menu {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-xs);
}

.ao-footer__menu li a {
	color: var(--color-text-on-dark);
	font-size: var(--text-caption);
	opacity: 0.8;
	transition: opacity var(--transition-fast);
}

.ao-footer__menu li a:hover {
	opacity: 1;
	color: var(--color-white);
}

.ao-footer__bottom {
	max-width: var(--container-max);
	margin: var(--spacing-lg) auto 0;
	padding: var(--spacing-md) var(--container-padding) 0;
	border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.ao-footer__copyright {
	font-size: var(--text-caption);
	opacity: 0.6;
	text-align: center;
}

/* ========================================
   Elementor上書き
   ======================================== */

/* Elementorのデフォルトフォントを統一 */
.elementor-widget-text-editor,
.elementor-widget-heading .elementor-heading-title,
.elementor-widget-text-editor p {
	font-family: var(--font-body) !important;
	color: var(--color-text);
}

/* Elementorセクションのコンテナ幅統一 */
.elementor-section.elementor-section-boxed > .elementor-container {
	max-width: var(--container-max);
}

/* Elementorのセクションパディングをdesign-rules準拠に */
.elementor-section {
	padding-top: var(--section-padding);
	padding-bottom: var(--section-padding);
}

/* Elementorボタンをピル型に統一 */
.elementor-widget-button .elementor-button {
	border-radius: var(--radius-btn) !important;
	font-family: var(--font-body) !important;
	font-weight: var(--weight-regular);
	padding: 12px 28px;
	transition: all var(--transition-normal);
}

/* Elementor背景altセクション */
.elementor-section.ao-bg-alt {
	background-color: var(--color-bg-alt) !important;
}

/* ========================================
   スクロールアニメーション
   ======================================== */
.ao-fade-in {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity var(--transition-slow), transform var(--transition-slow);
}

.ao-fade-in.ao-visible {
	opacity: 1;
	transform: translateY(0);
}

/* アクセシビリティ: モーション軽減 */
@media (prefers-reduced-motion: reduce) {
	.ao-fade-in {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

/* メインコンテンツ：ヘッダー分のオフセット */
.ao-main {
	padding-top: 64px;
}
