/**
 * Reusable Component Styles — indranil-theme
 *
 * Styled patterns used across multiple templates: buttons, cards, tags, form
 * elements, site header, and site footer. Depends on variables.css for design
 * tokens and base.css for element resets. Enqueue after layouts.css in the
 * stylesheet loading order (see inc/enqueue.php).
 *
 * Sections:
 *   1. Buttons
 *   2. Cards
 *   3. Tags
 *   4. Form Elements
 *   5. Site Header
 *   6. Site Footer
 *   7. Section Headers
 *   8. Hero
 *   9. Pathway Cards
 *  10. Post Cards
 *  11. Credentials Bar
 *  12. Homepage CTA
 *  13. Empty State
 *  14. About Page
 *  15. Blog Templates
 *  16. Contact Page
 *  17. Portfolio Page
 *  18. 404 Error Page
 */


/* ----------------------------------------
 * 1. Buttons
 * ---------------------------------------- */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: 14px 28px;
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: var(--weight-semibold);
	line-height: 1;
	text-decoration: none;
	border: 2px solid transparent;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: all var(--transition-smooth);
	background: var(--color-yellow);
	color: var(--color-black);
}

.btn:hover {
	background: var(--color-yellow-hover);
	color: var(--color-black);
	transform: translateY(-1px);
	box-shadow: var(--shadow-sm);
}

.btn:focus-visible {
	outline: 2px solid var(--color-black);
	outline-offset: 2px;
}

/* Secondary: outlined style */
.btn--secondary {
	background: transparent;
	border-color: var(--color-black);
	color: var(--color-black);
}

.btn--secondary:hover {
	background: var(--color-black);
	color: var(--color-white);
}

/* Ghost: minimal text-link style */
.btn--ghost {
	background: transparent;
	color: var(--color-black);
	padding: var(--space-sm) 0;
	border-radius: 0;
	border: none;
	border-bottom: 1px solid currentColor;
}

.btn--ghost:hover {
	color: var(--color-yellow-dark);
	background: transparent;
}

/* Size variants */
.btn--sm {
	padding: 8px 16px;
	font-size: var(--text-sm);
}

.btn--lg {
	padding: 18px 36px;
	font-size: var(--text-lg);
}


/* ----------------------------------------
 * 2. Cards
 * ---------------------------------------- */

.card {
	background: var(--color-white);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--radius-xl);
	padding: var(--space-xl);
	transition: box-shadow var(--transition-smooth), transform var(--transition-smooth);
}

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

/* Alternate card with subtle background */
.card--alt {
	background: var(--color-gray-100);
	border-color: transparent;
}

.card__title {
	font-family: var(--font-heading);
	font-size: var(--text-2xl);
	font-weight: var(--weight-semibold);
	margin-bottom: var(--space-sm);
}

.card__text {
	color: var(--color-gray-600);
	margin-bottom: var(--space-md);
}

.card__meta {
	font-size: var(--text-sm);
	color: var(--color-gray-500);
}


/* ----------------------------------------
 * 3. Tags
 * ---------------------------------------- */

.tag {
	display: inline-block;
	padding: 4px 10px;
	font-size: var(--text-xs);
	font-weight: var(--weight-medium);
	text-transform: uppercase;
	letter-spacing: 0.02em;
	border-radius: var(--radius-sm);
	background: var(--color-gray-100);
	color: var(--color-gray-600);
}

/* Yellow accent tag */
.tag--yellow {
	background: var(--color-yellow-light);
	color: var(--color-yellow-deep);
}


/* ----------------------------------------
 * 4. Form Elements
 * ---------------------------------------- */

input[type="text"],
input[type="email"],
input[type="url"],
input[type="search"],
textarea {
	width: 100%;
	padding: 14px var(--space-md);
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-black);
	background: var(--color-white);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--radius-lg);
	transition: border-color var(--transition-fast);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
textarea:focus {
	border-color: var(--color-yellow);
	outline: none;
	box-shadow: 0 0 0 4px var(--color-yellow-light);
}

::placeholder {
	color: var(--color-gray-300);
}


/* ----------------------------------------
 * 5. Site Header
 * ---------------------------------------- */

.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background-color: var(--color-white);
	border-bottom: 1px solid var(--color-gray-200);
	transition: box-shadow var(--transition-base);
}

