/* ==========================================================================
   Likhawat sitewide polish
   Path: wp-content/themes/kalos/assets/css/likhawat-polish.css
   Loaded by: mu-plugins/likhawat-footer.php
   ========================================================================== */

/* 1. Typography ------------------------------------------------------------- */
body {
	line-height: 1.65;
}
article p,
.mkd-post-text p,
.mkd-page-content p,
.entry-content p {
	max-width: 70ch;
	line-height: 1.65;
}

/* 2. Headings --------------------------------------------------------------- */
h1, .mkd-page-title h1, .entry-title {
	line-height: 1.15;
}
h2, .wp-block-heading {
	line-height: 1.25;
}

/* 3. Bottom footer ---------------------------------------------------------- */
.likhawat-bottom-footer {
	background: #f9f7f3;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
	font-size: 13.5px;
	line-height: 1.5;
	color: #4a4138;
	padding: 22px 32px;
}
.likhawat-bottom-footer .lf-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 14px;
	max-width: 1200px;
	margin: 0 auto;
}
.likhawat-bottom-footer a {
	color: #8a6a3a;
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color .18s ease, color .18s ease;
}
.likhawat-bottom-footer a:hover,
.likhawat-bottom-footer a:focus {
	color: #6a4f29;
	border-bottom-color: #8a6a3a;
}
.likhawat-bottom-footer .lf-right {
	white-space: normal;
}

/* 4. Portfolio archive grid ------------------------------------------------- */
.mkd-pl-holder .mkd-pl-inner,
.mkd-pl-grid-listing,
.mkd-portfolio-list-holder {
	gap: 18px;
}
.mkd-pl-item,
.mkd-portfolio-item,
.mkd-pli {
	transition: transform .25s ease, box-shadow .25s ease;
	will-change: transform;
}
.mkd-pl-item:hover,
.mkd-portfolio-item:hover,
.mkd-pli:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 28px -14px rgba(0, 0, 0, 0.18);
}

/* 5. Mobile page padding ---------------------------------------------------- */
@media (max-width: 480px) {
	.mkd-content-inner > .mkd-container > .mkd-container-inner,
	.mkd-content .mkd-container-inner {
		padding-left: 16px;
		padding-right: 16px;
	}
}

/* 6. Back-to-top button ----------------------------------------------------- */
#likhawat-back-to-top {
	position: fixed;
	right: 22px;
	bottom: 22px;
	width: 42px;
	height: 42px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: #8a6a3a;
	color: #fff;
	font: 600 18px/1 system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	cursor: pointer;
	box-shadow: 0 8px 22px -8px rgba(0, 0, 0, 0.35);
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity .25s ease, transform .25s ease, background .18s ease, visibility .25s;
	z-index: 999;
}
#likhawat-back-to-top:hover,
#likhawat-back-to-top:focus {
	background: #6a4f29;
	outline: none;
}
#likhawat-back-to-top.lf-show {
	opacity: .92;
	visibility: visible;
	transform: translateY(0);
}

/* 7. Mobile bottom-footer stack -------------------------------------------- */
@media (max-width: 720px) {
	.likhawat-bottom-footer {
		padding: 18px 18px;
	}
	.likhawat-bottom-footer .lf-inner {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: 8px;
	}
	#likhawat-back-to-top {
		right: 14px;
		bottom: 14px;
		width: 38px;
		height: 38px;
	}
}

/* ==========================================================================
   Polish round 2 — appended 2026-05-09
   Brand tokens, gallery, lightbox-friendly hooks, blog typography, print
   ========================================================================== */

/* 8. Brand colour & token system ------------------------------------------- */
:root {
	--likhawat-ink: #2c1f12;
	--likhawat-paper: #faf6ee;
	--likhawat-gold: #b08d3f;
	--likhawat-gold-deep: #8a6a3a;
	--likhawat-rose: #c97a6e;
	--likhawat-line: rgba(44, 31, 18, 0.12);
	--likhawat-shadow-sm: 0 6px 16px -8px rgba(44, 31, 18, 0.18);
	--likhawat-shadow-md: 0 14px 32px -14px rgba(44, 31, 18, 0.28);
	--likhawat-shadow-lg: 0 28px 60px -24px rgba(44, 31, 18, 0.4);
	--likhawat-radius-sm: 8px;
	--likhawat-radius-md: 14px;
	--likhawat-radius-pill: 999px;
}

/* 9. Typography hierarchy --------------------------------------------------- */
h1,
.mkd-page-title h1,
.entry-title,
.mkd-st-title {
	font-family: "Sacramento", "Cormorant Garamond", "Playfair Display", Georgia, serif;
	letter-spacing: -0.01em;
	color: var(--likhawat-ink);
}
h2,
.wp-block-heading,
.mkd-st-subtitle {
	letter-spacing: -0.005em;
	color: var(--likhawat-ink);
}
h3, h4 {
	color: var(--likhawat-ink);
}
body {
	color: var(--likhawat-ink);
}

/* 10. Section spacing ------------------------------------------------------- */
section,
.mkd-row,
.vc_row.wpb_row {
	padding-block: 80px;
}
@media (max-width: 768px) {
	section,
	.mkd-row,
	.vc_row.wpb_row {
		padding-block: 48px;
	}
}
/* Don't double-pad full-height/parallax hero rows */
.vc_row-o-full-height,
.mkd-parallax-row-holder {
	padding-block: 0;
}

