@charset "utf-8";

main{
	margin: 0 20px;
	padding: 30px;
	background: #fff;
	min-height: 900px;
}

#under {
  margin: 100px 0 0 60px;
}

@media screen and (max-width:768px) {
    main{
        margin: 2%;
    }
}

/***** 見出し *****/
#page_ttl {
	margin: 0 20px 30px 20px;
	padding: 25px;
	color: #fff;
	background: linear-gradient(349deg, rgb(232 233 150 / 62%) 2%, rgb(76 163 199 / 51%) 100%);
	clip-path: polygon(3% 0, 95% 0, 100% 0, 100% 80%, 97% 100%, 0% 100%, 0% 88%, 0% 23%);
}
#page_ttl h2 {
	font-size: 2.8rem;
	font-weight: 300;
	font-family: 'Noto Serif JP', serif;
	letter-spacing: 0.08em;
}

.cate_ttl {
	margin-bottom: 20px;
	padding: 15px;
	font-size: 2.2rem;
	font-weight: 700;
	font-family: 'Noto Serif JP', serif;
	color: var(--base-color);
	letter-spacing: 0.1em;
	border: var(--base-color) 1px solid;
}

.ttl {
	margin-bottom: 20px;
	padding: 10px 15px;
	font-size: 2rem;
	font-weight: 700;
	font-family: 'Noto Serif JP', serif;
	letter-spacing: 0.1em;
	color: #fff;
	background-color: var(--base-color);
	border-bottom: solid 3px #4681bf;
}
.caption {
	margin-bottom: 15px;
	padding-left: 10px;
	padding-bottom: 5px;
	font-size: 1.8rem;
	font-weight: bold;
	border-left: 4px solid;
	border-bottom: 1px solid;
	border-color: #4681bf;
	position: relative;
}
.caption:before {
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	border-left: 12px solid #4681bf;
	border-bottom: 12px solid transparent;
	transform: rotate(-180deg);
	position: absolute;
	bottom: 0;
	right: 0;
}

.sub_caption {
	margin: 0 0 6px;
	font-weight: bold;
	color: var(--point-color);
}
.sub_caption2 {
	margin: 0 0 10px;
	font-weight: bold;
	color: var(--point-color);
	background: #ebebeb;
	padding: 1.5% 2.5%;
}


@media screen and (max-width:768px) {
	#page_ttl {
        margin: 0 0 10px 0;
		padding: 10px 0;
		border: none;
		border-bottom: #fff 1px solid;
		clip-path: none;
	}	
	#page_ttl h2 {
		padding-left: 0;
		font-size: 1.9rem;
		text-align: center;
		color: #fff;
		border-left: none;
	}
	.cate_ttl {
		margin-bottom: 15px;
		padding: 10px;
	font-size: 2rem;
	}
	.ttl {
		margin-bottom: 15px;
		/*padding-bottom: 5px;*/
	font-size: 1.8rem;
	}
	.caption {
		padding-left: 7px;
	font-size: 1.6rem;
	}
	.sub_caption {
		margin: 15px 0 7px;
	}
}

/***** ボックス *****/
#contents {
	padding: 0 30px;
}
#column {
	min-height: 1000px;
	height: auto !important;
	height: 1000px;
	padding: 30px;
	background-color: #fff;
}
#under {
	margin: 100px 0 0 100px;
}
.inner {
	margin-bottom: 30px;
}
.inner_item {
	margin-bottom: 20px;
}
.inner .inner_item:last-child {
	margin-bottom: 0;
}
.box {
	margin: 20px 0;
	padding: 20px;
}
.box_bk_gry {
	background-color: #f5f5f5;
}
.box_bk_red {
	background-color: #ffecec;
}
.box_bd_red {
	border: #cc0000 2px solid;
}
.box_bd_green {
	border: var(--point-color) 2px solid;
}

@media screen and (max-width:768px) {
	#contents {
		padding: 0;
	}
	#column {
		min-height: auto;
		height: auto !important;
		margin: 0 10px;
		padding: 10px;
		box-shadow: none;
	}
	#under {
		margin: 100px 0;
		text-align: center;
	}
	.box {
		padding: 15px;
    }
}