.site-header--scrolled {
	box-shadow: var(--shadow-md);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: var(--max-width);
	margin-left: auto;
	margin-right: auto;
	padding: var(--space-md);
	height: 72px;
}

/* ---- Brand / Logo ---- */

.site-header__brand {
	display: flex;
	flex-direction: column;
	text-decoration: none;
	line-height: 1;
	flex-shrink: 0;
}

.site-header__brand:hover {
	text-decoration: none;
}

.site-header__name {
	font-family: var(--font-heading);
	font-size: var(--text-xl);
	font-weight: var(--weight-bold);
	color: var(--color-black);
	letter-spacing: -0.01em;
}

.site-header__dot {
	color: var(--color-yellow);
}

.site-header__handle {
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--weight-regular);
	color: var(--color-gray-400);
	margin-top: 2px;
}

/* ---- Desktop Navigation ---- */

.site-header__nav {
	display: none;
}

.site-header__nav-list {
	display: flex;
	align-items: center;
	gap: var(--space-xl);
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-header__nav-list > li {
	margin: 0;
}

.site-header__nav-list > li > a {
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: var(--weight-medium);
	color: var(--color-black);
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: var(--space-xs) 0;
	position: relative;
	transition: color var(--transition-fast);
}

.site-header__nav-list > li > a::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 0;
	height: 2px;
	background-color: var(--color-yellow);
	transition: width var(--transition-smooth);
}

.site-header__nav-list > li > a:hover::after,
.site-header__nav-list > li > a:focus::after {
	width: 100%;
}

.site-header__nav-list > li > a:hover {
	color: var(--color-black);
}

/* Active/current page link */
.site-header__nav-list > li.current-menu-item > a,
.site-header__nav-list > li.current_page_item > a {
	font-weight: var(--weight-semibold);
}

.site-header__nav-list > li.current-menu-item > a::after,
.site-header__nav-list > li.current_page_item > a::after {
	width: 100%;
}

/* ---- Mobile Menu Toggle ---- */

.site-header__toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	background: none;
	border: none;
	cursor: pointer;
	position: relative;
	z-index: 110;
}

.site-header__toggle-bar {
	display: block;
	width: 24px;
	height: 2px;
	background-color: var(--color-black);
	position: relative;
	transition: background-color var(--transition-fast);
}

.site-header__toggle-bar::before,
.site-header__toggle-bar::after {
	content: '';
	position: absolute;
	left: 0;
	width: 24px;
	height: 2px;
	background-color: var(--color-black);
	transition: transform var(--transition-base);
}

.site-header__toggle-bar::before {
	top: -7px;
}

.site-header__toggle-bar::after {
	top: 7px;
}

/* Toggle open state (X shape) */
.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar {
	background-color: transparent;
}

.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar::before {
	top: 0;
	transform: rotate(45deg);
}

.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar::after {
	top: 0;
	transform: rotate(-45deg);
}

/* ---- Mobile Slide-In Panel ---- */

.site-header__mobile-menu {
	position: fixed;
	top: 72px;
	right: -100%;
	width: 280px;
	height: calc(100vh - 72px);
	background-color: var(--color-white);
	border-left: 1px solid var(--color-gray-200);
	box-shadow: var(--shadow-lg);
	padding: var(--space-lg);
	transition: right var(--transition-slow);
	z-index: 99;
	overflow-y: auto;
}

.site-header__mobile-menu.is-open {
	right: 0;
}

.site-header__mobile-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-header__mobile-nav-list > li {
	margin: 0;
	border-bottom: 1px solid var(--color-gray-100);
}

.site-header__mobile-nav-list > li > a {
	display: block;
	padding: var(--space-md) 0;
	font-family: var(--font-body);
	font-size: var(--text-lg);
	font-weight: var(--weight-medium);
	color: var(--color-black);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.site-header__mobile-nav-list > li > a:hover {
	color: var(--color-yellow-dark);
}

.site-header__mobile-nav-list > li.current-menu-item > a,
.site-header__mobile-nav-list > li.current_page_item > a {
	color: var(--color-black);
	font-weight: var(--weight-semibold);
	border-left: 3px solid var(--color-yellow);
	padding-left: var(--space-md);
}

/* Mobile menu overlay/backdrop */
.site-header__overlay {
	display: none;
	position: fixed;
	top: 72px;
	left: 0;
	width: 100%;
	height: calc(100vh - 72px);
	background-color: rgba(26, 26, 26, 0.4);
	z-index: 98;
}

.site-header__overlay.is-open {
	display: block;
}


/* ----------------------------------------
 * 6. Site Footer
 * ---------------------------------------- */

.site-footer {
	background-color: var(--color-gray-900);
	color: var(--color-white);
	padding-top: var(--space-3xl);
	padding-bottom: var(--space-lg);
}

.site-footer__inner {
	max-width: var(--max-width);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--space-md);
	padding-right: var(--space-md);
}