/* 11. Buttons (calligraphy round) ------------------------------------------ */
.wp-block-button__link,
.mkd-btn,
.mkd-btn-solid,
button.mkd-btn,
input[type="submit"].mkd-btn {
	border-radius: var(--likhawat-radius-pill) !important;
	padding: 12px 28px !important;
	background: var(--likhawat-gold) !important;
	color: var(--likhawat-paper) !important;
	border: 1px solid var(--likhawat-gold) !important;
	transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
	letter-spacing: 0.03em;
}
.wp-block-button__link:hover,
.mkd-btn:hover,
.mkd-btn-solid:hover,
button.mkd-btn:hover {
	background: var(--likhawat-paper) !important;
	color: var(--likhawat-ink) !important;
	border-color: var(--likhawat-ink) !important;
}
.mkd-btn-simple {
	background: transparent !important;
	color: var(--likhawat-ink) !important;
	border: 1px solid var(--likhawat-line) !important;
}
.mkd-btn-simple:hover {
	background: var(--likhawat-gold) !important;
	color: var(--likhawat-paper) !important;
	border-color: var(--likhawat-gold) !important;
}

/* 12. Mobile menu trigger (Kalos) ------------------------------------------ */
.mkd-mobile-menu-opener a,
.mkd-mobile-header .mkd-mobile-menu-opener {
	color: var(--likhawat-ink) !important;
}

/* 13. Image captions (Wayback recoveries) ---------------------------------- */
figcaption,
.wp-caption-text,
.mkd-image-caption {
	font-style: italic;
	font-size: 14px;
	color: rgba(44, 31, 18, 0.78);
	border-left: 2px solid var(--likhawat-gold);
	padding-left: 12px;
	margin-top: 10px;
	line-height: 1.55;
}

/* 14. Portfolio archive — true masonry-style grid -------------------------- */
.mkd-pl-holder .mkd-pl-inner,
.mkd-pl-grid-listing,
.mkd-portfolio-list-holder,
.mkd-pl-outer {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 22px;
	float: none !important;
	width: 100% !important;
}
.mkd-pl-item,
.mkd-portfolio-item,
.mkd-pli {
	width: 100% !important;
	margin: 0 !important;
	float: none !important;
	border-radius: var(--likhawat-radius-md);
	overflow: hidden;
	background: #fff;
	box-shadow: var(--likhawat-shadow-sm);
	transition: transform .3s ease, box-shadow .3s ease;
	position: relative;
}
.mkd-pl-item:hover,
.mkd-portfolio-item:hover,
.mkd-pli:hover {
	transform: scale(1.02);
	box-shadow: var(--likhawat-shadow-md);
}
.mkd-pl-item .mkd-pli-image,
.mkd-pl-item .mkd-portfolio-image-frame,
.mkd-pli-image,
.mkd-portfolio-image-frame {
	aspect-ratio: 1 / 1;
	overflow: hidden;
	display: block;
}
.mkd-pl-item .mkd-pli-image img,
.mkd-pli-image img,
.mkd-portfolio-image-frame img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
	transition: transform .5s ease;
}
.mkd-pl-item:hover .mkd-pli-image img,
.mkd-portfolio-item:hover .mkd-pli-image img {
	transform: scale(1.05);
}
.mkd-pl-item .mkd-pli-text-holder,
.mkd-pli-text-holder {
	padding: 16px 18px 20px;
}
.mkd-pl-item .mkd-pli-title,
.mkd-pli-title {
	font-weight: 700;
	font-size: 17px;
	line-height: 1.3;
	margin: 0 0 6px;
	color: var(--likhawat-ink);
}
.mkd-pl-item .mkd-pli-category,
.mkd-pli-category,
.mkd-pli-category a {
	display: inline-block;
	background: rgba(176, 141, 63, 0.12);
	color: var(--likhawat-gold-deep);
	font-size: 11.5px;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: var(--likhawat-radius-pill);
	text-decoration: none;
}
/* Hover gradient overlay revealing title */
.mkd-pli-image::after,
.mkd-portfolio-image-frame::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(44, 31, 18, 0.55) 0%, rgba(44, 31, 18, 0) 60%);
	opacity: 0;
	transition: opacity .3s ease;
	pointer-events: none;
}
.mkd-pl-item:hover .mkd-pli-image::after,
.mkd-portfolio-item:hover .mkd-portfolio-image-frame::after {
	opacity: 1;
}

/* 15. Single portfolio item — hero & body --------------------------------- */
.single-portfolio-item .mkd-portfolio-single-holder .mkd-portfolio-single-image img,
.single-portfolio-item .mkd-pt-image img,
.single-portfolio-item .post-thumbnail img {
	width: 100%;
	max-height: 70vh;
	object-fit: cover;
	border-radius: 0;
}
.single-portfolio-item .mkd-portfolio-single-content,
.single-portfolio-item .mkd-pt-content,
.single-portfolio-item .entry-content {
	max-width: 720px;
	margin: 0 auto;
	padding: 40px 24px 60px;
}
.single-portfolio-item .mkd-portfolio-single-content p,
.single-portfolio-item .mkd-pt-content p,
.single-portfolio-item .entry-content p {
	max-width: 100%;
	font-size: 17px;
	line-height: 1.75;
}
.single-portfolio-item .mkd-page-title,
.single-portfolio-item .mkd-pt-title-holder {
	text-align: center;
	padding: 32px 24px 12px;
}
.single-portfolio-item .mkd-page-breadcrumbs,
.single-portfolio-item .mkd-pt-cat {
	text-align: center;
	font-size: 12.5px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--likhawat-gold-deep);
	margin-bottom: 24px;
}
/* Inline image groups in body become 3-col grid */
.single-portfolio-item .entry-content .gallery,
.single-portfolio-item .mkd-pt-content .gallery {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
	margin: 24px 0;
}
@media (max-width: 600px) {
	.single-portfolio-item .entry-content .gallery,
	.single-portfolio-item .mkd-pt-content .gallery {
		grid-template-columns: repeat(2, 1fr);
	}
}
.single-portfolio-item .entry-content .gallery-item,
.single-portfolio-item .mkd-pt-content .gallery-item {
	margin: 0 !important;
	width: 100% !important;
}
.single-portfolio-item .entry-content .gallery-item img,
.single-portfolio-item .mkd-pt-content .gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--likhawat-radius-sm);
}

