/* style_sp.css */

/*-------------------
common
---------------------*/

body {
    overflow-x: hidden;
}

.pc {
    display: none!important;
}

.sp {
    display: block!important;
}

.inner {
    padding-left: 15px;
    padding-right: 15px;
}

div, p, a, ul, li, dt, dd, span {
    font-size: 1.4rem;
}

.mt0_sp {
    margin-top: 0!important;
}

.mt5_sp {
    margin-top: 5px!important;
}

.mt10_sp {
    margin-top: 10px!important;
}

.mt15_sp {
    margin-top: 15px!important;
}

.mt20_sp {
    margin-top: 20px!important;
}

.mt25_sp {
    margin-top: 25px!important;
}

.mt30_sp {
    margin-top: 30px!important;
}

.mt35_sp {
    margin-top: 35px!important;
}

.mt40_sp {
    margin-top: 40px!important;
}

.mt45_sp {
    margin-top: 46px!important;
}

.mt50_sp {
    margin-top: 50px!important;
}

.mt55_sp {
    margin-top: 55px!important;
}

.mt60_sp {
    margin-top: 60px!important;
}

.mt65_sp {
    margin-top: 65px!important;
}

.mt70_sp {
    margin-top: 70px!important;
}

.mt75_sp {
    margin-top: 75px!important;
}

.mt80_sp {
    margin-top: 80px!important;
}

.mb0_sp {
    margin-top: 0!important;
}

.mb5_sp {
    margin-bottom: 5px!important;
}

.mb10_sp {
    margin-bottom: 10px!important;
}

.mb15_sp {
    margin-bottom: 15px!important;
}

.mb20_sp {
    margin-bottom: 20px!important;
}

.mb25_sp {
    margin-bottom: 25px!important;
}

.mb30_sp {
    margin-bottom: 30px!important;
}

.mb35_sp {
    margin-bottom: 35px!important;
}

.mb40_sp {
    margin-bottom: 40px!important;
}

.mb45_sp {
    margin-bottom: 46px!important;
}

.mb50_sp {
    margin-bottom: 50px!important;
}

.mb55_sp {
    margin-bottom: 55px!important;
}

.mb60_sp {
    margin-bottom: 60px!important;
}

.mb65_sp {
    margin-bottom: 65px!important;
}

.mb70_sp {
    margin-bottom: 70px!important;
}

.mb75_sp {
    margin-bottom: 75px!important;
}

.mb80_sp {
    margin-bottom: 80px!important;
}

.inner {
    max-width: 100%;
    min-width: 100%;
    padding-left: 15px;
    padding-right: 15px;
}

.bread {
    display: none;
}

.link_btn {
	height: 44px;
}


/*----------------
Top Main
------------------*/

.top_main_wrap {
	padding-top: 40px;
}

.top_main_img {
	width: 100%;
	max-width: 100%;
	position: static;
	padding-left: 15px;
	padding-right: 15px;
}

.top_main_text {
	width: 100%;
	max-width: 100%;
	padding-top: 20px;
}

.top_main_text .top_main_links {
	max-width: 326px;
	flex-direction: column;
	align-items: center;
	gap: 20px;
}

.top_main_text .top_main_links li {
	width: 100%;
}

.top_main_text h1 {
	width: fit-content;
	margin: 0 auto;
	font-size: 48px;
}

.top_main_text h1 span.lar {
	font-size: 48px;
}

.top_main_text h1 span.sml {
	font-size: 32px;
}

.top_main_text .top_main_text02 {
	font-size: 16px;
}

.top_main_text .top_main_links li a {
	height: 45px;
}

.top_profile {
	display: block;
}

.top_news {
	max-width: calc(100% - 35px);
	padding: 30px 20px 30px;
}

.top_news_cont {
	display: block;
}

.top_news_list {
	margin-top: 20px;
}

dl.top_news_list > div {
	flex-direction: column;
	gap: 10px;
}

dl.top_news_list > div > dt {
	font-size: 14px;
}

.tag {
	font-size: 11px;
}

dl.top_news_list > div {
	padding-bottom: 10px;
}

.tonews_list {
	font-size: 14px;
}

h2 {
	font-size: 30px;
}

/*----------------
Top ga4
------------------*/

.ga4_wrap {
	border-radius: 40px 0 0 0;
	padding-top: 190px;
	margin-top: -140px;
	padding-bottom: 60px;
}

.ga4_cont {
	display: block;
}

.ga4_cont .ga4_item {
	gap: 20px;
}