.site-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-2xl);
	margin-bottom: var(--space-3xl);
}

/* Bio section */
.site-footer__bio {
	max-width: 360px;
}

.site-footer__bio-name {
	font-family: var(--font-heading);
	font-size: var(--text-2xl);
	font-weight: var(--weight-bold);
	color: var(--color-white);
	margin-bottom: var(--space-sm);
}

.site-footer__bio-text {
	font-size: var(--text-sm);
	color: var(--color-gray-300);
	line-height: var(--leading-relaxed);
	margin-bottom: 0;
}

/* Navigation section */
.site-footer__nav-heading,
.site-footer__social-heading,
.site-footer__newsletter-heading {
	font-family: var(--font-heading);
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	color: var(--color-white);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: var(--space-md);
}

.site-footer__nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-footer__nav-list > li {
	margin-bottom: var(--space-sm);
}

.site-footer__nav-list > li > a {
	font-size: var(--text-sm);
	color: var(--color-gray-300);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.site-footer__nav-list > li > a:hover {
	color: var(--color-yellow);
}

/* Social links section */
.site-footer__social-list {
	display: flex;
	gap: var(--space-md);
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-footer__social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--radius-md);
	background-color: rgba(255, 255, 255, 0.08);
	color: var(--color-gray-300);
	text-decoration: none;
	transition: all var(--transition-smooth);
}

.site-footer__social-link:hover {
	background-color: var(--color-yellow);
	color: var(--color-black);
	transform: translateY(-2px);
}

.site-footer__social-link svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

/* Newsletter section */
.site-footer__newsletter-text {
	font-size: var(--text-sm);
	color: var(--color-gray-300);
	margin-bottom: var(--space-md);
}

.site-footer__newsletter-form {
	display: flex;
	gap: var(--space-sm);
}

.site-footer__newsletter-input {
	flex: 1;
	padding: 10px var(--space-md);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	color: var(--color-white);
	background-color: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: var(--radius-md);
	transition: border-color var(--transition-fast);
}

.site-footer__newsletter-input::placeholder {
	color: var(--color-gray-400);
}

.site-footer__newsletter-input:focus {
	border-color: var(--color-yellow);
	outline: none;
	box-shadow: 0 0 0 3px rgba(255, 224, 1, 0.2);
}

.site-footer__newsletter-submit {
	padding: 10px var(--space-lg);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	color: var(--color-black);
	background-color: var(--color-yellow);
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-base);
	white-space: nowrap;
}

.site-footer__newsletter-submit:hover {
	background-color: var(--color-yellow-hover);
}

/* Bottom bar (copyright) */
.site-footer__bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	padding-top: var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	align-items: center;
	text-align: center;
}

.site-footer__copyright {
	font-size: var(--text-xs);
	color: var(--color-gray-400);
	margin: 0;
}

.site-footer__tagline {
	font-size: var(--text-xs);
	color: var(--color-gray-400);
	font-style: italic;
	margin: 0;
}


/* ----------------------------------------
 * 7. Section Headers
 * ---------------------------------------- */

.section-header {
	text-align: center;
	max-width: 640px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: var(--space-3xl);
}

.section-header__label {
	display: inline-block;
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-yellow-dark);
	margin-bottom: var(--space-md);
}

/* Left-aligned variant — breaks visual monotony between sections */
.section-header--left {
	text-align: left;
	margin-left: 0;
	margin-right: 0;
	max-width: var(--max-text-width);
}

.section-header__title {
	margin-bottom: var(--space-md);
}

.section-header__description {
	color: var(--color-gray-600);
	font-size: var(--text-xl);
	margin-bottom: 0;
}