/***** スマホテーブル *****/
@media screen and (max-width:768px) {
	.js-scrollable {
		overflow-x: scroll;
		width: 100%;
	}
}
/***** ページリンク *****/
.page_link {
	padding: 20px 20px 15px;
	display: flex;
	flex-wrap: wrap;
	background-color: #f5f5f5;
	border-radius: 5px;
}
.page_link li {
	margin: 0 20px 5px 0;
	padding-left: 15px;
	position: relative;
}
.page_link li::before {
	content: "";
	width: 0;
	height: 0;
	border-left: 5px solid #d5b45c;
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.page_link li a {
	font-size: 1.5rem;
	color: #000;
}
/***** 画像 *****/
.fig {
	margin-top: 20px;
	margin-bottom: 20px;
}
.inner > .fig:first-child, .inner_item > .fig:first-child {
	margin-top: 0;
}
.inner > .fig:last-child, .inner_item > .fig:last-child {
	margin-bottom: 0;
}
.fig_full {
	width: 100%;
}
.fig_full img {
	width: 100%;
}
.fig_half {
	width: 60%;
	margin-left: auto;
	margin-right: auto;
}
.fig_half img {
	width: 100%;
}
.fig_half a {
	transition: 0.5s;
}
.fig_half a:hover {
	opacity: 0.7;
}
/***** ご挨拶 *****/
.greeting_ttl {
	margin: 50px 0 30px;
	padding: 15px;
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	color: #fff;
	background-color: #99559f;
}
.greeting_fig img {
	width: 100%;
}
#greeting_box {
	width: 100%;
	height: 180px;
	margin-bottom: 30px;
	position: relative
}
#greeting_box h3 {
	font-size: 1.8rem;
	font-weight: bold;
}
#greeting_box dl {
	text-align: right;
	position: absolute;
	right: 170px;
	bottom: 0;
}
#greeting_box dl strong {
	font-size: 1.8rem;
}
#greeting_box figure {
	width: 150px;
	position: absolute;
	right: 0;
	bottom: 0;
}
#greeting_box figure img {
	width: 100%;
}
.greeting_com {
	line-height: 1.8;
	text-indent: 1em;
}
@media screen and (max-width:768px) {
	.greeting_ttl {
		margin-bottom: 20px;
		padding: 10px;
		font-size: 1.8rem;
	}
	#greeting_box {
		height: auto;
		position: static;
	}
	#greeting_box dl {
		margin-top: 15px;
		text-align: center;
		position: static;
	}
	#greeting_box figure {
		margin: 20px auto 0;
		position: static;
	}
	.greeting_com {
		line-height: 1.7;
	}
}

/***** 開催概要 *****/
.summary_dl {
	width: 100%;
	margin-bottom: 20px;
	display: table;
}
.summary_dl dt {
	width: 150px;
	padding-bottom: 20px;
	display: table-cell;
	border-bottom: 1px solid;
	border-color: var(--point-color);
}
.summary_dl dd {
	padding: 0 0 20px 20px;
	display: table-cell;
	border-bottom: 1px solid;
	border-color: var(--sub-color);
}

@media screen and (max-width:768px) {
	.summary_dl {
		margin-bottom: 15px;
		display: block;
	}
	#contents_in .summary_dl:nth-last-child(1) {
		margin-bottom: 0;
	}
	.summary_dl dt {
		width: 100%;
		margin-bottom: 10px;
		padding: 0 0 7px;
		display: block;
	}
	.summary_dl dd {
		padding: 0;
		display: block;
		border: none;
	}
}

/***** プログラム *****/

.program_wrap {
    max-width: 100%;
	margin-top: 10px;
}

.program_wrap td {
	padding-bottom: 10px;
}

.program_wrap td p {
	line-height: 1.5;
}

.program_wrap .pro_name,
.program_wrap .pro_name_e {
	width: 8.5em;
	padding: 2px;
	font-size: 1.3rem;
	text-align: center;
	color: #000;
	background-color: var(--point-color);
	float: left;
	clear: left;
	margin-right: 3rem;
}

