@charset "utf-8";
/*
Theme Name: worldtourist
*/
.yellow {
	background-color: #F9A825;
	color: #FFFFFF
}

.blue-text {
	color: #21648E;
}

.blue-bg {
	background-color: #21648E;
	color: #FFFFFF
}

.secondary-b {
	background-color: #5997B0;
	color: #FFFFFF
}

.skyblue {
	background-color: #E3EEF4;
}

.relative {
	position: relative;
}

.absolute {
	position: absolute;
}

.isSP{
	display: none;
}

.english{
	font-family: "Poppins", sans-serif;
	font-weight: 400;
	font-style: normal;
}

header {
	background: #ffffff;
	display: flex;
	width: 90%;
	height: clamp(65px, 52.393px + 1.639vw, 76px);
	padding: clamp(8px, 3.416px + 0.596vw, 12px) clamp(10px, 3.124px + 0.894vw, 16px) clamp(8px, 3.416px + 0.596vw, 12px) clamp(24px, 5.663px + 2.385vw, 40px);
	justify-content: space-between;
	align-items: center;
	border-radius: 50px;
	box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.25);
	position: fixed;
	inset: 0;
	margin: 24px auto;
	z-index: 1000;
	background-color: #F4F7F9
}

header>a>img {
	width: clamp(160px, -23.368px + 23.845vw, 320px);
	height: auto;
	flex-shrink: 0;
	aspect-ratio: 160/21;
}

header .nav-container {
	margin: auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

header nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: clamp(20px, 3.962px + 2.086vw, 40px);
}

header nav ul>div {
	column-gap: clamp(16px, 2.247px + 1.788vw, 28px);
}

header nav li {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

header nav a {
	font-size: clamp(10px, 3.124px + 0.894vw, 16px);
	width: 100%;
	height: 100%;
}

/* サブメニュー */
.submenu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 1001;
	background-color: #F4F7F9
}

.submenu li {
	padding: 0.5rem 1rem;
}

@media (min-width: 768px) {
	header nav li:hover .submenu {
		display: block;
	}
}

/* ハンバーガーメニュー */
.hamburger {
	display: none;
	flex-direction: column;
	gap: 5px;
	cursor: pointer;
}

.hamburger div {
	width: 25px;
	height: 3px;
	background: #333;
}

.contact,
.tell {
	border-radius: 40px;
	min-height: clamp(47px, 41.270px + 0.745vw, 52px);
}

.contact a,
.tell a {
	width: clamp(140px, 25.395px + 14.903vw, 240px);
	padding: 8px 0px;
	gap: 4px;
	column-gap: 8px;
	border-radius: 40px;
	flex-wrap: wrap;
	line-height: 1;
}

.tell span {
	width: 100%;
	text-align: center;
	font-size: clamp(10px, 7.708px + 0.298vw, 12px);
}

.flex {
	display: flex;
	align-items: center;
	justify-content: center;
}

.flex-reverse {
	display: flex;
	flex-direction: row-reverse;
}

.flex-sus{
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
}

h2 {
	margin-bottom: 40px;
}

h2::after {
	content: "";
	display: block;
	width: 80px;
	height: 2px;
	background: #21648E;
	margin-top: 8px;
	margin-left: auto;
	margin-right: auto;
}

.inner {
	width: 90%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
}

section {
	margin-bottom: clamp(140px, 71.237px + 8.942vw, 200px);
}

#mainvisual , #schoolvisual , #companyvisual , #travelvisual ,#englishvisual,#officevisual {
	background-image: url("../images/top-bg.png");
	width: 100%;
	height: 100vh;
	background-position: center bottom;
	background-size: cover;
}

#mainvisual .fv-inner {
	height: 100%;
	color: #FFFFFF;
	justify-content: flex-start;
}

#section01 div , #u_section03.school-cont div , #u_section04.company-cont div{
	gap: 40px;
	align-items: center;
}

#section01 div p {
	width: 50%;
}

#section01 div img {
	display: block;
	width: 46.8%;
	border-radius: 16px;
}

