@charset "utf-8";

.page-visual .container {
	display: flex;
	justify-content: center;
	align-items: center;
}
.page-visual h2 {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	white-space: nowrap;
	line-height: 2;
}

.page-visual h2 span {
	font-size: var(--fz-20);
	display: block;
	margin-bottom: 0.2em;
	display: flex;
	align-items: center;
	gap: 4px;
}


.page-visual h2 .four {
	width: 24px;
}
.page-visual h2 .cnum {
	width: 20px;
}





.headtbl {
	margin-bottom: 60px;
}

.tblcell {
	display: flex;
	width: 100%;
}

.divth, .divtd, .divtdr {
	flex: 1;
	display: flex;
	flex-direction: column;
	position: relative;
}

.tblcell .divth {
	flex: 3;
	font-size: var(--fz-20);
	font-weight: var(--fw-bold);
	line-height: 1.8;
}
.tblcell .divth span {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
}

.tblcell .divtd {
	flex: 4;
	font-size: var(--fz-16);
}
.tblcell .divtdr {
	flex: 4;
	font-size: var(--fz-16);
}

.tblcell .divth .simple-frame-inner,
.tblcell .divtd .simple-frame-inner,
.tblcell .divtdr .simple-frame-inner {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: relative;
	padding: 40px 30px;
	width: 100%;
	text-align: center;
}
.tblcell .divtd .simple-frame-inner,
.tblcell .divtdr .simple-frame-inner {
	padding: 5px;
}

.tblcell .divtd .simple-frame-inner .scbox,
.tblcell .divtdr .simple-frame-inner .scbox,
.tblcell .divtd .simple-frame-inner .ptbox,
.tblcell .divtdr .simple-frame-inner .otbox,
.tblcell .divtdr .simple-frame-inner .ynbox {
	padding: 20px;
	width: 100%;
	border-radius: 10px;
	color: var(--color-wh);
	font-size: var(--fz-18);
	font-weight: var(--fw-bold);
	line-height: 1;
}
.tblcell .divtd .simple-frame-inner .scbox,
.tblcell .divtdr .simple-frame-inner .scbox {
	background: var(--color-org);
}
.tblcell .divtd .simple-frame-inner .ptbox {
	background: #0086C9;
}
.tblcell .divtdr .simple-frame-inner .otbox {
	background: #FBCA41;
}
.tblcell .divtdr .simple-frame-inner .ynbox {
	background: #00B097;
}

.tblcell .divtd .simple-frame-inner .scbox strong,
.tblcell .divtdr .simple-frame-inner .scbox strong,
.tblcell .divtd .simple-frame-inner .ptbox strong,
.tblcell .divtdr .simple-frame-inner .otbox strong,
.tblcell .divtdr .simple-frame-inner .ynbox strong {
	font-size: 72px;
}


.divth::before,
.divth::after,
.divtd::before,
.divtd::after,
.divtdr::before,
.divtdr::after {
	content: "";
	position: absolute;
	height: 1px;
	background: var(--color-bk);
}
.divth::before,
.divtd::before,
.divtdr::before { top: 0; }
.divth::after,
.divtd::after,
.divtdr::after { bottom: 0; }


.tblcell .divth::before,
.tblcell .divth::after { left: 0; right: 0; }
.tblcell .divtd::before,
.tblcell .divtd::after { left: 0; right: 0; }
.tblcell .divtdr::before,
.tblcell .divtdr::after { left: 0; right: 0; }


.tblcell .divtd .simple-frame-inner::before,
.tblcell .divtd .simple-frame-inner::after {
	content: "";
	position: absolute;
	width: 1px;
	background: var(--color-bk);
	top: 10px;
	bottom: 10px;
}
.tblcell .divtd .simple-frame-inner::before { left: 0; }
.tblcell .divtd .simple-frame-inner::after { right: 0; }


.tblcell.lastchild .divth::before,
.tblcell.lastchild .divtd::before,
.tblcell.lastchild .divtdr::before { 
	background: none;
}



.strengthtitle {
	margin-bottom: 80px;
}

.strengthtitle h3 {
	font-size: var(--fz-28);
	font-weight: var(--fw-bold);
	margin-bottom: 40px;
	padding-top: 20px;
	border-top: 1px solid var(--color-bk);
	position: relative;
	text-align: center;
	line-height: 1.2;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.strengthtitle h3 small {
	position: absolute;
	left: 0;
	top: 30px;
	padding-left: 20px;
	display: inline-flex;
	align-items: center;
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
}

.strengthtitle h3 small::after {
	content: "";
	display: inline-block;
	width: 1px;
	height: 80px;
	background: var(--color-bk);
	margin-left: 20px;
}

.strengthtitle .fukidashi {
	display: inline-block;
	position: relative;
	padding: 8px 20px;
	margin-bottom: 15px;
	color: var(--color-wh);
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	border-radius: 10px;
	line-height: 1.2;
	background: var(--color-org);
}

.strengthtitle .fukidashi::after {
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 8px solid transparent;
	border-top-color: var(--color-org);
}


.strengthpoint {
	display: flex;
	gap: 30px;
	padding-bottom: 80px;
	flex-wrap: wrap
}

.strengthpoint article {
	flex: 0 0 calc(50% - 15px);
	background: var(--color-beg5);
	border-radius: 15px;
	display: flex;
	flex-direction: column;
	padding: 0 15px 15px;
}

.strengthpoint figure {
	margin: 0 -15px 35px;
	position: relative;
}

.strengthpoint figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 15px 15px 0 0;
}

.strengthpoint figure span {
	position: absolute;
	bottom: -35px;
	left: 50%;
	transform: translate(-50%, -50%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--color-wh);
	color: var(--color-org);
	font-size: var(--fz-20);
	font-weight: var(--fw-bold);
	width: 160px;
	height: 44px;
	border-radius: 10px;
	z-index: 10;
}

.strengthpoint span::after {
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border-top: 10px solid var(--color-wh);
	border-right: 8px solid transparent;
	border-left: 8px solid transparent;
}

