/*
Theme Name:  Hello Elementor Child
Template:    hello-elementor
Description: Signal Sanctuary child theme — blog templates.
Version:     1.0.0
*/

/* ─── Design tokens ─────────────────────────────────────── */
:root {
	--ss-purple:      #7C3AED;
	--ss-indigo:      #4F46E5;
	--ss-lavender:    #EEF2FF;
	--ss-text:        #222222;
	--ss-muted:       #6B7280;
	--ss-dark:        #111827;
	--ss-border:      #E5E7EB;
	--ss-white:       #FFFFFF;
	--ss-max-w:       1140px;
	--ss-radius-pill: 999px;
	--ss-radius-card: 16px;
	--ss-font:        "Inter", sans-serif;
}

/* ─── Blog wrapper ──────────────────────────────────────── */
.ss-blog-wrap {
	max-width: var(--ss-max-w);
	margin: 0 auto;
	padding: 64px 24px 80px;
}

/* ─── Blog hero / page title ────────────────────────────── */
.ss-blog-hero {
	text-align: center;
	padding: 72px 24px 56px;
	background: var(--ss-lavender);
}
.ss-blog-hero__label {
	display: inline-block;
	font-family: var(--ss-font);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ss-purple);
	margin-bottom: 12px;
}
.ss-blog-hero__title {
	font-family: var(--ss-font);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 700;
	color: var(--ss-dark);
	margin: 0 0 16px;
	line-height: 1.15;
}
.ss-blog-hero__sub {
	font-family: var(--ss-font);
	font-size: 1.125rem;
	color: var(--ss-muted);
	max-width: 600px;
	margin: 0 auto;
}

/* ─── Post grid ─────────────────────────────────────────── */
.ss-posts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 32px;
	margin-top: 48px;
}

/* ─── Post card ─────────────────────────────────────────── */
.ss-card {
	background: var(--ss-white);
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius-card);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
	text-decoration: none;
}
.ss-card:hover {
	box-shadow: 0 12px 40px rgba(124, 58, 237, 0.12);
	transform: translateY(-3px);
}
.ss-card__thumb {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	background: var(--ss-lavender);
}
.ss-card__thumb-placeholder {
	width: 100%;
	aspect-ratio: 16 / 9;
	background: linear-gradient(135deg, var(--ss-lavender) 0%, #ddd8ff 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}
.ss-card__thumb-placeholder svg {
	opacity: 0.35;
}
.ss-card__body {
	padding: 24px 28px 28px;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.ss-card__meta {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 12px;
	font-weight: 500;
	color: var(--ss-muted);
	margin-bottom: 12px;
	font-family: var(--ss-font);
}
.ss-card__cat {
	background: var(--ss-lavender);
	color: var(--ss-purple);
	font-weight: 600;
	padding: 3px 10px;
	border-radius: var(--ss-radius-pill);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	text-decoration: none;
}
.ss-card__cat:hover { background: var(--ss-purple); color: var(--ss-white); }
.ss-card__title {
	font-family: var(--ss-font);
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--ss-dark);
	line-height: 1.3;
	margin: 0 0 10px;
	text-decoration: none;
}
.ss-card__title a {
	color: inherit;
	text-decoration: none;
}
.ss-card__title a:hover { color: var(--ss-purple); }
.ss-card__excerpt {
	font-family: var(--ss-font);
	font-size: 0.9375rem;
	color: var(--ss-muted);
	line-height: 1.65;
	margin: 0 0 20px;
	flex: 1;
}
.ss-card__read-more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--ss-font);
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--ss-purple);
	text-decoration: none;
}
.ss-card__read-more:hover { color: var(--ss-indigo); }
.ss-card__read-more svg { transition: transform 0.2s; }
.ss-card__read-more:hover svg { transform: translateX(3px); }

/* ─── No-posts state ─────────────────────────────────────── */
.ss-no-posts {
	text-align: center;
	padding: 80px 24px;
	color: var(--ss-muted);
	font-family: var(--ss-font);
}
.ss-no-posts h2 { color: var(--ss-dark); margin-bottom: 12px; }