#section02 .secrion02 {
	gap: clamp(20px, 3.962px + 2.086vw, 40px);
	flex-wrap: nowrap;
	margin-top: -5%;
}

#section02 .section02-u a{
	width: clamp(243px, -2.584px + 31.935vw, 540px);
}

.service-inner {
	width: max-content;
	padding: 8px 24px;
	border: 1px solid #F4F7F9;
	display: inline-block;
	z-index: 10;
	color: #F4F7F9;
	text-align: center;
	letter-spacing: clamp(5px, 2.708px + 0.298vw, 7px);
	font-size: clamp(28px, 11.962px + 2.086vw, 48px);
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	line-height:1.4;
}

#section03 {
	width: 100%;
	max-width: 1728px;
	margin-left: auto;
	margin-right: auto;
}

#section03>div {
	width: 100%;
	margin: auto;
	justify-content: flex-end;
	column-gap: clamp(20px, -2.921px + 2.981vw, 40px);
	align-items: center;
}

#section03>div>div {
	width: clamp(346px, 9.061px + 43.815vw, 640px);
}

#section03 h2 {
	text-align: left;
}

#section03 h2::after {
	margin-left: inherit;
}

.link-bottom {
	width: fit-content;
	height: auto;
	padding: 16px 24px;
	line-height: 1;
	border-radius: 30px;
	margin: 40px auto;
}

.link-bottom svg {
	margin-left: clamp(16px, 6.832px + 1.192vw, 24px);
}

#section03 .link-bottom {
	margin-top: 80px;
	margin-left: inherit;
}

#section03>div img {
	width: 47.6%;
	height: auto;
	aspect-ratio: 16/9;
	border-radius: 0px 16px 16px 0px;
}

#section04 ul ,#u_section03.travel-cont ul{
	max-width: 960px;
	width: 90%;
	margin: auto;
	border-top: 1px solid #21648E;
	padding: 0;
}

#section04 li a {
	align-items: center;
	justify-content: space-between;
	padding: 24px;
	border-bottom: 1px solid #21648E;
	font-weight: 400;
	column-gap: clamp(20px, -2.921px + 2.981vw, 40px);
}

#section04 .news-date {
	width: 110px;
}

#section04 .news-title {
	flex: 1;
}

#contact-link>div {
	padding: 64px 40px;
	border-radius: 16px;
	position: relative;
	z-index: 10;
}

#contact-link h2 {
	line-height: 1;
	margin-bottom: 24px;
}

#contact-link p {
	text-align: center;
	margin-bottom: 40px;
}

#contact-link>div>div {
	column-gap: clamp(20px, -2.921px + 2.981vw, 40px);
}

#contact-link>div>div a {
	width: 400px;
	min-height: 80px;
	font-size: clamp(24px, 14.832px + 1.192vw, 32px);
	font-weight: 500;
	border-radius: 40px;
	padding-top: 24px;
	padding-bottom: 24px;
	line-height: 1;
}

#contact-link>div>div a svg {
	width: clamp(24px, 14.832px + 1.192vw, 32px);
	height: auto;
	margin-right: 8px;
}

#contact-link>div>div a:nth-last-child(1) {
	background-color: #F4F7F9;
	flex-wrap: wrap;
	padding-top: 8px;
	padding-bottom: 8px;
	font-weight: 800;
	row-gap: 4px;
}

#contact-link>div>div a:nth-last-child(1) span {
	width: 100%;
	text-align: center;
	font-size: clamp(14px, 7.124px + 0.894vw, 20px);
	font-weight: 500;
}

#contact-link>img {
	width: 100%;
	height: 480px;
	object-fit: cover;
	margin-top: -120px;
	position: relative;
	z-index: 1
}

#schoolvisual{
	background-image: url("../images/school-bg.png");
}

#companyvisual{
	background-image: url("../images/group-bg.png");
}

#travelvisual{
	background-image: url("../images/travel-bg.png");
}

#englishvisual{
	background-image: url("../images/english-bg.png");
}

#officevisual{
	background-image: url("../images/company-bg.png");
	height: 400px;
}

