@charset "utf-8";

/*
 * wr-portfolio 위젯 — 메인 페이지용 포트폴리오 카드
 * 테마 배경(#2d2f3e)과 조화되는 색상 사용
 */

/* ── CSS 변수 ──────────────────────────────────────── */
.pf-widget-gallery {
	--pfw-bg-card   : #181727;
	--pfw-bg-hover  : #252440;
	--pfw-border    : rgba(97, 93, 250, 0.18);
	--pfw-border-h  : rgba(97, 93, 250, 0.50);
	--pfw-text      : rgba(210, 208, 255, 0.85);
	--pfw-text-b    : #ffffff;
	--pfw-muted     : rgba(165, 162, 240, 0.50);
	--pfw-primary   : #615dfa;
	--pfw-primary-bg: rgba(97, 93, 250, 0.12);
	--pfw-primary-bd: rgba(97, 93, 250, 0.28);
	--pfw-grad      : linear-gradient(135deg, #615dfa 0%, #8b5cf6 100%);
	--pfw-grad-gold : linear-gradient(135deg, #f0c040 0%, #e8953a 100%);
}

/* ── 갤러리 래퍼 ───────────────────────────────────────
   overflow-x: clip → 가로 음수마진 클리핑만, 세로는 열어둬
   호버 translateY + 글로우 테두리가 위쪽에서 잘리지 않게 */
.pf-widget-gallery {
	overflow-x: clip;   /* 가로만 클리핑 (세로는 visible 유지) */
	padding-top: 8px;   /* 첫 행 카드 호버 그림자·테두리 여백 */
	margin-top: -8px;   /* 외부 레이아웃 간격 보정 */
}
.pf-widget-gallery .pf-grid {
	list-style: none;
	margin: 0 !important;
	padding: 0;
}

/* ── 카드 inner ────────────────────────────────────── */
.pf-widget-gallery .pf-card__inner {
	border-radius: 12px;
	overflow: hidden;
	background: var(--pfw-bg-card);
	border: 1px solid var(--pfw-border);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.30);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	position: relative;
	color: var(--pfw-text);
}
.pf-widget-gallery .pf-card:hover .pf-card__inner {
	transform: translateY(-4px);
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45),
	            0 0 0 1px var(--pfw-border-h);
	border-color: rgba(95, 104, 250, 0.50);
	background: var(--pfw-bg-hover);
}

/* ── 썸네일 ────────────────────────────────────────── */
.pf-widget-gallery .pf-card__thumb-link {
	display: block;
	position: relative;
	overflow: hidden;
}
.pf-widget-gallery .pf-card__thumb {
	position: relative;
	width: 100%;
	background: #0a0917;
	overflow: hidden;
}
.pf-widget-gallery .pf-card__img {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
	display: block;
}
.pf-widget-gallery .pf-card:hover .pf-card__img {
	transform: scale(1.05);
}
.pf-widget-gallery .pf-card__no-img {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--pfw-muted);
	font-size: 2rem;
}

/* ── 오버레이 ──────────────────────────────────────── */
.pf-widget-gallery .pf-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(10,10,25,0) 35%, rgba(10,10,25,0.85) 100%);
	opacity: 0;
	transition: opacity .25s;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding-bottom: 16px;
	z-index: 2;
}
.pf-widget-gallery .pf-card:hover .pf-card__overlay {
	opacity: 1;
}
.pf-widget-gallery .pf-card__overlay-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--pfw-grad);
	color: #fff;
	border-radius: 30px;
	padding: 7px 18px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .03em;
	box-shadow: 0 3px 12px rgba(95, 104, 250, 0.55);
	transform: translateY(8px);
	transition: transform .25s;
	white-space: nowrap;
}
.pf-widget-gallery .pf-card:hover .pf-card__overlay-btn {
	transform: translateY(0);
}

/* ── NEW 뱃지 ──────────────────────────────────────── */
.pf-widget-gallery .pf-card__badge {
	position: absolute;
	top: 10px; right: 10px;
	z-index: 4;
	border-radius: 6px;
	padding: 2px 8px;
	font-size: 10px;
	font-weight: 800;
	letter-spacing: .06em;
	text-transform: uppercase;
}
.pf-widget-gallery .pf-card__badge--new {
	background: var(--pfw-grad-gold);
	color: #1a1406;
	box-shadow: 0 2px 6px rgba(240,192,64,0.40);
}

/* ── 카드 바디 ─────────────────────────────────────── */
.pf-widget-gallery .pf-card__body {
	padding: 14px 14px 16px;
}
.pf-widget-gallery .pf-card__cat {
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .07em;
	text-transform: uppercase;
	color: var(--pfw-primary);
	background: var(--pfw-primary-bg);
	border: 1px solid var(--pfw-primary-bd);
	border-radius: 20px;
	padding: 2px 10px;
	margin-bottom: 7px;
}
.pf-widget-gallery .pf-card__title {
	margin: 0 0 8px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.45;
	letter-spacing: -.02em;
	color: var(--pfw-text-b);
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.pf-widget-gallery .pf-card__title a {
	color: inherit !important;
	text-decoration: none !important;
}
.pf-widget-gallery .pf-card__title a:hover {
	color: #fff !important;
}
.pf-widget-gallery .pf-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	font-size: 11px;
	color: var(--pfw-muted);
}
.pf-widget-gallery .pf-card__client,
.pf-widget-gallery .pf-card__date {
	display: flex;
	align-items: center;
	gap: 4px;
}

/* ── 빈 메시지 ─────────────────────────────────────── */
.pf-widget-gallery .pf-empty {
	color: var(--pfw-muted);
	padding: 60px 20px;
	text-align: center;
}
.pf-widget-gallery .pf-empty i { opacity: .35; }

/* ── 모바일: 1열 가로 레이아웃 ─────────────────────── */
@media (max-width: 575px) {
	.pf-widget-gallery .pf-grid .pf-card {
		flex: 0 0 100% !important;
		max-width: 100% !important;
		padding-bottom: 10px !important;
	}
	.pf-widget-gallery .pf-card__inner {
		display: flex;
		flex-direction: row;
		align-items: stretch;
		min-height: 96px;
	}
	.pf-widget-gallery .pf-card__thumb-link {
		flex: 0 0 130px;
		width: 130px;
	}
	.pf-widget-gallery .pf-card__thumb {
		padding-bottom: 0 !important;
		height: 100%;
		min-height: 96px;
	}
	.pf-widget-gallery .pf-card__body {
		flex: 1;
		padding: 10px 12px;
		display: flex;
		flex-direction: column;
		justify-content: center;
		min-width: 0;
	}
	.pf-widget-gallery .pf-card__title {
		font-size: 13px;
		margin-bottom: 5px;
	}
	.pf-widget-gallery .pf-card__overlay { display: none; }
	.pf-widget-gallery .pf-card:hover .pf-card__inner {
		transform: none;
		box-shadow: none;
	}
}
