/* Portfolio — client wall (homepage) + card grid (/portfolio page). */

.wblb-portfolio { max-width: 1320px; margin-inline: auto; padding: 48px 24px; }
.wblb-portfolio__heading {
	font-family: var(--wp--preset--font-family--serif, Georgia, serif);
	color: var(--wp--preset--color--cedar, #2f2a24);
	text-align: center; font-size: clamp(1.4rem, 1rem + 1.6vw, 2.1rem); margin: 0 0 28px;
}
.wblb-portfolio__items { list-style: none; margin: 0; padding: 0; display: grid; }

/* Wall: logo grid */
.wblb-portfolio--wall .wblb-portfolio__items {
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 28px 36px; align-items: center;
}
.wblb-portfolio--wall .wblb-portfolio__item a {
	display: flex; align-items: center; justify-content: center; min-height: 72px; text-decoration: none;
}
.wblb-portfolio--wall .wblb-portfolio__logo {
	max-height: 56px; max-width: 100%; width: auto; object-fit: contain;
	filter: grayscale(1); opacity: .7;
	transition: filter .25s ease, opacity .25s ease, transform .25s ease;
}
.wblb-portfolio--wall .wblb-portfolio__item a:hover .wblb-portfolio__logo,
.wblb-portfolio--wall .wblb-portfolio__item a:focus-visible .wblb-portfolio__logo {
	filter: grayscale(0); opacity: 1; transform: translateY(-2px);
}

/* Wordmark fallback (no logo) */
.wblb-portfolio__wordmark {
	display: flex; align-items: center; justify-content: center; min-height: 56px; padding: 8px 16px; width: 100%;
	background: var(--wp--preset--color--cedar, #2f2a24); color: #fff; font-weight: 700; border-radius: 8px; text-align: center;
}

/* Grid: framed cards (/portfolio page) */
.wblb-portfolio--grid .wblb-portfolio__items {
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 24px;
}
.wblb-portfolio--grid .wblb-portfolio__item a {
	display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 28px 20px; height: 100%; text-decoration: none;
	background: var(--wp--preset--color--cream, #f7f3ec); border: 1px solid rgba(0,0,0,.06); border-radius: 12px;
	transition: box-shadow .25s ease, transform .25s ease;
}
.wblb-portfolio--grid .wblb-portfolio__item a:hover { box-shadow: 0 8px 28px rgba(0,0,0,.10); transform: translateY(-3px); }
.wblb-portfolio--grid .wblb-portfolio__logo { max-height: 64px; max-width: 80%; object-fit: contain; }
.wblb-portfolio--grid .wblb-portfolio__name {
	font-family: var(--wp--preset--font-family--serif, Georgia, serif);
	color: var(--wp--preset--color--cedar, #2f2a24); font-size: 1.05rem; text-align: center;
}
.wblb-portfolio--grid .wblb-portfolio__visit { color: #b8893d; font-weight: 600; font-size: .85rem; }

/* Document: rich entries (logo + name + sector + description + badges) */
.wblb-portfolio--document .wblb-portfolio__entry {
	display: flex; gap: 32px; align-items: center; padding: 40px 0;
	border-bottom: 1px solid rgba(0,0,0,.08);
}
.wblb-portfolio--document .wblb-portfolio__entry:nth-child(even) { flex-direction: row-reverse; }
.wblb-portfolio--document .wblb-portfolio__media {
	flex: 0 0 260px; max-width: 260px; display: flex; align-items: center; justify-content: center;
}
.wblb-portfolio--document .wblb-portfolio__body { flex: 1; min-width: 0; }
.wblb-portfolio--document .wblb-portfolio__logo {
	max-height: 120px; max-width: 100%; object-fit: contain;
}
.wblb-portfolio--document .wblb-portfolio__name {
	font-family: var(--wp--preset--font-family--serif, Georgia, serif);
	color: var(--wp--preset--color--cedar, #2f2a24);
	font-size: 1.4rem; margin: 0 0 6px;
}
.wblb-portfolio--document .wblb-portfolio__sector {
	text-transform: uppercase; font-size: .78rem; letter-spacing: .12em;
	color: var(--wp--preset--color--olive, #6b6a3a); margin: 0 0 14px;
}
.wblb-portfolio--document .wblb-portfolio__desc p {
	line-height: 1.6; max-width: 60ch; margin: 0 0 12px;
	color: var(--wp--preset--color--cedar, #2f2a24);
}
.wblb-portfolio--document .wblb-portfolio__badges {
	display: flex; flex-wrap: wrap; gap: 8px; list-style: none; padding: 0; margin: 12px 0;
}
.wblb-portfolio--document .wblb-portfolio__badge {
	background: var(--wp--preset--color--cream, #f7f3ec); border: 1px solid #b8893d;
	border-radius: 999px; padding: 4px 12px; font-size: .78rem;
}
.wblb-portfolio--document .wblb-portfolio__visit {
	display: inline-block; margin-top: 8px; color: #b8893d; font-weight: 600; text-decoration: none;
}

/* Screenshot strip — horizontal, CSS-only scroll-snap (RTL-safe, no JS). */
.wblb-pf-shots {
	display: flex; gap: 14px; margin: 18px 0 6px;
	overflow-x: auto; overflow-y: hidden;
	padding-block-end: 10px;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	scrollbar-color: rgba(184,137,61,.6) transparent;
}
.wblb-pf-shots::-webkit-scrollbar { height: 8px; }
.wblb-pf-shots::-webkit-scrollbar-track { background: transparent; }
.wblb-pf-shots::-webkit-scrollbar-thumb { background: rgba(184,137,61,.6); border-radius: 999px; }
.wblb-pf-shots__item {
	flex: 0 0 auto; scroll-snap-align: start;
	width: clamp(220px, 42%, 340px);
	border-radius: 12px; overflow: hidden;
	border: 1px solid rgba(0,0,0,.08);
	box-shadow: 0 4px 16px rgba(0,0,0,.08);
	background: var(--wp--preset--color--cream, #f7f3ec);
}
.wblb-pf-shots__img {
	display: block; width: 100%; height: 190px;
	object-fit: cover; object-position: top center;
	transition: transform .3s ease;
}
.wblb-pf-shots__item:hover .wblb-pf-shots__img { transform: scale(1.03); }

@media (max-width: 782px) {
	.wblb-pf-shots { justify-content: flex-start; }
	.wblb-pf-shots__item { width: 78%; }
	.wblb-pf-shots__img { height: 200px; }
}
@media (max-width: 782px) {
	.wblb-portfolio--document .wblb-portfolio__entry { flex-direction: column !important; text-align: center; }
	.wblb-portfolio--document .wblb-portfolio__badges { justify-content: center; }
}

/* See-all button */
.wblb-portfolio__more { text-align: center; margin-top: 32px; }
.wblb-portfolio__button {
	display: inline-block; padding: 12px 26px; border-radius: 999px;
	background: #b8893d; color: #fff; font-weight: 600; text-decoration: none;
}
.wblb-portfolio__button:hover { filter: brightness(1.06); }

/* a11y: visually-hidden client name (RTL-safe; no off-screen positioning). */
.wblb-portfolio .screen-reader-text {
	position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0); clip-path: inset(50%); white-space: nowrap; border: 0;
}