.pro_ttl_box {
	margin-bottom: 20px;
}
.pro_date {
	margin-bottom: 10px;
	text-align: right;
}
.pro_date2 {
	margin-bottom: 10px;
	text-align: right;
}
.pro_date span, .pro_date2 span {
	padding: 5px 7px;
	font-size: 1.4rem;
	background-color: #f5f5f5;
}
.pro_name dt, .pro_name_e dt {
	width: 8.5em;
	padding: 2px;
	font-size: 1.3rem;
	text-align: center;
	color: #000;
	background-color: var(--point-color);
	float: left;
	clear: left;
}
.pro_name2 dt {
	width: 8.5em;
	text-align: center;
	float: left;
	clear: left;
}
.pro_name dd, .pro_name2 dd {
	margin-left: 8.5em;
	padding: 1px 0;
	display: flex;
}
.pro_name dd p:nth-child(1), .pro_name2 dd p:nth-child(1) {
	width: 180px;
}
.pro_name dd p:nth-child(2), .pro_name2 dd p:nth-child(2) {
	padding-top: 2px;
	font-size: 1.4rem;
	flex: 1;
}
.pro_name_e dd {
	margin-left: 8.5em;
	padding: 1px 0;
}
.pro_name_e dd p:nth-child(2) {
	margin: 3px 0 0 180px;
	font-size: 1.4rem;
}
.pro_name td p {
	line-height: 1;
}

.program_wrap .sub_caption {
	margin: 0 0 5px;
	font-weight: bold;
	color: #899900;
	/*line-height: 1;*/
}

@media screen and (max-width:768px) {
	.pro_date {
		margin-bottom: 20px;
		text-align: left;
		position: static;
	}
	.pro_date span {
		font-size: 1.5rem;
	}
	/*.pro_name, .pro_name2, .pro_name_e {
		margin-top: 10px;
	}*/
	.pro_name dt, .pro_name_e dt {
		width: 100%;
		margin-bottom: 5px;
		padding: 2px 0;
		float: none;
	}
	.pro_name2 dt {
		width: 100%;
		margin-bottom: 5px;
		float: none;
	}
	.pro_name dd, .pro_name2 dd {
		margin: 0 0 5px 0;
	}
	.pro_name_e dd {
		margin-left: 0;
		padding: 2px 0 0;
	}
	.pro_name_e dd p:nth-child(2) {
		margin: 5px 0 0 140px;
	}

}

/***** 演題登録 *****/
.abs_tb1 {
	width: 100%;
}
.abs_tb1 th {
	padding: 7px 5px;
	text-align: center;
	font-size: 1.4rem;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--base-color);
}
.abs_tb1 td {
	padding: 7px 5px;
	font-size: 1.3rem;
	border: #ddd 1px solid;
}
.abs_tb1 tr td:nth-last-child(1) {
	width: 12%;
	text-align: center;
}
.abs_tb1 tr td:nth-last-child(2) {
	width: 12%;
	text-align: center;
}
.abs_tb1 tr td:nth-last-child(3) {
	width: 14%;
	text-align: center;
}
.abs_tb1 tr td:nth-last-child(4) {
	width: 12%;
	text-align: center;
}
.abs_tb1 tr td:nth-last-child(5) {
	width: 10%;
	text-align: center;
}
.abs_tb1 tr td:nth-last-child(6) {
	width: 28%;
}
.abs_td_cap {
	background-color: #f3f3f3;
}
.abs_td_cap .note {
	font-size: 0.9em;
}
.abs_tb2 {
	width: 100%;
}
.abs_tb2 th {
	width: 30%;
	padding: 10px;
	text-align: center;
	font-size: 1.6rem;
	color: #fff;
	border: #ddd 1px solid;
	background-color: #99559f;
}
.abs_tb2 td {
	padding: 10px;
	font-size: 1.6rem;
	border: #ddd 1px solid;
}

.abs_list1 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.abs_list1 li {
	width: 50%;
	margin-bottom: 5px;
}

.abs_dl1 dt {
	margin: 10px 0 5px;
	padding-bottom: 5px;
	font-weight: bold;
	border-bottom: #000 1px dotted;
}
.abs_dead {
	margin-top: -20px;
	font-weight: 700;
	text-align: center;
	color: #cc0000;
}