#schoolvisual .fv-inner , #companyvisual .fv-inner , #travelvisual .fv-inner , #englishvisual .fv-inner , #officevisual .fv-under {
	height: 100%;
	color: #FFFFFF;
	flex-direction: column;
	align-items: flex-start;
}

#officevisual .fv-under{
	align-items: center;
}

#schoolvisual .fv-inner p , #companyvisual .fv-inner p , #travelvisual .fv-inner p , #englishvisual .fv-inner p {
	font-family:"Shippori Mincho",serif;
	font-size: clamp(28px, 14.247px + 1.788vw, 40px);
}

.fv-under h1{
	font-size: clamp(24px, 21.183px + 0.751vw, 32px);
	font-family: "M PLUS 1p";
	font-weight: 500;
	line-height: 1;
	margin-top: 10%;
}

.fv-under h1::after{
	content: "";
	display: block;
	width: 80px;
	height: 1px;
	background: #F4F7F9;
	margin-top: 8px;
	margin-left: auto;
	margin-right: auto;
}

.under_section02-end{
	margin: 80px auto 0px;
	padding: 8px 24px;
	border-radius: 8px;
	font-size: clamp(24px, 14.832px + 1.192vw, 32px);
	line-height: 1.5;
	width: fit-content;
	text-align: center;
	max-width: 90%;
}

.u_section02{
	justify-content: space-between;
}

.u_section02>div{
	box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.25);
	gap: 16px;
	padding: 40px 24px 24px 24px;
	background: #FFFFFF;
	max-width: 300px;
	width: 24%;
}

.u_section02>div .absolute{
	width: clamp(40px, -0.112px + 5.216vw, 75px);
	height: clamp(27.9px, -0.064px + 3.636vw, 52.3px);
	aspect-ratio: 1/0.693;
	inset: 0;
	margin: -20px auto;
}

.u_section02>div .absolute p{
	font-size: clamp(16px, 6.832px + 1.192vw, 24px);
	color: #FFFFFF;
	font-weight: 400;
	width: 100%;
	position: absolute;
	text-align: center;
	height: 100%;
}

.u_section02>div .absolute svg{
	width: 100%;
	height: auto;
}

.u_section02_img{
	max-width: 1280px;
	width: 90%;
	height: auto;
	margin: 40px auto;
}

.u_section02_img img{
	margin: auto;
}

#u_section03 img , #u_section04.company-cont img{
	border-radius: 16px;
}

.tab-buttons {
	display: none;
	margin-bottom: 1rem;
	gap: 1rem;
}

.tab-buttons button {
	border: none;
	font-size: 1rem;
	cursor: pointer;
	padding: 0.5rem 1rem;
}

.tab-content {
	display: none;
}

.tab-content.active {
	display: block;
}

/* PC表示（横並び + ボタンは見出しとして表示） */
@media (min-width: 768px) {
	.tab-buttons {
		display: flex !important;
		width: 100%;
		justify-content: space-between
	}
	.tab-contents {
		display: flex;
		gap: 2rem;
	}
	.tab-content {
		display: block !important;
		flex: 1;
	}
}

@media (max-width: 767px) {
	.tab-buttons {
		display: flex;
	}
	.tab-buttons button::after{
		content: "　▶"
	}
	.tab-buttons button.active::after{
		content: "　▼"
	}
}

.color-bg{
	padding: clamp(80px, 24.990px + 7.154vw, 128px) 0px;
}

.tab-buttons button{
	width: 49%;
	padding: 16px 24px;
	text-align: left;
	font-size: clamp(16px, 6.832px + 1.192vw, 24px);
	border-radius: 16px;
	line-height: normal;
}

.tab-content{
	width: 44.6%;
}

#section04 .tab-contents ul , #u_section03.travel-cont .tab-contents ul {
	border-top: none;
	width: 100%;
}

.tab-contents ul li{
	padding: 16px 24px;
	justify-content: space-between;
	border-radius: 16px;
	border: 2px solid #21648E;
	background: #F4F7F9;
	font-weight: 500;
	flex-wrap: nowrap;
	gap: 24px;
}