.section-footer {
	text-align: center;
	margin-top: var(--space-xl);
}


/* ----------------------------------------
 * 8. Hero
 * ---------------------------------------- */

.hero {
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-4xl);
	background-color: var(--color-white);
}

.hero__grid {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xl);
}

.hero__content {
	flex: 1;
}

.hero__media {
	flex: 0 0 auto;
	max-width: 280px;
	margin-left: auto;
	margin-right: auto;
}

.hero__tagline {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-gray-500);
	margin-bottom: var(--space-lg);
}

.hero__headline {
	font-family: var(--font-heading);
	font-size: var(--text-5xl);
	font-weight: var(--weight-bold);
	line-height: var(--leading-tighter);
	letter-spacing: -0.03em;
	color: var(--color-black);
	margin-bottom: var(--space-xl);
}

.hero__dot {
	color: var(--color-yellow);
}

.hero__description {
	font-size: var(--text-xl);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	max-width: 600px;
	margin-bottom: var(--space-xl);
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
}

.hero__image {
	width: 100%;
	border-radius: var(--radius-lg);
	object-fit: cover;
}

.hero__image-placeholder {
	aspect-ratio: 4 / 5;
	width: 100%;
	background-color: var(--color-gray-100);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px dashed var(--color-gray-200);
}

.hero__image-initials {
	font-family: var(--font-heading);
	font-size: var(--text-5xl);
	font-weight: var(--weight-bold);
	color: var(--color-yellow);
	user-select: none;
}


/* ----------------------------------------
 * 9. Pathway Cards
 * ---------------------------------------- */

.pathway-card {
	text-align: left;
	transition: transform var(--transition-smooth), box-shadow var(--transition-smooth);
}

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

/* Editorial numbering — subtle, large, branded accent instead of emoji */
.pathway-card__number {
	display: block;
	font-family: var(--font-heading);
	font-size: var(--text-5xl);
	font-weight: var(--weight-bold);
	color: var(--color-yellow);
	line-height: 1;
	margin-bottom: var(--space-md);
	opacity: 0.5;
}

.pathway-card__link {
	display: inline-block;
	margin-top: auto;
}


/* ----------------------------------------
 * 10. Post Cards
 * ---------------------------------------- */

.post-card {
	display: flex;
	flex-direction: column;
}

.post-card__thumbnail {
	margin: calc(-1 * var(--space-xl)) calc(-1 * var(--space-xl)) var(--space-md);
	overflow: hidden;
	border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}

.post-card__image {
	display: block;
	width: 100%;
	height: 240px;
	object-fit: cover;
	transition: transform var(--transition-smooth);
}

.post-card:hover .post-card__image {
	transform: scale(1.05);
}

.post-card__category {
	margin-bottom: var(--space-sm);
}

.post-card__title a {
	color: var(--color-black);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.post-card__title a:hover {
	color: var(--color-yellow-dark);
}

.post-card__title a::after {
	content: ' \2192';
	opacity: 0;
	transition: opacity var(--transition-fast);
	font-size: 0.85em;
}

.post-card:hover .post-card__title a::after {
	opacity: 1;
}

.post-card__excerpt {
	flex: 1;
}

.post-card__meta {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	margin-top: auto;
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-gray-200);
	font-size: var(--text-sm);
	color: var(--color-gray-500);
}

.post-card__separator {
	color: var(--color-gray-300);
}


/* ----------------------------------------
 * 11. Credentials Bar
 * ---------------------------------------- */

.credentials__list {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
	text-align: center;
}

.credentials__item {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.credentials__number {
	font-family: var(--font-heading);
	font-size: var(--text-5xl);
	font-weight: var(--weight-bold);
	color: var(--color-yellow-dark);
	line-height: 1;
}

.credentials__label {
	font-size: var(--text-base);
	color: var(--color-gray-500);
	font-weight: var(--weight-medium);
}


/* ----------------------------------------
 * 12. Homepage CTA
 * ---------------------------------------- */

.homepage-cta {
	background-color: var(--color-yellow);
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-4xl);
}

.homepage-cta__inner {
	text-align: center;
	max-width: 560px;
	margin-left: auto;
	margin-right: auto;
}

.homepage-cta__title {
	color: var(--color-black);
	margin-bottom: var(--space-sm);
}