/* 16. Bottom CTA on single portfolio --------------------------------------- */
.likhawat-portfolio-cta {
	max-width: 720px;
	margin: 40px auto 80px;
	padding: 24px;
	border-top: 1px solid var(--likhawat-line);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
	font-size: 14.5px;
}
.likhawat-portfolio-cta a {
	color: var(--likhawat-gold-deep);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	padding-bottom: 2px;
	transition: border-color .2s ease, color .2s ease;
}
.likhawat-portfolio-cta a:hover {
	color: var(--likhawat-ink);
	border-bottom-color: var(--likhawat-gold);
}

/* 17. Homepage "Selected work" strip --------------------------------------- */
.likhawat-selected-work {
	background: var(--likhawat-paper);
	padding: 70px 0 80px;
	border-top: 1px solid var(--likhawat-line);
	border-bottom: 1px solid var(--likhawat-line);
}
.likhawat-selected-work .lsw-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 28px;
}
.likhawat-selected-work .lsw-eyebrow {
	font-size: 12.5px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--likhawat-gold-deep);
	margin: 0 0 8px;
}
.likhawat-selected-work .lsw-title {
	font-family: "Sacramento", "Cormorant Garamond", Georgia, serif;
	font-size: 42px;
	line-height: 1.1;
	margin: 0 0 28px;
	color: var(--likhawat-ink);
}
.likhawat-selected-work .lsw-strip {
	display: flex;
	gap: 18px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	padding: 4px 4px 18px;
	-webkit-overflow-scrolling: touch;
}
.likhawat-selected-work .lsw-strip::-webkit-scrollbar {
	height: 6px;
}
.likhawat-selected-work .lsw-strip::-webkit-scrollbar-thumb {
	background: var(--likhawat-line);
	border-radius: 99px;
}
.likhawat-selected-work .lsw-card {
	flex: 0 0 280px;
	scroll-snap-align: start;
	border-radius: var(--likhawat-radius-md);
	overflow: hidden;
	box-shadow: var(--likhawat-shadow-sm);
	background: #fff;
	text-decoration: none;
	color: inherit;
	transition: transform .3s ease, box-shadow .3s ease;
	position: relative;
	display: block;
}
.likhawat-selected-work .lsw-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--likhawat-shadow-md);
}
.likhawat-selected-work .lsw-card .lsw-img {
	aspect-ratio: 4 / 5;
	overflow: hidden;
	display: block;
}
.likhawat-selected-work .lsw-card .lsw-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .5s ease;
	display: block;
}
.likhawat-selected-work .lsw-card:hover .lsw-img img {
	transform: scale(1.06);
}
.likhawat-selected-work .lsw-card .lsw-label {
	padding: 14px 16px 18px;
}
.likhawat-selected-work .lsw-card .lsw-label strong {
	display: block;
	font-weight: 700;
	font-size: 15.5px;
	color: var(--likhawat-ink);
	margin-bottom: 4px;
}
.likhawat-selected-work .lsw-card .lsw-label span {
	font-size: 11.5px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--likhawat-gold-deep);
}
.likhawat-selected-work .lsw-cta {
	margin-top: 22px;
	font-size: 14.5px;
}
.likhawat-selected-work .lsw-cta a {
	color: var(--likhawat-gold-deep);
	text-decoration: none;
	border-bottom: 1px solid var(--likhawat-line);
	padding-bottom: 2px;
}
.likhawat-selected-work .lsw-cta a:hover {
	color: var(--likhawat-ink);
	border-bottom-color: var(--likhawat-gold);
}
@media (max-width: 600px) {
	.likhawat-selected-work {
		padding: 48px 0 56px;
	}
	.likhawat-selected-work .lsw-title {
		font-size: 34px;
	}
	.likhawat-selected-work .lsw-card {
		flex: 0 0 220px;
	}
}

/* 18. Lightbox -------------------------------------------------------------- */
.likhawat-lightbox-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(20, 13, 6, 0.92);
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
	cursor: zoom-out;
	animation: likhawat-fade-in .25s ease;
}
.likhawat-lightbox-backdrop.is-open {
	display: flex;
}
.likhawat-lightbox-backdrop img {
	max-width: 92vw;
	max-height: 88vh;
	object-fit: contain;
	box-shadow: 0 30px 80px -20px rgba(0, 0, 0, 0.6);
	border-radius: var(--likhawat-radius-sm);
}
.likhawat-lightbox-close,
.likhawat-lightbox-prev,
.likhawat-lightbox-next {
	position: absolute;
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
	border: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	cursor: pointer;
	font-size: 22px;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background .2s ease;
}
.likhawat-lightbox-close:hover,
.likhawat-lightbox-prev:hover,
.likhawat-lightbox-next:hover {
	background: rgba(255, 255, 255, 0.24);
}
.likhawat-lightbox-close { top: 18px; right: 18px; }
.likhawat-lightbox-prev  { left: 18px;  top: 50%; transform: translateY(-50%); }
.likhawat-lightbox-next  { right: 18px; top: 50%; transform: translateY(-50%); }
@keyframes likhawat-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

/* 19. Blog / journal -------------------------------------------------------- */
.blog .mkd-blog-holder article,
.archive .mkd-blog-holder article,
.single-post .mkd-blog-single-holder {
	background: #fff;
}
.single-post .mkd-blog-single-holder .post-content,
.single-post .entry-content {
	max-width: 720px;
	margin: 0 auto;
	font-size: 17.5px;
	line-height: 1.75;
}
.single-post .entry-content p,
.single-post .post-content p {
	max-width: 100%;
}
.single-post .entry-title,
.single-post .mkd-page-title h1 {
	max-width: 820px;
	margin: 0 auto 14px;
	text-align: center;
}
.single-post .wp-block-pullquote {
	border: 0;
	border-left: 4px solid var(--likhawat-gold);
	background: rgba(176, 141, 63, 0.06);
	padding: 26px 28px;
	margin: 32px 0;
	font-style: italic;
	font-size: 19px;
	line-height: 1.55;
	color: var(--likhawat-ink);
	border-radius: var(--likhawat-radius-sm);
}
.single-post .wp-block-pullquote p {
	margin: 0;
}
.single-post .wp-block-pullquote cite {
	display: block;
	margin-top: 10px;
	font-size: 13.5px;
	font-style: normal;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--likhawat-gold-deep);
}
.single-post .entry-content h2,
.single-post .post-content h2 {
	margin-top: 48px;
	font-size: 28px;
}
.single-post .entry-content h3,
.single-post .post-content h3 {
	margin-top: 32px;
	font-size: 22px;
}
.single-post .entry-content ul li,
.single-post .post-content ul li {
	margin-bottom: 8px;
}

