/* 記事ページ用インラインスタイル */
.article-container {
	max-width: 800px;
	margin: 0 auto;
	padding: 40px 20px;
	background-color: var(--bg-primary);
	color: var(--text-primary);
}

.article-header {
	position: static;
	top: auto;
	z-index: auto;
	margin-bottom: 40px;
	border-bottom: 1px solid var(--border-color);
	padding-bottom: 20px;
	/* Reset global header styles */
	background-color: transparent;
	box-shadow: none;
}

.article-title {
	font-size: 2rem;
	margin-bottom: 10px;
	color: var(--text-primary);
}

.article-content h2 {
	margin-top: 100px;
	margin-bottom: 30px;
	padding: 15px 10px;
	background-color: transparent;
	border-top: 3px solid #333;
	border-bottom: 3px solid #333;
	border-left: none;
	font-size: 1.5rem;
	font-weight: bold;
}

.article-content h3 {
	margin-top: 30px;
	margin-bottom: 15px;
	font-size: 1.2rem;
	border-left: 4px solid var(--accent-color);
	padding-left: 10px;
}

.article-content p {
	line-height: 1.8;
	margin-bottom: 20px;
}

.article-content ul,
.article-content ol {
	margin-bottom: 20px;
	padding-left: 2em;
}

.article-content li {
	margin-bottom: 10px;
	line-height: 1.6;
}

/* コードブロック */
pre {
	background-color: #1e1e1e;
	color: #d4d4d4;
	padding: 15px;
	border-radius: 8px;
	overflow-x: auto;
	margin-bottom: 25px;
	font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
	border: 1px solid var(--border-color);
}

code {
	font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
}

p code {
	background-color: var(--bg-alt);
	padding: 2px 6px;
	border-radius: 4px;
	color: var(--accent-color);
	font-size: 0.9em;
}

/* アラートボックス */
.alert-box {
	padding: 15px 25px;
	border-radius: 8px;
	margin-bottom: 25px;
	border-left: 5px solid;
}

.alert-info {
	background-color: rgba(64, 158, 255, 0.1);
	border-color: #409eff;
}

.alert-warning {
	background-color: rgba(230, 162, 60, 0.1);
	border-color: #e6a23c;
}

.alert-danger {
	background-color: rgba(245, 108, 108, 0.1);
	border-color: #f56c6c;
}

/* FAQ */
.faq-item {
	margin-bottom: 20px;
	border: 1px solid var(--border-color);
	border-radius: 8px;
	padding: 15px;
}

.faq-question {
	font-weight: bold;
	color: var(--accent-color);
	margin-bottom: 10px;
	display: flex;
	align-items: center;
}

.faq-question::before {
	content: "Q.";
	margin-right: 10px;
	font-size: 1.2em;
}

.faq-answer {
	padding-left: 25px;
}

/* 内部リンクボタン */
.cta-button {
	display: inline-block;
	background-color: #007bff;
	color: #fff;
	padding: 12px 24px;
	border-radius: 6px;
	text-decoration: none;
	font-weight: bold;
	margin: 20px 0;
	transition: opacity 0.2s;
}

.cta-button:hover {
	opacity: 0.9;
}