@media screen and (max-width:768px) {
	.abs_tb1 {
		width: 800px;
	}
		
	.abs_tb2 {
		width: 800px;
	}
	
	.abs_list1 {
		display: block;
	}
	
	.abs_list1 li {
		width: 100%;
	}
}
/***** 参加登録 *****/
.join_list1 {
	margin-bottom: 10px;
	display: flex;
	flex-wrap: wrap;
	border-left: #ddd 1px solid;
	border-top: #ddd 1px solid;
}
@media screen and (max-width:768px) {
	.join_list1 {}
}
.join_list1 li {
	width: calc(100% / 3);
	padding: 10px 0;
	display: flex;
	justify-content: center;
	align-items: center;
	border-right: #ddd 1px solid;
	border-bottom: #ddd 1px solid;
}
@media screen and (max-width:768px) {
	.join_list1 li {
		width: calc(100% / 2);
	}
}
.join_tb1 {
	width: 100%;
}
@media screen and (max-width:768px) {
	.join_tb1 {
		width: 800px;
	}
}
.join_tb1 th {
	padding: 7px 5px;
	text-align: center;
	font-size: 1.4rem;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--base-color);
}
.join_tb1 tr th:nth-child(1) {
	width: 28%;
}
.join_tb1 tr th:nth-child(2), .join_tb1 tr th:nth-child(3) {
	width: 23%;
}
.join_tb1 td {
	padding: 7px 5px;
	font-size: 1.4rem;
	border: #ddd 1px solid;
}
.join_tb1 tr td:nth-child(1) {
	background-color: #F3F3F3;
}
.join_tb1 tr td:nth-child(2), .join_tb1 tr td:nth-child(3) {
	text-align: center;
}
.join_tb2 {
	width: 100%;
}
.join_tb2 th {
	padding: 7px;
	text-align: center;
	font-size: 1.5rem;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--base-color);
}
.join_tb2 td {
	padding: 7px;
	font-size: 1.5rem;
	text-align: center;
	border: #ddd 1px solid;
}
.join_flow {
	margin-top: 15px;
}
.join_flow_box {
	padding: 20px;
	border: var(--point-color) 2px dotted;
}
.join_flow_box figure img {
	max-width: 100%;
	margin-top: 15px;
}
.join_flow_arr {
	width: 0;
	height: 0;
	margin: 10px auto;
	border-top: 15px solid var(--point-color);
	border-right: 50px solid transparent;
	border-left: 50px solid transparent;
}
@media screen and (max-width:768px) {
	.join_flow_arr {
		border-right: 40px solid transparent;
		border-left: 40px solid transparent;
	}
}
.join_sub_caption {
	margin-top: 15px;
}
/***** 参加者 *****/
.participant_tb1 {
	width: 100%;
}
.participant_tb1 th {
	padding: 10px;
	font-size: 1.4rem;
	text-align: center;
	color: #fff;
	border: #ddd 1px solid;
	background-color: #99559f;
}
@media screen and (max-width:768px) {
	.participant_tb1 th {
		padding: 5px;
		font-size: 1.3rem;
	}
}
.participant_tb1 td {
	padding: 10px;
	font-size: 1.4rem;
	text-align: center;
	border: #ddd 1px solid;
}
@media screen and (max-width:768px) {
	.participant_tb1 td {
		padding: 5px;
		font-size: 1.3rem;
	}
}
.participant_tb1 td:nth-child(1) {
	width: 30%;
	text-align: left;
	background-color: #f5f5f5;
}
@media screen and (max-width:768px) {
	.participant_tb1 td:nth-child(1) {
		width: 40%;
	}
}
/***** 日本眼科学会専門医制度単位 *****/
.sp_unit_tb {
	width: 100%;
}
.sp_unit_tb th {
	padding: 10px;
	text-align: center;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--point-color);
}
.sp_unit_tb td {
	padding: 10px;
	border: #ddd 1px solid;
}
.sp_unit_tb1 tr td:nth-child(1) {
	width: 60%;
	background-color: #f5f5f5;
}
.sp_unit_tb1 tr td:nth-child(2) {
	text-align: center;
}
.sp_unit_tb2 tr, .sp_unit_tb3 tr, .sp_unit_tb4 tr, .sp_unit_tb6 tr {
	font-size: 1.4rem;
}
.sp_unit_tb2 td, .sp_unit_tb3 td, .sp_unit_tb4 td {
	font-size: 1.3rem;
	text-align: center;
}
.sp_unit_tb2 tr td:nth-child(1) {
	width: 16%;
}
.sp_unit_tb3 tr td:nth-child(1) {
	width: 26%;
	text-align: left;
	background-color: #f5f5f5;
}
.sp_unit_th_cap1 {
	width: 18.5%;
	background-color: #fbdff3;
}
.sp_unit_th_cap2 {
	background-color: #fdf6e5;
}
.sp_unit_th_cap3 {
	background-color: #7592d9 !important;
}
.sp_unit_th_cap4 {
	color: #333 !important;
	background-color: #d9efdf !important;
}
.sp_unit_th_cap5 {
	color: #333 !important;
	background-color: #e5ecfd !important;
}
.sp_unit_td_cap {
	width: 26%;
	text-align: left !important;
	background-color: #f5f5f5;
}
.sp_unit_td_cap2 {
	background-color: #d9efdf;
}
.sp_unit_td_cap3 {
	background-color: #d3e3ff;
}
.sp_unit_td_cap4 {
	background-color: #fbdff3;
}
.sp_unit_td1 {
	width: 18%;
	background-color: #e5ecfd;
}
.sp_unit_td2 {
	background-color: #fbf3df;
}
.sp_unit_tb5 tr td:nth-child(1) {
	width: 50%;
	background-color: #fff;
}
.sp_unit_tb5 tr td:nth-child(2) {
	text-align: center;
	background-color: #fff;
}
.sp_unit_tb6 tr th {
	width: 20%;
}
.sp_unit_tb6 tr:nth-child(1) th {
	background-color: #d9efdf !important;
	color: #333 !important;
}
.sp_unit_tb6 tr:nth-child(2) th {
	background-color: #d3e3ff !important;
	color: #333 !important;
}
.sp_unit_tb6 tr:nth-child(3) th {
	background-color: #fbdff3 !important;
	color: #333 !important;
}

