/* ==========================================================================
   Biography Studio — blog.css
   Blog landing (bslg-) and single post (bspt-) styles.
   ========================================================================== */


/* ==========================================================================
   BLOG LANDING PAGE (home.php)
   ========================================================================== */

/* ── Header ──────────────────────────────────────────────────────────────── */
.bslg-header {
	background-color: var(--bs-cream);
	background-image:
		radial-gradient(ellipse 80% 60% at 50% 0%, rgba(255,254,250,0.8) 0%, transparent 60%);
	padding:    88px 0 80px;
	border-bottom: 1px solid var(--bs-border-light);
}
.bslg-header__inner {
	max-width: 640px;
}
.bslg-header__label {
	font-family:    var(--bs-ui-font);
	font-size:      0.8125rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color:          var(--bs-pink-dark);
	margin-bottom:  18px;
}
.bslg-header__heading {
	font-family:    var(--bs-heading-font);
	font-size:      clamp(2.25rem, 4.5vw, 4rem);
	font-weight:    400;
	font-style:     italic;
	line-height:    1.1;
	letter-spacing: -0.015em;
	color:          var(--bs-navy);
	margin-bottom:  20px;
}
.bslg-header__intro {
	font-family: var(--bs-body-font);
	font-size:   1.0625rem;
	line-height: 1.7;
	color:       var(--bs-text-muted);
}

/* ── Grid ─────────────────────────────────────────────────────────────────── */
.bslg-grid-section {
	background:  var(--bs-white);
	padding:     72px 0 96px;
}
.bslg-grid {
	display:               grid;
	grid-template-columns: repeat(3, 1fr);
	gap:                   40px 28px;
	margin-bottom:         64px;
}
.bslg-empty {
	font-family: var(--bs-body-font);
	color:       var(--bs-text-muted);
	font-style:  italic;
	padding:     48px 0;
}

/* ── Card ─────────────────────────────────────────────────────────────────── */
.bslg-card {
	display:        flex;
	flex-direction: column;
}
.bslg-card__img-link {
	display:     block;
	overflow:    hidden;
	border-radius: 3px;
	margin-bottom: 20px;
}
.bslg-card__img {
	display:    block;
	width:      100%;
	aspect-ratio: 3 / 2;
	object-fit: cover;
	transition: transform 0.4s ease;
}
.bslg-card__img-link:hover .bslg-card__img {
	transform: scale(1.03);
}
.bslg-card__img-placeholder {
	width:        100%;
	aspect-ratio: 3 / 2;
	background:   var(--bs-cream);
	border-radius: 3px;
	margin-bottom: 20px;
}
.bslg-card__body {
	display:        flex;
	flex-direction: column;
	flex:           1;
}
.bslg-card__cat {
	font-family:    var(--bs-ui-font);
	font-size:      0.6875rem;
	font-weight:    600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color:          var(--bs-pink-dark);
	margin-bottom:  8px;
	display:        block;
}
.bslg-card__title {
	font-family:    var(--bs-heading-font);
	font-size:      1.375rem;
	font-weight:    400;
	font-style:     italic;
	line-height:    1.3;
	letter-spacing: -0.01em;
	color:          var(--bs-navy);
	margin-bottom:  10px;
}
.bslg-card__title a {
	color:           inherit;
	text-decoration: none;
}
.bslg-card__title a:hover {
	color: var(--bs-pink-dark);
}
.bslg-card__excerpt {
	font-family:   var(--bs-body-font);
	font-size:     0.9375rem;
	line-height:   1.65;
	color:         var(--bs-text-muted);
	margin-bottom: 16px;
	flex:          1;
}
.bslg-card__more {
	font-family:    var(--bs-ui-font);
	font-size:      0.8125rem;
	font-weight:    600;
	letter-spacing: 0.04em;
	color:          var(--bs-navy);
	text-decoration: none;
	align-self:     flex-start;
}
.bslg-card__more:hover {
	color: var(--bs-pink-dark);
}

/* ── Pagination ───────────────────────────────────────────────────────────── */
.bslg-pagination .nav-links {
	display:         flex;
	flex-wrap:       wrap;
	justify-content: center;
	gap:             8px;
}
.bslg-pagination .page-numbers {
	font-family:    var(--bs-ui-font);
	font-size:      0.875rem;
	font-weight:    600;
	color:          var(--bs-navy);
	text-decoration: none;
	padding:        8px 14px;
	border:         1px solid var(--bs-border-light);
	border-radius:  3px;
	line-height:    1;
}
.bslg-pagination .page-numbers.current,
.bslg-pagination .page-numbers:hover {
	background:   var(--bs-navy);
	color:        #fff;
	border-color: var(--bs-navy);
}
.bslg-pagination .page-numbers.dots {
	border-color: transparent;
	background:   transparent;
}


/* ==========================================================================
   SINGLE POST (single-post.php)
   ========================================================================== */

.bspt {
	background: var(--bs-white);
}

/* ── Hero image ───────────────────────────────────────────────────────────── */
.bspt-hero {
	padding:      40px 0 0;
	background:   var(--bs-white);
}
.bspt-hero__img {
	display:      block;
	width:        100%;
	aspect-ratio: 16 / 7;
	object-fit:   cover;
	border-radius: 3px;
}