.tab-contents ul li img{
	width: 50%;
	max-width: 160px;
}

.tab-contents ul > svg,.u_flow > svg{
	display: block;
	margin: 16px auto;
}

.tab-contents ul .next{
	width: 100%;
	padding: 16px 24px;
	text-align: left;
	font-size: clamp(16px, 6.832px + 1.192vw, 24px);
	border-radius: 16px;
	line-height: normal;
	background-color: #5997B0;
	border: none;
	margin-top: 16px
}

.tab-contents-time{
	width: fit-content;
}

.tab-contents-time p{
	color: #F4F7F9;
	font-weight: 400;
	width: 100%;
	text-align: right;
	padding-right: 4px;
	padding-top: 2px;
}

.archive{
	margin: auto;
	width: 960px;
	max-width: 90%;
	flex-wrap: wrap;
	box-shadow: 0px 0px 16px 0px rgba(0, 0, 0, 0.25);
	border-radius: 16px;
	padding: 32px;
	gap: clamp(28px, 14.247px + 1.788vw, 40px);
	text-align: center;
	background-color: #FFFFFF;
}

.archive h3{
	width: 100%;
}

.archive .circle{
	aspect-ratio: 1 / 1;
	width: 50%;
	max-width: 240px;
	height: auto;
	border-radius: 50%;
	border: 5px solid #21648E;
	line-height: 1.4;
	flex-direction: column;
	font-weight: 500;
}

.archive span{
	font-weight: 700;
	margin-left: 8px;
	margin-right: 8px;
	font-size: clamp(32px, 6.787px + 3.279vw, 54px);
}

.archive .circle span{
	font-size: clamp(64px, 45.663px + 2.385vw, 80px);
}

.archive .circle img{
	height: auto;
	inset: 0;
	margin: -32px auto;
}

.u_flow{
	width: 90%;
	max-width: 800px;
	margin: auto;
}

.u_flow li{
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
}

.u_flow li .u_flow-list{
	width: 70%;
	max-width: 560px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.u_flow li .u_flow-list h3{
	text-align: left;
	padding-left: 24px;
}

.u_flow li .u_flow-list p{
	padding-left: 24px;
	padding-right: 24px;
}

.u_flow li .u_flow-list h3 img{
	margin-right: 10px;
}

.u_flow li .u_flow-list hr{
	width: 100%;
	height: 1px;
	background-color: #21648E;
	border: none;
}

.u_flow li > img{
	width: 25%;
	height: auto;
}

.swiper{
	padding-top: 24px!important;
	padding-bottom: 24px!important;
}

.swiper-wrapper{
	overflow-y: visible;
}

.swiper-slide{
	width: 90%;
	max-width: 800px;
	padding: 32px 24px;
	border-radius: 16px;
	box-shadow: 0px 0px 16px 0px rgba(0, 0, 0, 0.25);
	background-color: #F4F7F9;
}

.swiper-slide h3{
	text-align: center;
	margin-bottom: 24px;
}

.swiper-slide>div{
	align-items: flex-start;
	gap: 24px;
}

.swiper-slide>div span{
	font-size: 24px;
	font-weight: 500;
}

.swiper-slide img{
	width: 40%;
	height: auto;
}

#contact-link{
	margin-bottom: 0;
}

.u_section02>.card-double , .u_section02>.en-list , .u_section02>.en-link{
	background: none;
	box-shadow: none;
	width: 100%;
	max-width: 100%;
	align-items: flex-start;
	gap: clamp(40px, -5.842px + 5.961vw, 80px);
}

#section02 .en-lead{
	font-size: clamp(16px, 6.832px + 1.192vw, 24px);
	text-align: center;
	margin-top: -40px;
	margin-bottom: 40px;
}

.u_section02 h3{
	font-size: clamp(16px, 6.832px + 1.192vw, 24px);
	text-align: center;
}

.card-double div{
	display: flex;
	padding: 40px;
	flex-direction: column;
	align-items: center;
	gap: 27px;
	border-radius: 16px;
	border: 5px solid #21648E;
	background: #F4F7F9;
	flex: 1;
}