.sp_unit_ph {
	width: 230px;
	margin-left: 20px;
	margin-bottom: 10px;
	float: right;
}

@media screen and (max-width:768px) {
	.sp_unit_tb2, .sp_unit_tb3, .sp_unit_tb4 {
		width: 800px;
	}
}

@media screen and (max-width:768px) {
    .sp_unit_tb6 tr th {
        width: 30%;
    }
	.sp_unit_ph {
		width: 200px;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 20px;
		float: none;
	}
}
.sp_unit_ph img {
	width: 100%;
}
/***** 専門医制度講習会 *****/
.specialist_name1 dt {
	width: 10em;
	padding: 2px;
	font-size: 1.3rem;
	text-align: center;
	color: #000;
	background-color: var(--point-color);
	float: left;
	clear: left;
}

.specialist_name1 dd {
	margin-left: 10em;
	display: flex;
}

.specialist_name1 dd p:nth-child(1) {
	width: 110px;
}

.specialist_name1 dd p:nth-child(2) {
	padding-top: 2px;
	font-size: 1.4rem;
	flex: 1;
}

.specialist_name2 dt {
	width: 110px;
	float: left;
	clear: left;
}

.specialist_name2 dd {
	padding: 2px 0 0 110px;
	font-size: 1.4rem;
	flex: 1;
}

.specialist_tb {
	width: 100%;
}

.specialist_tb th {
	padding: 10px;
	text-align: center;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--base-color);
}

.specialist_tb td {
	padding: 10px;
	border: #ddd 1px solid;
}

.specialist_tb tr td:nth-child(2) {
	width: 20%;
	text-align: center;
	background: #f5f5f5;
}
@media screen and (max-width:768px) {
.specialist_name1 dt {
		width: 100%;
		margin-bottom: 5px;
		padding: 2px 0;
		float: none;
}
	
.specialist_name1 dd {
	margin-left: 0;
}
	
.specialist_tb tr td:nth-child(2) {
	width: 30%;
}
}


/***** 会場のご案内 *****/
.access_dl {
	margin-bottom: 30px;
	padding: 15px;
	display: flex;
	background: #e9ebed;
}
.access_dl dt {
	margin-right: 30px;
	padding: 0 30px;
	font-weight: 600;
	font-family: 'Noto Serif JP', serif;
	color: var(--base-color);
	background: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
}
.access_dl dd {
	padding: 5px 0;
}
.map iframe {
	width: 100%;
	height: 450px;
}
@media screen and (max-width:768px) {
	.access_dl {
		margin-bottom: 20px;
		display: block;
	}
	.access_dl dt {
		width: 100%;
		padding: 5px;
	}
	.access_dl dd {
		margin-top: 10px;
		padding: 0;
	}
	.map iframe {
		height: 250px;
	}
}

/***** 宿泊のご案内 *****/
.stay_tb1 {
	width: 100%;
	margin-top: 15px;
}
.stay_tb1 th {
	width: 50%;
	padding: 10px;
	text-align: center;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--base-color);
}
.stay_tb1 td {
	padding: 10px 20px;
	text-align: center;
	border: #ddd 1px solid;
}

