/**
 * Pro Magazines — Front-end styles.
 *
 * Provides minimal structural CSS. Visual styling (colours, typography,
 * spacing scale) is inherited from the active Divi child theme.
 *
 * @package Pro_Magazines
 */

/* =========================================================
   Archive — magazine grid
   ========================================================= */

.pm-archive-wrapper {
	padding: 40px 0;
}

.pm-archive-title {
	margin-bottom: 32px;
}

.pm-magazine-grid {
	display: grid;
	grid-template-columns: repeat( auto-fill, minmax( 280px, 1fr ) );
	gap: 32px;
	margin-bottom: 40px;
}

.pm-magazine-card {
	display: flex;
	flex-direction: column;
	border: 1px solid #e0e0e0;
	border-radius: 4px;
	overflow: hidden;
}

.pm-card-cover img {
	width: 100%;
	height: auto;
	display: block;
}

.pm-card-body {
	padding: 20px;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.pm-card-title {
	font-size: 1.1rem;
	margin-bottom: 6px;
}

.pm-card-title a {
	text-decoration: none;
}

.pm-card-date {
	font-size: 0.85rem;
	color: #888;
	margin-bottom: 10px;
}

.pm-card-summary {
	flex: 1;
	margin-bottom: 16px;
	font-size: 0.95rem;
}

.pm-card-cta {
	align-self: flex-start;
}

.pm-pagination {
	margin-top: 24px;
}

/* =========================================================
   Single magazine
   ========================================================= */

.pm-single-wrapper {
	padding: 40px 0;
}

.pm-single-header {
	display: flex;
	gap: 40px;
	margin-bottom: 48px;
	align-items: flex-start;
}

.pm-single-cover {
	flex: 0 0 260px;
}

.pm-single-cover img {
	width: 100%;
	height: auto;
	display: block;
	border: 1px solid #e0e0e0;
}

.pm-single-meta {
	flex: 1;
}

.pm-single-title {
	margin-top: 0;
}

.pm-single-date {
	font-size: 0.9rem;
	color: #888;
	margin-bottom: 8px;
}

.pm-single-conception {
	font-size: 0.9rem;
	margin-bottom: 16px;
}

.pm-single-summary {
	margin-top: 16px;
}

.pm-articles-heading {
	margin-bottom: 24px;
}

/* =========================================================
   Article list (shared: shortcode + single)
   ========================================================= */

.pm-article-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.pm-article-item {
	display: flex;
	gap: 20px;
	padding: 20px 0;
	border-bottom: 1px solid #e8e8e8;
	align-items: flex-start;
}

.pm-article-item:last-child {
	border-bottom: none;
}

.pm-article-image {
	flex: 0 0 80px;
}

.pm-article-image img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	display: block;
}

.pm-article-content {
	flex: 1;
}

.pm-article-title {
	margin: 0 0 6px;
	font-size: 1rem;
}

.pm-article-authors {
	margin-bottom: 8px;
}

.pm-author-name {
	margin: 0;
	font-size: 0.9rem;
	font-weight: 600;
}

.pm-author-titre {
	font-weight: 400;
	color: #666;
}

.pm-article-excerpt {
	font-size: 0.9rem;
	margin-bottom: 10px;
	color: #555;
}

/* =========================================================
   Latest summary shortcode
   ========================================================= */

.pm-latest-summary {
	display: flex;
	gap: 32px;
	align-items: flex-start;
}

.pm-cover-image {
	flex: 0 0 220px;
}

.pm-cover-image img {
	width: 100%;
	height: auto;
	display: block;
}

.pm-summary-content {
	flex: 1;
}

.pm-magazine-title {
	margin-top: 0;
}

.pm-magazine-date {
	font-size: 0.85rem;
	color: #888;
}

.pm-a-la-une {
	margin: 12px 0 16px;
}

/* =========================================================
   Author block (bottom of articles)
   ========================================================= */

.pm-author-block {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 2px solid #e0e0e0;
}

.pm-author-block-heading {
	margin-bottom: 24px;
	font-size: 1.1rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.pm-author-card {
	display: flex;
	gap: 24px;
	margin-bottom: 24px;
	align-items: flex-start;
}

.pm-author-photo img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: 50%;
	display: block;
}

.pm-author-info .pm-author-name {
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 2px;
}

.pm-author-info .pm-author-titre {
	font-size: 0.85rem;
	color: #666;
	display: block;
	margin-bottom: 8px;
}

.pm-author-bio {
	font-size: 0.9rem;
	color: #444;
}

/* =========================================================
   Back link
   ========================================================= */

.pm-back-link {
	margin-top: 40px;
	font-size: 0.9rem;
}

/* =========================================================
   Responsive
   ========================================================= */

@media ( max-width: 768px ) {
	.pm-single-header,
	.pm-latest-summary {
		flex-direction: column;
	}

	.pm-single-cover,
	.pm-cover-image {
		flex: none;
		width: 100%;
		max-width: 300px;
	}

	.pm-author-card {
		flex-direction: column;
	}
}