.strengthpoint article div {
	background: var(--color-wh);
	border-radius: 10px;
	padding: 20px;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.strengthpoint h4 {
	font-size: var(--fz-24);
	font-weight: var(--fw-bold);
	color: var(--color-org);
	line-height: 1.5;
	margin-bottom: 10px;
	text-align: center;
}

.strengthpoint p {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	line-height: 1.7;
	padding: 0;
}


.strength_message {
	background: var(--color-beg5);
	padding: 50px 0;
	margin-bottom: 100px;
}

.strength_message h3 {
	font-size: var(--fz-20);
	font-weight: var(--fw-bold);
	color: var(--color-org);
	text-align: center;
}

.strength_message {
	background: var(--color-beg5);
	padding: 80px 0;
	margin-bottom: 100px;
}

.strength_message h3 {
	font-size: var(--fz-20);
	font-weight: var(--fw-bold);
	color: var(--color-org);
	text-align: center;
	margin-bottom: 40px;
}

.strength_message ul {
	display: flex;
	gap: 40px;
}

.strength_message li {
	flex: 1;
	background: var(--color-wh);
	border-radius: 15px;
	padding: 20px;
}

.strength_message header {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	margin-bottom: 20px;
}

.strength_message figure {
	flex: 0 0 clamp(70px, 70px + 5vw, 140px);
	margin: 0;
}

.strength_message figure img {
	width: 100%;
	border-radius: 10px;
}

.strength_message header div {
	flex: 1;
}
.strength_message header .course {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	text-align: right;
	padding-bottom: 0;
}
.strength_message header .school {
	font-size: var(--fz-16);
	text-align: right;
	padding-bottom: .4em;
}
.strength_message header .name {
	font-size: var(--fz-16);
	text-align: right;
	padding-bottom: .8em;
}

.strength_message header .name span {
	font-size: var(--fz-13);
}

.strength_message .catchpc {
	display: block;
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	line-height: 1.4;
	padding-bottom: 0;
}

.strength_message .catchsp {
	display: none;
}

.strength_message .catchpc span,
.strength_message .catchsp span {
	color: var(--color-org);
}

.strength_message .content p {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	line-height: 1.8;
	padding-bottom: 0;
}



.strengthpicbox {
	padding-bottom: 80px;
}
.strengthpicbox .bflex {
	display: flex;
	gap: 20px;
	align-items: flex-start;
}
.strengthpicbox .bflex:nth-child(2) {
	margin-top: 40px;
	flex-direction: row-reverse;
}

.strengthpicbox .bflex figure {
	flex: 0 0 clamp(180px, 32%, 330px);
	margin: 0;
}

.strengthpicbox .bflex figure img {
	width: 100%;
	border-radius: 10px;
}

.strengthpicbox .bflex div {
	flex: 1;
}

.strengthpicbox .bflex h4 {
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	color: var(--color-org);
	padding-bottom: 1em;
}

.strengthpicbox .bflex p {
	font-size: var(--fz-16);
	padding-bottom: 0;
}



.aftersupport {
	margin-bottom: 100px;
}

.aftersupport h4 {
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	color: var(--color-org);
	text-align: center;
	padding-bottom: 1em;
}
.aftersupport h4 p {
	font-size: var(--fz-16);
	font-weight: var(--fw-regular);
	padding-bottom: 0;
}




/* --- 就職先一覧 セクション全体 --- */
.strengthpicbox .job_list {
	margin-top: 50px;
}

.strengthpicbox .job_list h3 {
	font-size: var(--fz-20);
	font-weight: var(--fw-bold);
	background: var(--color-org);
	color: var(--color-wh);
	text-align: center;
	border-radius: 10px;
	padding: 10px;
	margin-bottom: 30px;
}

/* 学科ラベル（PT/OT） */
.strengthpicbox .job_list .pt,
.strengthpicbox .job_list .ot {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	border-bottom: 1px solid var(--color-bk);
	padding-bottom: 5px;
	margin-bottom: 15px;
	text-align: center;
}

.strengthpicbox .job_list .pt { color: #0086C9; }
.strengthpicbox .job_list .ot { color: #FBCA41; }

/* 病院名リスト（共通） */
.strengthpicbox .job_list .jobs {
	font-size: var(--fz-16);
	line-height: 1.6;
	text-align: justify;
	word-break: break-all;
	margin-bottom: 30px;
}

.strengthpicbox .more_btn {
	display: none;
}





/* --- キャリア支援室セクション --- */
.career_support {
	background: var(--color-beg5);
	padding: 80px 0;
	margin-bottom: 100px;
}

.career_support h3 {
	font-size: var(--fz-24);
	font-weight: var(--fw-bold);
	color: var(--color-org);
	text-align: center;
	margin-bottom: 40px;
}

.career_box {
	background: var(--color-wh);
	border-radius: 15px;
	padding: 40px;
	display: flex;
	flex-wrap: wrap;
	gap: 30px 40px;
}

.career_info {
	flex: clamp(140px, 15%, 180px);
	max-width: 180px;
	text-align: center;
}

.career_text {
	flex: 1;
}


.newsletter_box {
	flex: 0 0 100%;
	background: #FFF8EF;
	border-radius: 10px;
	padding: 25px;
}

/* --- 以下、装飾設定（前回同様） --- */
.career_info figure {
	margin: 0;
	width: 100%;
}
.career_info figure img {
	width: 100%;
	border-radius: 10px;
}
.career_info .teacher_name {
	font-size: var(--fz-16);
	font-weight: var(--fw-regular);
	line-height: 1.4;
	margin-top: 10px;
}
.career_info .teacher_name span {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
}
.career_text p {
	font-size: var(--fz-16);
	line-height: 1.8;
	margin-bottom: 1em;
}
.career_text .underline {
	background: linear-gradient(transparent 95%, var(--color-bk) 95%);
}
.newsletter_box h4 {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	font-size: var(--fz-18);
	font-weight: var(--fw-bold);
	margin-bottom: 15px;
}
.newsletter_box h4 img {
	width: 25px;
}
.newsletter_box ul {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 30px;
}
.newsletter_box li a {
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	text-decoration: underline;
	color: var(--color-bk);
}




/* --- 学費セクション --- */
.cost_section {
	margin-bottom: 80px;
}

.cost_box {
	display: flex;
	align-items: center;
	gap: 40px;
}

.cost_content {
	flex: 1;
}

.cost_content h3 {
	font-size: var(--fz-18);
	color: var(--color-org);
	font-weight: var(--fw-bold);
	line-height: 1.5;
	margin-bottom: 40px;
}

.cost_content ul {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.cost_content ul li {
	display: flex;
	align-items: flex-start;
	gap: 15px;
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	line-height: 1.6;
}

.cost_content ul .icon_check {
	width: 20px; /* アイコンのサイズ */
	height: auto;
	margin-top: 4px; /* テキストの1行目と高さを微調整 */
}

/* グラフ画像エリア */
.cost_image {
	flex: 0 0 clamp(350px, 45%, 550px); /* グラフの可変設定 */
}

.cost_image img {
	width: 100%;
	height: auto;
}





.scholarship_section {
	margin-bottom: 80px;
}

.scholarship_grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px 40px;
	margin-bottom: 40px;
}


.scholar_card h4 {
	border-radius: 10px;
	color: var(--color-wh);
	padding: 4px 0;
	font-size: var(--fz-20);
	font-weight: var(--fw-bold);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
}

.scholar_card.green h4 { background: #00B097; }
.scholar_card.orange h4 { background: #ED8000; }

.scholar_card .tag {
	background: var(--color-bk);
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	padding: 2px 4px;
	border-radius: 4px;
}

.scholar_card .card_content {
	padding: 25px 0;
}

.scholar_card .card_content p {
		font-size: var(--fz-16);
		line-height: 1.7;
}


.special_reward_card {
	display: flex;
	border-radius: 15px;
	background: var(--color-beg5);
	overflow: hidden;
	align-items: stretch;
}

.special_reward_card figure {
	flex: 0 0 35%;
	margin: 0;
}

.special_reward_card figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.special_reward_card .reward_content {
	flex: 1;
	margin: 20px; 
	padding: 30px;
	background: var(--color-wh);
	border-radius: 10px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	font-size: var(--fz-16);
}

.special_reward_card h5 {
	font-size: var(--fz-16);
	color: var(--color-org);
	font-weight: var(--fw-bold);
	margin-bottom: 15px;
}











.recommend_support {
	background: #fbe6cc;
	padding: 80px 0;
	text-align: center;
}

.recommend_support .support_title {
	position: relative;
	margin-bottom: 40px;
	padding: 20px 0;
	background-image: url('../../images/strength/decor_confetti_pc.svg');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
}

.recommend_support .sub_title {
	font-size: var(--fz-24);
	font-weight: var(--fw-bold);
	display: inline-block;
	position: relative;
	padding: 0 1.5em;
	margin-bottom: 10px;
}

.recommend_support .sub_title::before,
.recommend_support .sub_title::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 2px;
	height: 0.8em;
	background-color: #00B097;
}

.recommend_support .sub_title::before {
	left: 0;
	transform: translateY(-50%) rotate(-25deg);
}

.recommend_support .sub_title::after {
	right: 0;
	transform: translateY(-50%) rotate(25deg);
}

/* 袋文字タイトル */
.recommend_support .main_title {
	font-size: var(--fz-28);
	font-weight: var(--fw-bold);
	color: var(--color-wh);
	line-height: 1.3;
	text-shadow: 
		2px 2px 0 #B9B9B9, -2px 2px 0 #B9B9B9, 
		2px -2px 0 #B9B9B9, -2px -2px 0 #B9B9B9, 
		2px 0 0 #B9B9B9, -2px 0 0 #B9B9B9, 
		0 2px 0 #B9B9B9, 0 -2px 0 #B9B9B9;
}

.recommend_support .main_title strong {
	font-size: var(--fz-40);
}

/* 3つのタブ（アンカーボタン） */
.recommend_support .support_tabs {
	display: flex;
	gap: 15px;
	margin: 40px 0 60px;
}

.recommend_support .support_tabs a {
	flex: 1;
	background: var(--color-wh);
	padding: 5px 15px;
	border-radius: 15px;
	font-size: var(--fz-18);
	font-weight: var(--fw-bold);
	color: var(--color-bk);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	text-decoration: none;
}

.recommend_support .support_tabs a span {
	color: var(--color-org);
	font-size: var(--fz-30);
	margin-top: -5px;
}

/* タブの右側の矢印(V字) */
.recommend_support .support_tabs a::after {
	content: "";
	width: 10px;
	height: 10px;
	border-right: 1px solid var(--color-bk);
	border-bottom: 1px solid var(--color-bk);
	transform: rotate(45deg);
	margin-left: auto;
}

/* コンテンツエリア（吹き出し付き白ボックス） */
.recommend_support .support_content {
	position: relative;
	margin-top: 50px;
}

.recommend_support .support_content .label {
	position: absolute;
	top: -22px;
	left: 0;
	background: var(--color-org);
	color: var(--color-wh);
	padding: 6px 20px;
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	border-radius: 10px;
	z-index: 2;
}

/* 吹き出しの三角部分 */
.recommend_support .support_content .label::after {
	content: "";
	position: absolute;
	bottom: -8px;
	left: 20px;
	border-left: 9px solid transparent;
	border-right: 9px solid transparent;
	border-top: 9px solid var(--color-org);
}

.recommend_support .support_content .inner_box {
	background: var(--color-wh);
	border-radius: 15px;
	padding: 30px;
	text-align: left;
}

.recommend_support .content_header {
	display: flex;
	align-items: center;
	gap: 15px;
	border-bottom: 1px solid var(--color-bk);
	padding-bottom: 15px;
	margin-bottom: 30px;
}

.recommend_support .content_header .num {
	font-size: var(--fz-40);
	font-weight: var(--fw-bold);
	color: var(--color-org);
	padding: 0 30px;
	line-height: 1;
	border-right: 1px solid var(--color-bk);
}

.recommend_support .content_header h4 {
	font-size: var(--fz-24);
	font-weight: var(--fw-bold);
	color: var(--color-org);
}





.support_detail {
	padding: 20px 40px;
}

.recommend_support .intro_text {
	margin-bottom: 30px;
}
.recommend_support .intro_text p {
	font-size: var(--fz-16);
	line-height: 1.8;
}
.recommend_support .intro_text .st {
	font-weight: var(--fw-bold);
}
.recommend_support .intro_text .ca {
	font-size: var(--fz-13);
	font-style: normal;
}
.recommend_support .intro_text p strong {
	color: var(--color-org);
	font-weight: var(--fw-bold);
}
.recommend_support .intro_text p span {
	-webkit-text-emphasis: filled sesame var(--color-org);
	text-emphasis: filled sesame var(--color-org);
	text-emphasis-position: over;
	display: inline-block; 
	line-height: 1.8;
}

.recommend_support .merit_box {
	position: relative;
	background: #F2F0EA;
	border-radius: 15px;
	padding: 35px 20px;
	text-align: center;
	margin-bottom: 40px;
}


.recommend_support .merit_box .title {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	padding: 0 40px;
	white-space: nowrap;
	display: inline-block;
}
.recommend_support .merit_box .title span {
	-webkit-text-emphasis: filled sesame var(--color-org);
	text-emphasis: filled sesame var(--color-org);
	text-emphasis-position: over;
	display: inline-block; 
	line-height: 1.8;
}

.recommend_support .merit_box .title::before,
.recommend_support .merit_box .title::after {
	content: "";
	position: absolute;
	top: 50%;
	margin-top: -20px; 
	width: 2px;
	height: 30px;
	background: var(--color-org);
	z-index: 10;
}

.recommend_support .merit_box .title::before {
	left: 0;
	transform: rotate(-25deg);
}

.recommend_support .merit_box .title::after {
	right: 0;
	transform: rotate(25deg);
}

.recommend_support .merit_box .highlight {
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	color: var(--color-bk);
	padding-bottom: 0;
}
/* 特定部分の太字と下線 */
.recommend_support .merit_box strong {
		font-weight: var(--fw-bold);
		text-decoration: underline;
		text-decoration-color: #00B097; /* 学科名の下線はグリーン */
		text-decoration-thickness: 2px;
		text-underline-offset: 4px;
}



/* コンテナ全体の並び */
.recommend_support .benefit_container {
	display: flex;
	align-items: flex-start;
	gap: 30px;
	margin-top: 40px;
}

.recommend_support .table_illust {
	flex: 0 0 40%;
	max-width: 400px;
}
.recommend_support .table_illust img {
	width: 100%;
	height: auto;
}

/* 給付額表エリア */
.recommend_support .benefit_content {
	flex: 1;
	display: flex;
	flex-direction: column;
}

/* 表のヘッダー */
.recommend_support .benefit_header {
	background: #00B097; /* グリーン */
	color: var(--color-wh);
	font-weight: var(--fw-bold);
	border-bottom: 2px solid var(--color-wh);
	padding: 15px;
	flex: 1;
	text-align: center;
}

/* 各行のスタイル */
.recommend_support .benefit_row {
	display: flex;
	border-bottom: 2px solid var(--color-wh);
	background: var(--color-beg3);
}
.recommend_support .benefit_row > div {
	padding: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.recommend_support .row_label {
	flex: 1;
	font-weight: var(--fw-bold);
	line-height: 1.4;
	border-right: 2px solid #fff;
	flex-direction: column;
}
.recommend_support .row_label small {
	font-size: var(--fz-13);
	font-weight: var(--fw-medium);
	text-align: center;
}

.recommend_support .row_value {
	flex: 0 0 40%;
	font-weight: var(--fw-bold);
	display: flex;
	align-items: baseline !important; 
	justify-content: center;
}
.recommend_support .row_value span {
	font-size: var(--fz-40);
	color: var(--color-org);
	margin-right: 2px;
	line-height: 1;
}

/* 合計行 */
.recommend_support .total_row {
	background: #D9D2B7; /* 濃いベージュ */
}

.recommend_support .benefit_content .caption {
	text-align: left;
	margin-top: 10px;
	font-size: var(--fz-13);
	line-height: 1.4;
}







.recommend_support .target_section {
	display: flex;
	align-items: flex-start;
	gap: 20px;
	margin: 50px 0;
	text-align: left;
}

/* 吹き出しラベルエリア */
.recommend_support .target_label {
	flex: 0 0 160px;
}

.recommend_support .target_label img {
	width: 100%;
	height: auto;
	display: block;
}

/* リストエリア */
.recommend_support .target_list {
	flex: 1;
}

.recommend_support .target_list li {
	line-height: 1.8;
	font-weight: var(--fw-medium);
}


.recommend_support .target_list li strong {
	color: var(--color-org);
	font-weight: var(--fw-bold);
}






.recommend_support .flow_check_section {
	margin: 60px 0;
	padding: 20px 30px 40px;
	border: 3px dotted var(--color-bk);
	border-radius: 15px;
}

.recommend_support .flow_check_section legend {
	font-size: var(--fz-20);
	font-weight: var(--fw-medium);
	color: var(--color-org);
	text-align: center;
	margin: 0 auto;
	padding: 0 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 15px;
	border: none;
	position: relative;
	line-height: 1.5;
}

/* ライン専用の要素を作成 */
.recommend_support .flow_check_section legend::after {
	content: "";
	position: absolute;
	/* ★ここがポイント：100%ではなく、左右の端を0に固定する */
	left: 0;
	right: 0;
	bottom: -20px;      /* 位置の下げ具合。お好みで調整してください */
	height: 18px;       /* SVGの高さ */
	background: url('../../images/strength/line_step.svg') no-repeat center center;
	background-size: 100% auto; /* 横幅いっぱいに引き伸ばす */
	pointer-events: none;
}

/* 画像とスクロールの設定（変更なし） */
.recommend_support .scroll_wrapper {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	margin-top: 20px;
}

.recommend_support .flow_chart_image {
	min-width: 800px;
}





.recommend_support .flow_step_section {
	display: flex;
	align-items: flex-start;
	gap: 40px;
	margin-top: 60px;
}

.recommend_support .step_label {
	flex: 0 0 160px;
}
.recommend_support .step_label img {
	width: 100%;
}

.recommend_support .step_list {
	flex: 1;
	padding: 0 0 0 30px;
	position: relative;
}

/* 垂直ライン */
.recommend_support .step_list::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 8px;
	background: var(--color-beg2);
}

.recommend_support .step_list li {
	margin-bottom: 20px;
}
.recommend_support .step_list li:last-child {
	margin-bottom: 0;
}

/* STEP 1 などのラベル */
.recommend_support .step_num {
	display: inline-block;
	background: var(--color-beg2);
	color: var(--color-bk);
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	padding: 2px 15px;
	border-radius: 20px;
	margin-bottom: 10px;
}

.recommend_support .step_list p {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	line-height: 1.6;
	color: var(--color-bk);
	margin: 0;
}








/* セクション全体 */
.recommend_support .shogakukin_section {
	margin: 80px 0 60px;
	border-radius: 15px;
	position: relative;
	background: var(--color-wh);
}

/* 枠線に乗るタイトル（CSS吹き出し版） */
.recommend_support .shogakukin_title {
	position: absolute;
	top: -12px;
	left: 5px;
	transform: translateY(-50%);
	z-index: 2;

	/* 吹き出し本体のスタイル */
	background: var(--color-gray);
	color: var(--color-wh);
	font-size: var(--fz-16);
	font-weight: var(--fw-bold);
	padding: 4px 25px;
	border-radius: 10px; /* 角丸で吹き出しらしく */
	white-space: nowrap;
}

/* 吹き出しのしっぽ（三角形） */
.recommend_support .shogakukin_title::after {
	content: "";
	position: absolute;
	bottom: -8px; /* 下側に配置 */
	left: 30px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 8px 0 8px; /* 三角形の形を調整 */
	border-color: var(--color-gray) transparent transparent transparent;
}


/* PC版：テーブルスタイル */
.recommend_support .shogakukin_table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	
	border: 1px solid var(--color-org);
	border-radius: 15px;
	overflow: hidden;
}
/* 小さいテーブル用の設定 */
.shogakukin_table_container.is-small {
	width: 40%;
	margin-top: 15px;
}
.recommend_support .shogakukin_table th {
	background: var(--color-org);
	color: var(--color-wh);
	font-weight: var(--fw-bold);
	padding: 5px;
	text-align: center;
	border-bottom: 1px solid var(--color-wh);
	border-right: 1px solid var(--color-wh);
}

.recommend_support .shogakukin_table td {
	padding: 15px;
	font-size: var(--fz-15);
	line-height: 1.6;
	border-bottom: 1px solid var(--color-org);
	border-right: 1px solid var(--color-org);
	white-space: nowrap;
}

.recommend_support .shogakukin_table th:last-child,
.recommend_support .shogakukin_table td:last-child {
	border-right: none;
}

.recommend_support .shogakukin_table tr:last-child td {
	border-bottom: none;
}
.recommend_support .shogakukin_table .hosname {
	background: var(--color-beg3);
	font-weight: var(--fw-medium);
}
.recommend_support .shogakukin_table .pt,
.recommend_support .shogakukin_table .ot {
	background: #0086C9;
	border-radius: 4px;
	display: inline-block;
	padding: 2px 4px;
	margin: 0 2px;
	color: var(--color-wh);
	font-weight: var(--fw-bold);
}
.recommend_support .shogakukin_table .ot {
	background: #FBCA41;
}
.recommend_support .shogakukin_table .tohos {
	white-space: pre-wrap
}










.support_system_section li {
	margin-bottom: 60px;
}


.support_system_section h3 {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
	font-size: var(--fz-20);
	font-weight: var(--fw-bold);
	color: var(--color-org);
	margin-bottom: 20px;
	position: relative;
	padding-left: 20px;
}

.support_system_section h3::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.1em;
	bottom: 0.1em;
	width: 6px;
	background: var(--color-org);
}

/* バッジスタイル */
.support_system_section h3 .badge {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	color: var(--color-bk);
	border: 1px solid var(--color-bk);
	padding: 0 8px;
	border-radius: 4px;
	line-height: 1.2;
}

.support_body {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	line-height: 1.8;
}

.support_note {
	font-size: var(--fz-13);
}




/* セクションタイトル */
.student_model_section {
	margin: 60px 0;
}

.student_model_section h3 {
	font-size: var(--fz-24);
	font-weight: var(--fw-bold);
	display: inline-block;
	position: relative;
	padding: 0 1.5em;
	margin-bottom: 10px;
}

.student_model_section h3::before,
.student_model_section h3::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 2px;
	height: 0.8em;
	background-color: #00B097;
}

.student_model_section h3::before {
	left: 0;
	transform: translateY(-50%) rotate(-25deg);
}

.student_model_section h3::after {
	right: 0;
	transform: translateY(-50%) rotate(25deg);
}



/* カードレイアウト */
.student_model_section .model_flex {
	display: flex;
	gap: 30px;
}

.student_model_section .model_card {
	flex: 1;
	background: var(--color-wh);
	border-radius: 15px;
	padding: 30px;
}

.student_model_section .model_layout {
	display: flex;
	align-items: flex-end;
	gap: 40px;
	margin-bottom: 16px;
}

.student_model_section .model_layout figure {
	flex: 0 0 110px;
	width: 100%;
	margin: 0;
}
.student_model_section .model_layout figure img {
	width: 100%;
	height: auto;
}

/* 数値データエリア */
.student_model_section .model_data {
	flex: 1;
}

.student_model_section .model_data .data_group {
	display: flex;
	gap: 15px;
	margin-bottom: 16px;
	padding: 5px;
	background: var(--color-beg3);
	border-radius: 4px;
	position: relative;
}
.student_model_section .model_data .data_group:last-child {
	margin-bottom: 0;
}
.student_model_section .model_data .income:after {
	position: absolute;
	content: '';
	height: 1px;
	bottom: -8px;
	left: 0;
	width: 100%;
	background: var(--color-bk);
}

.student_model_section .model_data h4 {
	font-size: var(--fz-14);
	font-weight: var(--fw-medium);
}

.student_model_section .model_data dl {
	flex: 1;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0 10px;
	font-weight: var(--fw-medium);
	font-size: var(--fz-14);
}
.student_model_section .model_data dt {
	text-align: left;
}
.student_model_section .model_data .total {
	color: var(--color-org);
	font-weight: var(--fw-bold);
	font-size: var(--fz-14);
	margin-top: 5px;
}

/* 下部の説明テキスト */
.student_model_section .model_text {
	font-size: var(--fz-16);
	line-height: 1.7;
	padding-top: 10px;
	text-align: left;
}







/* --- シミュレーションセクション --- */
.simulation_section {
	margin-bottom: 60px;
	background: var(--color-wh);
	border-radius: 15px;
	padding: 40px;
	text-align: center;
}

.simulation_section .lead {
	font-size: var(--fz-16);
	font-weight: var(--fw-medium);
	line-height: 1.6;
	margin-bottom: 30px;
}

.sim_btn_flex {
	display: flex;
	justify-content: center;
	gap: 30px;
}

.sim_btn_flex.tm {
	margin-top: 40px;
}

.sim_btn_flex a {
	position: relative;
	display: flex;
	align-items: center;
	width: 360px;
	height: 57px;
	background: var(--color-wh);
	border: 1px solid var(--color-bk);
	border-radius: 50px;
	text-decoration: none;
	color: var(--color-bk);
	font-weight: var(--fw-bold);
	font-size: var(--fz-16);
	text-align: left;
	padding: 0 60px 0 30px;
	transition: background 0.3s;
}

.sim_btn_flex a:hover {
	background: #f8f8f8;
}

.sim_btn_flex a::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	width: 55px; 
	background-color: var(--color-beg2);
	border-radius: 50%;
	background-image: url("../../images/common/icon_arrow.svg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 30%;
}



.detail_links_section {
	background: var(--color-beg5);
	padding: 40px 0;
	border-top: 1px solid var(--color-bk);
	border-bottom: 1px solid var(--color-bk);
	margin-bottom: 50px;
}

.detail_links_section h3 {
	font-size: var(--fz-24);
	font-weight: var(--fw-bold);
	margin-bottom: 20px;
}

.detail_links_section .links_desc {
	font-size: var(--fz-16);
	line-height: 1.8;
	margin-bottom: 20px;
}










/* /////////////////////////// */
/* /////////////////////////// */
/* /////////////////////////// */
/* スマホ用 */
@media (max-width:769px) {




	.page-visual h2 {
		display: block;
		line-height: 1.4;
		letter-spacing: 0;
	}
	
	.page-visual h2 span {
		display: flex;
		align-items: center;
		justify-content: center;
		flex-wrap: wrap;
	}


	.tblcell {
		flex-wrap: wrap; /* 折り返しを許可 */
	}
	.tblcell .divth {
		flex: 0 0 100%; /* タイトルを1枚板に */
	}
	.tblcell .divtd .simple-frame-inner .scbox strong,
	.tblcell .divtdr .simple-frame-inner .scbox strong,
	.tblcell .divtd .simple-frame-inner .ptbox strong,
	.tblcell .divtdr .simple-frame-inner .otbox strong,
	.tblcell .divtdr .simple-frame-inner .ynbox strong {
		font-size: 6.5rem;
	}
	.tblcell .divtd .simple-frame-inner .scbox strong.spsmall,
	.tblcell .divtdr .simple-frame-inner .scbox strong.spsmall,
	.tblcell .divtd .simple-frame-inner .ptbox strong.spsmall,
	.tblcell .divtdr .simple-frame-inner .otbox strong.spsmall,
	.tblcell .divtdr .simple-frame-inner .ynbox strong.spsmall {
		font-size: 4rem;
	}
	.tblcell .divtd, 
	.tblcell .divtdr {
		flex: 0 0 50%;  /* 下の2つを半分ずつに */
	}
	.tblcell .divth .simple-frame-inner {
		display: block;
		padding: 20px;
		line-height: 1.2
	}
	.tblcell .divtd .simple-frame-inner {
		padding-left: 0;
	}
	.tblcell .divtdr .simple-frame-inner {
		padding-right: 0;
	}
	.tblcell .divtd .simple-frame-inner::before,
	.divtd::before,
	.divtdr::before {
		background: none;
	}



	.strengthtitle {
		margin-bottom: 40px;
	}
	
	.strengthtitle h3 {
		margin-bottom: 20px;
		padding-top: 25px;
	}
	
	
	.strengthtitle h3 small,
	.strengthtitle h3 small::after {
		display: none;
	}
	.strengthtitle {
		flex-direction: column;
		gap: 20px;
	}

	.strengthpoint article {
		flex: 0 0 100%;
	}
	.strength_message {
		padding: 40px 0;
	}
	.strength_message ul {
		flex-direction: column;
		gap: 20px;
	}
	
	.strength_message figure {
		flex: 0 0 clamp(110px, 90px + 5vw, 140px);
	}
	.strength_message .catchpc {
		display: none;
	}
	.strength_message .content .catchsp {
		display: block;
		font-size: var(--fz-16);
		font-weight: var(--fw-bold);
		line-height: 1.4;
		padding-bottom: 0;
	}

	.aftersupport {
		margin-bottom: 50px;
	}
	
	.aftersupport h4 {
		text-align: left;
	}


	.strengthpicbox .bflex {
		flex-direction: column;
		gap: 20px;
	}
	.strengthpicbox .bflex:nth-child(2) {
		margin-top: 20px;
		flex-direction: column;
	}
	.strengthpicbox .bflex figure {
		width: 100%;
		flex: 0 0 100%;
	}





	.strengthpicbox .job_list {
		padding: 30px 0;
	}
	
	/* スライド対象：初期状態 */
	.strengthpicbox .jobs {
		position: relative;
		max-height: 120px;
		overflow: hidden;
		transition: max-height 0.6s cubic-bezier(0.4, 0, 0.2, 1);
		margin-bottom: 10px;
	}
	
	/* グラデーション */
	.strengthpicbox .jobs::before {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 60px;
		background: linear-gradient(to top, rgba(255,255,255,1), rgba(255,255,255,0));
		z-index: 1;
		transition: opacity 0.3s;
	}
	
	/* 開いた時のグラデーション非表示（JSで制御） */
	.strengthpicbox .jobs.is-open::before {
		opacity: 0;
	}
	
	/* moreボタン */
	.strengthpicbox .more_btn {
		display: flex;         /* 横並びにする */
		align-items: center;   /* 垂直中央 */
		justify-content: center; /* 水平中央 */
		gap: 8px;              /* 文字と矢印の間隔 */
		width: 120px;
		margin: 0 auto 30px;
		padding: 8px 0;
		color: var(--color-bk);
		font-size: var(--fz-18);
		font-weight: var(--fw-bold);
		border-radius: 20px;
		cursor: pointer;
	}
	
	/* 下向き矢印をCSSで作成 */
	.strengthpicbox .more_btn::after {
		content: "";
		width: 8px;
		height: 8px;
		border-right: 2px solid var(--color-bk);
		border-bottom: 2px solid var(--color-bk);
		transform: rotate(45deg); /* 45度回転させてL字を矢印に見せる */
	}






	.career_support {
		padding: 50px 0; /* 余白をスマホ用に */
	}
	
	.career_box { 
		padding: 20px; 
		gap: 20px; 
		display: block; /* ★重要：Flexを解除して、要素を縦に流します */
	}
	
	/* 先生の情報エリアを横並びに（画像と名前） */
	.career_info {
		display: flex; 
		flex: none;
		max-width: none;
		width: 100%;
		align-items: center;
		gap: 15px;
		text-align: left;
		margin-bottom: 20px;
	}
	
	.career_info figure {
		flex: 0 0 clamp(60px, 40%, 120px);
		margin: 0;
	}
	
	.career_info .teacher_name {
		margin-top: 0;
	}
	
	.career_text {
		width: 100%;
	}


	.newsletter_box h4 {
		justify-content: flex-start;
	}
	
	.newsletter_box ul {
		flex-direction: column;
		gap: 12px;
	}




	.cost_box {
		flex-direction: column;
		gap: 30px;
	}


	.cost_content ul li {
		gap: 10px;
	}

	.cost_content ul .icon_check {
		width: 18px;
	}

	.cost_image {
		width: 100%;
		margin: 0 auto;
	}



	.scholarship_section {
		margin-bottom: 40px;
	}
	.scholarship_grid {
		grid-template-columns: 1fr;
		gap: 0;
		margin-bottom: 20px;
	}

	.special_reward_card {
			flex-direction: column;
	}

	.scholar_card .card_content {
		padding: 10px 0;
	}

	.special_reward_card figure {
			flex: 0 0 200px;
	}

	.special_reward_card .reward_content {
			padding: 10px 20px 0;
	}



	.recommend_support {
		padding: 40px 0;
	}

	.recommend_support .support_title {
		background-image: url('../../images/strength/decor_confetti_sp.svg');
		background-position: center top; 
		background-size: 100% auto;
		padding: 40px 0;
		margin-bottom: 0;
	}
	.recommend_support .support_tabs {
		flex-direction: column;
		gap: 10px;
		margin-top: 0
	}
	
	.recommend_support .support_content .inner_box {
		padding: 20px;
	}

	.recommend_support .support_content .label {
		font-size: var(--fz-13);
	}
	.recommend_support .content_header {
		flex-direction: column;
		border-bottom: none;
		gap: 0;
	}
	.recommend_support .content_header .num {
		width: 100%;
		font-size: var(--fz-30);
		border-right: none;
		border-bottom: 1px solid var(--color-bk);
		padding: 0 0 10px 0;
		text-align: center;
	}

	.recommend_support .benefit_table_container { padding: 10px; }
	.recommend_support .step_item { flex-direction: column; gap: 5px; }
	.recommend_support .scroll_wrapper img { width: 800px; max-width: none; } /* フローチャート画像を固定幅にしてスクロールさせる */


	.support_detail {
		padding: 20px 0;
	}




	.recommend_support .benefit_container {
		flex-direction: column;
		align-items: center;
		gap: 0;
	}
	.recommend_support .merit_box .title {
		transform: translateX(-50%) translateY(-40%); /* ★上に60%分浮かせて枠をまたぐ */
		padding: 0 20px;
	}
	
	.recommend_support .table_illust {
		width: 80%;
		max-width: none;
	}
	
	.recommend_support .benefit_content {
		width: 100%;
	}

	.recommend_support .benefit_header {
		flex-direction: column;
	}

	.recommend_support .benefit_row {
		flex-direction: column; /* ★ここがポイント：1行内を縦並びに */
	}

	.recommend_support .row_label {
		border-right: none;
		padding: 10px;
		background: rgba(0,0,0,0.03);
	}

	.recommend_support .row_value {
		padding: 15px;
		justify-content: flex-end;
	}




	.recommend_support .target_section {
		flex-direction: column;
		align-items: flex-start;
		gap: 15px;
	}
	
	.recommend_support .target_label {
		flex: none;
		width: 140px;
	}





	.recommend_support .flow_check_section {
		margin: 40px 0;
		padding: 20px 10px 30px;
		border-width: 2px;
		display: block; 
		min-width: 0;
	}

	.recommend_support .flow_check_section legend {
		font-size: var(--fz-18);
		width: 100%;
		line-height: 1.4;
		padding: 0 5px;
		display: flex;
		justify-content: center;
	}

	.recommend_support .flow_check_section legend::after {
		bottom: -15px;
		height: 12px;
		background-size: 100% auto;
	}

	.recommend_support .scroll_wrapper {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		width: 100%;
		margin-top: 40px;
		display: block;
	}
	
	.recommend_support .flow_chart_image {
		width: 800px;
		min-width: 800px;
		display: block;
	}
	
	.recommend_support .flow_chart_image img {
		width: 100%;
		max-width: none !important;
		height: auto;
	}




	.recommend_support .flow_step_section {
		flex-direction: column;
		align-items: center;
		gap: 30px;
	}

	.recommend_support .step_label {
		flex: none;
		width: 150px;
		margin: 0 auto 0 0;
	}

	.recommend_support .step_list {
		padding-left: 25px;
	}



	.recommend_support .shogakukin_section {
		padding: 40px 10px 10px;
	}

	.recommend_support .shogakukin_title {
		left: 50%;
		transform: translate(-50%, -50%); /* スマホでは中央寄せ */
		font-size: var(--fz-14);
		padding: 6px 15px;
		width: 90%; /* はみ出し防止 */
		text-align: center;
	}




	/* 1. 全体をブロック要素にして縦に並べる */
	.recommend_support .shogakukin_table,
	.recommend_support .shogakukin_table thead,
	.recommend_support .shogakukin_table tbody,
	.recommend_support .shogakukin_table tr,
	.recommend_support .shogakukin_table td {
		display: block;
		width: 100%;
	}

	/* 2. テーブル本体のスタイルリセット */
	.recommend_support .shogakukin_table {
		border: none;
		border-radius: 0;
	}

	/* 3. PC用の見出しを非表示 */
	.recommend_support .shogakukin_table thead {
		display: none;
	}

	/* 4. 各行（tr）を独立したカードにする */
	.recommend_support .shogakukin_table tr {
		border: 1px solid var(--color-org) !important;
		border-radius: 12px;
		margin-bottom: 20px;
		overflow: hidden; /* 角丸からはみ出さないように */
		background: var(--color-wh);
		display: block;
	}

	/* 5. セル（td）の共通設定 */
	.recommend_support .shogakukin_table td {
		padding: 12px 15px 12px 35%; /* 左側にラベル分の余白 */
		position: relative;
		border-right: none !important;
		/* カード内の区切り線 */
		border-bottom: 1px solid var(--color-org) !important; 
		min-height: 45px;
		display: flex;
		align-items: center;
		white-space: normal;
		text-align: left;
		box-sizing: border-box;
	}

	/* 6. data-labelを使って項目名を表示 */
	.recommend_support .shogakukin_table td::before {
		content: attr(data-label);
		position: absolute;
		left: 0;
		top: 0;
		bottom: 0;
		width: 30%;
		background: #fff5e6;
		color: var(--color-org);
		font-weight: var(--fw-bold);
		display: flex;
		align-items: center;
		justify-content: center;
		border-right: 1px solid var(--color-org);
		padding: 10px;
	}

	/* 7. 特定の箇所の微調整 */
	
	/* カードの最後のtdは、枠線と重ならないよう下線を消す（全てのtrに対して適用） */
	.recommend_support .shogakukin_table td:last-child {
		border-bottom: none !important;
	}

	/* 施設名（hosname）：ラベルなしのヘッダー風にする */
	.recommend_support .shogakukin_table .hosname {
		background: var(--color-beg3) !important;
		padding-left: 15px; 
		font-weight: var(--fw-bold);
	}
	.recommend_support .shogakukin_table .hosname::before {
		display: none; 
	}

	/* 対象学科：中のspanを縦に潰さないよう調整 */
	.recommend_support .shogakukin_table td[data-label="対象学科"] {
		display: block; 
		padding-top: 15px;
		padding-bottom: 15px;
	}


	.is-small .shogakukin_table {
			display: table !important; /* カード化を解除して表に戻す */
			width: 100%;
			border: 1px solid var(--color-org) !important; /* オレンジの外枠を復活 */
			border-collapse: separate;
			border-radius: 8px;
			overflow: hidden;
	}
	
	.is-small .shogakukin_table tr {
			display: table-row !important;
			border: none !important;
	}
	
	.is-small .shogakukin_table td {
		display: table-cell !important;
		width: auto;
		white-space: nowrap;
		padding: 12px 10px !important;
		border-bottom: 1px solid var(--color-org) !important;
		background: var(--color-wh);
		text-align: center;
		position: static !important; /* カード版の疑似要素用基準をリセット */
	}
	.is-small .shogakukin_table td:last-child {
		border-bottom: 1px solid var(--color-org) !important;
	}
	/* 左側の薄グレー背景の見出しセル */
	.is-small .shogakukin_table .hosname {
			background: var(--color-beg3) !important; /* PC版と同じ背景色 */
			border-right: 1px solid var(--color-org) !important; /* 縦の区切り線を復活 */
			padding-left: 10px !important; /* カード版の余白設定を上書き */
	}
	
	/* 最後の行の底辺の線を消して、tableの外枠と重ならないようにする */
	.is-small .shogakukin_table tr:last-child td {
			border-bottom: none !important;
	}
	
	/* カード型用の「data-label」などの疑似要素を完全に消去 */
	.is-small .shogakukin_table td::before {
			display: none !important;
	}





	/* セクション全体の調整 */
	.student_model_section {
			margin-top: 40px;
			text-align: center; /* タイトルを中央に */
	}
	
	/* 2つのカードを縦並びに */
	.student_model_section .model_flex {
			flex-direction: column;
			gap: 20px;
	}
	
	.student_model_section .model_card {
			padding: 20px; /* 余白を少し絞る */
	}
	
	/* カード内のイラストとデータを縦並びに */
	.student_model_section .model_layout {
			flex-direction: column;
			align-items: center; /* 中央寄せ */
			gap: 20px;
			margin-bottom: 20px;
	}
	
	/* イラストのサイズをスマホ用に調整 */
	.student_model_section .model_layout figure {
		flex: 0 0 50%;
		width: 50%;
	}
	
	/* データエリアを横幅いっぱいに */
	.student_model_section .model_data {
			width: 100%;
	}






			.simulation_box {
					padding: 30px 20px;
			}
	
			.detail_links_section {
					padding: 50px 0;
			}
	
			.sim_btn_flex {
					flex-direction: column;
					align-items: center;
					gap: 15px;
			}
	
			.btn_white_beige {
					max-width: 100%;
					min-height: 60px;
					padding-right: 55px;
					font-size: var(--fz-15);
			}
	
			.btn_white_beige::after {
					width: 48px;
					height: 48px;
			}
	
			.links_title {
					font-size: var(--fz-20);
			}







}