.stay_tb1 a {
	padding: 5px 0;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
	color: #fff;
	background-color: var(--point-color);
	display: block;
	border: 1px solid;
	border-color: var(--point-color);
	transition: 0.5s;
}
.stay_tb1 a:hover {
	color: var(--point-color);
	background-color: #fff;
}
@media screen and (max-width:768px) {
.stay_tb1 th {
	width: 35%;
	padding: 5px;
	font-size: 1.4rem;
}
.stay_tb1 td {
	padding: 5px;
	font-size: 1.4rem;
}

.stay_tb1 a {
	padding: 5px 0;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
	color: #fff;
	border-radius: 50px;
	background-color: var(--point-color);
	display: block;
	border: 1px solid;
	border-color: var(--point-color);
	transition: 0.5s;
}
.stay_tb1 a:hover {
	color: var(--point-color);
	background-color: #fff;
}
}

/***** 関連学会告知 *****/

/***** 関連学会告知 *****/
.anno_dl {
	margin-top: 10px;
	padding-top: 10px;
	border-top: #000 1px dotted;
}
.anno_dl dt {
	width: 5.5em;
	float: left;
	clear: left;
}
.anno_dl dd {
	margin-bottom: 10px;
	padding: 0 0 10px 5.5em;
	border-bottom: #000 1px dotted;
}
@media screen and (max-width:768px) {
	.anno_dl {
		margin-top: 10px;
		padding-top: 10px;
		border-top: #000 1px dotted;
	}
	.anno_dl dt {
		width: 100%;
		font-weight: bold;
		float: none;
	}
	.anno_dl dd {
		margin-bottom: 10px;
		padding: 0 0 10px 0;
	}
}


/***** 協賛申込のご案内 *****/
.sponsor_tb {
	width: 100%;
}
.sponsor_tb th {
	padding: 10px;
	text-align: center;
	font-size: 1.5rem;
	font-weight: 500;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--base-color);
}
.sponsor_tb td {
	padding: 10px;
	font-size: 1.5rem;
	border: #ddd 1px solid;
}
.sponsor_tb tr td:nth-child(2) {
	text-align: center;
}
.sponsor_tb tr td:nth-child(2) a,
.sponsor_tb .company_tb_btn a {
	padding: 3px 0;
	font-size: 1.4rem;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
	color: #fff;
	background-color: var(--point-color);
	display: block;
	border: 1px solid;
	border-color: var(--point-color);
	transition: 0.5s;
}
.sponsor_tb tr td:nth-child(2) a:hover,
.sponsor_tb .company_tb_btn a:hover {
	color: var(--point-color);
	background-color: #fff;
}
.sponsor_icon {
	margin-right: 5px;
	padding: 3px 8px;
	font-size: 1.3rem;
	font-weight: bold;
	color: #7f3585;
	background-color: #fff7a4;
}
@media screen and (max-width:768px) {
	.sponsor_tb {
		width: 800px;
	}
	.sponsor_tb tr td:nth-child(2) {
		text-align: center;
	}
	.sponsor_tb tr td:nth-child(2) a,
	.sponsor_tb .sponsor_tb_btn a {
		padding: 5px 0;
	}
}