.homepage-cta__text {
	color: var(--color-black);
	font-size: var(--text-lg);
	margin-bottom: var(--space-xl);
}

.homepage-cta__form {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.homepage-cta__input {
	width: 100%;
	padding: 12px var(--space-md);
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-black);
	background-color: var(--color-white);
	border: 2px solid var(--color-black);
	border-radius: var(--radius-md);
	transition: border-color var(--transition-fast);
}

.homepage-cta__input::placeholder {
	color: var(--color-gray-400);
}

.homepage-cta__input:focus {
	border-color: var(--color-black);
	outline: none;
	box-shadow: 0 0 0 3px rgba(50, 50, 50, 0.2);
}

.homepage-cta__submit {
	background-color: var(--color-black);
	color: var(--color-white);
	border: 2px solid var(--color-black);
}

.homepage-cta__submit:hover {
	background-color: var(--color-white);
	color: var(--color-black);
	border-color: var(--color-white);
}


/* ----------------------------------------
 * 13. Empty State
 * ---------------------------------------- */

.empty-state {
	text-align: center;
	padding: var(--space-2xl) var(--space-md);
}

.empty-state__text {
	font-size: var(--text-lg);
	color: var(--color-gray-500);
	margin-bottom: var(--space-lg);
}


/* ----------------------------------------
 * 14. About Page
 * ---------------------------------------- */

/* ---- Editorial Intro ---- */

.about-intro {
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-2xl);
}

.about-intro__label {
	display: inline-block;
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-yellow-dark);
	margin-bottom: var(--space-lg);
}

.about-intro__headline {
	font-family: var(--font-heading);
	font-size: var(--text-5xl);
	font-weight: var(--weight-bold);
	line-height: var(--leading-snug);
	letter-spacing: -0.01em;
	color: var(--color-black);
	margin-bottom: var(--space-lg);
}

.about-intro__subtitle {
	font-size: var(--text-2xl);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	margin-bottom: 0;
}

/* ---- Narrative Prose ---- */

.about-narrative {
	font-size: var(--text-lg);
	line-height: var(--leading-loose);
	color: var(--color-gray-600);
}

.about-narrative p {
	margin-bottom: var(--space-xl);
}

.about-narrative p:last-child {
	margin-bottom: 0;
}

/* ---- Inline Photo Figure ---- */

.about-photo {
	margin: var(--space-3xl) 0;
}

.about-photo__placeholder {
	aspect-ratio: 3 / 2;
	width: 100%;
	background-color: var(--color-gray-100);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px dashed var(--color-gray-200);
}

.about-photo__initials {
	font-family: var(--font-heading);
	font-size: var(--text-5xl);
	font-weight: var(--weight-bold);
	color: var(--color-yellow);
	user-select: none;
}

.about-photo__caption {
	font-size: var(--text-sm);
	color: var(--color-gray-400);
	font-style: italic;
	margin-top: var(--space-sm);
}

/* ---- Pull Quote (editorial variant) ---- */

.about-pullquote {
	background-color: transparent;
	margin: var(--space-3xl) 0;
	padding: var(--space-xl) var(--space-2xl);
}

.about-pullquote p {
	font-family: var(--font-heading);
	font-size: var(--text-2xl);
	font-weight: var(--weight-semibold);
	line-height: var(--leading-normal);
	color: var(--color-black);
	margin-bottom: 0;
}

/* ---- Product Cards ---- */

.about-product .tag {
	margin-bottom: var(--space-md);
}

.about-product--more {
	border-style: dashed;
	background-color: transparent;
}

.about-product--more:hover {
	box-shadow: none;
}

/* ---- Expertise Domains ---- */

.about-domains {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
	margin-bottom: var(--space-2xl);
}

.about-domains__label {
	font-family: var(--font-heading);
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-gray-500);
	margin-bottom: var(--space-md);
}

.about-domains__tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

/* ---- Expertise Heading (standalone, no section-header wrapper) ---- */

.about-expertise__heading {
	margin-bottom: var(--space-2xl);
}

/* ---- Personal Section ---- */

.about-personal__heading {
	margin-bottom: var(--space-xl);
}

/* ---- Connect CTA (dark background) ---- */

.about-connect {
	background-color: var(--color-gray-900);
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-4xl);
}