.card-double div h4 {
	text-align: center;
	font-size: clamp(16px, 6.832px + 1.192vw, 24px);
}

.u_section02>.en-list{
	width: 90%;
	max-width: 960px;
	margin: auto;
}

.en-list ul {
	border-top: 1px solid #21648E;
	width: 100%;
	padding: 0;
}

.en-list li {
	align-items: flex-start;
	width: 100%;
	border-bottom: 1px solid #21648E;
	padding: 16px 24px;
}

.en-list li p:nth-child(1){
	width: 16%;
}

.en-list li p:nth-last-child(1){
	flex: 1;
}

.u_section02>.en-link{
	gap: 40px;
}

.u_section02>.en-link a{
	margin: 0;
}

#section03.u_section03_sche h2{
	text-align: center;
}

#section03.u_section03_sche h2::after{
	margin-left: auto;
}

#section03 .en-sche-wrapper{
	width: 800px;
	max-width: 90%;
}

#section03 .en-sche-wrapper .en-sche{
	width: 100%;
}

#section03 .en-sche-wrapper .en-sche ul{
	padding: 0;
}

.en-sche .tab-contents-time p{
	padding-right: 12px;
}

.en-sche-cont{
	align-items: flex-start;
	gap: 8px;
	margin-bottom: 12px;
	width: 100%;
}

.en-sche ul li div {
	flex: 1
}

.en-sche-cont p{
	line-height: normal;
}

.en-sche-cont p:nth-child(1){
	width: 40px;
}

.en-sche-cont p:nth-last-child(1){
	flex: 1;
}

#section03>div .en-sche img{
	border-radius: 0px;
	width: 240px;
	max-width: 100%;
}

#section05 .en-list{
	width: 90%;
	max-width: 960px;
	margin: auto;
}

#section01 .co-list-wrapper , #section02 .co-list-wrapper{
	align-items: flex-start;
	gap: 0;
}

.co-list{
	width: 50%;
	border-top: 1px solid #21648E;
	padding: 0;
	margin-left: 40px;
}

#section02 .co-list{
	margin-left: 0;
	margin-right: 40px;
}

.co-list li{
	border-bottom: 1px solid #21648E;
	padding: 24px 40px;
	align-items: flex-start;
}

#section01 .co-list li p:nth-child(1),#section02 .co-list li p:nth-child(1){
	width: 25%;
	font-weight: 500;
}

#section02 .co-list li p:nth-child(1){
	width: 37.5%;
}

#section01 .co-list li p:nth-last-child(1),#section02 .co-list li p:nth-last-child(1){
	flex: 1;
}

#section01 .co-list li div,#section02 .co-list li div{
	display: flex;
	flex: 1;
	gap: 8px;
}

#section01 .co-list li div p:nth-child(1),#section02 .co-list li div p:nth-child(1){
	width: 40%;
}

#section01 .co-list-wrapper>div,#section02 .co-list-wrapper>div{
	width: 50%;
}

#section01 .co-list-wrapper>div img,#section02 .co-list-wrapper>div img{
	width: 100%;
}

#section01 .co-list-wrapper>div p,#section02 .co-list-wrapper>div p{
	width: 100%;
	text-align: center;
}

footer{
	margin-top: 0;
	padding-top: 96px;
}

.footer-inner {
	width: 90%;
	margin: auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: 96px;
}

.footer-left {
	flex: 1;
	min-width: 300px;
}

.footer-logo {
	width: clamp(260px, -91.838px + 45.753vw, 567px);
	margin-bottom: 32px;
}

.footer-company p{
	font-size:clamp(14px, 7.124px + 0.894vw, 20px);
	margin-bottom: 16px;
}

.footer-company .footer-name {
	font-size: clamp(16px, 6.832px + 1.192vw, 24px);
	font-weight: 500;
}

.footer-right {
	flex: 1;
	min-width: 300px;
	display: flex;
	flex-direction: column;
	gap: 24px;
	align-items: flex-end;
}

.footer-nav {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 2rem;
	flex-wrap: wrap;
}