/***** リンク *****/
.link_dl dt {
	padding-left: 15px;
	font-weight: bold;
	position: relative;
}
.link_dl dt::before {
	content: "";
	display: inline-block;
	border-style: solid;
	border-width: 5px 0 5px 7px;
	border-color: transparent;
	border-left-color: var(--point-color); 
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.link_dl dd {
	margin: 5px 0 20px;
	padding: 0 0 20px 20px;
	border-bottom: #603b6c 1px dotted;
}

@media screen and (max-width:768px) {
	.link_dl dt {
		padding-left: 15px;
	}
	
	.link_dl dt::before {
		border-width: 4px 0 4px 7px;
	}	
	.link_dl dd {
		margin: 5px 0 15px;
		padding: 0 0 15px 15px;
		border-bottom: #603b6c 1px dotted;
	}
	.link_dl dd:last-child {
		margin-bottom: 0;
		padding-bottom: 0;
		border-bottom: none;
	}
}

/***** お問い合わせ *****/
.contact_dl dt {
	margin-bottom: 5px;
	font-weight: bold;
}
/*****  *****/
#pw_com {
	margin: 50px 0 30px;
	text-align: center;
}
@media screen and (max-width:768px) {
	#pw_com {
		margin: 0 0 15px;
		text-align: center;
	}
}
#pw_box {
	padding: 20px;
	border: #ecd2ee 3px solid;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media screen and (max-width:768px) {
	#pw_box {
		padding: 15px;
		text-align: center;
		border: #ecd2ee 2px solid;
		display: block;
	}
}
#pw_box p:nth-child(1) {
	margin-right: 10px;
}
@media screen and (max-width:768px) {
	#pw_box p:nth-child(1) {
		margin-right: 0;
		margin-bottom: 5px;
	}
}
#pw_box p:nth-child(2) {
	margin-right: 20px;
}
@media screen and (max-width:768px) {
	#pw_box p:nth-child(2) {
		margin-right: 0;
		margin-bottom: 10px;
	}
}
#pw_box p:nth-child(2) input {
	width: 200px;
	padding: 5px;
}
@media screen and (max-width:768px) {
	#pw_box p:nth-child(2) input {
		width: 100%;
		padding: 5px;
		box-sizing: border-box;
	}
}
#pw_box p:nth-child(3) input {
	width: 80px;
	padding: 3px;
	color: #fff;
	background-color: #99559f;
	border: #99559f 1px solid;
}
#form_btn {
	width: 50%;
	margin: 80px auto 0;
}
@media screen and (max-width:768px) {
	#form_btn {
		width: 100%;
		margin: 50px auto;
	}
}
#form_btn a {
	padding: 25px 0;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	letter-spacing: normal;
	color: #fff;
	background-color: #99559f;
	border: #99559f 3px solid;
	border-radius: 5px;
	display: block;
	transition: all 0.4s;
}
@media screen and (max-width:768px) {
	#form_btn a {
		padding: 10px 0;
	}
}
#form_btn a:hover {
	color: #99559f;
	background-color: #fff;
}
/***** 託児 *****/
.nursery_info {
	margin-top: 30px;
	padding: 30px;
	border-radius: 10px;
	background-color: #f5f5f5;
}
@media screen and (max-width:768px) {
	.nursery_info {
		margin: 30px 0;
		padding: 20px;
		background-color: #f5f5f5;
	}
}
/***** 関連会合 *****/
.meeting_tb {
	width: 100%;
}
@media screen and (max-width:768px) {
	.meeting_tb {
		width: 800px;
	}
}
.meeting_tb th {
	width: 20%;
	padding: 10px;
	text-align: center;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--base-color);
}
.meeting_tb td {
	padding: 10px;
	text-align: center;
	border: #ddd 1px solid;
}
.meeting_tb td:nth-child(1) {
	background-color: #f5f5f5;
}