/* Blog archive cards --------------------------------------------------------*/
.blog .mkd-blog-holder .mkd-bli,
.blog .mkd-blog-holder .post,
.archive .mkd-blog-holder .mkd-bli {
	border-radius: var(--likhawat-radius-md);
	overflow: hidden;
	box-shadow: var(--likhawat-shadow-sm);
	transition: transform .3s ease, box-shadow .3s ease;
	background: #fff;
	margin-bottom: 30px;
}
.blog .mkd-blog-holder .mkd-bli:hover,
.archive .mkd-blog-holder .mkd-bli:hover {
	transform: translateY(-3px);
	box-shadow: var(--likhawat-shadow-md);
}

/* 20. Print ---------------------------------------------------------------- */
@media print {
	.mkd-page-header,
	.mkd-mobile-header,
	.mkd-side-menu,
	.mkd-footer-top-holder,
	.mkd-footer-bottom-holder,
	.likhawat-bottom-footer,
	#likhawat-back-to-top,
	.likhawat-lightbox-backdrop,
	.mkd-fullscreen-search-holder,
	.likhawat-selected-work {
		display: none !important;
	}
	body, .mkd-content, .mkd-content-inner {
		background: #fff !important;
		color: #000 !important;
	}
	.mkd-content-inner > .mkd-container > .mkd-container-inner,
	.mkd-content .mkd-container-inner,
	.entry-content,
	.post-content {
		max-width: 100% !important;
		width: 100% !important;
		padding: 0 !important;
		margin: 0 !important;
	}
	a {
		color: #000 !important;
		text-decoration: underline !important;
	}
	h1, h2, h3 {
		page-break-after: avoid;
	}
	img {
		max-width: 100% !important;
		page-break-inside: avoid;
	}
}


/* ==========================================================================
   Title-area dedup HARD KILL (round 4 — 2026-05-09)
   Live HTML uses Mikado prefix `mkd-` (NOT mkdf- or qode-).
   Some pages render TWO banners: `.mkd-title-holder.mkd-standard-type`
   (small grey strip below sticky nav, holds an <h3>) AND
   `.mkd-title-holder.mkd-centered-type` (large in-body H1).
   When both exist the title shows twice — kill the small standard-type
   ONLY on those pages. Pages with only the standard-type (most inner
   pages) keep their single banner intact.
   `:has()` is supported in all current evergreen browsers (2023+).
   ========================================================================== */
body:has(.mkd-title-holder.mkd-centered-type) .mkd-title-holder.mkd-standard-type {
	display: none !important;
	height: 0 !important;
	min-height: 0 !important;
	max-height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	visibility: hidden !important;
	overflow: hidden !important;
}

/* Belt-and-braces: hide the H3 inside the redundant banner. */
body:has(.mkd-title-holder.mkd-centered-type) .mkd-title-holder.mkd-standard-type h3.mkd-page-title,
body:has(.mkd-title-holder.mkd-centered-type) .mkd-title-holder.mkd-standard-type .mkd-title-wrapper,
body:has(.mkd-title-holder.mkd-centered-type) .mkd-title-holder.mkd-standard-type .mkd-title-inner {
	display: none !important;
}

/* Page-id fallback for any UA without :has() support — explicitly
   hide on the two confirmed dual-banner pages: about-me (page 6)
   and likhawat-on-print-media (page 7). */
body.page-id-6 .mkd-title-holder.mkd-standard-type,
body.page-id-7 .mkd-title-holder.mkd-standard-type {
	display: none !important;
	height: 0 !important;
	min-height: 0 !important;
	visibility: hidden !important;
}

/* H1 size cap — long slugs (e.g. shipra-rohatgi-tang-magazine-...)
   were rendering huge in the Sacramento script and felt awkward.
   A tighter clamp keeps them legible at all widths. */
h1,
.mkd-page-title h1,
.entry-title {
	font-size: clamp(28px, 4.2vw, 56px) !important;
	line-height: 1.15 !important;
}

/* === Portfolio landing redesign 2026-05-09 === */
/* All rules scoped to body.page-id-10 (post 10 = /portfolio/). */
body.page-id-10 .lk-portfolio-redesign {
    color: var(--likhawat-ink);
    font-family: inherit;
    line-height: 1.65;
    --lk-shadow-sm: 0 2px 8px rgba(44,31,18,0.06);
    --lk-shadow-md: 0 8px 24px rgba(44,31,18,0.10);
    --lk-shadow-lg: 0 14px 40px rgba(44,31,18,0.14);
}
body.page-id-10 .lk-portfolio-redesign section { margin: 0 0 56px 0; }
body.page-id-10 .lk-portfolio-redesign h2.lk-h2 {
    font-size: clamp(24px, 3vw, 36px);
    line-height: 1.25;
    color: var(--likhawat-ink);
    margin: 0 0 18px 0;
    letter-spacing: 0.005em;
}
body.page-id-10 .lk-portfolio-redesign p { margin: 0 0 14px 0; }
body.page-id-10 .lk-portfolio-redesign a { color: var(--likhawat-gold-deep); text-decoration: none; }
body.page-id-10 .lk-portfolio-redesign a:hover { color: var(--likhawat-ink); text-decoration: underline; }

