/**
 * Blog Archive & Single Post Styles
 * Matches homepage design system with cards, shadows, and red accents
 */

/* ==========================================================================
   ARCHIVE PAGE (BLOG LISTING)
   ========================================================================== */

.ptasi-blog-archive {
	background-color: var(--ptasi-background);
}

/* Blog Hero Section with Background Image */
.ptasi-blog-hero {
	position: relative;
	min-height: clamp(160px, 20vh, 240px); /* Compact for no image */
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	overflow: hidden;
	margin-bottom: var(--space-hero);
	
	/* Default fallback background */
	background-color: var(--ptasi-text);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

/* Remove bottom margin when toggle is enabled */
.ptasi-blog-hero--no-bottom-margin {
	margin-bottom: 0;
}

/* Taller hero when background image is present */
.ptasi-blog-hero[style*="background-image"] {
	min-height: clamp(280px, 35vh, 420px);
}

/* Dark overlay for better text readability */
.ptasi-blog-hero__overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(17, 17, 23, 0.5);
	z-index: 1;
}

.ptasi-blog-hero .ptasi-container {
	position: relative;
	z-index: 2;
}

.ptasi-blog-hero__content {
	max-width: 800px;
	margin: 0 auto;
	padding: clamp(1.5rem, 4vw, 2.5rem) 0; /* Compact for no image */
}

/* More padding when background image is present */
.ptasi-blog-hero[style*="background-image"] .ptasi-blog-hero__content {
	padding: clamp(3rem, 8vw, 5rem) 0;
}

.ptasi-blog-hero__title {
	font-family: var(--ptasi-font-family);
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	font-weight: 900;
	color: var(--ptasi-surface);
	margin: 0 0 1.5rem 0;
	letter-spacing: -0.02em;
	line-height: 1.1;
	text-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

/* Remove bottom margin when title is the only child (no subtitle) */
.ptasi-blog-hero__title:last-child {
	margin-bottom: 0;
}

.ptasi-blog-hero__description {
	font-family: var(--ptasi-font-family);
	font-size: clamp(1.125rem, 2.5vw, 1.5rem);
	color: rgba(255, 255, 255, 0.95);
	margin: 0;
	line-height: 1.6;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
	font-weight: 400;
}

/* Hide empty paragraphs that might affect vertical centering */
.ptasi-blog-hero__content p:empty,
.ptasi-blog-hero__content p:empty::before,
.ptasi-blog-hero__content p:empty::after {
	display: none;
	margin: 0;
	padding: 0;
	height: 0;
}

/* Ensure all direct children have no unexpected margins */
.ptasi-blog-hero__content > *:first-child {
	margin-top: 0;
}

.ptasi-blog-hero__content > *:last-child {
	margin-bottom: 0;
}

@media (max-width: 768px) {
	.ptasi-blog-hero {
		min-height: clamp(140px, 18vh, 200px); /* Compact for no image on mobile */
	}

	.ptasi-blog-hero[style*="background-image"] {
		min-height: clamp(240px, 30vh, 360px); /* Taller with image on mobile */
	}

	.ptasi-blog-hero__content {
		padding: clamp(1.25rem, 3vw, 2rem) 0; /* Compact for no image on mobile */
	}

	.ptasi-blog-hero[style*="background-image"] .ptasi-blog-hero__content {
		padding: clamp(2rem, 5vw, 3rem) 0; /* More padding with image on mobile */
	}
}

/* Container - Blog-specific only to avoid conflicts with theme blocks */
.ptasi-blog-archive .ptasi-container,
.ptasi-single-post .ptasi-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 clamp(1rem, 3vw, 2rem);
}

.ptasi-blog-archive .ptasi-container--narrow,
.ptasi-single-post .ptasi-container--narrow {
	max-width: 800px;
}

/* Blog Grid */
.ptasi-blog-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: clamp(1.5rem, 3vw, 2.5rem);
	margin-bottom: clamp(2rem, 5vw, 4rem);
}

@media (max-width: 768px) {
	.ptasi-blog-grid {
		grid-template-columns: 1fr;
	}
}

/* Blog Card */
.ptasi-blog-card {
	background: var(--ptasi-surface);
	border-radius: 0;
	box-shadow: 0 4px 40px rgba(0, 0, 0, 0.1);
	overflow: hidden;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	display: flex;
	flex-direction: column;
	height: 100%;
    padding: 0; /* ensure no inner padding so image touches edges */
}