/***** ライブ *****/
.web_tb1 {
	width: 100%;
}
@media screen and (max-width:768px) {
	.web_tb1 {
		width: 800px;
	}
}
.web_tb1 th {
	padding: 10px;
	font-size: 1.4rem;
	text-align: center;
	color: #fff;
	border: #ddd 1px solid;
	background-color: #99559f;
}
@media screen and (max-width:768px) {
	.web_tb1 th {
		padding: 5px;
		font-size: 1.3rem;
	}
}
.web_tb1 td {
	padding: 10px;
	font-size: 1.4rem;
	text-align: center;
	border: #ddd 1px solid;
}
@media screen and (max-width:768px) {
	.web_tb1 td {
		padding: 5px;
		font-size: 1.3rem;
	}
}
.web_tb1 td:nth-child(1) {
	width: 30%;
	text-align: left;
	background-color: #f5f5f5;
}
@media screen and (max-width:768px) {
	.web_tb1 td:nth-child(1) {
		width: 40%;
	}
}
.web_tb2 {
	width: 100%;
}
.web_tb2 th {
	padding: 10px;
	text-align: center;
	color: #fff;
	border: #ddd 1px solid;
	background-color: #99559f;
}
@media screen and (max-width:768px) {
	.web_tb2 th {
		padding: 5px;
		font-size: 1.3rem;
	}
}
.web_tb2 td {
	padding: 10px;
	border: #ddd 1px solid;
}
@media screen and (max-width:768px) {
	.web_tb2 td {
		padding: 5px;
		font-size: 1.3rem;
	}
}
.web_td1 {
	background-color: #fbdff3;
}
.web_faq_box {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: #eee 3px solid;
}
.web_faq_box > div {
	display: flex;
}
.web_faq_box > div > p:nth-child(1) {
	width: 40px;
	height: 40px;
	margin-right: 15px;
	font-weight: bold;
	text-align: center;
	color: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media screen and (max-width:768px) {
	.web_faq_box > div > p:nth-child(1) {
		width: 30px;
		height: 30px;
		margin-right: 10px;
	}
}
.web_faq_box > div > p:nth-child(2), .web_faq_box > div > div {
	padding-top: 10px;
	flex: 1;
}
@media screen and (max-width:768px) {
	.web_faq_box > div > p:nth-child(2), .web_faq_box > div > div {
		padding-top: 5px;
		flex: 1;
	}
}
.web_q_box > p:nth-child(1) {
	background-color: #99559f;
}
.web_q_box > p:nth-child(2) {
	font-weight: bold;
}
.web_a_box {
	margin-top: 10px;
}
.web_a_box > p:nth-child(1) {
	background-color: #7592d9;
}







/***** 依頼回答フォーム *****/
.el_formBox{
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 30px;
	background-color: #F3F3F3;
	margin: 20px 0;
}

.el_formTtl{
	margin-right: 15px;
}

.el_formTxt{
	display: inline-block;
	padding: 5px;
	margin-right: 15px;
	box-sizing: border-box;
}

.el_formBtn{
	display: inline-block;
	border: none;
	background-color: var(--point-color);
	color: #fff;
	padding: 5px 10px;
	cursor: pointer;
}


@media screen and (max-width:768px) {
.el_formBox{
		display: block;
		padding: 20px;
		text-align: center;
	}
	
	.el_formTtl{
		margin-right: 0;
	}
	
	.el_formTxt{
		width: 100%;
		max-width: 500px;
		margin: 10px 0;
	}
}

/***** 市民公開講座 *****/
.public_movie {
	width: 100%;
  aspect-ratio: 16 / 9;
}

.public_movie iframe {
	width: 100%;
  height: 100%;
}

.public_box {
	display: flex;
	justify-content: space-between;
}

.public_box figure {
	width: 35%;
	margin-left: 5%;
	order: 2;
}

.public_box > div {
	flex: 1;
	order: 1;
}

@media screen and (max-width:768px){
.public_movie iframe {
	width: 100%;
}

.public_box {
	display: block;
}

.public_box figure {
	width: 60%;
	margin: 0 auto 20px;
}
}


/***** micenavi *****/
#page_ttl .app_page_ttl {
	letter-spacing: 0.14em;
}

.app_list {
	margin: 30px 0;
	display: flex;
	justify-content: center;
}

.app_list li {
	margin: 0 30px;
	text-align: center;
}

.app_list li dt {
	font-size: 2rem;
	font-weight: 700;
}

.app_list li figure:nth-child(1) {
	width: 150px;
}

.app_list li figure:nth-child(1) img {
	width: 100%;
}

.app_list li figure:nth-child(2) {
	height: 40px;
}

.app_list li figure:nth-child(2) img {
	height: 100%;
}

.app_qr {
	width: 150px;
	margin-left: auto;
	margin-right: auto;
}

.app_qr img {
	width: 100%;
}

.app_tb1 {
	width: 100%;
	margin: 15px 0;
}

.app_tb1 th {
	width: 25%;
	padding: 10px;
	text-align: center;
	color: #fff;
	border: #ddd 1px solid;
	background-color: var(--base-color);
}

.app_tb1 td {
	padding: 10px;
	border: #ddd 1px solid;
}

@media screen and (max-width:768px){
.app_list li {
	margin: 0 20px;
	text-align: center;
}
	
.app_list li dt {
	font-size: 1.8rem;
}
	
.app_list li figure:nth-child(1) {
	width: 120px;
}

.app_list li figure:nth-child(2) {
	height: 30px;
}
	
.app_qr {
	width: 120px;
}


.app_tb1 th {
	width: 30%;
}
}

/***** ドライビングシミュレータ体験 *****/
.drivig_img {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.drivig_img img {
	width: 32%;
}
.drivig_img p {
	width: 64%;
}

@media screen and (max-width:768px){
.drivig_img {
	display: block;
	margin: 0 auto;
}
.drivig_img img {
	width: 46%;
	margin: 20px auto 25px auto;
	display: block;
}
.drivig_img p {
	width: 100%;
}
	
}

/***** 電子抄録集 *****/
.my_abs_img {
	height: 24px;
	margin-right: 5px;
	display: inline-block;
}

/***** 屈折矯正手術講習会・オルソケラトロジー講習会 *****/
.refraction_pro .sub_caption {
	margin-top: 20px;
}

@media screen and (max-width:768px){
	.refraction_pro .sub_caption {
		margin-top: 15px;
	}
}