.ga4_cont .ga4_item:nth-child(2) {
	margin-top: 20px;
}

.ga4_item .ga4_text01 {
	font-size: 16px;
}

.ga4_item h3 {
	font-size: 26px;
}

.outline_text {
	font-size: 16px;
}


/*----------------
Top Academy
------------------*/

.aca_wrap {
	padding-top: 60px;
}

.aca_list {
	display: block;
}

.aca_list .aca_items {
	width: 100%;
	border-left: none;
	border-top: 1px solid #E2E5E9;
	padding-top: 30px;
	margin-top: 30px;
}

.aca_list .aca_items:first-child {
	border-top: none;
	padding-top: 0;
}

.fukidashi p {
	font-size: 14px;
}

.fukidashi {
	padding: 20px 20px 20px;
}

.aca_list .aca_items h3 {
	font-size: 20px;
}

/*----------------
Top about
------------------*/

.top_about_wrap {
	border-radius: 0 40px 0 0;
	padding-top: 60px;
	padding-bottom: 60px;
}

.top_about_heading {
	display: block;
	margin-top: 30px;
}

.top_about_heading .catch {
	width: 100%;
}

.top_about_heading .text {
	width: 100%;
	padding-top: 30px;
}

.to_about_link {
	margin-top: 40px;
}

/*----------------
Top profile
------------------*/

.top_profile_wrap {
	padding: 40px 20px 40px 20px;
	margin-top: 60px;
}

.top_profile .profile_img {
	width: 170px;
	margin: 0 auto;
}

.top_profile .profile_cont {
	margin-top: 20px;
	display: block;
}

.top_profile .profile_cont .profile_name {
	font-size: 20px;
}

.top_profile .profile_cont .profile_name span {
	font-size: 16px;
	margin-bottom: 2px;
}

.top_profile .profile_cont .profile_text01 {
	margin-top: 10px;
}

.top_profile .profile_cont .profile_text02 {
	margin-top: 20px;
}

.top_profile_wrap .books_heading {
	font-size: 20px;
	margin-top: 60px;
}

.top_profile_wrap ul.books_list {
	flex-wrap: wrap;
	row-gap: 30px;
}

.top_profile_wrap ul.books_list > li {
	width: 48%;
	max-width: 48%
}

.top_profile .profile_cont .link_btn {
	margin: 20px auto 0;
}

/*----------------
Top mail form
------------------*/

.mail_form_wrap {
	margin-top: 0;
	padding-left: 15px;
	padding-right: 15px;
	padding-bottom: 0;
	padding-top: 60px;
}

.mail_form_box {
	position: relative;
	top: 0;
	gap: 15px;
	padding: 40px 20px 40px;
}

.mail_form_inner input[type="email"] {
	font-size: 14px;
}

.mail_form_inner button {
	font-size: 14px;
}


.mail_form_box .sub_tit {
	font-size: 20px;
}

.mail_form_box h3 {
	font-size: 26px;
}

/*----------------
Top notice
------------------*/

.notice_wrap {
	padding-top: 60px;
	padding-bottom: 60px;
}

.notice_wrap:before {
	top: 30px;
}

.notice_info_btns {
	flex-wrap: wrap;
}

.notice_info_conts {
	margin-top: 20px;
}

.notice_info_list {
	display: block;
}

.notice_info_list > li {
	margin-top: 30px;
}

.notice_info_list > li:first-child {
	margin-top: 0;
}

.notice_info_list > li > a {
	flex-direction: row;
	align-items: flex-start;
	grid-gap: 3%;
}

.notice_info_list > li > a .n_img {
	width: 42%;
}

.notice_info_list > li > a .n_cont {
	width: 55%;
	gap: 5px;
}

/*----------------
Follow us
------------------*/

.follow_wrap {
	padding-bottom: 60px;
	padding-top: 60px;
}

h2.follow_tit {
	font-size: 30px;
}

ul.follow_items {
	flex-direction: column;
	gap: 15px;
	margin-top: 30px;
}

ul.follow_items > li > a {
	column-gap: 10px;
	padding: 20px 20px 20px 20px;
}


ul.follow_items > li > a .img {
	width: 40px;
	max-width: 40px;
}

/*----------------
Footer
------------------*/

.ft_cont_wrap {
	padding-top: 30px;
}

.ft_logo {
	width: 255px;
}

.ft_cont {
	display: block;
}

.ft_cont .ft_left {
	width: 100%;
}