.ptasi-blog-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 50px rgba(0, 0, 0, 0.15);
}

.ptasi-blog-card__image {
	display: block;
	overflow: hidden;
	aspect-ratio: 16 / 9;
	position: relative;
    padding: 0;
    margin: 0;
}

.ptasi-blog-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
    display: block; /* remove inline-gap so it flushes to edges */
}

.ptasi-blog-card:hover .ptasi-blog-card__image img {
	transform: scale(1.05);
}

.ptasi-blog-card__content {
	padding: clamp(1.25rem, 3vw, 2rem);
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

.ptasi-blog-card__category {
    display: inline-block;
    background-color: var(--ptasi-primary);
    color: var(--ptasi-surface);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    padding: 0.375rem 0.75rem;
    margin-bottom: 1rem;
    letter-spacing: 0.05em;
    align-self: flex-start;
}

/* Category badge when placed inside the image */
.ptasi-blog-card__image .ptasi-blog-card__category {
    position: absolute;
    right: 12px;
    top: 12px;
    margin: 0;
    align-self: auto;
    padding: 6px 12px;
    letter-spacing: 0.08em;
    border-radius: 0; /* no rounded corners */
    /* Semi-transparent red using theme token; fallback to solid */
    background-color: color-mix(in srgb, var(--ptasi-primary) 88%, transparent);
    color: var(--ptasi-surface);
}

@supports not (background-color: color-mix(in srgb, white 50%, black)) {
    .ptasi-blog-card__image .ptasi-blog-card__category {
        background-color: rgba(236, 37, 38, 0.88); /* fallback close to var(--ptasi-primary) */
    }
}

@media (max-width: 768px) {
    .ptasi-blog-card__image .ptasi-blog-card__category {
        font-size: 0.6875rem;
        padding: 6px 10px;
        right: 10px;
        top: 10px;
    }
}

.ptasi-blog-card__title {
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
	font-weight: 700;
	color: var(--ptasi-text);
	margin: 0 0 0.75rem 0;
	line-height: 1.3;
	letter-spacing: -0.02em;
}

.ptasi-blog-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color 0.3s ease;
}

.ptasi-blog-card__title a:hover {
	color: var(--ptasi-primary);
}

.ptasi-blog-card__meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--ptasi-muted);
	margin-bottom: 1rem;
}

.ptasi-blog-card__meta-separator {
	opacity: 0.5;
}

.ptasi-blog-card__excerpt {
	font-size: 1rem;
	line-height: 1.6;
	color: var(--ptasi-muted);
	margin-bottom: 1.5rem;
	flex-grow: 1;
}

.ptasi-blog-card__link {
	display: inline-flex;
	align-items: center;
	color: var(--ptasi-primary);
	font-weight: 700;
	text-decoration: none;
	font-size: 0.9375rem;
	transition: gap 0.3s ease;
	gap: 0.25rem;
	margin-top: auto;
}

.ptasi-blog-card__link:hover {
	gap: 0.5rem;
}

/* Pagination */
.ptasi-blog-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.5rem;
	padding: clamp(2rem, 4vw, 3rem) 0;
}

.ptasi-blog-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 1rem;
	background: var(--ptasi-surface);
	color: var(--ptasi-text);
	text-decoration: none;
	font-weight: 600;
	transition: all 0.3s ease;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.ptasi-blog-pagination .page-numbers:hover {
	background: var(--ptasi-primary);
	color: var(--ptasi-surface);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.ptasi-blog-pagination .page-numbers.current {
	background: var(--ptasi-primary);
	color: var(--ptasi-surface);
	box-shadow: 0 4px 12px rgba(236, 37, 38, 0.3);
}

.ptasi-blog-pagination .page-numbers.dots {
	background: transparent;
	box-shadow: none;
}

/* Empty State */
.ptasi-blog-empty {
	text-align: center;
	padding: 4rem 2rem;
	color: var(--ptasi-muted);
}

/* ==========================================================================
   SINGLE POST PAGE
   ========================================================================== */

.ptasi-single-post {
	background-color: var(--ptasi-background);
}

/* Post Header */
.ptasi-single-post__header {
	background-color: var(--ptasi-surface);
	padding-bottom: clamp(2rem, 5vw, 4rem);
	margin-bottom: clamp(2rem, 5vw, 4rem);
}

.ptasi-single-post__hero {
	width: 100%;
	max-height: 500px;
	overflow: hidden;
	margin-bottom: clamp(2rem, 5vw, 3rem);
}

.ptasi-single-post__hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ptasi-single-post__category {
	display: inline-block;
	background-color: var(--ptasi-primary);
	color: var(--ptasi-surface);
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	padding: 0.5rem 1rem;
	margin-bottom: 1.5rem;
	letter-spacing: 0.05em;
}

.ptasi-single-post__title {
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 800;
	color: var(--ptasi-text);
	line-height: 1.2;
	letter-spacing: -0.02em;
	margin: 0 0 1rem 0;
}

.ptasi-single-post__meta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 1rem;
	color: var(--ptasi-muted);
}