.about-connect__inner {
	text-align: center;
	max-width: 560px;
	margin-left: auto;
	margin-right: auto;
}

.about-connect__title {
	color: var(--color-white);
	margin-bottom: var(--space-md);
}

.about-connect__text {
	color: var(--color-gray-300);
	font-size: var(--text-lg);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-xl);
}

.about-connect__actions {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	align-items: center;
}

.about-connect__contact-btn {
	border-color: var(--color-white);
	color: var(--color-white);
}

.about-connect__contact-btn:hover {
	background-color: var(--color-white);
	color: var(--color-black);
}


/* ----------------------------------------
 * 15. Blog Templates
 * ---------------------------------------- */

/* ---- Archive Header ---- */

.archive-header {
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-2xl);
}

.archive-header__label {
	display: inline-block;
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-yellow-dark);
	margin-bottom: var(--space-lg);
}

.archive-header__title {
	font-family: var(--font-heading);
	font-size: var(--text-4xl);
	font-weight: var(--weight-bold);
	line-height: var(--leading-snug);
	letter-spacing: -0.01em;
	color: var(--color-black);
	margin-bottom: var(--space-md);
}

.archive-header__description {
	font-size: var(--text-lg);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	margin-bottom: 0;
}

/* ---- Pagination ---- */

.pagination {
	margin-top: var(--space-2xl);
}

.pagination .nav-links {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: var(--space-sm) var(--space-md);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--weight-medium);
	color: var(--color-black);
	text-decoration: none;
	border: 1px solid var(--color-gray-200);
	border-radius: var(--radius-md);
	transition: all var(--transition-fast);
}

.pagination .page-numbers:hover {
	background-color: var(--color-gray-100);
}

.pagination .page-numbers.current {
	background-color: var(--color-yellow);
	color: var(--color-black);
	border-color: var(--color-yellow);
	font-weight: var(--weight-semibold);
}

.pagination .page-numbers.dots {
	border: none;
	pointer-events: none;
}

.pagination .prev,
.pagination .next {
	font-weight: var(--weight-semibold);
	letter-spacing: 0.02em;
}

/* ---- Article Header ---- */

.article-header {
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-2xl);
}

.article-header__category {
	margin-bottom: var(--space-md);
}

.article-header__title {
	font-family: var(--font-heading);
	font-size: var(--text-4xl);
	font-weight: var(--weight-bold);
	line-height: var(--leading-snug);
	letter-spacing: -0.01em;
	color: var(--color-black);
	margin-bottom: var(--space-lg);
}

.article-header__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-sm);
	font-size: var(--text-sm);
	color: var(--color-gray-400);
}

.article-header__separator {
	color: var(--color-gray-300);
}

/* ---- Featured Image ---- */

.article-featured-image {
	margin-bottom: var(--space-2xl);
}

.article-featured-image img {
	width: 100%;
	border-radius: var(--radius-lg);
	object-fit: cover;
}

/* ---- Article Content (the_content() output) ---- */

.article-content {
	font-size: var(--text-lg);
	line-height: var(--leading-loose);
	color: var(--color-gray-600);
}

.article-content p {
	margin-bottom: var(--space-lg);
}

.article-content h2 {
	margin-top: var(--space-2xl);
	margin-bottom: var(--space-md);
	font-size: var(--text-3xl);
	color: var(--color-black);
}

.article-content h3 {
	margin-top: var(--space-xl);
	margin-bottom: var(--space-md);
	font-size: var(--text-2xl);
	color: var(--color-black);
}

.article-content h4 {
	margin-top: var(--space-lg);
	margin-bottom: var(--space-sm);
	color: var(--color-black);
}

.article-content img {
	border-radius: var(--radius-lg);
	margin-top: var(--space-xl);
	margin-bottom: var(--space-xl);
}

.article-content > *:last-child {
	margin-bottom: 0;
}

/* ---- Author Bio ---- */

.author-bio {
	border-top: 1px solid var(--color-gray-200);
	margin-top: var(--space-2xl);
	padding-top: var(--space-2xl);
}

.author-bio__inner {
	display: flex;
	gap: var(--space-lg);
	align-items: flex-start;
}

.author-bio__avatar {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background-color: var(--color-gray-100);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	border: 2px dashed var(--color-gray-200);
}

