/**
 * メッセージカードコンポーネント
 */

/*
======================================
message card
======================================
*/
.message-card {
	--message-card-accent: var(--student-primary);
	--message-card-secondary: var(--student-secondary);
	background-color: var(--white);
	border-radius: 8px;
	box-shadow: 4px 5px 0 0 var(--message-card-accent);
	box-sizing: border-box;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	gap: 12px;
	/* overflow: hidden; */
	padding: 32px 42px 40px;
	position: relative;
	transition: width 0.3s ease, height 0.3s ease, opacity 0.3s ease, transform 0.3s ease;
	width: 380px;
	height: 260px;
}

.message-card__btn{
	align-items: flex-end;
	cursor: pointer;
	display: flex;
	position: absolute;
	right: 0;
	top: 0;
	transition: var(--transition-animation);
	z-index: 3;
	border-radius: 8px;
}

.message-card__btn:hover {
	transform: scale(1.05);
	right: 2px;
	top: 2px;
}

.message-card__title {
	color: var(--message-card-accent);
	font-size: var(--font-size-2xl);
	font-weight: var(--font-weight-bold);
	line-height: var(--line-height-none);
	margin: 0;
	max-width: 240px;
}

.message-card__meta {
	color: var(--message-card-secondary);
	font-size: var(--font-size-l);
	font-weight: var(--font-weight-medium);
	line-height: var(--line-height-normal);
	margin: 0;
}

.message-card__text {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4;
	color: var(--blue-primary);
	display: -webkit-box;
	font-size: var(--font-size-m);
	font-weight: var(--font-weight-medium);
	line-clamp: 4;
	line-height: var(--line-height-relaxed);
	margin: 0;
	overflow: hidden;
}

.message-card__kuti{
	position: absolute;
	bottom: -20px;
	left: 0;
}

.message-card--student {
	--message-card-accent: var(--student-primary);
	--message-card-secondary: var(--student-secondary);
}

.message-card--parent {
	--message-card-accent: var(--parent-primary);
	--message-card-secondary: var(--parent-secondary);
}

.message-card--graduate {
	--message-card-accent: var(--graduate-primary);
	--message-card-secondary: var(--graduate-secondary);
}

.message-card--university {
	--message-card-accent: var(--university-primary);
	--message-card-secondary: var(--university-secondary);
}

.message-card--other {
	--message-card-accent: var(--other-primary);
	--message-card-secondary: var(--other-secondary);
}

.message-card--staff {
	--message-card-accent: var(--staff-primary);
	--message-card-secondary: var(--staff-secondary);
}

/*
======================================
message card popup
======================================
*/
.message-card-popup {
	align-items: center;
	display: none;
	inset: 0;
	justify-content: center;
	position: fixed;
	z-index: 10000;
	height: 100vh;
}

.message-card-popup.is-open {
	display: flex;
}

.message-card-popup__overlay {
	background: rgba(var(--black-rgb), 0.4);
	cursor: pointer;
	inset: 0;
	position: absolute;
	z-index: 1;
}

.message-card-popup__content {
	position: relative;
	z-index: 2;
	position: fixed;
	transform: translate(-50%,-50%);
	top: 50%;
	left: 50%;
}

.message-card-popup__content .message-card {
	margin-bottom: 20px;
	max-width: 706px;
	
	width :90vw;
	height: auto;
	max-height: 80vh;
	min-height: 200px;
	overflow-y: auto;
}

.message-card-popup__content .message-card__text {
	display: block;
	overflow: clip;
}

/* ポップアップ内の画像 */
.message-card-popup__content .message-card__image-wrap {
	margin-top: 16px;
}

.message-card-popup__content .message-card__image {
	border-radius: 8px;
	display: block;
	height: auto;
	max-width: 622px;
	width: 100%;
	object-fit: contain;
}


/*
======================================
SP Media Query (max-width: 599px)
======================================
*/
@media screen and (max-width: 599px) {
	.message-card {
		border-radius: 8px;
		gap: 12px;
		padding: 20px 24px 24px;
		width: 272px;
		height: 185px;
	}

	.message-card::after {
		left: 73px;
	}

	.message-card::before {
		left: 75px;
	}

	.message-card__btn {
		width: 56px;
	}

	.message-card__btn::before {
		font-size: 20px;
	}

	.message-card__title {
		font-size: var(--font-size-xl);
	}

	.message-card__meta {
		font-size: var(--font-size-s);
	}

	.message-card__text {
		-webkit-line-clamp: 2;
		font-size: var(--font-size-m);
		line-clamp: 2;
	}

	/* === Message Card Popup === */
	.message-card-popup__content .message-card {
		margin-bottom: 20px;
		max-width: calc(100vw - 24px);
	}

	.message-card-popup__content .message-card__image-wrap {
		margin-top: 12px;
	}

	.message-card-popup__content .message-card__image {
		max-width: 100%;
	}
}