.footer-subnav {
	list-style: none;
	padding-left: 1rem;
	margin-top: 0.5rem;
	border-left: 2px solid #21648e;
	font-size: clamp(12px, 7.416px + 0.596vw, 16px);
}

.footer-links {
	display: flex;
	gap: 2rem;
	flex-wrap: wrap;
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-nav a , .footer-links a{
	font-weight: 400;
}

.footer-logos {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 1rem;
}

.footer-logos img {
	width: 100px;
	height: auto;
	object-fit: contain;
}

.footer-bottom {
	text-align: center;
	padding: 8px;
	line-height: 1;
	font-size: 10px;
}

#section01 .contact-tel{
	width: fit-content;
	margin: auto;
	text-align: center;
	padding: 40px 80px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 24px;
	border-radius: 24px;
}

#section01 .contact-tel p{
	width: 100%;
}

.contact-tel a{
	background-color: #ffffff;
	display: flex;
	color: #21648E;
	justify-content: center;
	align-items: center;
	padding: 16px 24px;
	width: fit-content;
	border-radius: 40px;
	line-height: 1;
	gap: 8px;
	font-size: clamp(24px, 14.832px + 1.192vw, 32px);
}

.wpcf7-form{
	max-width: 800px;
	width: 90%;
	margin: auto;
}

.wpcf7-form > div{
	margin-bottom: 24px;
}

.optional,.required{
	border-radius: 4px;
	text-align: center;
	padding: 0 4px;
	color: #ffffff;
	font-size: 14px;
	margin-right: clamp(16px, 6.832px + 1.192vw, 24px);
}

.required{
	background: #E83B3B;
}

.optional{
	background: #A0A0A0;
}

.label{
	display: flex;
	justify-content: space-between;
}

.label > p:nth-child(1){
	width: 35%;
}

.label > p:nth-last-child(1){
	width: auto;
	flex: 1;
}

.label > p:nth-last-child(1) input , .label > p:nth-last-child(1) select , .label > p:nth-last-child(1) textarea{
	width: 100%;
	border-radius: 4px;
	border: 1px solid #1A1A1A;
}

.label > p:nth-last-child(1) input , .label > p:nth-last-child(1) select{
	height: 40px;
}

.wpcf7-list-item label{
	display: flex;
	margin-left: 35%;
	align-items: center;
}

.label > p:nth-last-child(1) .wpcf7-list-item label input{
	width: auto;
}

.wpcf7-submit{
	margin: auto;
	border-radius: 40px;
	background: #F9A825;
	width: 320px;
	padding: 24px 0px;
	line-height: 1;
	border: none;
	display: block;
	color: #FFFFFF;
	font-size: clamp(24px, 14.832px + 1.192vw, 32px);
	margin-top: 24px;
}

.pp > div{
	margin-top: 40px;
}

.pp h2{
	text-align: left;
	font-size:clamp(16px, 11.416px + 0.596vw, 20px);
	margin-bottom: 16px;
	letter-spacing: normal;
}

.pp h2::after{
	margin-left: 0;
	width: 100%;
}

#section01.pp div p{
	width: 100%;
}