.author-bio__avatar-initials {
	font-family: var(--font-heading);
	font-size: var(--text-xl);
	font-weight: var(--weight-bold);
	color: var(--color-yellow);
	user-select: none;
}

.author-bio__name {
	font-family: var(--font-heading);
	font-size: var(--text-xl);
	font-weight: var(--weight-semibold);
	margin-bottom: var(--space-xs);
}

.author-bio__description {
	font-size: var(--text-base);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-sm);
}

.author-bio__link {
	font-size: var(--text-sm);
}

/* ---- Post Navigation (prev/next) ---- */

.article-nav {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
	border-top: 1px solid var(--color-gray-200);
	border-bottom: 1px solid var(--color-gray-200);
	padding-top: var(--space-xl);
	padding-bottom: var(--space-xl);
	margin-top: var(--space-xl);
}

.article-nav__label {
	display: block;
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-gray-400);
	margin-bottom: var(--space-xs);
}

.article-nav__title {
	font-family: var(--font-heading);
	font-size: var(--text-base);
	font-weight: var(--weight-semibold);
	color: var(--color-black);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.article-nav__title:hover {
	color: var(--color-yellow-dark);
}

.article-nav__item--next {
	text-align: right;
}


/* ----------------------------------------
 * 16. Contact Page
 * ---------------------------------------- */

/* ---- Contact Header ---- */

.contact-header {
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-xl);
}

.contact-header__label {
	display: inline-block;
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-yellow-dark);
	margin-bottom: var(--space-lg);
}

.contact-header__title {
	font-family: var(--font-heading);
	font-size: var(--text-5xl);
	font-weight: var(--weight-bold);
	line-height: var(--leading-snug);
	letter-spacing: -0.01em;
	color: var(--color-black);
	margin-bottom: var(--space-md);
}

.contact-header__text {
	font-size: var(--text-lg);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	margin-bottom: 0;
}

/* ---- Contact Form Area ---- */

.contact-form-area {
	margin-bottom: var(--space-2xl);
}

/* ---- Connect Channels ---- */

.contact-channels {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-2xl);
	text-align: center;
}

.contact-channel__heading {
	font-family: var(--font-heading);
	font-size: var(--text-xl);
	font-weight: var(--weight-semibold);
	margin-bottom: var(--space-sm);
}

.contact-channel__text {
	font-size: var(--text-base);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-lg);
}

/* ---- Social Links in Contact Context ---- */

.contact-social .site-footer__social-list {
	justify-content: center;
	gap: var(--space-lg);
}

.contact-social .site-footer__social-link {
	width: 48px;
	height: 48px;
	background-color: var(--color-gray-200);
	color: var(--color-gray-600);
}

.contact-social .site-footer__social-link:hover {
	background-color: var(--color-yellow);
	color: var(--color-black);
}

.contact-social .site-footer__social-link svg {
	width: 22px;
	height: 22px;
}


/* ----------------------------------------
 * 17. Portfolio Page
 * ---------------------------------------- */

/* ---- Portfolio Header ---- */

.portfolio-header {
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-xl);
}

.portfolio-header__label {
	display: inline-block;
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-yellow-dark);
	margin-bottom: var(--space-lg);
}

.portfolio-header__title {
	font-family: var(--font-heading);
	font-size: var(--text-5xl);
	font-weight: var(--weight-bold);
	line-height: var(--leading-snug);
	letter-spacing: -0.01em;
	color: var(--color-black);
	margin-bottom: var(--space-md);
}

.portfolio-header__text {
	font-size: var(--text-lg);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	margin-bottom: 0;
}

/* ---- Project Showcase (stacked, NOT grid — each project gets full width) ---- */

.portfolio-showcase {
	display: flex;
	flex-direction: column;
	gap: var(--space-4xl);
}

/* ---- Individual Project ---- */