/* ── Post header ──────────────────────────────────────────────────────────── */
.bspt-header {
	padding: 40px 0 32px;
}
.bspt-header__inner {
	max-width: 720px;
}
.bspt-cat {
	display:        inline-block;
	font-family:    var(--bs-ui-font);
	font-size:      0.6875rem;
	font-weight:    600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color:          var(--bs-pink-dark);
	margin-bottom:  14px;
}
.bspt-title {
	font-family:    var(--bs-heading-font);
	font-size:      clamp(2rem, 4vw, 3.25rem);
	font-weight:    400;
	font-style:     italic;
	line-height:    1.15;
	letter-spacing: -0.015em;
	color:          var(--bs-navy);
	margin-bottom:  20px;
}
.bspt-meta {
	display:     flex;
	flex-wrap:   wrap;
	align-items: center;
	gap:         0 10px;
}
.bspt-meta__author {
	font-family:     var(--bs-body-font);
	font-size:       0.9375rem;
	color:           var(--bs-navy);
	text-decoration: none;
	font-weight:     500;
}
.bspt-meta__author:hover { color: var(--bs-pink-dark); }
.bspt-meta__sep {
	color:   var(--bs-text-muted);
	opacity: 0.5;
}
.bspt-meta__date,
.bspt-meta__read {
	font-family: var(--bs-body-font);
	font-size:   0.9375rem;
	color:       var(--bs-text-muted);
}

/* ── Body content ─────────────────────────────────────────────────────────── */
.bspt-body {
	padding-bottom: 64px;
}
.bspt-content {
	max-width: 720px;
}

/* Post-specific overrides on top of .bs-entry-content */
.bspt-content h2 {
	font-family:    var(--bs-heading-font);
	font-size:      1.75rem;
	font-weight:    400;
	font-style:     italic;
	letter-spacing: -0.01em;
}
.bspt-content p {
	font-size:   1.0625rem;
	line-height: 1.9;
}
.bspt-content li {
	font-size:   1.0625rem;
	line-height: 1.8;
}

/* ── Inline lead magnet block ─────────────────────────────────────────────── */
.bspt-lead-magnet {
	background:    var(--bs-cream);
	border:        1px solid var(--bs-border-light);
	border-radius: 4px;
	padding:       36px 40px;
	margin:        48px 0;
}

/* ── MailerLite form (shared: lead magnet + signup) ──────────────────────── */
.bspt-mlform__heading {
	font-family:    var(--bs-heading-font);
	font-size:      1.5rem;
	font-weight:    400;
	font-style:     italic;
	line-height:    1.2;
	letter-spacing: -0.01em;
	color:          var(--bs-navy);
	margin-bottom:  8px;
}
.bspt-mlform__sub {
	font-family:   var(--bs-body-font);
	font-size:     0.9375rem;
	line-height:   1.65;
	color:         var(--bs-text-muted);
	margin-bottom: 20px;
}
.bspt-mlform__fields {
	display:   flex;
	flex-wrap: wrap;
	gap:       10px;
	margin-bottom: 12px;
}
.bspt-mlform__input {
	flex:          1 1 180px;
	font-family:   var(--bs-body-font);
	font-size:     1rem;
	color:         var(--bs-text);
	background:    var(--bs-white);
	border:        1px solid rgba(9, 58, 102, 0.25);
	border-radius: 3px;
	padding:       10px 14px;
	outline:       none;
	transition:    border-color 0.2s;
}
.bspt-mlform__input:focus { border-color: var(--bs-navy); }
.bspt-mlform__consent {
	font-family: var(--bs-body-font);
	font-size:   0.8125rem;
	color:       var(--bs-text-muted);
	opacity:     0.65;
}
.bspt-mlform__error {
	font-family:  var(--bs-body-font);
	font-size:    0.875rem;
	color:        #c0392b;
	margin-top:   8px;
}
.bspt-mlform__success {
	padding-top: 4px;
}
.bspt-mlform__confirm-msg {
	font-family:   var(--bs-body-font);
	font-size:     1rem;
	line-height:   1.7;
	color:         var(--bs-text);
	margin-bottom: 20px;
}

/* ── Signup block ─────────────────────────────────────────────────────────── */
.bspt-signup {
	background:  var(--bs-cream);
	padding:     64px 0;
	border-top:  1px solid var(--bs-border-light);
}
.bspt-signup__inner {
	max-width: 560px;
}

/* ── CTA block ────────────────────────────────────────────────────────────── */
.bspt-cta {
	background:  #ccd8e2;
	padding:     72px 0 80px;
	border-top:  1px solid rgba(9, 58, 102, 0.1);
}
.bspt-cta__inner {
	max-width: 560px;
}
.bspt-cta__heading {
	font-family:    var(--bs-heading-font);
	font-size:      clamp(1.75rem, 3.5vw, 2.75rem);
	font-weight:    400;
	font-style:     italic;
	line-height:    1.2;
	letter-spacing: -0.01em;
	color:          var(--bs-navy);
	margin-bottom:  12px;
}
.bspt-cta__body {
	font-family:   var(--bs-body-font);
	font-size:     1rem;
	line-height:   1.7;
	color:         rgba(46, 74, 94, 0.75);
	margin-bottom: 28px;
}


/* ==========================================================================
   RESPONSIVE — below 1024px
   ========================================================================== */
@media ( max-width: 1024px ) {

	.bslg-grid {
		grid-template-columns: 1fr 1fr;
	}

}


/* ==========================================================================
   RESPONSIVE — below 768px
   ========================================================================== */
@media ( max-width: 768px ) {

	.bslg-header  { padding: 56px 0 48px; }
	.bslg-grid    { grid-template-columns: 1fr; gap: 40px; }

	.bspt-hero__img   { aspect-ratio: 4 / 3; }
	.bspt-lead-magnet { padding: 28px 24px; }

	.bspt-mlform__fields {
		flex-direction: column;
	}
	.bspt-mlform__input { flex-basis: auto; }

}