/* ---- Hero ---- */
body.page-id-10 .lk-hero {
    background-size: cover;
    background-position: center 40%;
    min-height: 60vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 80px 24px;
    margin: -20px -24px 56px -24px;
    color: var(--likhawat-paper);
    border-radius: 4px;
}
body.page-id-10 .lk-hero-inner { max-width: 820px; text-align: center; }
body.page-id-10 .lk-hero-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.22em;
    font-size: 12px;
    color: var(--likhawat-paper);
    opacity: 0.85;
    margin: 0 0 14px 0;
}
body.page-id-10 .lk-hero-h {
    font-size: clamp(28px, 4.4vw, 48px);
    line-height: 1.18;
    color: var(--likhawat-paper);
    margin: 0 0 18px 0;
}
body.page-id-10 .lk-hero-sub {
    font-size: clamp(15px, 1.6vw, 18px);
    color: var(--likhawat-paper);
    opacity: 0.92;
    margin: 0 0 26px 0;
}
body.page-id-10 .lk-hero-ctas { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---- Buttons ---- */
body.page-id-10 .lk-btn {
    display: inline-block;
    padding: 12px 26px;
    border-radius: 999px;
    font-size: 14px;
    letter-spacing: 0.04em;
    border: 1px solid transparent;
    transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
    text-decoration: none !important;
    cursor: pointer;
}
body.page-id-10 .lk-btn-primary {
    background: var(--likhawat-gold);
    color: var(--likhawat-paper) !important;
    border-color: var(--likhawat-gold);
}
body.page-id-10 .lk-btn-primary:hover {
    background: var(--likhawat-paper);
    color: var(--likhawat-ink) !important;
    border-color: var(--likhawat-ink);
}
body.page-id-10 .lk-btn-ghost {
    background: transparent;
    color: var(--likhawat-paper) !important;
    border-color: rgba(250,246,238,0.7);
}
body.page-id-10 .lk-btn-ghost:hover {
    background: var(--likhawat-paper);
    color: var(--likhawat-ink) !important;
    border-color: var(--likhawat-paper);
}
body.page-id-10 .lk-closing .lk-btn-ghost {
    color: var(--likhawat-ink) !important;
    border-color: var(--likhawat-ink);
}
body.page-id-10 .lk-closing .lk-btn-ghost:hover {
    background: var(--likhawat-ink);
    color: var(--likhawat-paper) !important;
}

/* ---- Stats ---- */
body.page-id-10 .lk-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    padding: 28px 0;
    border-top: 1px solid var(--likhawat-line);
    border-bottom: 1px solid var(--likhawat-line);
}
body.page-id-10 .lk-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    color: var(--likhawat-ink);
}
body.page-id-10 .lk-stat-icon {
    color: var(--likhawat-gold);
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 8px;
}
body.page-id-10 .lk-stat-icon svg { width: 32px; height: 32px; }
body.page-id-10 .lk-stat-num {
    font-size: clamp(28px, 3.4vw, 40px);
    font-weight: 600;
    line-height: 1.05;
    color: var(--likhawat-ink);
}
body.page-id-10 .lk-stat-label {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: rgba(44,31,18,0.7);
    margin-top: 4px;
}
@media (max-width: 720px) { body.page-id-10 .lk-stats { grid-template-columns: repeat(2, 1fr); gap: 24px; } }
@media (max-width: 420px) { body.page-id-10 .lk-stats { grid-template-columns: 1fr; gap: 18px; } }

/* ---- How-to ---- */
body.page-id-10 .lk-howto { max-width: 780px; }
body.page-id-10 .lk-howto-note { color: rgba(44,31,18,0.7); font-size: 14px; }

/* ---- Section common ---- */
body.page-id-10 .lk-section-lede {
    color: rgba(44,31,18,0.78);
    font-size: 16px;
    margin: 0 0 28px 0;
    max-width: 720px;
}

/* ---- Categories grid ---- */
body.page-id-10 .lk-cat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
}
body.page-id-10 .lk-cat-card {
    background: var(--likhawat-paper);
    border: 1px solid var(--likhawat-line);
    border-radius: 6px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    box-shadow: var(--lk-shadow-sm);
}
body.page-id-10 .lk-cat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--lk-shadow-md);
    border-color: var(--likhawat-gold);
}
body.page-id-10 .lk-cat-imgwrap { display: block; }
body.page-id-10 .lk-cat-img {
    width: 100%;
    aspect-ratio: 4 / 3;
    background-size: cover;
    background-position: center;
    transition: transform .35s ease;
}
body.page-id-10 .lk-cat-card:hover .lk-cat-img { transform: scale(1.04); }
body.page-id-10 .lk-cat-body { padding: 20px 22px 22px; display: flex; flex-direction: column; gap: 10px; flex: 1 1 auto; }
body.page-id-10 .lk-cat-title {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    font-size: 22px;
    line-height: 1.25;
    color: var(--likhawat-ink);
}
body.page-id-10 .lk-cat-title .lk-icon { color: var(--likhawat-gold); width: 26px; height: 26px; flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center; }
body.page-id-10 .lk-cat-title .lk-icon svg { width: 24px; height: 24px; }
body.page-id-10 .lk-cat-desc {
    font-size: 14.5px;
    color: rgba(44,31,18,0.82);
    margin: 0;
    line-height: 1.6;
}
body.page-id-10 .lk-cat-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px dashed var(--likhawat-line);
}
body.page-id-10 .lk-cat-count {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: rgba(44,31,18,0.65);
}
body.page-id-10 .lk-cat-cta {
    font-size: 14px;
    color: var(--likhawat-gold-deep);
    font-weight: 500;
}