/* ─── Pagination ─────────────────────────────────────────── */
.ss-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
	margin-top: 56px;
	flex-wrap: wrap;
	font-family: var(--ss-font);
}
.ss-pagination a,
.ss-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 14px;
	border-radius: var(--ss-radius-pill);
	font-size: 0.875rem;
	font-weight: 500;
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}
.ss-pagination a {
	border: 1px solid var(--ss-border);
	color: var(--ss-dark);
}
.ss-pagination a:hover {
	background: var(--ss-lavender);
	border-color: var(--ss-purple);
	color: var(--ss-purple);
}
.ss-pagination .current {
	background: var(--ss-purple);
	color: var(--ss-white);
	border: 1px solid var(--ss-purple);
}

/* ═══════════════════════════════════════════════════════════
   SINGLE POST
════════════════════════════════════════════════════════════ */

/* ─── Post hero ─────────────────────────────────────────── */
.ss-post-hero {
	position: relative;
	background: var(--ss-lavender);
	overflow: hidden;
}
.ss-post-hero__image {
	width: 100%;
	max-height: 520px;
	object-fit: cover;
	display: block;
}
.ss-post-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(17,24,39,0.6) 0%, transparent 60%);
}
.ss-post-hero__content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 40px clamp(24px, 5vw, 80px) 48px;
	max-width: var(--ss-max-w);
	margin: 0 auto;
}
.ss-post-hero--no-image .ss-post-hero__content {
	position: static;
	padding: 64px 24px 48px;
	max-width: var(--ss-max-w);
	margin: 0 auto;
}

.ss-post-hero__cats {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 16px;
}
.ss-post-hero__cat {
	background: rgba(255,255,255,0.2);
	color: var(--ss-white);
	border: 1px solid rgba(255,255,255,0.4);
	padding: 4px 14px;
	border-radius: var(--ss-radius-pill);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-decoration: none;
	backdrop-filter: blur(4px);
}
.ss-post-hero__cat:hover { background: var(--ss-purple); border-color: var(--ss-purple); }

.ss-post-hero--no-image .ss-post-hero__cat {
	background: var(--ss-lavender);
	color: var(--ss-purple);
	border-color: transparent;
}
.ss-post-hero--no-image .ss-post-hero__cat:hover {
	background: var(--ss-purple);
	color: var(--ss-white);
}

.ss-post-hero__title {
	font-family: var(--ss-font);
	font-size: clamp(1.75rem, 4.5vw, 3rem);
	font-weight: 800;
	line-height: 1.15;
	color: var(--ss-white);
	margin: 0 0 20px;
}
.ss-post-hero--no-image .ss-post-hero__title {
	color: var(--ss-dark);
}
.ss-post-hero__meta {
	display: flex;
	align-items: center;
	gap: 20px;
	flex-wrap: wrap;
	font-family: var(--ss-font);
	font-size: 0.875rem;
	color: rgba(255,255,255,0.8);
}
.ss-post-hero--no-image .ss-post-hero__meta { color: var(--ss-muted); }
.ss-post-hero__meta-item {
	display: flex;
	align-items: center;
	gap: 6px;
}
.ss-post-hero__meta-item svg { opacity: 0.7; flex-shrink: 0; }
.ss-post-hero__avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: 2px solid rgba(255,255,255,0.5);
}

/* ─── Post body ─────────────────────────────────────────── */
.ss-post-layout {
	max-width: var(--ss-max-w);
	margin: 0 auto;
	padding: 0 24px 80px;
	display: grid;
	grid-template-columns: 1fr min(680px, 100%) 1fr;
}
.ss-post-layout > * { grid-column: 2; }