@media (max-width: 768px) {
	.isSP{
		display: block;
	}
	
	.isPC{
		display: none;
	}
	
	header {
		height: 48px;
		padding-right: 24px;
		width: 95%;
		margin: 12px auto;
	}

	.hamburger {
		display: flex;
		z-index: 1001;
	}

	.hamburger.open div:nth-child(1) {
		transform: rotate(45deg) translate(5px, 5px);
	}

	.hamburger.open div:nth-child(2) {
		opacity: 0;
	}

	.hamburger.open div:nth-child(3) {
		transform: rotate(-45deg) translate(6px, -6px);
	}

	.hamburger div {
		transition: all 0.3s ease;
	}

	header nav {
		display: none;
		flex-direction: column;
		height: auto;
		gap: 1rem;
		padding: 32px 16px;
		position: absolute;
		top: 0;
		right: 0;
		background: #F4F7F9;
		z-index: 1000;
		border-top-right-radius: 24px;
	}

	header nav ul {
		flex-direction: column;
	}
	
	header nav li{
		display: block;
	}
	
	header nav a{
		font-size: 14px;
	}

	header nav.active {
		display: flex;
	}

	.submenu {
		display: block;
		position: static;
		border: none;
		padding-left: 16px;
	}

	.has-submenu.open .submenu {
		display: block;
	}

	.flex,
	.flex-reverse {
		flex-direction: column;
	}
	
	.sp-footer{
		width: 95%;
		height: 47px;
		position: fixed;
		inset: 0;
		margin: auto auto 16px auto;
		column-gap: 16px;
		z-index: 1000;
	}
	
	.sp-footer .contact svg{
		width: 18px;
		height: 18px;
		margin-right: 4px;
	}
	
	.sp-footer .tell svg{
		width: 14px;
		height: 14px;
		margin-right: 4px;
	}
	
	.sp-footer .contact,.sp-footer .tell{
		width: auto;
		flex: 1;
		line-height: 1;
	}
	
	.tell span{
		margin-top: -14px;
	}

	#mainvisual {
		background-image: url("../images/top-bg-sp.png");
		height: 540px;
	}

	header>img {
		width: 160px;
		height: auto;
	}
	
	section{
		margin-bottom: 80px;
	}
	
	.link-bottom{
		padding: 12px 24px;
	}
	
	#mainvisual .fv-inner{
		justify-content: center;
		align-items: flex-start;
	}
	
	#section01 div p,#section01 div img{
		width: 100%;
		border-radius: 8px;
	}
	
	.service-inner{
		font-size: 20px;
		padding: 4px 8px;
		letter-spacing: 0;
		line-height: 1.2;
	}
	
	#section02 .secrion02{
		flex-wrap: nowrap;
		gap: 12px;
	}
	
	#section02 .section02-u a{
		width: clamp(109px, -7.388px + 33.254vw, 248px);
	}
	
	#section02 .secrion02 svg{
		width: 16px;
		height: 16px;
		margin-left: 8px;
		margin-top: 2px;
		position: relative;
		top: 1px;
	}
	
	#section03 h2{
		text-align: center
	}
	
	#section03 h2::after{
		margin-left: auto
	}
	
	#section03>div>div{
		width: 90%;
	}
	
	#section03>div img{
		width: 90%;
		border-radius: 8px;
		margin-top: 24px;
	}
	
	#section03 .link-bottom{
		margin-left: auto;
		margin-top: 24px;
	}
	
	#section04 li a{
		flex-wrap: wrap;
		padding: 16px;
	}
	
	#section04 .news-date{
		width: 100%;
	}
	
	#contact-link>div{
		padding: 32px 24px;
	}
	
	#contact-link>div>div{
		row-gap: 24px;
	}
	
	#contact-link>div>div a{
		width: 100%;
		min-height: 60px;
		padding-top: 16px;
		padding-bottom: 16px
	}
	
	#contact-link>img{
		height: 320px;
	}
	
	#schoolvisual{
		background-image: url("../images/school-bg-sp.png");
		height: 540px;
	}
	
	#companyvisual{
		background-image: url("../images/group-bg-sp.png");
		height: 540px;
	}
	
	#travelvisual{
		background-image: url("../images/travel-bg-sp.png");
		height: 540px;
	}
	
	#englishvisual{
		background-image: url("../images/english-bg-sp.png");
		height: 540px;
	}
	
	#officevisual{
		background-image: url("../images/company-bg-sp.png");
		height: 350px;
	}
	
	#schoolvisual .fv-inner p , #companyvisual .fv-inner p , #travelvisual .fv-inner p , #englishvisual .fv-inner p{
		font-size: 20px;
	}
	
	.u_section02{
		flex-wrap: wrap;
		align-items: flex-start;
		row-gap: 24px;
	}
	
	.u_section02>div{
		width: 49%;
		min-width: inherit;
		padding: 32px 12px 12px;
		margin-bottom: 12px;
	}
	
	.u_section02>div img{
		width: 54px;
		margin: -12px auto;
	}
	
	.under_section02-end{
		padding: 4px 16px;
		font-size: 20px;
	}
	
	.tab-content{
		width: 100%;
	}
	
	.tab-contents ul li>div{
		flex: 1;
		margin-right: 5%;
	}
	
	.u_section02>div .absolute{
		width: clamp(40px, 10.694px + 8.373vw, 75px);
		height: clamp(27.9px, 7.469px + 5.837vw, 52.3px);
		margin: -15px auto;
	}

	.u_section02>div .absolute p{
		font-size: clamp(16px, 9.301px + 1.914vw, 24px);
	}
	
	.u_flow{
		padding: 0;
	}
	
	.u_flow li{
		position: relative;
	}
	
	.u_flow li .u_flow-list h3 img{
		width: 48px;
		height: auto;
	}
	
	.u_flow li .u_flow-list{
		width: 100%;
	}
	
	.u_flow li .u_flow-list p{
		padding-right: 80px;
	}
	
	.u_flow li > img{
		width: 72px;
		position: absolute;
		right: 0;
		top: -12px;
	}
	
	.swiper-slide{
		width: 90%!important;
	}
	
	.swiper-slide img{
		width: 100%;
	}
	
	.u_section02>.en-list{
		padding: 0;
	}
	
	.en-list li p:nth-child(1){
		width: 100%;
	}

	.en-sche ul li{
		flex-wrap: wrap;
		gap: 8px;
	}
	
	.u_section02 .card-double img{
		width: 100%;
		margin: auto;
	}
	
	.card-double div{
		padding: 24px;
	}
	
	.en-list li{
		padding: 8px 12px;
	}
	
	#section03>div .en-sche img{
		margin-top: inherit;
		width: 100%;
	}
	
	.u_section02>.card-double{
		padding: 0;
		gap: 12px;
		margin-top: 12px;
	}
	
	.u_section02>.en-list{
		width: 100%;
	}
	
	.u_section02>.en-link{
		align-items: center;
		gap: 12px;
	}
	
	.en-sche .tab-contents-time p{
		padding-right: 16px;
		padding-top: 8px;
	}
	
	.en-sche-cont{
		gap: 4px;
	}
	
	.en-sche ul li div{
		margin-right: 0;
	}
	
	.co-list{
		width: 100%;
		margin: auto;
		margin-bottom: 24px;
	}
	
	.co-list li{
		padding: 12px 16px;
	}
	
	#section01 .co-list li div, #section02 .co-list li div{
		width: 100%;
	}

	#section01 .co-list li div p:nth-child(1),#section02 .co-list li div p:nth-child(1){
		width: 50%;
	}
	
	#section01 .co-list-wrapper>div, #section02 .co-list-wrapper>div{
		width: 80%;
		margin: auto;
	}
	
	#section02 .co-list li p:nth-child(1){
		width: 100%;
	}
	
	.footer-logo{
		width: 100%;
	}
	
	.footer-company p {
		margin-bottom: 8px;
	}
	
	.footer-inner{
		gap: 24px;
	}
	
	.footer-nav{
		align-items: flex-start;
		flex-direction: column;
		width: 100%;
		gap: 8px;
	}
	
	.footer-links{
		align-items: flex-start;
		flex-direction: column;
		width: 100%;
		gap: 8px;
	}
	
	.footer-right{
		align-items: center;
	}
	
	.footer-bottom{
		margin-bottom: 72px;
	}
	
	#section01 .contact-tel{
		padding: 16px 40px;
		border-radius: 12px;
		gap: 12px;
	}
	
	.wpcf7-form{
		width: 100%;
	}
	
	.label{
		flex-direction: column;
	}
	
	.label > p:nth-child(1){
		width: 100%;
		margin-bottom: 12px;
	}
	
	.label > p:nth-last-child(1) input, .label > p:nth-last-child(1) select, .label > p:nth-last-child(1) textarea{
		height: 40px;
	}
	
	.wpcf7-list-item label{
		margin-left: 0;
	}
	
	.label > p:nth-last-child(1) textarea{
		height: 300px;
	}
}