/* ---- Scripts ---- */
body.page-id-10 .lk-script-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
body.page-id-10 .lk-script-pill {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px 10px 14px;
    background: var(--likhawat-paper);
    border: 1px solid var(--likhawat-line);
    border-radius: 999px;
    text-decoration: none !important;
    color: var(--likhawat-ink) !important;
    transition: border-color .2s ease, background .2s ease, transform .2s ease;
}
body.page-id-10 .lk-script-pill:hover {
    border-color: var(--likhawat-gold);
    background: #fffaf0;
    transform: translateY(-2px);
}
body.page-id-10 .lk-script-glyph {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: var(--likhawat-gold);
    color: var(--likhawat-paper);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    line-height: 1;
}
body.page-id-10 .lk-script-name { font-size: 14.5px; }
body.page-id-10 .lk-script-count {
    font-size: 12px;
    color: rgba(44,31,18,0.6);
    background: rgba(176,141,63,0.10);
    padding: 2px 8px;
    border-radius: 999px;
}

/* ---- Case studies ---- */
body.page-id-10 .lk-case-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 24px;
}
body.page-id-10 .lk-case-card {
    background: var(--likhawat-paper);
    border: 1px solid var(--likhawat-line);
    border-top: 3px solid var(--likhawat-gold);
    border-radius: 6px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform .25s ease, box-shadow .25s ease;
    box-shadow: var(--lk-shadow-sm);
}
body.page-id-10 .lk-case-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--lk-shadow-md);
}
body.page-id-10 .lk-case-img {
    width: 100%;
    aspect-ratio: 4 / 3;
    background-size: cover;
    background-position: center;
    transition: transform .35s ease;
}
body.page-id-10 .lk-case-card:hover .lk-case-img { transform: scale(1.04); }
body.page-id-10 .lk-case-body { padding: 18px 20px 22px; display: flex; flex-direction: column; gap: 8px; flex: 1 1 auto; }
body.page-id-10 .lk-case-title { font-size: 19px; line-height: 1.3; margin: 0; }
body.page-id-10 .lk-case-title a { color: var(--likhawat-ink) !important; }
body.page-id-10 .lk-case-title a:hover { color: var(--likhawat-gold-deep) !important; }
body.page-id-10 .lk-case-excerpt {
    font-size: 14.5px;
    color: rgba(44,31,18,0.82);
    margin: 0;
    line-height: 1.6;
}
body.page-id-10 .lk-case-cta {
    margin-top: auto;
    padding-top: 10px;
    font-size: 14px;
    color: var(--likhawat-gold-deep);
}

/* ---- Services bullets ---- */
body.page-id-10 .lk-services-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 14px 28px;
}
body.page-id-10 .lk-services-list li {
    padding: 12px 14px 12px 18px;
    background: var(--likhawat-paper);
    border-left: 3px solid var(--likhawat-gold);
    border-radius: 0 4px 4px 0;
    font-size: 15px;
}
body.page-id-10 .lk-services-foot { margin-top: 18px; }
body.page-id-10 .lk-link-arrow {
    color: var(--likhawat-gold-deep);
    font-weight: 500;
    border-bottom: 1px solid var(--likhawat-gold);
    padding-bottom: 2px;
}

/* ---- Closing ---- */
body.page-id-10 .lk-closing {
    background: #fffaf0;
    border: 1px solid var(--likhawat-line);
    border-radius: 6px;
    padding: 36px 28px;
    text-align: center;
    max-width: 820px;
    margin-left: auto;
    margin-right: auto;
}
body.page-id-10 .lk-closing-icon {
    color: var(--likhawat-gold);
    width: 40px;
    height: 40px;
    display: inline-flex;
    margin-bottom: 8px;
}
body.page-id-10 .lk-closing-icon svg { width: 36px; height: 36px; }
body.page-id-10 .lk-closing-ctas { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 18px; }

/* ---- Print ---- */
@media print {
    body.page-id-10 .lk-hero,
    body.page-id-10 .lk-stats { display: none !important; }
}

/* === Single portfolio-item layout fix (2026-05-09 round 5) ===
   Kalos portfolio-single template puts post body in a 4-col sidebar with
   an 8-col image holder that's empty (no portfolio gallery custom field
   was ever set). It also stamps a tall .mkd-title-holder banner above the
   content. Fix all three issues here.

   Body class on these pages is exactly: body.single-portfolio-item
*/

/* 1. Hide the redundant title banner that sits above the body content.
   Match every plausible Kalos variant — 'mkd-standard-type' is what the
   live HTML uses, but cover '*-type' wildcards too so future Kalos updates
   don't bring it back. */
body.single-portfolio-item .mkd-title-holder,
body.single-portfolio-item .mkd-title-holder.mkd-standard-type,
body.single-portfolio-item .mkd-title-holder.mkd-breadcrumb-type,
body.single-portfolio-item .mkd-page-title-holder,
body.single-portfolio-item .qode-title-holder,
body.single-portfolio-item .mkd-title-image-holder,
body.single-portfolio-item > .mkd-title,
body.single-portfolio-item .mkd-content > .mkd-content-inner > .mkd-title-holder,
body.single-portfolio-item .mkd-content-inner > .mkd-title-holder {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
}

/* 2. Restore content top breathing room without the title banner. */
body.single-portfolio-item .mkd-content { padding-top: 32px !important; }
@media (max-width: 768px) {
  body.single-portfolio-item .mkd-content { padding-top: 16px !important; }
}

/* 3. The Kalos template forces post body into mkd-grid-col-4 (33%) and
   leaves mkd-grid-col-8 (67%) empty for a portfolio gallery that was
   never populated. Collapse the empty image column and let body content
   span full width. The injected hero image (see likhawat-portfolio-hero.php
   mu-plugin) renders inline via wp-block-image, so the empty image holder
   on the right is always redundant. */