.ptasi-single-post__meta-separator {
	opacity: 0.5;
}

/* Post Content */
.ptasi-single-post__content {
	font-size: 1.125rem;
	line-height: 1.8;
	color: var(--ptasi-text);
	margin-bottom: 3rem;
}

.ptasi-single-post__content h2:where(:not(.ptasi-phone-cta__heading, .ptasi-generic-cta__heading)),
.ptasi-single-post__content h3:where(:not(.ptasi-phone-cta__heading, .ptasi-generic-cta__heading)),
.ptasi-single-post__content h4:where(:not(.ptasi-phone-cta__heading, .ptasi-generic-cta__heading)) {
	font-weight: 700;
	color: var(--ptasi-text);
	margin-top: 2em;
	margin-bottom: 0.75em;
	letter-spacing: -0.02em;
}

.ptasi-single-post__content h2:where(:not(.ptasi-phone-cta__heading, .ptasi-generic-cta__heading)) {
	font-size: clamp(1.5rem, 4vw, 2rem);
}

.ptasi-single-post__content h3:where(:not(.ptasi-phone-cta__heading, .ptasi-generic-cta__heading)) {
	font-size: clamp(1.25rem, 3vw, 1.5rem);
}

.ptasi-single-post__content p:where(:not(.ptasi-phone-cta__subtext, .ptasi-generic-cta__description)) {
	margin-bottom: 1.5em;
}

.ptasi-single-post__content a:where(:not(.site-btn, .wp-block-button__link, .wp-element-button, .ptasi-btn-bestia, .ptasi-btn-stroke, .ptasi-phone-cta__phone, .ptasi-generic-cta__phone)) {
	color: var(--ptasi-primary);
	text-decoration: underline;
	transition: opacity 0.3s ease;
}

.ptasi-single-post__content a:where(:not(.site-btn, .wp-block-button__link, .wp-element-button, .ptasi-btn-bestia, .ptasi-btn-stroke, .ptasi-phone-cta__phone, .ptasi-generic-cta__phone)):hover {
	opacity: 0.8;
}

.ptasi-single-post__content img {
	max-width: 100%;
	height: auto;
	border-radius: 0;
	margin: 2rem 0;
}

.ptasi-single-post__content ul,
.ptasi-single-post__content ol {
	margin-bottom: 1.5em;
	padding-left: 1.5em;
}

.ptasi-single-post__content li {
	margin-bottom: 0.5em;
}

.ptasi-single-post__content blockquote {
	border-left: 4px solid var(--ptasi-primary);
	padding: 1.5rem;
	margin: 2rem 0;
	background-color: rgba(236, 37, 38, 0.05);
	font-style: italic;
	color: var(--ptasi-text);
}

/* Tags */
.ptasi-single-post__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	padding: 2rem 0;
	border-top: 1px solid rgba(0, 0, 0, 0.1);
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
	margin-bottom: 3rem;
}

.ptasi-single-post__tags a {
	display: inline-block;
	padding: 0.5rem 1rem;
	background-color: var(--ptasi-background);
	color: var(--ptasi-text);
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 600;
	transition: all 0.3s ease;
}

.ptasi-single-post__tags a:hover {
	background-color: var(--ptasi-primary);
	color: var(--ptasi-surface);
}

/* Post Navigation */
.ptasi-single-post__navigation {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	margin-bottom: 4rem;
}

@media (max-width: 768px) {
	.ptasi-single-post__navigation {
		grid-template-columns: 1fr;
	}
}

