/* SMEN — Card Grid */
.smen-cardgrid{
	width:100%;
}
.smen-cardgrid__list{
	display:grid;
	grid-template-columns:repeat(var(--cg-cols-pc, 2), 1fr);
	gap:var(--cg-gap, 36px);
}
@media(max-width:768px){
	.smen-cardgrid__list{
		grid-template-columns:repeat(var(--cg-cols-mo, 1), 1fr);
		gap:calc(var(--cg-gap, 36px) * .7);
	}
}

/* 카드 */
.smen-cardgrid__card{
	background:var(--cg-card-bg, #fff);
	border-radius:var(--cg-radius, 14px);
	overflow:hidden;
	display:flex;
	flex-direction:column;
	text-decoration:none;
	color:inherit;
	transition:transform .35s cubic-bezier(.22,.61,.36,1), box-shadow .35s;
}
a.smen-cardgrid__card:hover{color:inherit;}

/* 그림자 */
.smen-cardgrid.is-shadow-soft   .smen-cardgrid__card{box-shadow:0 1px 3px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.04);}
.smen-cardgrid.is-shadow-medium .smen-cardgrid__card{box-shadow:0 2px 6px rgba(0,0,0,.08), 0 16px 40px rgba(0,0,0,.08);}
.smen-cardgrid.is-shadow-strong .smen-cardgrid__card{box-shadow:0 4px 12px rgba(0,0,0,.12), 0 24px 60px rgba(0,0,0,.12);}
.smen-cardgrid.is-shadow-none   .smen-cardgrid__card{box-shadow:none;}
.smen-cardgrid:not(.is-shadow-none) .smen-cardgrid__card:hover{transform:translateY(-4px);}
.smen-cardgrid.is-shadow-soft   .smen-cardgrid__card:hover{box-shadow:0 4px 8px rgba(0,0,0,.08), 0 16px 40px rgba(0,0,0,.08);}
.smen-cardgrid.is-shadow-medium .smen-cardgrid__card:hover{box-shadow:0 6px 14px rgba(0,0,0,.10), 0 22px 50px rgba(0,0,0,.10);}
.smen-cardgrid.is-shadow-strong .smen-cardgrid__card:hover{box-shadow:0 8px 20px rgba(0,0,0,.16), 0 32px 80px rgba(0,0,0,.16);}