body.single-portfolio-item .mkd-portfolio-single-holder .mkd-grid-row {
  display: block !important;
}
body.single-portfolio-item .mkd-portfolio-single-holder .mkd-grid-col-4 {
  width: 100% !important;
  max-width: 880px;
  margin: 0 auto !important;
  float: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
body.single-portfolio-item .mkd-portfolio-single-holder .mkd-grid-col-8 {
  display: none !important;
}

/* 4. Drop the sticky behaviour of the info holder — it was designed to
   stick beside a tall image gallery; with the gallery gone it just
   floats awkwardly. */
body.single-portfolio-item .mkd-ps-info-holder.mkd-ps-info-sticky-holder {
  position: static !important;
  top: auto !important;
}

/* 5. Body text — left-aligned, comfortable reading width. */
body.single-portfolio-item .mkd-portfolio-single-holder,
body.single-portfolio-item .mkd-portfolio-single-holder .mkd-ps-info-content-item,
body.single-portfolio-item .mkd-portfolio-single-holder .mkd-ps-info-item,
body.single-portfolio-item .mkd-portfolio-single-holder p,
body.single-portfolio-item .mkd-portfolio-single-holder ul,
body.single-portfolio-item .mkd-portfolio-single-holder ol,
body.single-portfolio-item .mkd-portfolio-single-holder h1,
body.single-portfolio-item .mkd-portfolio-single-holder h2,
body.single-portfolio-item .mkd-portfolio-single-holder h3,
body.single-portfolio-item .mkd-portfolio-single-holder h4,
body.single-portfolio-item .mkd-portfolio-single-holder .wp-block-heading,
body.single-portfolio-item .mkd-portfolio-single-holder .wp-block-paragraph,
body.single-portfolio-item .mkd-portfolio-single-holder .wp-block-list {
  text-align: left !important;
}

/* 6. Pull-quote stays centred (deliberate accent). */
body.single-portfolio-item .wp-block-pullquote,
body.single-portfolio-item .wp-block-pullquote p {
  text-align: center !important;
}

/* 7. Hero image (injected at top of post_content by likhawat-portfolio-hero
   mu-plugin) — full-width, capped height for a cinematic feel. */
body.single-portfolio-item .lk-pf-hero {
  margin: 0 0 32px 0 !important;
}
body.single-portfolio-item .lk-pf-hero img {
  width: 100% !important;
  max-height: 60vh;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 8px 28px rgba(44,31,18,0.10);
  display: block;
}

/* 8. The next/prev navigation block lived in the (now hidden) col-8
   container; surface it back at the bottom of the content. */
body.single-portfolio-item .mkd-ps-navigation {
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  max-width: 880px;
  margin: 40px auto 24px !important;
  padding: 18px 0;
  border-top: 1px solid rgba(44,31,18,0.10);
}

/* ============================================================
   LIKHAWAT POLISH — ROUND 6 (2026-05-09 evening)
   Bug fixes: dual-page-title (sitewide), mobile responsive overhaul
   Appended; previous rules preserved.
   ============================================================ */

/* ------------------------------------------------------------
   A. Sitewide title-banner dedup HARD KILL
   ------------------------------------------------------------
   Kalos renders <h3 class="mkd-page-title entry-title"> inside a
   .mkd-title-holder.mkd-standard-type strip on EVERY page (regular
   pages, single posts, portfolio items, archives). When the page
   body already contains its own <h1> (e.g. /services/) or another
   centred banner (e.g. /about-me/), we end up with two title
   elements stacked. Fix: hide the standard-type banner sitewide,
   except on home/archive/search where it IS the canonical heading.
*/
.mkd-title-holder.mkd-standard-type,
.mkd-title-holder.mkd-breadcrumb-type:not(.mkd-centered-type),
.mkdf-title-holder.mkdf-standard-type,
.qode-title-holder.qode-standard-type,
.mkd-title-holder.mkd-page-title-default,
body.page .mkd-title.mkd-standard-type,
body.single .mkd-title.mkd-standard-type,
body.single-portfolio-item .mkd-title.mkd-standard-type,
body:not(.home):not(.archive):not(.search):not(.error404) > .mkd-title.mkd-standard-type,
body:not(.home) .mkd-title-image-holder.mkd-empty-image-holder {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  visibility: hidden !important;
  overflow: hidden !important;
}

/* Preserve the standard-type strip ON archives + search where it IS the heading */
body.archive .mkd-title-holder.mkd-standard-type,
body.search .mkd-title-holder.mkd-standard-type,
body.error404 .mkd-title-holder.mkd-standard-type,
body.home .mkd-title-holder.mkd-standard-type {
  display: block !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 28px 0 !important;
  visibility: visible !important;
  overflow: visible !important;
}

/* Don't double-pad content after we've removed the banner */
body.page .mkd-content,
body.single:not(.home) .mkd-content,
body.single-portfolio-item .mkd-content {
  padding-top: 24px !important;
}
@media (max-width: 768px) {
  body.page .mkd-content,
  body.single:not(.home) .mkd-content,
  body.single-portfolio-item .mkd-content { padding-top: 12px !important; }
}

/* ------------------------------------------------------------
   B. Mobile responsive overhaul
   ------------------------------------------------------------
   Diagnosis: the "Archives + Categories" widgets that user sees
   stacked over the page H1 on mobile live in
   .mkd-position-right > .widget.mkd-right-from-mobile-logo —
   a Kalos header widget area meant for desktop right-rail. On
   mobile the theme should hide it, but custom widgets bleed
   through. Force-hide the widget block on mobile <= 1024px.

   Also: existing polish CSS uses position:absolute and 60vh hero
   heights without mobile guards. Round 7 of @media (max-width:768px)
   neutralises them.
*/
@media (max-width: 1024px) {
  /* Kill the bleeding "Archives / Categories / Recent posts" widgets in mobile header */
  .mkd-position-right .widget.widget_block.mkd-right-from-mobile-logo,
  .mkd-mobile-header .mkd-position-right > .widget,
  .mkd-mobile-header-inner .widget_block,
  .mkd-mobile-header-inner .widget_archive,
  .mkd-mobile-header-inner .widget_categories,
  .mkd-mobile-header-inner .widget_recent_entries,
  .mkd-mobile-header-inner .widget_recent_comments,
  .mkd-mobile-header-inner .widget_meta {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    width: 0 !important;
    overflow: hidden !important;
  }
}

@media (max-width: 768px) {
  /* Force every existing layered hero / overlay to be in-flow on mobile */
  .lk-portfolio-hero,
  .lk-pf-hero,
  .lk-stats,
  .lk-category-grid,
  .lk-script-pills,
  .lk-case-studies,
  body.page-id-10 .lk-hero,
  body.page-id-10 .lk-stats,
  body.page-id-168 .lk-hero,
  body.page-id-8 .lk-hero {
    position: static !important;
    transform: none !important;
    height: auto !important;
    min-height: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Hero images cap to a sane mobile aspect */
  .lk-pf-hero img,
  body.single-portfolio-item .wp-post-image,
  body .lk-portfolio-hero img {
    max-height: 40vh !important;
    width: 100% !important;
    object-fit: cover !important;
    border-radius: 8px !important;
  }

  /* H1/H3 titles cap on mobile so the script font never overflows */
  body h1,
  body .mkd-page-title,
  body .lk-portfolio-hero h1,
  body.archive h1,
  body.archive .mkd-page-title,
  body.search h1,
  body.category h1 {
    font-size: clamp(22px, 5.5vw, 32px) !important;
    line-height: 1.2 !important;
    max-width: 92vw !important;
    word-wrap: break-word !important;
    overflow-wrap: anywhere !important;
  }

  /* Category-archive intro text — own block, no negative margin */
  body.archive .term-description,
  body.archive .archive-description,
  body.archive .taxonomy-description,
  body.category .term-description {
    position: static !important;
    margin: 12px 0 18px !important;
    font-size: 13.5px !important;
    line-height: 1.5 !important;
    max-width: 92vw !important;
  }

  /* Standard mobile padding on every content container */
  .mkd-content,
  .mkd-container,
  .mkd-container-inner,
  .lk-portfolio-hero {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* Kalos's grid system — force fluid */
  .mkd-grid,
  .mkd-row {
    width: 100% !important;
    max-width: 100% !important;
  }
  .mkd-grid > [class*="mkd-col"],
  .mkd-row > [class*="mkd-col"] {
    width: 100% !important;
    max-width: 100% !important;
    flex-basis: 100% !important;
  }

  /* WhatsApp + back-to-top FABs — slightly smaller on phones */
  #likhawat-whatsapp-fab { bottom: 18px !important; right: 18px !important; width: 52px !important; height: 52px !important; }
  #likhawat-back-to-top  { bottom: 80px !important; right: 18px !important; }

  /* Tables on mobile must scroll horizontally */
  body.single-page table,
  body.page table,
  body.single-post table,
  body.single-portfolio-item table {
    display: block !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    max-width: 100vw !important;
  }

  /* WP block-group widgets that fall through to mobile main */
  .wp-block-group .wp-block-archives,
  .wp-block-group .wp-block-categories {
    padding-left: 0 !important;
    margin-left: 0 !important;
  }
}

/* Even narrower (≤ 480px) — extra guard */
@media (max-width: 480px) {
  body h1,
  body .mkd-page-title { font-size: clamp(20px, 6vw, 28px) !important; }
  .mkd-content { padding-left: 12px !important; padding-right: 12px !important; }
  body.page-id-10 .lk-stats { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
}

/* ============================================================
   LIKHAWAT POLISH — ROUND 6b CORRECTION (2026-05-09 evening)
   The earlier Round 6 was too aggressive: it hid mkd-standard-type
   on every page, leaving pages with no other banner (journal,
   testimonials, shipping-policy etc.) untitled. Round 6b uses :has()
   to only hide the small grey strip when something else can serve
   as the page heading.
   ============================================================ */

/* RESET round 6's blanket hide — restore mkd-standard-type by default */
.mkd-title-holder.mkd-standard-type,
.mkd-title-holder.mkd-breadcrumb-type:not(.mkd-centered-type),
.mkdf-title-holder.mkdf-standard-type,
.qode-title-holder.qode-standard-type,
.mkd-title-holder.mkd-page-title-default,
body.page .mkd-title.mkd-standard-type,
body.single .mkd-title.mkd-standard-type,
body.single-portfolio-item .mkd-title.mkd-standard-type,
body:not(.home):not(.archive):not(.search):not(.error404) > .mkd-title.mkd-standard-type {
  display: block !important;
  height: auto !important;
  min-height: 0 !important;
  visibility: visible !important;
  overflow: visible !important;
}

/* Hide BOTH duplicates on pages with only mkd-standard-type variants
   (sessions, shipra) — keep the one with breadcrumbs which is the
   richer banner; hide the plain duplicate. */
body:has(.mkd-title-holder.mkd-standard-with-breadcrumbs-type)
  .mkd-title.mkd-standard-type:not(.mkd-standard-with-breadcrumbs-type),
body:has(.mkd-title-holder.mkd-standard-with-breadcrumbs-type)
  .mkd-title-holder.mkd-standard-type:not(.mkd-standard-with-breadcrumbs-type) {
  display: none !important;
  height: 0 !important;
  visibility: hidden !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* On pages with a centered-type banner, the centered banner is
   primary — hide the small grey standard-type strip. */
body:has(.mkd-title-holder.mkd-centered-type)
  .mkd-title.mkd-standard-type,
body:has(.mkd-title-holder.mkd-centered-type)
  .mkd-title-holder.mkd-standard-type {
  display: none !important;
  height: 0 !important;
  visibility: hidden !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* On pages where the body content has its own H1 (e.g. /services/,
   /portfolio/), hide the redundant standard-type banner. */
body.page:has(.mkd-page-content h1):has(.mkd-title-holder.mkd-standard-type)
  .mkd-title.mkd-standard-type,
body.page:has(.mkd-content h1):has(.mkd-title-holder.mkd-standard-type)
  .mkd-title-holder.mkd-standard-type,
body.page-id-168 .mkd-title-holder.mkd-standard-type,
body.page-id-168 .mkd-title.mkd-standard-type,
body.page-id-10  .mkd-title-holder.mkd-standard-type,
body.page-id-10  .mkd-title.mkd-standard-type {
  display: none !important;
  height: 0 !important;
  visibility: hidden !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
}