.ptasi-single-post__nav-prev,
.ptasi-single-post__nav-next {
	background: var(--ptasi-surface);
	padding: 1.5rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
}

.ptasi-single-post__nav-prev:hover,
.ptasi-single-post__nav-next:hover {
	box-shadow: 0 6px 30px rgba(0, 0, 0, 0.15);
	transform: translateY(-2px);
}

.ptasi-single-post__nav-next {
	text-align: right;
}

.ptasi-single-post__navigation a {
	display: block;
	text-decoration: none;
	color: var(--ptasi-text);
}

.ptasi-single-post__nav-label {
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--ptasi-primary);
	margin-bottom: 0.5rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.ptasi-single-post__nav-title {
	display: block;
	font-size: 1.125rem;
	font-weight: 600;
	line-height: 1.4;
	transition: color 0.3s ease;
}

.ptasi-single-post__navigation a:hover .ptasi-single-post__nav-title {
	color: var(--ptasi-primary);
}

/* Comments */
.ptasi-single-post .comments-area {
	margin-top: 4rem;
	padding-top: 3rem;
	border-top: 2px solid rgba(0, 0, 0, 0.1);
}

/* ==========================================================================
   FOOTER FIX - Ensure footer displays centered like homepage
   ========================================================================== */

.ptasi-blog-archive + footer,
.ptasi-single-post + footer {
	text-align: center;
}

.ptasi-blog-archive + footer .wp-block-group,
.ptasi-single-post + footer .wp-block-group {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
}

.ptasi-blog-archive + footer .wp-block-site-logo,
.ptasi-single-post + footer .wp-block-site-logo {
	margin: 0 auto;
}

.ptasi-blog-archive + footer .wp-block-navigation,
.ptasi-single-post + footer .wp-block-navigation {
	justify-content: center !important;
	margin: 0 auto;
}

.ptasi-blog-archive + footer .wp-block-navigation__container,
.ptasi-single-post + footer .wp-block-navigation__container {
	justify-content: center !important;
}

/* ==========================================================================
   PAGE TEMPLATE STYLES
   ========================================================================== */

/* Page content area with hero header */
.ptasi-page-content {
	margin-bottom: clamp(3rem, 6vw, 5rem);
}

/* Default constrained layout for page content blocks */
.ptasi-page-content > * {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(1rem, 3vw, 2rem);
	padding-right: clamp(1rem, 3vw, 2rem);
}

/* First block after hero - no extra margin (hero padding-bottom provides spacing) */
.ptasi-page-content > *:first-child {
	margin-top: 0;
}

/* Remove top margin from entry-content wrapper when it's the first child */
.ptasi-page-content .entry-content:first-child,
.ptasi-page-content > .entry-content {
	margin-top: 0 !important;
	margin-block-start: 0 !important;
}

/* Remove top margin from wp-block-post-content when it's first child or contains alignfull */
.ptasi-page-content.wp-block-post-content:first-child,
.ptasi-page-content.wp-block-post-content > .entry-content:first-child,
.ptasi-page-content.wp-block-post-content.is-layout-flow:first-child,
.ptasi-page-content.wp-block-post-content.is-layout-flow .entry-content:first-child {
	margin-top: 0 !important;
	margin-block-start: 0 !important;
}

/* Remove top margin from entry-content when it contains alignfull blocks */
.ptasi-page-content .entry-content > .alignfull:first-child,
.ptasi-page-content.wp-block-post-content.is-layout-flow .entry-content > .alignfull:first-child {
	margin-top: 0 !important;
	margin-block-start: 0 !important;
}

/* Specific fix for entry-content.alignfull.ptasi-page-content.wp-block-post-content.is-layout-flow */
.entry-content.alignfull.ptasi-page-content.wp-block-post-content.is-layout-flow,
.ptasi-page-content.wp-block-post-content.is-layout-flow.entry-content {
	margin-top: 0 !important;
	margin-block-start: 0 !important;
}

/* Section blocks as first child - their padding-top provides the spacing */
.ptasi-page-content > [class*="-section"]:first-child {
	margin-top: 0;
	padding-top: 0;
}

/* Ensure blocks have consistent vertical spacing */
.ptasi-page-content > * + * {
	margin-top: var(--space-between-blocks);
}

/* But don't add margin if the previous sibling is entry-content with alignfull */
.ptasi-page-content .entry-content + * {
	margin-top: 0;
}