.ss-post-content {
	padding-top: 56px;
	font-family: var(--ss-font);
	font-size: 1.0625rem;
	line-height: 1.8;
	color: var(--ss-text);
}
.ss-post-content h1, .ss-post-content h2, .ss-post-content h3,
.ss-post-content h4, .ss-post-content h5, .ss-post-content h6 {
	font-weight: 700;
	color: var(--ss-dark);
	margin: 2em 0 0.6em;
	line-height: 1.25;
}
.ss-post-content h2 { font-size: 1.7rem; }
.ss-post-content h3 { font-size: 1.35rem; }
.ss-post-content h4 { font-size: 1.1rem; }
.ss-post-content p   { margin: 0 0 1.4em; }
.ss-post-content a   { color: var(--ss-indigo); text-decoration: underline; }
.ss-post-content a:hover { color: var(--ss-purple); }
.ss-post-content img {
	max-width: 100%;
	height: auto;
	border-radius: 12px;
	margin: 1.5em 0;
	display: block;
}
.ss-post-content ul, .ss-post-content ol {
	margin: 0 0 1.4em 1.5em;
}
.ss-post-content li { margin-bottom: 0.5em; }
.ss-post-content blockquote {
	border-left: 4px solid var(--ss-purple);
	margin: 2em 0;
	padding: 16px 24px;
	background: var(--ss-lavender);
	border-radius: 0 12px 12px 0;
	font-style: italic;
	color: var(--ss-dark);
}
.ss-post-content blockquote p:last-child { margin-bottom: 0; }
.ss-post-content pre, .ss-post-content code {
	font-family: "Courier New", Courier, monospace;
	background: #F3F4F6;
	border-radius: 6px;
}
.ss-post-content code { padding: 2px 6px; font-size: 0.9em; }
.ss-post-content pre  { padding: 20px; overflow-x: auto; margin: 1.5em 0; }
.ss-post-content hr   {
	border: none;
	border-top: 1px solid var(--ss-border);
	margin: 2.5em 0;
}
.ss-post-content figure { margin: 2em 0; }
.ss-post-content figcaption {
	text-align: center;
	font-size: 0.8rem;
	color: var(--ss-muted);
	margin-top: 8px;
}

/* ─── Post footer ────────────────────────────────────────── */
.ss-post-tags {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid var(--ss-border);
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
}
.ss-post-tags__label {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--ss-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-right: 4px;
}
.ss-tag {
	display: inline-block;
	background: var(--ss-lavender);
	color: var(--ss-indigo);
	font-size: 0.8125rem;
	font-weight: 500;
	padding: 5px 14px;
	border-radius: var(--ss-radius-pill);
	text-decoration: none;
	border: 1px solid transparent;
	transition: all 0.15s;
}
.ss-tag:hover {
	background: var(--ss-purple);
	color: var(--ss-white);
}

/* ─── Author bio ─────────────────────────────────────────── */
.ss-author-box {
	margin-top: 48px;
	padding: 32px;
	background: var(--ss-lavender);
	border-radius: var(--ss-radius-card);
	display: flex;
	gap: 24px;
	align-items: flex-start;
}
.ss-author-box__avatar {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	flex-shrink: 0;
	border: 3px solid var(--ss-white);
	box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}
.ss-author-box__name {
	font-weight: 700;
	color: var(--ss-dark);
	font-size: 1rem;
	margin: 0 0 4px;
}
.ss-author-box__role {
	font-size: 0.8125rem;
	color: var(--ss-purple);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	margin-bottom: 8px;
}
.ss-author-box__bio {
	font-size: 0.9375rem;
	color: var(--ss-muted);
	line-height: 1.6;
	margin: 0;
}

/* ─── Post nav ───────────────────────────────────────────── */
.ss-post-nav {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid var(--ss-border);
}
.ss-post-nav__item {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 20px;
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius-card);
	text-decoration: none;
	transition: all 0.15s;
	background: var(--ss-white);
}
.ss-post-nav__item:hover {
	border-color: var(--ss-purple);
	background: var(--ss-lavender);
}
.ss-post-nav__item--next { text-align: right; }
.ss-post-nav__dir {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--ss-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	display: flex;
	align-items: center;
	gap: 4px;
}
.ss-post-nav__item--next .ss-post-nav__dir { justify-content: flex-end; }
.ss-post-nav__title {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--ss-dark);
	line-height: 1.35;
}
.ss-post-nav__item:hover .ss-post-nav__title { color: var(--ss-purple); }

@media (max-width: 600px) {
	.ss-post-nav { grid-template-columns: 1fr; }
	.ss-post-nav__item--next { text-align: left; }
	.ss-post-nav__item--next .ss-post-nav__dir { justify-content: flex-start; }
}

/* ─── Back to blog link ──────────────────────────────────── */
.ss-back-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--ss-font);
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--ss-purple);
	text-decoration: none;
	margin: 32px 0 0 24px;
}
.ss-back-link:hover { color: var(--ss-indigo); }
.ss-back-link svg { transition: transform 0.2s; }
.ss-back-link:hover svg { transform: translateX(-3px); }
