/*
 * layout.css
 * Container, grid system, section spacing, and shared layout utilities.
 */

/* ==========================================================================
   Container
   ========================================================================== */
.container {
	width: 100%;
	max-width: var(--container-max);
	margin-right: auto;
	margin-left: auto;
	padding-right: var(--container-padding);
	padding-left: var(--container-padding);
}

.container--narrow {
	max-width: 800px;
}

.container--wide {
	max-width: 1400px;
}

/* ==========================================================================
   Section Spacing
   ========================================================================== */
.section-title {
	font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl));
	font-weight: var(--font-weight-bold);
	color: var(--colour-navy);
	margin-bottom: var(--space-4);
	line-height: var(--line-height-tight);
}

.section-subtitle {
	font-size: var(--font-size-lg);
	color: var(--colour-text-muted);
	max-width: 600px;
	margin-bottom: var(--space-8);
}

/* ==========================================================================
   Grid Utilities
   ========================================================================== */
.posts-grid {
	display: grid;
	gap: var(--space-8);
}

.posts-grid--3col {
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.posts-grid--2col {
	grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
}

/* ==========================================================================
   Post Card
   ========================================================================== */
.post-card {
	display: flex;
	flex-direction: column;
	background-color: var(--colour-white);
	border: 1px solid var(--colour-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.post-card:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-2px);
}

.post-card__thumbnail-link {
	display: block;
	overflow: hidden;
	aspect-ratio: 3 / 2;
}

.post-card__thumbnail {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.post-card:hover .post-card__thumbnail {
	transform: scale(1.04);
}

.post-card__thumbnail-placeholder {
	aspect-ratio: 3 / 2;
	background: linear-gradient(135deg, var(--colour-navy) 0%, var(--colour-navy-light) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 3rem;
}

.post-card__content {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: var(--space-6);
}

.post-card__categories {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-bottom: var(--space-3);
}

.post-card__category-link {
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--colour-green-dark);
	text-decoration: none;
}
.post-card__category-link:hover {
	color: var(--colour-navy);
}

.post-card__title {
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	color: var(--colour-navy);
	line-height: var(--line-height-snug);
	margin-bottom: var(--space-3);
}

.post-card__title a {
	color: inherit;
	text-decoration: none;
}
.post-card__title a:hover {
	color: var(--colour-green-dark);
}

.post-card__excerpt {
	color: var(--colour-text-muted);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	margin-bottom: var(--space-4);
	flex: 1;
}

.post-card__meta {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	font-size: var(--font-size-xs);
	color: var(--colour-grey-600);
	margin-bottom: var(--space-4);
}

.post-card__read-more {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--colour-navy);
	text-decoration: none;
	transition: color var(--transition-fast);
}
.post-card__read-more:hover {
	color: var(--colour-green-dark);
}

/* ==========================================================================
   Page Layout (legal pages, about, etc.)
   ========================================================================== */
.financeblog-page-wrapper {
	padding: var(--space-12) 0 var(--space-20);
}

.page-header {
	margin-bottom: var(--space-10);
	padding-bottom: var(--space-6);
	border-bottom: 3px solid var(--colour-green);
}

.page-title {
	font-size: clamp(var(--font-size-3xl), 5vw, var(--font-size-4xl));
	font-weight: var(--font-weight-bold);
	color: var(--colour-navy);
	margin-bottom: var(--space-2);
}

.page-meta {
	font-size: var(--font-size-sm);
	color: var(--colour-text-muted);
	margin: 0;
}

/* ==========================================================================
   Legal Content Styling
   ========================================================================== */
.legal-content h2 {
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-bold);
	color: var(--colour-navy);
	margin-top: var(--space-10);
	margin-bottom: var(--space-4);
	padding-bottom: var(--space-2);
	border-bottom: 1px solid var(--colour-border);
}

.legal-content h3 {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-semibold);
	color: var(--colour-navy);
	margin-top: var(--space-6);
	margin-bottom: var(--space-3);
}

.legal-content p,
.legal-content ul,
.legal-content ol {
	margin-bottom: var(--space-4);
	line-height: var(--line-height-loose);
}

.legal-content ul,
.legal-content ol {
	padding-left: var(--space-6);
}

.legal-content li {
	margin-bottom: var(--space-2);
}

.legal-notice {
	background-color: #fff3cd;
	border: 1px solid #ffc107;
	border-radius: var(--radius-md);
	padding: var(--space-4) var(--space-6);
	margin-bottom: var(--space-8);
}

/* ==========================================================================
   Pro/Con Box Shortcode
   ========================================================================== */
.pro-con-box {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-4);
	margin: var(--space-8) 0;
	border-radius: var(--radius-md);
	overflow: hidden;
	border: 1px solid var(--colour-border);
}

.pro-con-box__pros,
.pro-con-box__cons {
	padding: var(--space-6);
}

.pro-con-box__pros {
	background-color: #f0fff4;
}

.pro-con-box__cons {
	background-color: #fff5f5;
}

.pro-con-box__heading {
	font-size: var(--font-size-lg);
	font-weight: var(--font-weight-bold);
	margin-bottom: var(--space-4);
}

.pro-con-box__heading--pros {
	color: #276749;
}

.pro-con-box__heading--cons {
	color: #9b2c2c;
}

.pro-con-box ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.pro-con-box li {
	padding: var(--space-2) 0;
	font-size: var(--font-size-sm);
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.pro-con-box li:last-child {
	border-bottom: none;
}