ul.ft_menu {
	display: block;
	margin-top: 30px;
}

ul.ft_menu > li {
	margin-top: 25px;
}

ul.ft_menu > li:first-child {
	width: 100%;
}

ul.ft_menu > li:nth-child(2) {
	width: 100%;
}

ul.ft_menu > li:nth-child(3) {
	width: 100%;
}

ul.ft_menu > li:nth-child(4) {
	width: 100%;
}

.ft_cont .ft_right {
	width: 100%;
	margin-top: 60px;
}

ul.ft_sns {
	justify-content: center;
}

.ft_linkbtn {
	margin-top: 30px;
	align-items: center;
}

.ft_linkbtn > li {
	aspect-ratio: auto;
	max-width: 343px;
}

.ft_linkbtn > li > a {
	min-height: 63px;
}

.ft_linkbtn > li > a span {
	font-size: 14px;
}

ul.ft_menu > li > a {
	font-size: 16px;
}

ul.ft_menu > li > ul {
	margin-left: 10px;
}

ul.ft_menu > li > ul > li > a {
	font-size: 14px;
	padding: 4px 0 4px 15px;
}

ul.ft_textlinks {
	flex-direction: column;
	align-items: center;
	column-gap: 10px;
}

footer .copy_right P {
	text-align: center;
}

/*----------------
Header
------------------*/

.h_top_btns {
	display: none;
}

ul.page_navi {
	display: none;
}

ul.page_navi.show-on-mobile {
	padding-bottom: 100px;
	height: 100vh;
  	height: 100dvh;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.h_cont {
	width: 100%;
	display: block;
	padding: 0;
	height: 60px;
}

header.active .h_cont {
	height: auto;
}

.h_logo {
	width: 180px;
	min-width: 180px;
	position: absolute;
	top: 20px;
	left: 15px;
}

.h_logo img {
	width: 100%;
}

header {
	z-index: 100;
	height: 60px;
	background-color: #fff;
	position: sticky;
	top: 0;
	left: 0;
}

.menu-container {
	width: 100%;
	max-width: 100%;
	min-width: 100%;
	height: 60px;
	padding: 0;
	margin: 0 auto;
	position: fixed;
	top: 0;
}

.h_com .h_com_logo {
	margin-left: 15px;
	margin-left: 10px;
	height: 100%;
}

.header_menu.active .menu-container {
	z-index: 100;
}

.menu-container > .menu {
	transition: all 0.1s;
	width: 100%;
	min-width: 100%;
	position: fixed;
	-webkit-overflow-scrolling: touch;
	height: 0;
}

.header_menu.active .menu-container > .menu {
	height: 100%;
}

.menu-container > .menu > ul {
	display: block;
	transition: all 0.2s;
	transform: translate(800px);
}

.menu-container > .menu > ul.show-on-mobile {
	transform:translate(0px);
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	height: auto;
	position: absolute;
	position: fixed;
	top: 56px;
	right: 0;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch;
	z-index: 99;
	height: 100vh;
	margin-top: 0;
	padding: 40px 0 150px 0;
}

.menu > ul > li > a > span {
	border-right: none;
	padding: 0;
	font-size: 14px;
	font-weight: 600;
	color: #00A0E9;
	display: block;
	width: fit-content;
	position: relative;
}

ul.page_navi > li > a span:after {
	content: none;
}

#menuButton {
	overflow: hidden;
	display: block;
	position: relative;
	z-index: 998;
	width: 60px;
	height: 60px;
	border: none;
	padding: 0;
	cursor: pointer;
	float: right;
	position: fixed;
	margin: 0;
	color: #212121;
	font-size: 1.4rem;
	line-height: 30px;
	font-family: "Anta", sans-serif;
	font-weight: 400;
	font-style: normal;
	padding: 15px 15px 15px;
	top: 0;
	right: 0;
}

#menuButton span.h-bar,
#menuButton::before,
#menuButton::after {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 15px;
	width: 30px;
	height: 1px;
	margin: auto 0;
	background: #212121;
}

#menuButton span.h-bar {
	overflow: hidden;
	z-index: 1;
	color: #212121;
}

#menuButton::before {
	z-index: 2;
	transform: translate(0, -7px);
	content: "";
}

#menuButton::after {
	z-index: 2;
	transform: translate(0, 7px);
	content: "";
}

#menuButton span.h-bar {
	opacity: 1;
	transition: opacity 150ms 50ms;
	padding: 0;
}

#menuButton::before,
#menuButton::after {
	transition: transform 200ms;
}