/* Add top padding for custom block sections (pricing, services, team, etc.) */
.ptasi-page-content > .ptasi-pricing-section,
.ptasi-page-content > .ptasi-services-section,
.ptasi-page-content > .ptasi-team-section,
.ptasi-page-content > .ptasi-features-section,
.ptasi-page-content > .ptasi-testimonials-section,
.ptasi-page-content > .ptasi-program-section,
.ptasi-page-content > .ptasi-about-section,
.ptasi-page-content > .ptasi-process-section {
	padding-top: var(--space-section);
	padding-bottom: var(--space-section);
}

/* Remove top padding from first section block - hero provides spacing */
.ptasi-page-content > .ptasi-pricing-section:first-child,
.ptasi-page-content > .ptasi-services-section:first-child,
.ptasi-page-content > .ptasi-team-section:first-child,
.ptasi-page-content > .ptasi-features-section:first-child,
.ptasi-page-content > .ptasi-testimonials-section:first-child,
.ptasi-page-content > .ptasi-program-section:first-child,
.ptasi-page-content > .ptasi-about-section:first-child,
.ptasi-page-content > .ptasi-process-section:first-child {
	padding-top: 0;
	margin-top: 0;
}

/* Override WordPress core alignfull padding reset for our custom sections */
.ptasi-page-content.wp-block-post-content > .alignfull.ptasi-pricing-section,
.ptasi-page-content.wp-block-post-content > .alignfull[class*="-section"] {
	padding-top: var(--space-section);
	padding-bottom: var(--space-section);
}

/* Remove top padding from first alignfull section block */
.ptasi-page-content.wp-block-post-content > .alignfull.ptasi-pricing-section:first-child,
.ptasi-page-content.wp-block-post-content > .alignfull[class*="-section"]:first-child {
	padding-top: 0;
	margin-top: 0;
}

/* Ensure section headings inside blocks have proper top spacing */
.ptasi-page-content .ptasi-section-heading {
	margin-top: 0;
	padding-top: 0;
}

/* Full-width alignment support - breaks out of container */
.ptasi-page-content > .alignfull {
	max-width: none;
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding-left: 0;
	padding-right: 0;
}

/* When custom blocks are set to full-width, expand their internal containers */
.ptasi-page-content > .alignfull .ptasi-container {
	max-width: none;
	width: 100%;
	padding-left: clamp(2rem, 5vw, 4rem);
	padding-right: clamp(2rem, 5vw, 4rem);
}

/* Wide alignment - wider than default but not full viewport */
.ptasi-page-content > .alignwide {
	max-width: min(1600px, 90vw);
}

/* Override alignwide constraint when block has ptasi-layout--full */
.ptasi-page-content > .alignwide.ptasi-layout--full,
.ptasi-page-content > .alignwide.ptasi-testimonials.ptasi-layout--full,
.ptasi-page-content > .alignwide.wp-block-ptasiserwis-testimonials.ptasi-layout--full,
.wp-block-post-content > .alignwide.ptasi-layout--full,
.wp-block-post-content > .alignwide.ptasi-testimonials.ptasi-layout--full,
.wp-block-post-content > .alignwide.wp-block-ptasiserwis-testimonials.ptasi-layout--full {
	max-width: none !important;
	width: 100vw !important;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* Ensure custom blocks inherit full-width properly */
.ptasi-page-content > .alignfull .wp-block-group__inner-container,
.ptasi-page-content > .alignfull > div {
	/* Reset any internal constraints */
}

/* Maintain spacing for full-width blocks */
.ptasi-page-content > .alignfull {
	margin-top: clamp(2rem, 4vw, 3rem);
	margin-bottom: clamp(2rem, 4vw, 3rem);
}

/* Apply blog hero styles to all pages using page.php template */
.page-template-default .ptasi-blog-hero {
	/* Hero styles already defined above */
}

@media (max-width: 768px) {
	.ptasi-page-content > * {
		padding-left: clamp(1rem, 3vw, 1.5rem);
		padding-right: clamp(1rem, 3vw, 1.5rem);
	}

	.ptasi-page-content > .alignfull {
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
	}

	/* Ensure alignwide with ptasi-layout--full breaks out on mobile */
	.ptasi-page-content > .alignwide.ptasi-layout--full {
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
		padding-left: 0;
		padding-right: 0;
	}
}