.portfolio-project {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.portfolio-project__media {
	flex: 0 0 auto;
}

.portfolio-project__placeholder {
	aspect-ratio: 16 / 10;
	width: 100%;
	background-color: var(--color-gray-100);
	border-radius: var(--radius-xl);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	border: 2px dashed var(--color-gray-200);
	overflow: hidden;
}

.portfolio-project__placeholder-icon {
	font-family: var(--font-heading);
	font-size: var(--text-4xl);
	font-weight: var(--weight-bold);
	color: var(--color-yellow);
	line-height: 1;
	user-select: none;
}

.portfolio-project__placeholder-label {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	color: var(--color-gray-300);
	letter-spacing: 0.02em;
}

.portfolio-project__content {
	flex: 1;
}

.portfolio-project__status {
	margin-bottom: var(--space-md);
}

.portfolio-project__title {
	font-family: var(--font-heading);
	font-size: var(--text-3xl);
	font-weight: var(--weight-bold);
	line-height: var(--leading-snug);
	color: var(--color-black);
	margin-bottom: var(--space-md);
}

.portfolio-project__description {
	font-size: var(--text-lg);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-lg);
}

.portfolio-project__tech {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	margin-bottom: var(--space-lg);
}

.portfolio-project__tech .tag {
	font-size: var(--text-xs);
}

/* Teaser variant — dashed border, centered text for "more coming" */
.portfolio-project--teaser {
	border: 2px dashed var(--color-gray-200);
	border-radius: var(--radius-xl);
	padding: var(--space-2xl);
	text-align: center;
	align-items: center;
}

.portfolio-project--teaser .portfolio-project__title {
	font-size: var(--text-2xl);
}

.portfolio-project--teaser .portfolio-project__description {
	max-width: 480px;
}

/* ---- Enterprise Work Section ---- */

.portfolio-enterprise {
	background-color: var(--color-gray-900);
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-4xl);
}

.portfolio-enterprise__inner {
	text-align: center;
	max-width: 640px;
	margin-left: auto;
	margin-right: auto;
}

.portfolio-enterprise__label {
	display: inline-block;
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-yellow);
	margin-bottom: var(--space-lg);
}

.portfolio-enterprise__title {
	color: var(--color-white);
	margin-bottom: var(--space-md);
}

.portfolio-enterprise__text {
	color: var(--color-gray-300);
	font-size: var(--text-lg);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-xl);
}

.portfolio-enterprise__stats {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
	margin-bottom: var(--space-xl);
}

.portfolio-enterprise__stat {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.portfolio-enterprise__stat-number {
	font-family: var(--font-heading);
	font-size: var(--text-3xl);
	font-weight: var(--weight-bold);
	color: var(--color-yellow);
	line-height: 1;
}

.portfolio-enterprise__stat-label {
	font-size: var(--text-sm);
	color: var(--color-gray-400);
}

/* Portfolio project image (when real screenshots are added) */
.portfolio-project__image {
	width: 100%;
	border-radius: var(--radius-lg);
	object-fit: cover;
}


/* ----------------------------------------
 * 18. 404 Error Page
 * ---------------------------------------- */

.error-404 {
	padding-top: calc(var(--space-4xl) + var(--space-2xl));
	padding-bottom: var(--space-4xl);
	text-align: center;
}

.error-404__code {
	font-family: var(--font-heading);
	font-size: 8rem;
	font-weight: var(--weight-bold);
	color: var(--color-yellow);
	line-height: 1;
	margin-bottom: var(--space-lg);
	user-select: none;
	opacity: 0.6;
}

.error-404__title {
	margin-bottom: var(--space-lg);
}

.error-404__text {
	font-size: var(--text-lg);
	color: var(--color-gray-600);
	line-height: var(--leading-relaxed);
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: var(--space-xl);
}

.error-404__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	justify-content: center;
	margin-bottom: var(--space-3xl);
}

.error-404__search {
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
}

.error-404__search-label {
	font-size: var(--text-sm);
	color: var(--color-gray-400);
	margin-bottom: var(--space-md);
}

/* WordPress search form styling */
.search-form {
	display: flex;
	gap: var(--space-sm);
}

.search-form .search-field {
	flex: 1;
	padding: 14px var(--space-md);
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-black);
	background: var(--color-white);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--radius-lg);
	transition: border-color var(--transition-fast);
}

.search-form .search-field:focus {
	border-color: var(--color-yellow);
	outline: none;
	box-shadow: 0 0 0 4px var(--color-yellow-light);
}

.search-form .search-submit {
	padding: 12px var(--space-lg);
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: var(--weight-semibold);
	color: var(--color-black);
	background-color: var(--color-yellow);
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-base);
	white-space: nowrap;
}

.search-form .search-submit:hover {
	background-color: var(--color-yellow-hover);
}