#menuButton.active span.h-bar {
	opacity: 0;
	transition: opacity 150ms;
}

#menuButton.active::before {
	transform: rotate(45deg);
}

#menuButton.active::after {
	transform: rotate(-45deg);
}

.menu > ul > li > ul.normal-sub > li {
	margin-right: 0;
	margin-top: 0;
	border-bottom: 1px solid #d9d9d9;
}

.menu > ul > li > ul > li > a {
	color: #212121;
	font-size: 1.4rem;
	padding: 12px 0 12px 2em;
	display: block;
	position: relative;
	width: 100%;
	border-right: none;
}

.menu > ul > li > ul li a:before {
	content: none;
}

.menu > ul > li > ul li a:after {
	content: '';
	width: 6px;
	height: 6px;
	border: 0;
	border-top: solid 2px #00A0E9;
	border-right: solid 2px #00A0E9;
	transform: rotate(45deg);
	position: absolute;
	top: 0;
	right: 15px;
	bottom: 0;
	margin: auto;
}

.menu > ul > li:hover a span {
	filter: alpha(opacity=100);
	-ms-filter: "alpha(opacity=100)";
	-moz-opacity: 1;
	-khtml-opacity: 1;
	opacity: 1;
}

.menu > ul > li > ul > li {
	position: relative;
	margin: 0;
}

.menu > ul > li.h_menu_sp {
	padding-top: 10px;
	padding-bottom: 30px;
}

.menu > ul > li.h_menu_sp a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 300px;
	max-width: 100%;
	height: 40px;
	font-size: 1.4rem;
	border-radius: 4px;
	font-weight: 500;
	background-color: #fff;
	margin: 0 auto 10px;
}

header.active {
	overflow: auto;
}

.page_head {
	display: block;
	width: 100%;
	background: #fff;
	padding-right: 0;
}

ul.page_navi > li {
	width: 100%;
	margin: 0;
	padding: 0;
}

ul.page_navi > li.menu-dropdown-icon {
	margin-bottom: 30px;
}

ul.page_navi > li > a {
	width: 100%;
	color: #0D0D0D;
	text-align: left;
	padding: 15px 1em 5px 1em;
	position: relative;
}

ul.page_navi li.single > a {
	width: 100%;
	border-right: none;
	position: relative;
}

ul.page_navi li.single > a > span:after {
	content: '';
	display: inline-block;
	vertical-align: middle;
	width: 6px;
	height: 6px;
	border: 0;
	border-top: solid 2px #00A0E9;
	border-right: solid 2px #00A0E9;
	transform: rotate(45deg);
	margin-left: 7px;
	margin-top: -2px;
	position: static;
}

.menu > ul > li.h_search form {
	width: 85%;
	max-width: 335px;
	margin: 40px auto 0;
	position: relative;
}

input.f_text {
	display: block;
	padding: 10px 25px 10px 15px;
	width: 100%;
	min-height: 44px;
	margin: 0;
}

.menu > ul > li > ul.normal-sub {
	width: 100%;
	background: transparent;
	position: static;
	box-shadow: none;
	display: block!important;
}

ul.page_navi > li.h_sp_menu {
	width: 85%;
	max-width: 335px;
	margin: 30px auto 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.h_sp_menu a.h_menu_btn {
	width: 100%;
	max-width: 100%;
	padding: 15px 1em 15px 1em;
	display: flex;
	justify-content: center;
	align-items: center;
}

.h_sp_menu a.h_menu_btn span {
	text-align: center;
	color: #fff;
}

a.h_menu_btn.ex_link span:after {
	position: static;
	border: none;
	transform: none;
}

/*----------------
PageTop
------------------*/

#pageTop.is-fixed {
	width: fit-content;
	bottom:0;
	left: 0;
	right: 0;
	margin: 0 auto;
}

#pageTop.is-absolute {
	width: fit-content;
	left: 0;
	right: 0;
	margin: 0 auto;
}

/*-- add --*/

ul.ft_menu > li > span {
  font-size: 16px;
}

ul.page_navi > li > div {
  width: 100%;
  color: #0D0D0D;
  text-align: left;
  padding: 15px 1em 5px 1em;
  position: relative;
}

.menu > ul > li > div > span {
	border-right: none;
	padding: 0;
	font-size: 14px;
	font-weight: 600;
	color: #00A0E9;
	display: block;
	width: fit-content;
	position: relative;
}

ul.page_navi > li > div span:after {
	content: none;
}