/* 미디어 (이미지 슬라이드 영역) */
.smen-cardgrid__media{
	position:relative;
	aspect-ratio:var(--cg-ratio, 4/3);
	background:#eee;
	overflow:hidden;
}
.smen-cardgrid__slides{
	position:absolute;inset:0;
	display:flex;
	width:100%;height:100%;
	transition:transform .5s cubic-bezier(.22,.61,.36,1);
}
.smen-cardgrid__slide{
	flex:0 0 100%;
	width:100%;height:100%;
	background-size:cover;
	background-position:center;
}
.smen-cardgrid__slide.is-empty{
	background:linear-gradient(135deg,#dadada,#9e9e9e);
}

/* 화살표 — 1px 라인 SVG */
.smen-cardgrid__arrow{
	position:absolute;top:50%;
	transform:translateY(-50%);
	width:30px;height:30px;
	background:transparent;
	border:none;
	display:flex;align-items:center;justify-content:center;
	cursor:pointer;
	padding:0;
	color:var(--cg-arrow, #fff);
	opacity:0;
	transition:opacity .25s;
	z-index:2;
}
.smen-cardgrid__arrow svg{width:18px;height:18px;display:block;}
.smen-cardgrid__arrow svg path{
	stroke:currentColor;
	stroke-width:1;
	fill:none;
	stroke-linecap:round;
	stroke-linejoin:round;
}
.smen-cardgrid__card:hover .smen-cardgrid__arrow{opacity:.85;}
.smen-cardgrid__card:hover .smen-cardgrid__arrow:hover{opacity:1;}
.smen-cardgrid__arrow--prev{left:14px;}
.smen-cardgrid__arrow--next{right:14px;}

/* 도트 */
.smen-cardgrid__dots{
	position:absolute;
	bottom:10px;left:50%;
	transform:translateX(-50%);
	display:flex;gap:6px;
	z-index:2;
}
.smen-cardgrid__dot{
	width:6px;height:6px;
	border-radius:50%;
	background:rgba(255,255,255,.5);
	transition:background .25s, width .25s;
	cursor:pointer;
}
.smen-cardgrid__dot.is-active{
	background:#fff;
	width:18px;
	border-radius:3px;
}

/* 카드 본문 */
.smen-cardgrid__body{
	padding:26px 28px 28px;
	display:flex;
	flex-direction:column;
	gap:12px;
	flex:1;
}
@media(max-width:768px){
	.smen-cardgrid__body{padding:20px 22px 22px;gap:10px;}
}
.smen-cardgrid__title{
	font-size:var(--cg-title-size, 22px);
	font-weight:600;
	color:var(--cg-title, #111);
	margin:0;
	letter-spacing:-.01em;
	line-height:1.3;
}
@media(max-width:768px){
	.smen-cardgrid__title{font-size:var(--cg-title-size-mo, 18px);}
}
.smen-cardgrid__desc{
	font-size:var(--cg-desc-size, 14.5px);
	color:var(--cg-desc, #666);
	line-height:1.75;
	margin:0;
	display:-webkit-box;
	-webkit-line-clamp:var(--cg-desc-lines, 3);
	-webkit-box-orient:vertical;
	overflow:hidden;
}
@media(max-width:768px){
	.smen-cardgrid__desc{
		font-size:var(--cg-desc-size-mo, 13px);
		-webkit-line-clamp:var(--cg-desc-lines-mo, 3);
	}
}

/* 팝업 트리거 */
[data-cg-popup] .smen-cardgrid__desc{cursor:pointer;}
[data-cg-popup] .smen-cardgrid__desc.is-clamped::after{
	content:'더 보기';
	display:block;
	margin-top:6px;
	font-size:12px;
	font-weight:500;
	color:var(--cg-more, #a89568);
	letter-spacing:.02em;
}

/* 팝업 오버레이 */
.cg-popup-overlay{
	display:none;
	position:fixed;inset:0;
	z-index:99999;
	background:rgba(0,0,0,.55);
	align-items:center;
	justify-content:center;
	padding:24px;
}
.cg-popup-overlay.is-open{display:flex;}
.cg-popup-modal{
	background:#fff;
	border-radius:16px;
	max-width:540px;
	width:100%;
	max-height:80vh;
	overflow-y:auto;
	padding:36px 40px 40px;
	position:relative;
	box-shadow:0 24px 80px rgba(0,0,0,.18);
}
@media(max-width:600px){.cg-popup-modal{padding:28px 24px 32px;}}
.cg-popup-close{
	position:absolute;top:16px;right:18px;
	width:32px;height:32px;
	background:none;border:none;
	font-size:22px;line-height:1;
	color:#999;cursor:pointer;
	display:flex;align-items:center;justify-content:center;
	border-radius:50%;
	transition:background .2s, color .2s;
}
.cg-popup-close:hover{background:#f0f0f0;color:#333;}
.cg-popup-title{
	font-size:20px;font-weight:700;
	color:#111;margin:0 0 16px;
	line-height:1.3;
	padding-right:24px;
}
.cg-popup-desc{
	font-size:14.5px;color:#555;
	line-height:1.85;
	white-space:pre-line;
	margin:0;
}

/* 자세히 버튼 */
.smen-cardgrid__meta{
	margin-top:auto;
	padding-top:16px;
	display:flex;
	justify-content:flex-end;
}
.smen-cardgrid__more{
	color:var(--cg-more, #a89568);
	text-decoration:none;
	font-weight:500;
	font-size:13px;
	display:inline-flex;
	align-items:center;
	gap:4px;
	transition:gap .25s, opacity .25s;
}
.smen-cardgrid__more:hover{gap:8px; opacity:.85;}
