@charset "UTF-8";

/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
/* 
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
} */

/* HTML5 display-role reset for older browsers */
/* article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
	display: block;
}

body {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

html {
	font-size: 62.5%;
}

body {
	font-family: YakuHanJP_Noto, "Noto Sans JP", sans-serif;
	font-size: 1.4rem;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
	color: #000;
	word-wrap: break-word;
	-webkit-font-feature-settings: 'palt' 1;
	font-feature-settings: 'palt' 1;
}

a {
	color: inherit;
	text-decoration: none;
}

img {
	max-width: 100%;
	height: auto;
}

input,
textarea,
select,
button {
	font: inherit;
	color: inherit;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	outline: none;
}

select::-ms-expand {
	display: none;
}

button {
	cursor: pointer;
} */


/* for development */
/* pre {
	padding: 15px;
	background: #eee;
	font-size: 1.2rem;
	line-height: 1.2;
}

.text-align-center {
	text-align: center;
}

.text-align-right {
	text-align: right;
}

.display-block {
	display: block;
}

.hidden {
	display: none !important;
	visibility: hidden;
}

.clearfix::before,
.clearfix::after {
	content: "";
	display: table;
}

.clearfix::after {
	clear: both;
}

.clear {
	clear: both;
} */


/* show only  SP/PC
-------------------------------*/
.sp-only {
	display: none !important;
}

.sp-only-2 {
	display: none !important;
}

.pc-only {
	display: block !important;
}

.pc-only-2 {
	display: inline-block !important;
}


/* font
-------------------------------*/
.bold {
	font-weight: bold;
}


/* margin
-------------------------------*/


/* padding
-------------------------------*/
/* 
.l-body {
	width: 100%;
	overflow: hidden;
}

.l-body.is-fixed {
	position: fixed;
}

.l-wrapper {
	position: relative;
	width: 84%;
	margin-left: auto;
	margin-right: auto;
}

.l-wrapper-lg {
	position: relative;
	width: 84%;
	margin-left: auto;
	margin-right: auto;
}

.l-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	padding: 13px 0;
	z-index: 1100;
	transition: background .2s linear;
}

.l-header.on {
	background: rgba(255, 255, 255, .9);
}

.l-navi {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	background: -o-linear-gradient(315deg, #0096d0, #c64e90);
	background: linear-gradient(135deg, #0096d0, #c64e90);
	display: none;
	z-index: 1000;
	overflow: auto;
}

.l-main {
	background: url(../img/bg_sp.png) repeat-y center top/680px auto, -o-linear-gradient(315deg, #c64e90, #0096d0);
	background: url(../img/bg_sp.png) repeat-y center top/680px auto, linear-gradient(135deg, #c64e90, #0096d0);
	padding-bottom: 60px;
} */

/* .navi {
	color: #ffffff;
	padding: 90px 30px;
}

.navi__list {
	border-top: 1px solid rgba(255, 255, 255, 0.3);
}

.navi__list__item a {
	display: block;
	font-size: 1.3rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.6;
	padding: 14px 0;
}

.navi__list__item a::before {
	content: "";
	width: 14px;
	height: 14px;
	display: inline-block;
	background: url(../img/icon_menu.svg) no-repeat center/contain;
	margin-right: 7px;
	vertical-align: middle;
	-webkit-transform: translateY(-3px);
	-ms-transform: translateY(-3px);
	transform: translateY(-3px);
} */

.navi__child {
	border-top: 1px solid rgba(255, 255, 255, 0.3);
}

.navi__child__item:not(:last-child) {
	border-bottom: 1px dotted rgba(255, 255, 255, 0.3);
}

.navi__child__item a {
	position: relative;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0;
	padding: 7px 10px;
}

.navi__child__item a::before {
	content: none;
}

.navi__child__item a::after {
	position: absolute;
	top: 50%;
	right: 10px;
	-webkit-transform: translateY(-50%) rotate(45deg);
	-ms-transform: translateY(-50%) rotate(45deg);
	transform: translateY(-50%) rotate(45deg);
	content: "";
	width: 4px;
	height: 4px;
	border-top: 1px solid #ffffff;
	border-right: 1px solid #ffffff;
}

.navi__child__item a span {
	font-size: 1.2rem;
}

.navi__button {
	display: block;
	font-size: 1.3rem;
	font-weight: 700;
	background: #06c755;
	padding: 9px 0;
	max-width: 260px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	margin-top: 27px;
}

.navi__button span::before {
	content: "";
	width: 30px;
	height: 30px;
	display: inline-block;
	background: url(../img/icon_line_white.svg) no-repeat center/contain;
	margin-right: 5px;
	vertical-align: middle;
}
/* 
.header {
	padding: 0 0 0 calc(33.333vw + 25px);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
}

.header-logo {
	position: absolute;
	top: 20px;
	left: 15px;
	display: block;
	width: 33.33%;
	max-width: 117px;
	z-index: 1100;
}

.header-buttons {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	position: relative;
	z-index: 1100;
}

.header-buttons__item {
	width: 50px;
	height: 44px;
	color: #ffffff;
	font-size: 1.1rem;
	font-weight: 700;
	line-height: 1.18;
	text-align: center;
}

.header-buttons__item a {
	display: block;
	height: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.header-buttons__item:first-child {
	border-radius: 5px 0 0 5px;
}

.header-buttons__item:last-child {
	border-radius: 0 5px 5px 0;
}

.header-buttons__item:not(:last-child) {
	margin-right: 1px;
}

.header-buttons__item span {
	font: 700 0.9rem "Roboto", sans-serif;
	line-height: 1;
}

.header-buttons__item--green {
	background: #006441;
}

.header-buttons__item--yellow {
	background: #e99600;
}

.header-buttons__item--orange {
	background: #e96e00;
}

.header-buttons__icon {
	display: none;
} */
/* 
.menu-btn {
	width: 44px;
	height: 44px;
	border: none;
	background: none;
	padding: 0;
	position: relative;
	margin: 0 8px 0 7px;
	z-index: 1100;
}

.menu-btn span {
	display: block;
	width: 20px;
	height: 1px;
	background: #c6c6c6;
	position: absolute;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	-webkit-transition: 0.4s;
	-o-transition: 0.4s;
	transition: 0.4s;
}

.on .menu-btn span {
	background: #999;
}

.menu-btn span:first-child {
	top: 13px;
}

.menu-btn span:nth-child(2) {
	top: 22px;
}

.menu-btn span:nth-child(3) {
	top: 30px;
}

.menu-btn.is-opened span {
	width: 26px;
}

.menu-btn.is-opened span:first-child {
	top: 50%;
	-webkit-transform: translate(-50%, -50%) rotate(45deg);
	-ms-transform: translate(-50%, -50%) rotate(45deg);
	transform: translate(-50%, -50%) rotate(45deg);
}

.menu-btn.is-opened span:nth-child(2) {
	opacity: 0;
}

.menu-btn.is-opened span:nth-child(3) {
	top: 50%;
	-webkit-transform: translate(-50%, -50%) rotate(-45deg);
	-ms-transform: translate(-50%, -50%) rotate(-45deg);
	transform: translate(-50%, -50%) rotate(-45deg);
} */

.mainvisual__main {
	position: relative;
}

.mainvisual__main::before {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 100%;
	min-width: 575px;
	height: 100%;
	display: block;
	background: url(../img/bg_mv_sp.jpg) no-repeat center top/cover;
}

.mainvisual__main::after {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 100%;
	min-width: 575px;
	height: 100%;
	display: block;
	background: url(../img/img_mv_sp.png) no-repeat center top/cover;
	opacity: 0;
}

.mainvisual__main__image {
	width: 100%;
	height: 100%;
}

.mainvisual__main__image img {
	display: block;
	-o-object-fit: cover;
	object-fit: cover;
}

.mainvisual__main.is-visible::after {
	-webkit-animation: fadeIn 1.5s forwards;
	animation: fadeIn 1.5s forwards;
}

.mainvisual__copy {
	position: absolute;
	top: 78px;
	left: 30px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	overflow: hidden;
	z-index: 1;
}

.mainvisual__copy span {
	position: relative;
	display: inline-block;
	padding: 1px;
	background: #000;
	overflow: hidden;
	-webkit-transform-origin: left top;
	-ms-transform-origin: left top;
	transform-origin: left top;
	-webkit-transform: translateY(-100%);
	-ms-transform: translateY(-100%);
	transform: translateY(-100%);
}

.mainvisual__copy span:not(:last-child) {
	margin-left: 10px;
}

.mainvisual__copy span::after {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background: #000;
}

.mainvisual__copy span img {
	display: inline-block;
	width: 16.5px;
}

.mainvisual__copy.is-visible span:first-child {
	-webkit-animation: stretchDown1 0.3s ease-out forwards;
	animation: stretchDown1 0.3s ease-out forwards;
}

.mainvisual__copy.is-visible span:first-child::after {
	-webkit-animation: stretchDown2 0.3s ease-out 0.3s forwards;
	animation: stretchDown2 0.3s ease-out 0.3s forwards;
}

.mainvisual__copy.is-visible span:nth-child(2) {
	-webkit-animation: stretchDown1 0.3s ease-out 0.6s forwards;
	animation: stretchDown1 0.3s ease-out 0.6s forwards;
}

.mainvisual__copy.is-visible span:nth-child(2)::after {
	-webkit-animation: stretchDown2 0.3s ease-out 0.9s forwards;
	animation: stretchDown2 0.3s ease-out 0.9s forwards;
}

.mainvisual__copy.is-visible span:nth-child(3) {
	-webkit-animation: stretchDown1 0.3s ease-out 1.2s forwards;
	animation: stretchDown1 0.3s ease-out 1.2s forwards;
}

.mainvisual__copy.is-visible span:nth-child(3)::after {
	-webkit-animation: stretchDown2 0.3s ease-out 1.5s forwards;
	animation: stretchDown2 0.3s ease-out 1.5s forwards;
}

.mainvisual__new {
	background: #c64e90;
	color: #ffffff;
	padding-bottom: 64px;
}

.mainvisual__new__heading {
	text-align: center;
}

.mainvisual__new__heading__img {
	display: inline-block;
	overflow: hidden;
	will-change: transform;
}

.mainvisual__new__heading__img--1 {
	position: relative;
	background: -o-linear-gradient(45deg, #0096d0, #c64e90) no-repeat right top/236px 100%;
	background: linear-gradient(45deg, #0096d0, #c64e90) no-repeat right top/236px 100%;
	margin-bottom: 10px;
	margin-top: -15px;
	padding: 2px 9px 2px 5px;
	-webkit-transform: scale(0, 1);
	-ms-transform: scale(0, 1);
	transform: scale(0, 1);
	-webkit-transform-origin: left top;
	-ms-transform-origin: left top;
	transform-origin: left top;
}

.mainvisual__new__heading__img--1::after {
	position: absolute;
	top: 0;
	right: 0;
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background: inherit;
}

.mainvisual__new__heading__img--2 {
	position: relative;
	background: -o-linear-gradient(45deg, #0096d0, #c64e90) no-repeat right top/275px 100%;
	background: linear-gradient(45deg, #0096d0, #c64e90) no-repeat right top/275px 100%;
	padding: 2px 3px;
	-webkit-transform: scale(0, 1);
	-ms-transform: scale(0, 1);
	transform: scale(0, 1);
	-webkit-transform-origin: left top;
	-ms-transform-origin: left top;
	transform-origin: left top;
}

.mainvisual__new__heading__img--2::after {
	position: absolute;
	top: 0;
	right: 0;
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background: inherit;
}

.mainvisual__new__heading__img--3 {
	margin-top: 12px;
	opacity: 0;
}

.mainvisual__new__heading.is-visible .mainvisual__new__heading__img--1 {
	-webkit-animation: stretchRight1 0.5s ease-out forwards;
	animation: stretchRight1 0.5s ease-out forwards;
}

.mainvisual__new__heading.is-visible .mainvisual__new__heading__img--1::after {
	-webkit-animation: stretchRight2 0.5s ease-out 0.5s forwards;
	animation: stretchRight2 0.5s ease-out 0.5s forwards;
}

.mainvisual__new__heading.is-visible .mainvisual__new__heading__img--2 {
	-webkit-animation: stretchRight1 0.5s ease-out 0.5s forwards;
	animation: stretchRight1 0.5s ease-out 0.5s forwards;
}

.mainvisual__new__heading.is-visible .mainvisual__new__heading__img--2::after {
	-webkit-animation: stretchRight2 0.5s ease-out 1s forwards;
	animation: stretchRight2 0.5s ease-out 1s forwards;
}

.mainvisual__new__heading.is-visible .mainvisual__new__heading__img--3 {
	-webkit-animation: fadeUp 0.5s 1.5s forwards;
	animation: fadeUp 0.5s 1.5s forwards;
}

.mainvisual__new__note {
	font-size: 1rem;
	font-weight: 500;
	text-align: center;
	margin-top: 13px;
	-webkit-transform: translateY(20px);
	-ms-transform: translateY(20px);
	transform: translateY(20px);
	opacity: 0;
}

.mainvisual__new__note span {
	display: block;
}

.mainvisual__new__note.is-visible {
	-webkit-animation: fadeUp 0.5s 0.5s forwards;
	animation: fadeUp 0.5s 0.5s forwards;
}

.link {
	background: #F8F8F8;
	padding: 27px 0 30px;
}

.link__head {
	font-weight: 700;
	margin-bottom: 22px;
	text-align: center;
}

.link__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.link__item {
	text-decoration: none;
	font-size: 1.3rem;
	font-weight: 700;
	line-height: 1.5;
	color: #ffffff;
	text-align: center;
	display: block;
	width: 31.7%;
	height: 13.9vw;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.link__item__icon {
	display: block;
	width: 29.1%;
}

.link__item--gray {
	background: #646464;
}

.link__item--orange {
	background: #DB8E2B;
}

.link__item--green {
	background: #34AC37;
}

.footer {
	padding: 30px 0 60px;
	text-align: center;
}

.footer__logo {
	width: 157px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 18px;
}

.js-accordion-sp {
	position: relative;
}

.js-accordion-sp-btn {
	margin-top: 26px;
	position: relative;
	width: 100%;
	background: #000;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 700;
	padding: 17px;
	border: none;
	-webkit-transition: 0.4s;
	-o-transition: 0.4s;
	transition: 0.4s;
}

.js-accordion-sp-btn::before,
.js-accordion-sp-btn::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 24px;
	width: 1px;
	height: 10px;
	background: #fff;
	-webkit-transition: 0.4s;
	-o-transition: 0.4s;
	transition: 0.4s;
}

.js-accordion-sp-btn::before {
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

.js-accordion-sp-btn::after {
	-webkit-transform: translateY(-50%) rotate(-90deg);
	-ms-transform: translateY(-50%) rotate(-90deg);
	transform: translateY(-50%) rotate(-90deg);
}

.js-accordion-sp-btn.is-opend {
	background: #ffffff;
	color: #000;
}

.js-accordion-sp-btn.is-opend::before {
	background: #000;
	-webkit-transform: translateY(-50%) rotate(90deg);
	-ms-transform: translateY(-50%) rotate(90deg);
	transform: translateY(-50%) rotate(90deg);
	z-index: 1;
}

.heading-2 {
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-align: center;
	color: #fff;
}

.heading-3 {
	margin-bottom: 14px;
	background: #513473;
	padding: 1em;
	color: #fff;
	font-size: 1.5rem;
	letter-spacing: 0.05em;
	font-weight: 700;
}

.heading-4-wrap {
	position: relative;
	padding: 77px 0 97px;
	background: rgb(198, 78, 144);
	background: -webkit-gradient(linear, left top, right top, from(rgb(198, 78, 144)), to(rgb(0, 150, 208)));
	background: -o-linear-gradient(left, rgb(198, 78, 144) 0%, rgb(0, 150, 208) 100%);
	background: linear-gradient(90deg, rgb(198, 78, 144) 0%, rgb(0, 150, 208) 100%);
	outline: 2px solid #ffffff;
	outline-offset: -10px;
}

.heading-4 {
	position: relative;
	text-align: center;
	z-index: 20;
}

.heading-4::before {
	position: absolute;
	content: "";
	background: url(../img/deco_01_sp.png) no-repeat center/contain;
	width: 531px;
	height: 416px;
	top: 89%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	pointer-events: none;
}

.heading-4__top {
	display: inline-block;
	background: #000;
	border-radius: 14px;
	text-align: center;
	font-size: 1.3rem;
	letter-spacing: 0.1em;
	color: #fff;
	font-weight: 700;
	padding: 7px 19px;
}

.heading-4__main {
	margin-top: 8px;
	display: block;
	color: #fff;
	font-size: 5.2736rem;
	font-weight: 500;
}

.heading-4__main span {
	padding: 0 0.1em 0 0.2em;
	color: #000;
	font-weight: 700;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(20%, transparent), color-stop(20%, #ffdf00), color-stop(90%, #ffdf00), color-stop(90%, transparent));
	background: -o-linear-gradient(transparent 20%, #ffdf00 20%, #ffdf00 90%, transparent 90%);
	background: linear-gradient(transparent 20%, #ffdf00 20%, #ffdf00 90%, transparent 90%);
	letter-spacing: .1em;
}

.heading-4__main img {
	margin: 0 13px 4px;
}

.heading-4__text {
	margin-top: 9px;
	display: block;
	text-align: center;
	color: #fff;
	font-size: 1.3rem;
	letter-spacing: 0.05em;
}

.heading-4__text span {
	font-size: 1.8rem;
}

.heading-5 {
	display: inline-block;
	background: #93a6b0;
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	padding: 6px;
	-webkit-transform: scale(0.9);
	-ms-transform: scale(0.9);
	transform: scale(0.9);
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

.heading-6 {
	text-align: center;
	font-weight: 700;
	margin-bottom: 26px;
}

.heading-6__en {
	font-size: 3.6rem;
	letter-spacing: 0.25em;
	color: #00B4AA;
	margin-bottom: 10px;
	display: block;
}

.heading-6__jp {
	font-size: 1.6rem;
	letter-spacing: 0.04em;
}

.text {
	/* font-size: 1.3rem;
	font-weight: 500;
	line-height: 2;
	color: #fff; */
}

.about__image {
	margin-right: calc(50% - 50vw);
	margin-left: calc(50% - 50vw);
}

.about__image__inner img {
	display: block;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.about__main {
	margin-top: -63px;
}

.about__heading__sub {
	position: relative;
	display: block;
	width: 110px;
	background: #513473;
	font-size: 1rem;
	color: #fff;
	font-weight: 500;
	border-radius: 6px;
	padding: 6px 6px 7px;
	white-space: nowrap;
}

.about__heading__sub__lg {
	font-size: 1.377rem;
}

.about__heading__main {
	position: relative;
	margin-top: 9px;
	display: inline-block;
	color: #fff;
	background: #000;
	font-size: 4.4rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	padding: 5px 15px 6px 6px;
	white-space: nowrap;
}

.about__heading__sm {
	position: absolute;
	top: 3px;
	right: 5px;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	vertical-align: middle;
	font-size: 1rem;
	-webkit-transform: scale(0.8);
	-ms-transform: scale(0.8);
	transform: scale(0.8);
	white-space: nowrap;
	font-family: "Noto Sans JP", sans-serif;
}

.about__heading__tentative {
	display: inline-block;
	-webkit-transform: translateY(-5px);
	-ms-transform: translateY(-5px);
	transform: translateY(-5px);
}

.about__department-name {
	margin-top: 7px;
	display: inline-block;
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	color: #fff;
	background: #000;
	padding: 5px 6px 6px 6px;
}

.about__lead {
	margin-top: 25px;
}

.about__lead p {
	display: inline;
	color: #a75a93;
	font-size: 1.6rem;
	line-height: 2.3;
	font-weight: 700;
	padding: 1px 5px;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
	background-color: #fff;
}

.about__text {
	margin-top: 16px;
}

.course {
	margin: 55px 0 39px;
}

.course__heading {
	text-align: center;
	color: #fff;
}

.course__heading__sub {
	display: block;
	font-size: 1.5rem;
	letter-spacing: 0.05em;
	line-height: 1.6;
	padding-bottom: 1em;
	border-bottom: 1px solid #fff;
}

.course__heading__main {
	display: block;
	margin-top: 6px;
	font-size: 2.4rem;
	letter-spacing: 0.05em;
	font-weight: 500;
}

.course__heading__main span {
	font-size: 3.6rem;
}

.course__image {
	margin: 27px auto 0;
	width: 295px;
	max-width: 95%;
}

.feature {
	margin-top: 53px;
}

.feature__inner {
	margin: 31px calc(50% - 50vw) 0;
	width: 100vw;
	background: #fff;
	padding: 10px 9.5% 28px;
}

.feature__item {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	padding: 19px 0;
}

.feature__item:not(:last-child) {
	border-bottom: 1px solid #cacaca;
	border-bottom: none;
}

.feature__image {
	position: relative;
	width: 42%;
}

.feature__image::before {
	content: "";
	display: block;
	padding-top: 90.22%;
}

.feature__image img {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	display: block;
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.feature__main {
	width: 53%;
}

.feature__heading {
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.5714;
}

.feature__text {
	margin-top: 6px;
	font-size: 1.1rem;
	line-height: 1.6364;
	text-align: justify;
}

.list-2col {
	padding: 87px 0 28px;
}

.list:not(:last-of-type) {
	margin-bottom: 35px;
}

.list__item {
	font-size: 1.3rem;
	color: #fff;
	letter-spacing: 0;
	line-height: 1.6923;
}

.list__item::before {
	content: "●";
	color: #513473;
	font-size: 0.8em;
}

.list__item sup {
	font-size: 75%;
	vertical-align: super;
}


.list__note {
	margin-top: 12px;
	width: 100%;
	color: #fff;
	font-size: 1rem;
	line-height: 1.7;
	font-weight: 300;
}

.list__note span {}

.list__note span:not(:first-of-type) {
	margin-left: 10px;
}

.list-2 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}

.list-2:not(:last-child) {
	margin-bottom: 10px;
}

.list-2__item {
	display: inline;
	color: #fff;
	line-height: 1.33;
	font-size: 0.9rem;
	font-weight: 700;
}

.list-2__item::before {
	content: "●";
	color: #000;
	font-size: 0.8em;
}

.seminar {
	padding-top: 40px;
}

/*.introduction { padding: 0 0 60px; }*/

.introduction__lead {
	margin: 80px 0 63px;
	text-align: center;
}

.introduction__lead span {
	display: inline-block;
	background: #fff;
	font-size: 2rem;
	letter-spacing: 0.05em;
	padding: 5px 6px;
	color: #e26c80;
}

.introduction__lead span:not(:last-child) {
	margin-bottom: 10px;
}

.introduction-item {
	padding: 40px 0 0;
}

.introduction-item:not(:last-of-type) {
	padding-bottom: 38px;
}

.introduction-item__head {
	position: relative;
}

.introduction-item__heading {
	display: block;
	z-index: 20;
	color: #fff;
	font-size: 4.5641rem;
	font-weight: 500;
}

.introduction-item__heading span {
	color: #000;
	font-weight: 700;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(20%, transparent), color-stop(20%, #ffdf00), color-stop(90%, #ffdf00), color-stop(90%, transparent));
	background: -o-linear-gradient(transparent 20%, #ffdf00 20%, #ffdf00 90%, transparent 90%);
	background: linear-gradient(transparent 20%, #ffdf00 20%, #ffdf00 90%, transparent 90%);
}

.introduction-item__heading img {
	display: inline-block;
	margin: 0 8px;
}

.introduction-item__heading--1 {
	position: absolute;
	top: -27px;
	left: -14px;
	-webkit-transform: rotate(-5deg);
	-ms-transform: rotate(-5deg);
	transform: rotate(-5deg);
}

.introduction-item__heading--2 {
	position: absolute;
	top: -23px;
	left: -14px;
	-webkit-transform: rotate(-5deg);
	-ms-transform: rotate(-5deg);
	transform: rotate(-5deg);
	font-size: 2.719rem;
}

.introduction-item__heading--2 img {
	width: 18px;
	margin: 0 4px;
}

.introduction-item__heading--3 {
	position: absolute;
	top: -20px;
	left: -14px;
	-webkit-transform: rotate(-5deg);
	-ms-transform: rotate(-5deg);
	transform: rotate(-5deg);
	font-size: 3.571rem;
}

.introduction-item__heading--3 img {
	width: 23px;
	margin: 0 6px;
}

.introduction-item__heading--4 {
	position: absolute;
	top: -20px;
	left: -14px;
	-webkit-transform: rotate(-5deg);
	-ms-transform: rotate(-5deg);
	transform: rotate(-5deg);
	font-size: 2.892rem;
}

.introduction-item__heading--4 img {
	width: 19px;
	margin: 0 5px;
}

.introduction-item__heading--5 {
	position: absolute;
	top: -20px;
	left: -14px;
	-webkit-transform: rotate(-5deg);
	-ms-transform: rotate(-5deg);
	transform: rotate(-5deg);
	font-size: 3.732rem;
}

.introduction-item__heading--5 img {
	width: 24px;
	margin: 0 4px;
}

.introduction-item__image {
	position: relative;
	margin: 0 calc(50% - 50vw);
	width: 100vw;
}

.introduction-item__image--deco01::before {
	position: absolute;
	content: "";
	background: url(../img/deco_drone.png) no-repeat center/contain;
	width: 282px;
	height: 97px;
	left: -73px;
	bottom: 58px;
}

.introduction-item__image--deco02::before {
	position: absolute;
	content: "";
	background: url(../img/deco_projector.png) no-repeat center/contain;
	width: 205px;
	height: 142px;
	right: -75px;
	bottom: -75px;
}

.introduction-item__image--deco03::before {
	position: absolute;
	content: "";
	background: url(../img/deco_money.png) no-repeat center/contain;
	width: 164px;
	height: 130px;
	right: -20px;
	bottom: -20px;
}

.introduction-item__image--deco04::before {
	position: absolute;
	content: "";
	background: url(../img/deco_phone.png) no-repeat center/contain;
	width: 143px;
	height: 148px;
	right: -25px;
	top: calc(100% + 20px);
	z-index: 1;
}

.introduction-item__image--deco05::before {
	position: absolute;
	content: "";
	background: url(../img/deco_ball.png) no-repeat center/contain;
	width: 128px;
	max-width: 56%;
	height: 128px;
	right: -35px;
	bottom: -35px;
}

.introduction-item__lead {
	position: absolute;
	left: 0;
	bottom: -10px;
}

.introduction-item__lead span {
	display: inline-block;
	font-size: 1.6rem;
	font-weight: 700;
	background: #000;
	color: #fff;
	padding: 6px 8px;
}

.introduction-item__content__heading {
	margin: 15px 0 14px;
	background: #e26c80;
	border-radius: 24px 24px 24px 0;
	padding: 10px 10px 11px 20px;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.7333;
}

.introduction-item__content__text {
	text-align: justify;
}

.teacher {
	position: relative;
	margin-bottom: 14px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	color: #fff;
	padding: 18px 0 16px;
}

.teacher::after {
	position: absolute;
	content: "";
	background: #fff;
	width: 100vw;
	height: 1px;
	bottom: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
}

.teacher__image {
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

.teacher__image img {
	width: 65px;
}

.teacher__profile {
	margin-left: 3%;
}

.teacher__major {
	display: block;
	font-size: 1.2rem;
	font-weight: 500;
}

.teacher__major span {
	margin-top: 5px;
	display: block;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}

.teacher__major span::after {
	content: "分野";
}

.teacher__name {
	margin-top: 5px;
	display: block;
	font-size: 1.2rem;
	font-weight: 700;
}

.course-item-wrap.swiper {
	overflow: visible;
}

.course-item-wrap.swiper .swiper-pagination {
	bottom: -28px;
}

.course-item-wrap.swiper .swiper-pagination .swiper-pagination-bullet {
	background: #ffffff;
	opacity: 1;
	width: 6px;
	height: 6px;
	margin: 0 5px;
	vertical-align: middle;
}

.course-item-wrap.swiper .swiper-pagination .swiper-pagination-bullet-active {
	background: #513473;
	width: 8px;
	height: 8px;
}

.course-item {
	overflow: visible;
	color: #fff;
	padding: 0 6.1% 30px;
	position: relative;
	background: #000;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(6%, transparent), color-stop(6%, #000), to(#000));
	background: -o-linear-gradient(transparent 6%, #000 6%, #000 100%);
	background: linear-gradient(transparent 6%, #000 6%, #000 100%);
}

.course-item__image {
	margin-right: auto;
	margin-left: auto;
}

.course-item__inner {
	margin: 0 11px;
}

.course-item__heading {
	margin-top: -33px;
}

.course-item__heading__major {
	display: inline-block;
	background: #000;
	font-size: 1.2rem;
	font-weight: 500;
}

.course-item__heading__course {
	display: inline-block;
	background: #000;
	margin-top: 8px;
	font-size: 1.8rem;
	font-weight: 500;
}

.course-item__text {
	margin-top: 15px;
	font-size: 1.2rem;
	line-height: 1.6;
	letter-spacing: 0.05em;
}

.course-item__link {
	margin-top: 17px;
	display: block;
	text-decoration: none;
	width: 100%;
	text-align: center;
	font-size: 1.3rem;
	letter-spacing: 0.05em;
	font-weight: 500;
	background: -webkit-gradient(linear, right top, left top, from(rgb(198, 78, 144)), to(rgb(0, 150, 208)));
	background: -o-linear-gradient(right, rgb(198, 78, 144) 0%, rgb(0, 150, 208) 100%);
	background: linear-gradient(to left, rgb(198, 78, 144) 0%, rgb(0, 150, 208) 100%);
	padding: 13px;
	-webkit-transition: 0.4s;
	-o-transition: 0.4s;
	transition: 0.4s;
}

.course-item__link:hover {
	opacity: 0.6;
}

.course-item__link span::after {
	content: "";
	width: 0;
	height: 0;
	display: inline-block;
	border-left: 6px solid #ffffff;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
	margin-left: 10px;
	vertical-align: middle;
	-webkit-transform: translateY(-1px);
	-ms-transform: translateY(-1px);
	transform: translateY(-1px);
}

.swiper-button-prev,
.swiper-button-next {
	position: absolute;
	width: 38px;
	height: 38px;
	top: 50%;
	z-index: 1;
	cursor: pointer;
}

.swiper-button-prev::after,
.swiper-button-next::after {
	content: "";
}

.swiper-button-prev {
	background: url(../img/icon_arrow_left.svg) no-repeat center center/contain;
	left: 0;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.swiper-button-next {
	background: url(../img/icon_arrow_right.svg) no-repeat center center/contain;
	right: 0;
	-webkit-transform: translate(50%, -50%);
	-ms-transform: translate(50%, -50%);
	transform: translate(50%, -50%);
}

.access {
	padding: 30px 0 48px;
}

.access__image {
	width: calc(100vw - 20px);
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	margin-top: -7px;
	margin-bottom: 20px;
}

.access__image img {
	display: block;
}

.access__note {
	font-size: 1.1rem;
	line-height: 1.45;
	text-align: justify;
}

.access__btn {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #00b4aa;
	width: 200px;
	height: 40px;
	margin: 20px auto 0;
	color: #fff;
}

.facility-wrap {
	padding: 40px 0 0;
}

.facility {
	position: relative;
	padding-top: calc(179% + 10px);
	width: calc(100% + 10px);
	margin-left: -5px;
	margin-bottom: 15px;
	margin-top: -8px;
}

.facility__item {
	padding: 5px;
	position: absolute;
}

.facility__item button {
	display: block;
	padding: 0;
	background: none;
	border: none;
	position: relative;
}

.facility__item button:after {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	right: 0;
	width: 20px;
	height: 20px;
	background: url(../new-building_facility/img/icon_search.svg) no-repeat right bottom, #FFFFFF;
}

.facility__item--01 {
	top: 0;
	left: 0;
	width: 55.3%;
}

.facility__item--02 {
	top: 0;
	right: 0;
	width: 44.7%;
}

.facility__item--03 {
	top: 15.5%;
	right: 0;
	width: 44.7%;
}

.facility__item--04 {
	top: 31.1%;
	left: 0;
	width: 33.333333%;
}

.facility__item--05 {
	top: 31.1%;
	left: 33.333333%;
	width: 33.333333%;
}

.facility__item--06 {
	top: 31.1%;
	right: 0;
	width: 33.333333%;
}

.facility__item--07 {
	top: 50%;
	left: 0;
	width: 44.6%;
}

.facility__item--08 {
	top: 65.5%;
	left: 0;
	width: 44.6%;
}

.facility__item--09 {
	top: 50%;
	right: 0;
	width: 55.4%;
}

.facility__item--10 {
	bottom: 0;
	left: 0;
	width: 33.333333%;
}

.facility__item--11 {
	bottom: 0;
	left: 33.333333%;
	width: 33.333333%;
}

.facility__item--12 {
	bottom: 0;
	right: 0;
	width: 33.333333%;
}

.facility__item img {
	display: block;
}

.facility__main {
	display: none;
}

.facility__name {
	font-size: 1.8rem;
	font-weight: 700;
	margin-top: 10px;
}

.facility__detail {
	margin-top: 14px;
	font-size: 1.2rem;
	letter-spacing: 0.1em;
}

.facility__detail:after {
	content: "";
	background: url(../img/arrow_white.svg) no-repeat center/contain;
	width: 40px;
	height: 6px;
	display: inline-block;
	vertical-align: middle;
	margin: 0 0 7px 5px;
}

.facility-detail__inner {
	padding: 0 30px 30px;
}

.facility-detail__image {
	margin-bottom: 30px;
	width: 100%;
	padding-top: 66.666666%;
	position: relative;
}

.facility-detail__image img {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: block;
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.facility-detail__heading {
	text-align: center;
	font-weight: 700;
	font-size: 2rem;
	margin-bottom: 25px;
}

.facility-detail__text {
	line-height: 1.78;
	text-align: justify;
}

.new-building {
	position: relative;
	padding: 42px 0 48px;
	margin-bottom: 20px;
}

.new-building::before {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 100vw;
	height: 100%;
	display: block;
	background: #006441;
}

.new-building__head {
	position: relative;
	color: #ffffff;
}

.new-building__head__text {
	line-height: 1.71;
	width: 87.5%;
	margin-left: auto;
	margin-right: auto;
	text-align: justify;
}

.new-building__head__text sup {
	font-size: 50%;
	vertical-align: top;
}

.new-building__heading {
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.59;
	margin-bottom: 15px;
	text-align: center;
}

.new-building__heading span {
	font-size: 80%;
}

.new-building__heading sup {
	font-size: 50%;
	font-weight: 400;
	vertical-align: top;
}

.new-building__image-wrap {
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 100vw;
	margin: 25px 0 28px;
}

.new-building__image figcaption {
	position: absolute;
	top: 7.5%;
	left: 5.6%;
	background: #006441;
	color: #ffffff;
	padding: 8px 14px 10px;
	font-weight: 700;
	line-height: 1.5;
}

.new-building__image figcaption::before {
	position: absolute;
	top: 100%;
	left: 60px;
	content: "";
	width: 20px;
	height: 20px;
	display: block;
	background: -o-linear-gradient(225deg, #006441 50%, transparent 50%);
	background: linear-gradient(225deg, #006441 50%, transparent 50%);
}

.new-building__detail {
	position: relative;
}

.new-building__point {
	background: #ffffff;
	width: 93.75%;
	margin-left: auto;
	margin-right: auto;
	padding: 14px 20px 20px;
}

.new-building__point__text {
	font-weight: 700;
	color: #006441;
	line-height: 1.71;
	letter-spacing: 0.04em;
	margin-bottom: 10px;
}

.new-building__point__list {
	font-weight: 500;
	line-height: 1.64;
	text-align: justify;
}

.new-building__point__list li {
	text-indent: -1em;
	padding-left: 1em;
}

.new-building__point__list li::before {
	content: "■";
	color: #006441;
}

.new-building__note {
	font-size: 1.1rem;
	line-height: 1.54;
	color: #ffffff;
	width: 87.5%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 12px;
	text-align: justify;
}

.content-lead {
	line-height: 1.71;
	margin-bottom: 34px;
	text-align: justify;
}

.modal {
	opacity: 0;
	visibility: hidden;
	background: rgba(255, 255, 255, 0.8);
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1000;
	-webkit-transition: 0.4s;
	-o-transition: 0.4s;
	transition: 0.4s;
}

.modal.is-visible {
	opacity: 1;
	visibility: visible;
}

.modal__wrapper {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.modal__inner {
	background: rgba(0, 0, 0, 0.8);
	color: #FFFFFF;
	padding-top: 70px;
	width: 100vw;
	-webkit-transition: 0.4s;
	-o-transition: 0.4s;
	transition: 0.4s;
}

.modal__inner[data-type=course] {
	height: 100%;
}

.modal__item {
	overflow: auto;
	max-height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	opacity: 0;
	visibility: hidden;
	-webkit-transition: 0.4s;
	-o-transition: 0.4s;
	transition: 0.4s;
	padding-top: 70px;
}

.modal__item.is-visible {
	opacity: 1;
	visibility: visible;
}

.modal__close {
	background: none;
	border: none;
	padding: 0;
	position: absolute;
	top: 0;
	right: 0;
	width: 70px;
	height: 70px;
}

.modal__arrows {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	position: absolute;
	top: calc(70px + 67vw);
	left: 50%;
	width: 100%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.modal__arrows--course {
	top: calc(70px + 75vw);
}

.modal__arrow {
	background: none;
	border: none;
	padding: 0;
	width: 30px;
	height: 40px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.modal__arrow--left {
	margin-left: 20px;
}

.modal__arrow--right {
	margin-right: 20px;
}

@font-face {
	src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
	font-weight: 400;
	font-style: normal;
}

.swiper {
	margin-left: auto;
	margin-right: auto;
	position: relative;
	overflow: hidden;
	list-style: none;
	padding: 0;
	/* Fix of Webkit flickering */
	z-index: 1;
}

.swiper-vertical>.swiper-wrapper {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.swiper-wrapper {
	position: relative;
	width: 100%;
	height: 100%;
	z-index: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-transition-property: -webkit-transform;
	transition-property: -webkit-transform;
	-o-transition-property: transform;
	transition-property: transform;
	transition-property: transform, -webkit-transform;
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
}

.swiper-android .swiper-slide,
.swiper-wrapper {
	-webkit-transform: translate3d(0px, 0, 0);
	transform: translate3d(0px, 0, 0);
}

.swiper-pointer-events {
	-ms-touch-action: pan-y;
	touch-action: pan-y;
}

.swiper-pointer-events.swiper-vertical {
	-ms-touch-action: pan-x;
	touch-action: pan-x;
}

.swiper-slide {
	-ms-flex-negative: 0;
	flex-shrink: 0;
	width: 100%;
	height: 100%;
	position: relative;
	-webkit-transition-property: -webkit-transform;
	transition-property: -webkit-transform;
	-o-transition-property: transform;
	transition-property: transform;
	transition-property: transform, -webkit-transform;
}

.swiper-slide-invisible-blank {
	visibility: hidden;
}

/* Auto Height */

.swiper-autoheight,
.swiper-autoheight .swiper-slide {
	height: auto;
}

.swiper-autoheight .swiper-wrapper {
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-transition-property: height, -webkit-transform;
	transition-property: height, -webkit-transform;
	-o-transition-property: transform, height;
	transition-property: transform, height;
	transition-property: transform, height, -webkit-transform;
}

.swiper-backface-hidden .swiper-slide {
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

/* 3D Effects */

.swiper-3d,
.swiper-3d.swiper-css-mode .swiper-wrapper {
	-webkit-perspective: 1200px;
	perspective: 1200px;
}

.swiper-3d .swiper-wrapper,
.swiper-3d .swiper-slide,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-cube-shadow {
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d;
}

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 10;
}

.swiper-3d .swiper-slide-shadow {
	background: rgba(0, 0, 0, 0.15);
}

.swiper-3d .swiper-slide-shadow-left {
	background-image: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: -o-linear-gradient(right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
	background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-right {
	background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
	background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-top {
	background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
	background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-bottom {
	background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: -o-linear-gradient(top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
	background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

/* CSS Mode */

.swiper-css-mode>.swiper-wrapper {
	overflow: auto;
	scrollbar-width: none;
	/* For Firefox */
	-ms-overflow-style: none;
	/* For Internet Explorer and Edge */
}

.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar {
	display: none;
}

.swiper-css-mode>.swiper-wrapper>.swiper-slide {
	scroll-snap-align: start start;
}

.swiper-horizontal.swiper-css-mode>.swiper-wrapper {
	-ms-scroll-snap-type: x mandatory;
	scroll-snap-type: x mandatory;
}

.swiper-vertical.swiper-css-mode>.swiper-wrapper {
	-ms-scroll-snap-type: y mandatory;
	scroll-snap-type: y mandatory;
}

.swiper-centered>.swiper-wrapper::before {
	content: "";
	-ms-flex-negative: 0;
	flex-shrink: 0;
	-webkit-box-ordinal-group: 10000;
	-ms-flex-order: 9999;
	order: 9999;
}

.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child {
	-webkit-margin-start: var(--swiper-centered-offset-before);
	margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-horizontal>.swiper-wrapper::before {
	height: 100%;
	width: var(--swiper-centered-offset-after);
}

.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child {
	-webkit-margin-before: var(--swiper-centered-offset-before);
	margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-vertical>.swiper-wrapper::before {
	width: 100%;
	height: var(--swiper-centered-offset-after);
}

.swiper-centered>.swiper-wrapper>.swiper-slide {
	scroll-snap-align: center center;
	scroll-snap-stop: always;
}

.swiper-pagination {
	position: absolute;
	text-align: center;
	-webkit-transition: 300ms opacity;
	-o-transition: 300ms opacity;
	transition: 300ms opacity;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
	opacity: 0;
}

.swiper-pagination-disabled>.swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
	display: none !important;
}

/* Common Styles */

.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal {
	bottom: 10px;
	left: 0;
	width: 100%;
}

/* Bullets */

.swiper-pagination-bullets-dynamic {
	overflow: hidden;
	font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	-webkit-transform: scale(0.33);
	-ms-transform: scale(0.33);
	transform: scale(0.33);
	position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
	-webkit-transform: scale(1);
	-ms-transform: scale(1);
	transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
	-webkit-transform: scale(1);
	-ms-transform: scale(1);
	transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
	-webkit-transform: scale(0.66);
	-ms-transform: scale(0.66);
	transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
	-webkit-transform: scale(0.33);
	-ms-transform: scale(0.33);
	transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
	-webkit-transform: scale(0.66);
	-ms-transform: scale(0.66);
	transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
	-webkit-transform: scale(0.33);
	-ms-transform: scale(0.33);
	transform: scale(0.33);
}

.swiper-pagination-bullet {
	width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
	height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
	display: inline-block;
	border-radius: 50%;
	background: var(--swiper-pagination-bullet-inactive-color, #000);
	opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}

button.swiper-pagination-bullet {
	border: none;
	margin: 0;
	padding: 0;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
	cursor: pointer;
}

.swiper-pagination-bullet:only-child {
	display: none !important;
}

.swiper-pagination-bullet-active {
	opacity: var(--swiper-pagination-bullet-opacity, 1);
	background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-vertical>.swiper-pagination-bullets,
.swiper-pagination-vertical.swiper-pagination-bullets {
	right: 10px;
	top: 50%;
	-webkit-transform: translate3d(0px, -50%, 0);
	transform: translate3d(0px, -50%, 0);
}

.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
	display: block;
}

.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 8px;
}

.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	display: inline-block;
	-webkit-transition: 200ms top, 200ms -webkit-transform;
	transition: 200ms top, 200ms -webkit-transform;
	-o-transition: 200ms transform, 200ms top;
	transition: 200ms transform, 200ms top;
	transition: 200ms transform, 200ms top, 200ms -webkit-transform;
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	white-space: nowrap;
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	-webkit-transition: 200ms left, 200ms -webkit-transform;
	transition: 200ms left, 200ms -webkit-transform;
	-o-transition: 200ms transform, 200ms left;
	transition: 200ms transform, 200ms left;
	transition: 200ms transform, 200ms left, 200ms -webkit-transform;
}

.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	-webkit-transition: 200ms right, 200ms -webkit-transform;
	transition: 200ms right, 200ms -webkit-transform;
	-o-transition: 200ms transform, 200ms right;
	transition: 200ms transform, 200ms right;
	transition: 200ms transform, 200ms right, 200ms -webkit-transform;
}

/* Progress */

.swiper-pagination-progressbar {
	background: rgba(0, 0, 0, 0.25);
	position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	background: var(--swiper-pagination-color, var(--swiper-theme-color));
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	-webkit-transform: scale(0);
	-ms-transform: scale(0);
	transform: scale(0);
	-webkit-transform-origin: left top;
	-ms-transform-origin: left top;
	transform-origin: left top;
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	-webkit-transform-origin: right top;
	-ms-transform-origin: right top;
	transform-origin: right top;
}

.swiper-horizontal>.swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
	width: 100%;
	height: 4px;
	left: 0;
	top: 0;
}

.swiper-vertical>.swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
	width: 4px;
	height: 100%;
	left: 0;
	top: 0;
}

.swiper-pagination-lock {
	display: none;
}

/* base */

/* Tools */

/* Layout */

/* Module */

@media screen and (min-width: 681px) {

	.l-body {
		/* pc */
		/* min-width: 1100px; */
	}

	.l-wrapper {
		/* pc */
		/* width: 1000px; */
	}

	.l-wrapper-lg {
		/* pc */
		/* min-width: 1000px;
		max-width: 1100px; */
	}

	.l-header {
		/* pc */
		/* padding: 16px 0;
		min-width: 1100px; */
	}

	.l-navi {
		/* pc */
		/* min-width: 1100px;
		padding: 80px 0; */
	}

	.l-main {
		/* pc */
		/* background: url(../img/bg_pc.png) repeat-y center top/clamp(2500px, 100vw, 100vw) auto, -o-linear-gradient(315deg, #c64e90, #0096d0);
		background: url(../img/bg_pc.png) repeat-y center top/clamp(2500px, 100vw, 100vw) auto, linear-gradient(135deg, #c64e90, #0096d0);
		padding-top: 118px;
		padding-bottom: 200px; */
	}

	.navi {
		/* pc */
		/* padding: 0;
		width: 90%;
		max-width: 800px;
		margin-left: auto;
		margin-right: auto; */
	}

	.navi__list {
		/* pc */
		/*
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
*/
		border-top: none;
	}

	.navi__list__item {
		/* pc */
		border-bottom: 1px solid rgba(255, 255, 255, 0.3);
		/*	width: 45%;*/
	}

	.navi__list__item:first-child,
	.navi__list__item:nth-child(2) {
		border-top: 1px solid rgba(255, 255, 255, 0.3);
	}

	.navi__list__item a {
		/* pc */
		/* font-size: 1.6rem;
		padding: 16px 10px 17px;
		-webkit-transition: 0.4s;
		-o-transition: 0.4s;
		transition: 0.4s; */
	}

	.navi__list__item a:hover {
		/* opacity: 0.6; */
	}

	.navi__list__item a::before {
		/* pc */
		/* width: 19px;
		height: 19px; */
	}

	.navi__list__item--wide {
		/* pc */
		/* width: 100%; */
	}

	.navi__child {
		/* pc */
	}

	.navi__child__item:not(:last-child) {
		/* pc */
	}

	.navi__child__item a {
		/* pc */
		font-size: 1.5rem;
		padding: 12px 20px 13px;
		-webkit-transition: 0.4s;
		-o-transition: 0.4s;
		transition: 0.4s;
	}

	.navi__child__item a:hover {
		opacity: 0.6;
	}

	.navi__child__item a::after {
		/* pc */
		right: 20px;
	}

	.navi__child__item a span {
		/* pc */
		font-size: inherit;
	}

	.navi__button {
		/* pc */
		font-size: 1.6rem;
		width: 100%;
		max-width: 440px;
		padding: 12px 0;
		margin-top: 60px;
		-webkit-transition: 0.4s;
		-o-transition: 0.4s;
		transition: 0.4s;
	}

	.navi__button:hover {
		opacity: 0.6;
	}

	.navi__button span::before {
		/* pc */
		width: 36px;
		height: 36px;
	}

	.header-logo {
		/* pc */
		top: 25px;
		left: 32px;
		width: 120px;
		max-width: none;
	}

	.header-buttons__item {
		/* pc */
		width: 112px;
		height: 48px;
		border-radius: 5px;
		font-size: 1.28rem;
		line-height: 1;
	}

	.header-buttons__item a {
		/* pc */
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}

	.header-buttons__item:first-child {
		/* pc */
		border-radius: 5px;
	}

	.header-buttons__item:first-child .header-buttons__icon {
		-webkit-transform: translateX(3px);
		-ms-transform: translateX(3px);
		transform: translateX(3px);
	}

	.header-buttons__item:last-child {
		/* pc */
		border-radius: 5px;
	}

	.header-buttons__item:not(:last-child) {
		/* pc */
		margin-right: 10px;
	}

	.header-buttons__item span {
		/* pc */
		font-size: 1.6rem;
	}

	.header-buttons__icon {
		/* pc */
		display: block;
		width: 24px;
		margin: -6px 0 -3px;
	}

	.menu-btn {
		/* pc */
		width: 48px;
		height: 48px;
		margin: 0 23px 0 23px;
	}

	.menu-btn span {
		/* pc */
		width: 30px;
	}

	.menu-btn span:first-child {
		/* pc */
		top: 12px;
	}

	.menu-btn span:nth-child(2) {
		/* pc */
		top: 24px;
	}

	.menu-btn span:nth-child(3) {
		/* pc */
		top: 37px;
	}

	.mainvisual {
		/* pc */
		position: relative;
	}

	.mainvisual__main {
		/* pc */
		height: 100vh;
		min-height: 700px;
	}

	.mainvisual__main::before {
		/* pc */
		min-width: none;
		background-image: url(../img/bg_mv_pc.jpg);
	}

	.mainvisual__main::after {
		/* pc */
		min-width: none;
		background-image: url(../img/img_mv_pc.png);
	}

	.mainvisual__copy {
		/* pc */
		top: 118px;
		left: 18.8%;
	}

	.mainvisual__copy span:not(:last-child) {
		/* pc */
		margin-left: 17px;
	}

	.mainvisual__copy span img {
		/* pc */
		width: 28px;
	}

	.mainvisual__new {
		/* pc */
		background: none;
		position: absolute;
		bottom: 2.2%;
		left: 50%;
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		transform: translateX(-50%);
	}

	.mainvisual__new__heading__img--1 {
		/* pc */
		background-size: 502px auto;
		padding: 4px 6px 3px 4px;
	}

	.mainvisual__new__heading__img--1 img {
		width: 492px;
	}

	.mainvisual__new__heading__img--2 {
		/* pc */
		background: -o-linear-gradient(45deg, #0096d0, #c64e90) no-repeat right top/100% 100%;
		background: linear-gradient(45deg, #0096d0, #c64e90) no-repeat right top/100% 100%;
		padding: 4px 7px;
		-webkit-transform: scale(0, 1);
		-ms-transform: scale(0, 1);
		transform: scale(0, 1);
		-webkit-transform-origin: left top;
		-ms-transform-origin: left top;
		transform-origin: left top;
	}

	.mainvisual__new__heading__img--2::after {
		position: absolute;
		top: 0;
		right: 0;
		content: "";
		width: 100%;
		height: 100%;
		display: block;
		background: inherit;
	}

	.mainvisual__new__heading__img--2 img {
		width: 566px;
		max-width: none;
	}

	.mainvisual__new__heading.is-visible .mainvisual__new__heading__img--2 {
		/* pc */
		-webkit-animation: stretchRight1 0.5s ease-out 0.5s forwards;
		animation: stretchRight1 0.5s ease-out 0.5s forwards;
	}

	.mainvisual__new__heading.is-visible .mainvisual__new__heading__img--2::after {
		-webkit-animation: stretchRight2 0.5s ease-out 1s forwards;
		animation: stretchRight2 0.5s ease-out 1s forwards;
	}

	.mainvisual__new__note {
		/* pc */
		font-size: 1.1rem;
		letter-spacing: 0.05em;
		margin-top: 16px;
	}

	.mainvisual__new__note.is-visible {
		/* pc */
		-webkit-animation: fadeUp 0.5s forwards;
		animation: fadeUp 0.5s forwards;
	}

	.link {
		/* pc */
		padding: 58px 0 80px;
	}

	.link__head {
		/* pc */
		font-size: 2rem;
		letter-spacing: 0.1em;
		margin-bottom: 42px;
	}

	.link__inner {
		/* pc */
		width: 800px;
		margin-left: auto;
		margin-right: auto;
	}

	.link__item {
		/* pc */
		width: 250px;
		height: 60px;
		font-size: 1.8rem;
		-webkit-transition: 0.4s;
		-o-transition: 0.4s;
		transition: 0.4s;
	}

	.link__item:hover {
		opacity: 0.7;
	}

	.link__item__icon {
		/* pc */
		width: 31px;
		display: inline;
		vertical-align: middle;
		margin-top: 5px;
		margin-right: 10px;
	}

	.footer {
		/* pc */
		padding: 60px 0;
	}

	.js-accordion-sp-btn {
		/* pc */
		display: none;
	}

	.heading-2 {
		/* pc */
		font-size: 3rem;
	}

	.heading-3 {
		/* pc */
		font-size: 1.6rem;
		padding: 1.1em 1.2em;
	}

	.heading-4-wrap {
		/* pc */
		position: relative;
		padding: 65px 0 87px;
		outline: none;
	}

	.heading-4-wrap::before,
	.heading-4-wrap::after {
		position: absolute;
		content: "";
		background: #fff;
		width: 100%;
		height: 1px;
		left: 50%;
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		transform: translateX(-50%);
	}

	.heading-4-wrap::before {
		top: 10px;
	}

	.heading-4-wrap::after {
		bottom: 10px;
	}

	.heading-4::before {
		/* pc */
		background: url(../img/deco_01_pc.png) no-repeat center/contain;
		width: 906px;
		height: 503px;
		top: 61%;
		left: 46.2%;
	}

	.heading-4__top {
		/* pc */
		font-size: 1.6827rem;
		padding: 10px 23px;
		border-radius: 18.121px;
	}

	.heading-4__main {
		/* pc */
		margin-top: 9px;
		font-size: 6.8259rem;
	}

	.heading-4__text {
		/* pc */
		margin-top: 11px;
		font-size: 1.68267rem;
	}

	.heading-4__text span {
		/* pc */
		font-size: 2.3298rem;
	}

	.heading-5 {
		/* pc */
		padding: 7px;
		font-size: 1.1rem;
		-webkit-transform: none;
		-ms-transform: none;
		transform: none;
		margin-right: 5px;
	}

	.heading-6 {
		/* pc */
		margin-bottom: 35px;
	}

	.heading-6__en {
		/* pc */
		font-size: 4.5rem;
		margin-bottom: 15px;
	}

	.text {
		/* pc */
		font-size: 1.4rem;
	}

	.about {
		/* pc */
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.about__image {
		/* pc */
		width: 42%;
		margin-left: 0;
		margin-right: 0;
		-ms-flex-negative: 0;
		flex-shrink: 0;
	}

	.about__image__inner {
		/* pc */
		width: calc(50vw - 500px + 100%);
		min-width: calc(100% + 50px);
		height: 500px;
		position: relative;
		left: 100%;
		-webkit-transform: translateX(-100%);
		-ms-transform: translateX(-100%);
		transform: translateX(-100%);
	}

	.about__main {
		/* pc */
		-ms-flex-negative: 0;
		flex-shrink: 0;
		margin-top: 69px;
		width: 53%;
	}

	.about__heading {
		/* pc */
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: reverse;
		-ms-flex-direction: row-reverse;
		flex-direction: row-reverse;
		-webkit-box-pack: end;
		-ms-flex-pack: end;
		justify-content: flex-end;
	}

	.about__heading__sub__lg {
		/* pc */
		display: inline-block;
		margin-top: 3px;
		font-size: 1.8rem;
	}

	.about__heading__sub {
		/* pc */
		margin-left: 11px;
		border-radius: 10px;
		font-size: 1.2rem;
		text-align: center;
		padding: 24px 12px;
	}

	.about__heading__main {
		/* pc */
		margin-top: 0;
		font-size: 6rem;
		line-height: 1;
		padding: 8px 30px 14px 9px;
	}

	.about__heading__sm {
		/* pc */
		top: 13px;
		right: 15px;
		vertical-align: middle;
		font-size: 1.1rem;
		-webkit-transform: scale(1);
		-ms-transform: scale(1);
		transform: scale(1);
	}

	.about__heading__tentative {
		/* pc */
		-webkit-transform: translateY(-7px);
		-ms-transform: translateY(-7px);
		transform: translateY(-7px);
	}

	.about__department-name {
		/* pc */
		margin-top: 14px;
		font-size: 2.4rem;
		padding: 8px 8px 9px 8px;
		;
	}

	.about__lead {
		/* pc */
		margin-top: 45px;
	}

	.about__lead p {
		/* pc */
		font-size: 2rem;
		line-height: 2.5;
		padding: 3px 6px 3px 8px;
		white-space: nowrap;
	}

	.about__text {
		/* pc */
		margin-top: 24px;
	}

	.course {
		/* pc */
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		margin: 102px 0 46px;
	}

	.course__heading {
		/* pc */
		margin-top: 70px;
		width: 55%;
		text-align: left;
	}

	.course__heading__sub {
		/* pc */
		font-size: 2.2rem;
		line-height: 1.8182;
		padding-bottom: 25px;
	}

	.course__heading__main {
		/* pc */
		margin-top: 10px;
		font-size: 6rem;
	}

	.course__heading__main span {
		/* pc */
		font-size: 9rem;
	}

	.course__image {
		/* pc */
		margin: 0;
		width: 39.5%;
	}

	.feature {
		/* pc */
		margin-top: 122px;
	}

	.feature__inner {
		/* pc */
		margin: 41px auto 0;
		max-width: 1000px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		width: auto;
		padding: 50px 25px 23px;
	}

	.feature__item:not(:last-child) {
		/* pc */
		border-right: 1px solid #cacaca;
	}

	.feature__item {
		/* pc */
		display: block;
		padding: 0 30px;
		width: 33.3333%;
	}

	.feature__image {
		/* pc */
		width: 100%;
	}

	.feature__image::before {
		/* pc */
		padding-top: 62.3%;
	}

	.feature__main {
		/* pc */
		width: 100%;
	}

	.feature__heading {
		/* pc */
		margin-top: 23px;
		font-size: 1.8rem;
		line-height: 1.4444;
		text-align: center;
	}

	.feature__text {
		/* pc */
		margin-top: 14px;
		font-size: 1.4rem;
		line-height: 1.7143;
	}

	.list-2col {
		/* pc */
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		padding: 210px 0 50px;
	}

	.list-2col--with-note {
		flex-wrap: wrap;
	}

	.list__note {
		width: 100%;
		text-align: right;
	}

	.list:not(:last-child) {
		/* pc */
		margin-bottom: 0;
	}

	.list {
		/* pc */
		width: 47.3%;
	}

	.list__item {
		/* pc */
		display: inline;
		font-size: 1.4rem;
		margin-right: 0.5em;
		line-height: 1.8571;
	}

	.list__note {
		/* pc */
		margin-top: 10px;
		width: 100%;
	}

	.list-2 {
		/* pc */
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}

	.list-2__item {
		/* pc */
		font-size: 1.2rem;
	}

	.seminar {
		/* pc */
		margin-top: 80px;
		padding-top: 110px;
	}


	.introduction__lead {
		/* pc */
		margin: 114px 0 65px;
	}

	.introduction__lead span:not(:last-child) {
		/* pc */
		margin-bottom: 13px;
	}

	.introduction__lead span {
		/* pc */
		font-size: 3rem;
		letter-spacing: 0.1em;
		padding: 8px 13px;
	}

	.introduction-item {
		/* pc */
		padding: 60px 0 0;
	}

	.introduction-item:not(:last-child) {
		/* pc */
		margin-bottom: 63px;
	}

	.introduction-item__inner {
		/* pc */
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.introduction-item__head {
		/* pc */
		width: 48%;
	}

	.introduction-item__heading {
		/* pc */
		width: 600px;
		font-size: 6.8461rem;
	}

	.introduction-item__heading img {
		/* pc */
		width: 44px;
		margin: 0 12px 4px;
	}

	.introduction-item__heading--1 {
		/* pc */
		top: -50px;
		left: -29px;
	}

	.introduction-item__heading--2 {
		/* pc */
		top: -42px;
		left: -29px;
		font-size: 4.766rem;
	}

	.introduction-item__heading--2 img {
		/* pc */
		width: 31px;
		margin: 0 8px 4px;
	}

	.introduction-item__heading--3 {
		/* pc */
		top: -43px;
		left: -29px;
		font-size: 5.189rem;
	}

	.introduction-item__heading--3 img {
		/* pc */
		width: 34px;
		margin: 0 8px;
	}

	.introduction-item__heading--4 {
		/* pc */
		top: -45px;
		left: -29px;
		font-size: 5.189rem;
	}

	.introduction-item__heading--4 img {
		/* pc */
		width: 34px;
		margin: 0 8px;
	}

	.introduction-item__heading--5 {
		/* pc */
		top: -45px;
		left: -29px;
		font-size: 5.189rem;
	}

	.introduction-item__heading--5 img {
		/* pc */
		width: 34px;
		margin: 0 8px;
	}

	.introduction-item__image {
		/* pc */
		margin: 0;
		width: 90%;
		width: auto;
	}

	.introduction-item__image--deco01::before {
		/* pc */
		width: 564px;
		height: 194px;
		left: -325px;
		bottom: 67px;
	}

	.introduction-item__image--deco02::before {
		/* pc */
		width: 435px;
		height: 302px;
		right: auto;
		left: calc(100% + 370px);
		bottom: -290px;
		z-index: 1;
	}

	.introduction-item__image--deco03::before {
		/* pc */
		width: 308px;
		height: 244px;
		right: auto;
		left: -240px;
		bottom: 20px;
	}

	.introduction-item__image--deco04::before {
		/* pc */
		width: 251px;
		height: 260px;
		right: auto;
		left: calc(100% + 545px);
		top: auto;
		bottom: -90px;
	}

	.introduction-item__image--deco05::before {
		/* pc */
		width: 227px;
		height: 227px;
		right: auto;
		left: -150px;
		bottom: 15px;
	}

	.introduction-item__lead {
		/* pc */
		left: -31px;
		bottom: 31px;
	}

	.introduction-item__lead span {
		/* pc */
		font-size: 2.4rem;
		padding: 8px;
	}

	.introduction-item__lead span:not(:last-child) {
		margin-bottom: 10px;
	}

	.introduction-item__content {
		/* pc */
		width: 48%;
		margin-bottom: 46px;
	}

	.introduction-item__content__heading {
		/* pc */
		margin: 0 0 22px;
		font-size: 1.6rem;
		padding: 13px 10px 15px 20px;
	}

	.introduction-item__content__text {
		/* pc */
		font-size: 1.3rem;
	}

	.teacher-wrap {
		/* pc */
		padding-top: 31px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		position: relative;
	}

	.teacher-wrap::after {
		position: absolute;
		content: "";
		background: #fff;
		width: 100%;
		height: 1px;
		top: 0;
		left: 50%;
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		transform: translateX(-50%);
	}

	.teacher {
		/* pc */
		padding: 0;
		margin-right: 39px;
		margin-bottom: 0;
	}

	.teacher::after {
		/* pc */
		display: none;
	}

	.teacher__image img {
		/* pc */
		width: 80px;
	}

	.teacher__profile {
		/* pc */
		margin-left: 15px;
	}

	.teacher__major {
		/* pc */
		font-size: 1.3rem;
	}

	.teacher__major span {
		/* pc */
		margin-top: 9px;
		font-size: 1.8rem;
	}

	.teacher__name {
		/* pc */
		margin-top: 11px;
		font-size: 1.3rem;
	}

	.course-item-wrap.swiper .swiper-pagination {
		/* pc */
		bottom: -70px;
	}

	.course-item-wrap.swiper .swiper-pagination .swiper-pagination-bullet {
		/* pc */
		width: 8px;
		height: 8px;
		margin: 0 8px;
	}

	.course-item-wrap.swiper .swiper-pagination .swiper-pagination-bullet-active {
		/* pc */
		width: 12px;
		height: 12px;
	}

	.course-item {
		/* pc */
		padding: 0 0 48px;
		text-align: center;
		background: -o-linear-gradient(transparent 50px, #000 50px, #000 100%);
		background: linear-gradient(transparent 50px, #000 50px, #000 100%);
	}

	.course-item__image {
		/* pc */
		width: 500px;
	}

	.course-item__inner {
		/* pc */
		margin: 0;
	}

	.course-item__heading {
		/* pc */
		margin-top: -46px;
	}

	.course-item__heading__major {
		/* pc */
		font-size: 1.8rem;
	}

	.course-item__heading__course {
		/* pc */
		margin-top: 10px;
		font-size: 3.2rem;
	}

	.course-item__text {
		/* pc */
		margin-top: 26px;
		font-size: 1.5rem;
	}

	.course-item__link {
		/* pc */
		margin: 27px auto 0;
		padding: 17px;
		font-size: 1.6rem;
		max-width: 500px;
	}

	.swiper-button-prev,
	.swiper-button-next {
		/* pc */
		width: 90px;
		height: 90px;
	}

	.swiper-button-prev {
		/* pc */
		left: 175px;
	}

	.swiper-button-next {
		/* pc */
		right: 175px;
	}

	.access {
		/* pc */
		padding: 95px 0 150px;
	}

	.access__image {
		/* pc */
		width: 95vw;
		max-width: 1400px;
		margin-bottom: 40px;
		margin-top: 0;
	}

	.access__note {
		/* pc */
		text-align: center;
		font-size: 1.2rem;
		lien-height: 1.5;
		letter-spacing: 0.1em;
	}

	.access__btn {
		/* pc */
		width: 500px;
		height: 50px;
		margin-top: 40px;
		font-size: 1.5rem;
		transition: .2s linear;
	}

	.access__btn:hover {
		/* pc */
		background: #00c6b7;
	}

	.facility-wrap {
		/* pc */
		padding: 81px 0 0;
	}

	.facility {
		/* pc */
		width: calc(100vw + 10px);
		min-width: 1110px;
		padding-top: 0;
		height: calc(62.75vw + 10px);
		min-height: 700.25px;
		margin-left: 0;
		left: 50%;
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		transform: translateX(-50%);
		margin-bottom: 0;
	}

	.facility__item button:after {
		/* pc */
		content: none;
	}

	.facility__item--01 {
		/* pc */
		width: 45.4%;
	}

	.facility__item--02 {
		/* pc */
		width: 25.6%;
		right: 29%;
	}

	.facility__item--03 {
		/* pc */
		top: 0;
		width: 29%;
	}

	.facility__item--04 {
		/* pc */
		top: 45%;
		width: 19.7%;
	}

	.facility__item--05 {
		/* pc */
		top: 31.2%;
		left: 45.4%;
		width: 34.1%;
	}

	.facility__item--06 {
		/* pc */
		top: 45%;
		right: auto;
		left: 19.7%;
		width: 25.6%;
	}

	.facility__item--07 {
		/* pc */
		top: 31.2%;
		left: auto;
		right: 0;
		width: 20.6%;
	}

	.facility__item--08 {
		/* pc */
		top: auto;
		bottom: 0;
		width: 19.7%;
	}

	.facility__item--09 {
		/* pc */
		top: auto;
		bottom: 0;
		right: auto;
		left: 19.7%;
		width: 25.6%;
	}

	.facility__item--10 {
		/* pc */
		left: auto;
		right: 0;
		width: 20.6%;
	}

	.facility__item--11 {
		/* pc */
		width: 17%;
		left: auto;
		right: 20.6%;
	}

	.facility__item--12 {
		/* pc */
		right: 37.6%;
		width: 17%;
	}

	.facility__main {
		/* pc */
		display: block;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		background: rgba(0, 0, 0, 0.5);
		color: #FFFFFF;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		opacity: 0;
		-webkit-transition: 0.4s;
		-o-transition: 0.4s;
		transition: 0.4s;
	}

	.facility__main:hover {
		opacity: 1;
	}

	.facility-detail__inner {
		/* pc */
		padding: 0 70px 70px;
	}

	.facility-detail__heading {
		/* pc */
		font-size: 3rem;
	}

	.facility-detail__text {
		/* pc */
		font-size: 1.7rem;
		line-height: 1.88;
	}

	.new-building {
		/* pc */
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		padding: 0;
		margin-bottom: 55px;
	}

	.new-building::before {
		/* pc */
		min-width: 1100px;
	}

	.new-building__head {
		/* pc */
		width: 45%;
		padding: 52px 0;
		/*padding: 44px 0;*/
	}

	.new-building__head__text {
		/* pc */
		width: 100%;
		font-weight: 500;
	}

	.new-building__heading {
		/* pc */
		font-size: 2.8rem;
		line-height: 1.46;
		text-align: left;
		margin-right: -1em;
		margin-bottom: 18px;
	}

	.new-building__heading sup {
		/* pc */
		display: inline-block;
		-webkit-transform: translateY(3px);
		-ms-transform: translateY(3px);
		transform: translateY(3px);
	}

	.new-building__image-wrap {
		/* pc */
		position: static;
		-webkit-transform: translateX(0);
		-ms-transform: translateX(0);
		transform: translateX(0);
		width: 50%;
		margin: 0;
	}

	.new-building__image {
		/* pc */
		width: 50vw;
		min-width: 550px;
		height: 100%;
		max-height: 547px;
	}

	.new-building__image img {
		height: 100%;
		-o-object-fit: cover;
		object-fit: cover;
	}

	.new-building__image figcaption {
		/* pc */
		top: 5.5%;
		left: 6.2%;
		padding: 8px 18px 12px;
		font-size: 1.6rem;
		line-height: 1.56;
	}

	.new-building__image figcaption::before {
		/* pc */
		left: 95px;
	}

	.new-building__point {
		/* pc */
		width: 100%;
		padding: 16px 21px 22px;
		margin: 25px 0 16px;
	}

	.new-building__point__text {
		/* pc */
		font-size: 1.5rem;
		line-height: 1.53;
		letter-spacing: 0;
		margin-bottom: 8px;
	}

	.new-building__point__list {
		/* pc */
		color: #000;
		font-size: 1.3rem;
		line-height: 1.61;
	}

	.new-building__point__list li {
		/* pc */
		text-indent: 0;
		padding-left: 0;
	}

	.new-building__note {
		/* pc */
		width: 100%;
	}

	.content-lead {
		/* pc */
		font-size: 1.8rem;
		line-height: 2;
		text-align: center;
		margin-bottom: 49px;
	}

	.modal__inner {
		/* pc */
	}

	.modal__inner[data-type=facility] {
		width: 940px;
	}

	.modal__inner[data-type=course] {
		width: 1080px;
	}

	.modal__item {
		/* pc */
	}

	.modal__arrows {
		/* pc */
		top: 340px;
	}

	.modal__arrows--course {
		width: calc(100% - 60px);
	}

	.modal__arrow {
		/* pc */
		width: 40px;
	}

	.modal__arrow img {
		width: 20px;
	}

	.modal__arrow--left {
		/* pc */
		margin-left: 0;
	}

	.modal__arrow--right {
		/* pc */
		margin-right: 0;
	}

}

@media screen and (max-width: 680px) {

	.sp-only {
		/* sp */
		display: block !important;
	}

	.sp-only-2 {
		/* sp */
		display: inline-block !important;
	}

	.pc-only {
		/* sp */
		display: none !important;
	}

	.pc-only-2 {
		/* sp */
		display: none !important;
	}

	.navi__list__item {
		/* sp */
		border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	}

	.mainvisual__new__note span {
		/* sp */
		-webkit-transform: scale(0.9);
		-ms-transform: scale(0.9);
		transform: scale(0.9);
	}

	.js-accordion-sp-content {
		/* sp */
		display: none;
	}

	.modal__wrapper--none {
		/* sp */
		position: static;
		-webkit-transform: translate(0, 0);
		-ms-transform: translate(0, 0);
		transform: translate(0, 0);
		width: 100%;
		height: 100%;
	}

}

@media screen and (max-width: 374px) {

	.mainvisual__new__note {
		/* iPhone5s */
		line-height: 1.3;
		padding: 0 10px;
	}

	.about__heading__main {
		/* iPhone5s */
		font-size: 4rem;
	}

	.introduction-item__heading--2 {
		/* iPhone5s */
		font-size: 2.4rem;
	}

	.introduction-item__image--deco04::before {
		/* iPhone5s */
		width: 100px;
		height: 110px;
	}

}

@-webkit-keyframes stretchDown1 {

	0% {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%);
	}

	100% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}

}

@keyframes stretchDown1 {

	0% {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%);
	}

	100% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}

}

@-webkit-keyframes stretchDown2 {

	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}

	100% {
		-webkit-transform: translateY(100%);
		transform: translateY(100%);
	}

}

@keyframes stretchDown2 {

	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}

	100% {
		-webkit-transform: translateY(100%);
		transform: translateY(100%);
	}

}

@-webkit-keyframes stretchRight1 {

	0% {
		-webkit-transform: scale(0, 1);
		transform: scale(0, 1);
	}

	100% {
		-webkit-transform: scale(1, 1);
		transform: scale(1, 1);
	}

}

@keyframes stretchRight1 {

	0% {
		-webkit-transform: scale(0, 1);
		transform: scale(0, 1);
	}

	100% {
		-webkit-transform: scale(1, 1);
		transform: scale(1, 1);
	}

}

@-webkit-keyframes stretchRight2 {

	0% {
		width: 100%;
	}

	100% {
		width: 0;
	}

}

@keyframes stretchRight2 {

	0% {
		width: 100%;
	}

	100% {
		width: 0;
	}

}

@-webkit-keyframes fadeUp {

	0% {
		opacity: 0;
		-webkit-transform: translateY(20px);
		transform: translateY(20px);
	}

	100% {
		opacity: 1;
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}

}

@keyframes fadeUp {

	0% {
		opacity: 0;
		-webkit-transform: translateY(20px);
		transform: translateY(20px);
	}

	100% {
		opacity: 1;
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}

}

@-webkit-keyframes fadeIn {

	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}

}

@keyframes fadeIn {

	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}

}



.topic-outer {
	margin-top: 25px;
	margin-bottom: 70px;
}

.topic-ttl {}

.topic-ttl__label {
	margin-right: 18px;
}

.topic-ttl__main {
	font-size: 2.1rem;
	font-weight: 700;
	line-height: 1.334;
}

.topic-ttl__sub {
	font-size: 1.3rem;
	font-weight: 400;
	line-height: 1.6923;
}

.topic-wrap {
	margin-top: 20px;
}

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

.topic__ttl {
	position: relative;
	flex: 1;
}

.topic__ttl::before {
	position: absolute;
	top: 22px;
	left: 0;
	width: 100%;
	height: 1px;
	background: #cacaca;
	content: "";
}

.topic__ttl__label {}

.topic__ttl__txt {
	position: relative;
	width: 100%;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.375;
	letter-spacing: 0.05em;
}

.topic__ttl__txt::before {
	display: block;
	width: 64px;
	height: 10px;
	background-repeat: no-repeat;
	background-position: 0 50%;
	background-size: contain;
	margin-bottom: 20px;
	content: "";
}

.topic--1 .topic__ttl__txt::before {
	background-image: url("../img/label_topic_1.svg");
}

.topic--2 .topic__ttl__txt::before {
	background-image: url("../img/label_topic_2.svg");
}

.topic--3 .topic__ttl__txt::before {
	background-image: url("../img/label_topic_3.svg");
}

.topic__img img {
	width: 160px;
}

.topic__txt {
	margin-top: 18px;
	font-size: 1.1rem;
	font-weight: 400;
	line-height: 1.6363;
	text-align: justify;
}

.topic__ttl__txt .br_resp {
	display: block;
}

@media screen and (max-width: 374px) {
	.topic__img {
		width: 150px;
	}
}

@media screen and (max-width: 680px) {
	.topic-ttl {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		align-items: center;
		color: #fff;
	}

	.topic-ttl__label {
		width: 86px;
	}

	.topic-ttl__main {
		flex: 1;
		margin-right: -20px;
	}

	.topic-ttl__sub {
		position: relative;
		width: 100%;
		margin-top: 30px;
		text-align: center;
	}

	.topic-ttl__sub::before {
		position: absolute;
		top: -15px;
		left: 50%;
		transform: translateX(-50%);
		width: 100vw;
		height: 2px;
		background: url("../img/ptn_dot.svg") repeat-x 0 0/4px auto;
		content: "";
	}

	.topic {
		position: relative;
	}

	.topic:not(:last-of-type) {
		margin-bottom: 20px;
	}

	.topic--1,
	.topic--3 {
		background: rgb(0, 150, 208);
		background: linear-gradient(90deg, rgba(0, 150, 208, 1) 0%, rgba(198, 78, 144, 1) 100%);
		border-radius: 24px 0 0 0;
		margin-right: -10%;
		padding: 3px 0 3px 3px;
	}

	.topic--2 {
		background: rgb(0, 150, 208);
		background: linear-gradient(270deg, rgba(0, 150, 208, 1) 0%, rgba(198, 78, 144, 1) 100%);
		border-radius: 0 24px 0 0;
		margin-left: -10%;
		padding: 3px 3px 3px 0;
	}

	.topic__frame {
		background: #fff;
		padding: 27px 27px 23px;
	}

	.topic--1 .topic__frame,
	.topic--3 .topic__frame {
		border-radius: 21px 0 0 0;
	}

	.topic--2 .topic__frame {
		border-radius: 0 21px 0 0;
	}

	.topic__inner--irr {
		position: relative;
		justify-content: flex-end;
	}

	.topic__inner--irr::before {
		position: absolute;
		top: 22px;
		left: 0;
		width: 100%;
		height: 1px;
		background: #cacaca;
		content: "";
		z-index: 0;
	}

	.topic__inner--irr .topic__img {
		position: relative;
		z-index: 50;
	}

	.topic__ttl--posabs {
		position: absolute;
		width: 100%;
		z-index: 100;
	}

	.topic__ttl--posabs .topic__ttl__txt {
		box-decoration-break: clone;
		line-height: 1.45;
		background: #fff;
		padding-top: 1px;
		padding-bottom: 3px;
	}

	.topic__ttl--posabs::before {
		display: none;
	}

}

@media screen and (min-width: 481px) {
	.topic__ttl__txt .br_resp {
		display: none;
	}
}

@media screen and (min-width: 681px) {
	.topic-outer {
		width: 1000px;
		background: rgb(0, 150, 208);
		background: linear-gradient(90deg, rgba(0, 150, 208, 1) 0%, rgba(198, 78, 144, 1) 100%);
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 0;
		padding: 4px;
	}

	.topic-outer .l-wrapper {
		background: #fff;
		width: 100%;
		padding: 54px 56px 53px;
	}

	.topic-wrap {
		position: relative;
		display: flex;
		justify-content: space-between;
		margin-top: 38px;
	}

	.topic-wrap::before,
	.topic-wrap::after {
		position: absolute;
		top: 0;
		width: 2px;
		height: calc(100% - 4px);
		background: url("../img/ptn_dot_vert.svg") repeat-y 0 0/contain;
		content: "";
	}

	.topic-wrap::before {
		left: 280px;
	}

	.topic-wrap::after {
		right: 280px;
	}

	.topic {
		width: 240px;
	}

	/*	.topic-ttl { display: grid; grid-template-columns: 96px 1fr; grid-template-rows: repeat(2, auto); grid-column-gap: 22px; grid-row-gap: 0px; background: url("../img/ptn_dot_blue.svg") repeat 0 0/8px auto; margin-left: -56px; margin-right: -56px; padding: 18px 56px; }*/
	.topic-ttl {
		display: flex;
		align-items: center;
		background: url("../img/ptn_dot_blue.svg") repeat 0 0/8px auto;
		margin-left: -56px;
		margin-right: -56px;
		padding: 18px 56px;
	}

	.topic__ttl {
		padding-top: 10px;
	}

	.topic__ttl::before {
		top: 40px;
	}

	/*
	.topic-ttl__label { grid-area: 1 / 1 / 3 / 2; margin-right: 0; }
	.topic-ttl__main { grid-area: 1 / 2 / 2 / 3; margin-bottom: 2px; font-size: 2.6rem; line-height: 1; }
	.topic-ttl__sub { grid-area: 2 / 2 / 3 / 3; font-size: 1.4rem; line-height: 1.5714; letter-spacing: 0.03em; }
*/
	.topic-ttl__label {
		margin-right: 22px;
	}

	/*0px*/
	.topic-ttl__main {
		margin-bottom: 2px;
		font-size: 2.6rem;
		line-height: 1;
	}

	.topic-ttl__sub {
		font-size: 1.4rem;
		line-height: 1.5714;
		letter-spacing: 0.03em;
	}

	.topic-ttl__sub {
		flex: 1;
		font-size: 1.4rem;
		line-height: 1.5714;
		letter-spacing: 0.03em;
	}

	.topic-ttl__main,
	.topic-ttl__sub {
		display: flex;
		align-items: flex-end;
	}

	.topic__ttl__txt::before {
		width: 75px;
		height: 11px;
		margin-bottom: 30px;
	}

	.topic__ttl__txt {
		font-size: 1.55rem;
		font-weight: 400;
		line-height: 1.45;
	}

	.topic__ttl__txt .br_resp {
		display: block;
	}

	.topic__ttl__txt ._lsless {
		letter-spacing: 0;
	}

	.topic__img {
		margin-top: 18px;
	}

	/*	.topic__img img { width: auto; height: 147px; }*/
	.topic__img img {
		width: 100%;
		height: auto;
	}

	.topic__txt {
		font-size: 1.4rem;
		line-height: 1.7142;
	}
}

/*----------------------------------
		New Building Gallery
----------------------------------*/
.nbgal-wrap .swiper-button-disabled,
.nbgal-wrap .swiper-button-hidden {
	opacity: 0;
	cursor: auto;
	pointer-events: none;
	display: none !important;
}

.nbgal-wrap-outer {
	position: relative;
}

.nbgal-pagination {
	position: absolute;
	bottom: -24px !important;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
}

.nbgal-pagination .swiper-pagination-bullet {
	width: 6px;
	height: 6px;
	background: #ccc;
	opacity: 1;
}

.nbgal-pagination .swiper-pagination-bullet-active {
	width: 8px;
	height: 8px;
	background: #df9f0b;
}

.nbgal-wrap-outer .nbgal-prev,
.nbgal-wrap-outer .nbgal-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
	cursor: pointer;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 46px;
	height: 46px;
	background: #006837;
	border-radius: 50%;
}

.nbgal-wrap-outer .nbgal-prev {
	left: 35px;
}

.nbgal-wrap-outer .nbgal-next {
	right: 35px;
}

.nbgal-wrap-outer .nbgal-prev::after,
.nbgal-wrap-outer .nbgal-next::after {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 4px;
	height: 4px;
	border-right: 1px solid #fff;
	border-top: 1px solid #fff;
	content: "";
}

.nbgal-wrap-outer .nbgal-prev::after {
	transform: translate(-50%, -50%) rotate(225deg);
}

.nbgal-wrap-outer .nbgal-next::after {
	transform: translate(-50%, -50%) rotate(45deg);
}



@media screen and (max-width: 680px) {
	.nbgal-wrap-outer {
		margin-left: -10%;
		margin-right: -10%;
		margin-top: 30px;
		margin-bottom: 54px;
	}

	.nbgal-thumb-wrap {
		display: none;
	}
}

@media screen and (min-width: 681px) {
	.nbgal-wrap-outer {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		width: calc(50% + 50px);
		height: 100%;
		margin-right: -50px;
		overflow: hidden;
	}

	.nbgal-wrap {
		height: 390px;
		max-height: 390px;
	}

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

	.nbgal-thumb-wrap {
		width: 100%;
		height: 157px;
		max-height: 157px;
		background: #000;
		padding: 10px;
	}

	.nbgal-wrap-outer .nbgal-prev,
	.nbgal-wrap-outer .nbgal-next {
		transform: translate(-50%, -200%);
	}

	.nbgal-wrap-outer .nbgal-prev {
		left: 53px;
	}

	.nbgal-wrap-outer .nbgal-next {
		right: 7px;
	}

	.nbgal-thumb {
		height: 110px;
		max-height: 110px;
	}

	.nbgal-thumb img {
		object-fit: cover;
		width: 100%;
		height: 100%;
	}

	.nbgal-thumb-pagination {
		position: absolute;
		bottom: 14px !important;
		display: flex;
		justify-content: center;
		align-items: center;
		width: 100%;
	}

	.nbgal-thumb-pagination .swiper-pagination-bullet {
		width: 6px;
		height: 6px;
		background: #ccc;
		opacity: 1;
	}

	.nbgal-thumb-pagination .swiper-pagination-bullet-active {
		width: 8px;
		height: 8px;
		background: #006837;
	}

	.nbgal-thumb.swiper-slide {
		opacity: .8;
		transition: .4s;
	}

	.nbgal-thumb.swiper-slide-thumb-active {
		opacity: 1;
	}

}

@media screen and (min-width: 1001px) {
	.nbgal-wrap-outer {
		position: absolute;
		top: 0;
		right: 50%;
		transform: translateX(100%);
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		width: 50vw;
		height: 100%;
		margin-right: 0;
		overflow: hidden;
	}
}


/*----------------------------------
		Added 20250401
----------------------------------*/
/*	Other Seminar Button	*/
.btn--other-seminar {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 500px;
	height: 52px;
	background: #ffdf00;
	margin-top: 40px;
	margin-left: auto;
	margin-right: auto;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.5;
	color: #000;
	text-decoration: none;
	text-align: center;
}

@media screen and (min-width: 681px) {
	.btn--other-seminar {
		font-size: 1.8rem;
	}
}

/*	Student Voice Title	*/
.sec-stvo {
	margin-top: 60px;
}

.stvo {
	background: linear-gradient(90deg, rgba(0, 150, 208, 1) 0%, rgba(198, 78, 144, 1) 100%);
}

.stvo__frame {
	background: #fff;
}

.stvo__ttl {}

.stvo__ttl__upper {}

.stvo__ttl__label {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 40px;
	background: #2c9fa4;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.1em;
	text-indent: 0.1em;
	text-align: center;
	color: #fff;
}

.stvo__ttl__txt {
	text-align: center;
}

.stvo__ttl__txt img {
	width: 280px;
}

.stvo__ttl__lower {
	text-align: center;
}

.stvo__ttl__lower img {
	width: 259px;
}

@media screen and (max-width: 680px) {
	.stvo {
		margin-right: -10%;
		padding: 3px 0 3px 3px;
	}

	.stvo__frame {
		padding: 25px 25px 20px;
	}

	.stvo__ttl__txt {
		margin-top: 20px;
	}

	.stvo__ttl__lower {
		margin-top: 20px;
	}
}

@media screen and (min-width: 681px) {
	.sec-stvo {
		margin-top: 100px;
	}

	.stvo {
		padding: 3px;
	}

	.stvo__frame {
		padding: 55px 55px 55px;
	}

	.stvo__ttl {
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
	}

	.stvo__ttl__upper {
		display: flex;
		justify-content: space-between;
		align-items: stretch;
	}

	.stvo__ttl__label {
		width: 130px;
		height: auto;
		font-size: 1.8rem;
		line-height: 1.389;
	}

	.stvo__ttl__txt {
		margin-left: 20px;
	}

	.stvo__ttl__txt img {
		width: 230px;
	}

	.stvo__ttl__lower img {
		width: 464px;
	}
}

/*	Student Voice Content	*/
.stvo__person-wrap {
	margin-top: 30px;
}

.stvo__person {}

.stvo__person__ttl {
	font-size: 1.7rem;
	font-weight: 400;
	line-height: 1.647;
	color: #2c9fa4;
}

.stvo__person__info {
	margin-top: 10px;
}

.stvo__person__info__txt {
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.642;
}

.stvo__person__info__img {}

.stvo__person__txt {
	margin-top: 15px;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.714;
}

@media screen and (max-width: 680px) {
	.stvo__person:not(:first-of-type) {
		position: relative;
		margin-top: 47px;
	}

	.stvo__person:not(:first-of-type)::before {
		position: absolute;
		top: -24px;
		left: 0;
		display: block;
		width: 100%;
		height: 1px;
		background: url("../img/ptn_dot_land.svg") repeat-x 0 0/4px auto;
		content: "";
	}

	.stvo__person__info {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	.stvo__person__info__txt span {
		display: block;
	}

	.stvo__person__info__img {
		width: 100px;
		height: 100px;
		border: 1px solid #2c9fa4;
		border-radius: 50%;
	}
}

@media screen and (min-width: 681px) {
	.stvo__person-wrap {
		position: relative;
		display: flex;
		justify-content: space-between;
		margin-top: 50px;
	}

	.stvo__person-wrap::before {
		position: absolute;
		top: 8px;
		left: 50%;
		transform: translateX(-50%);
		display: block;
		width: 1px;
		height: calc(100% - 10px);
		background: url("../img/ptn_dot_vert.svg") repeat-y 50% 0/2px auto;
		content: "";
	}

	.stvo__person {
		position: relative;
		width: 390px;
	}

	.stvo__person__ttl {
		font-size: 2.0rem;
		line-height: 1.5;
	}

	.stvo__person__info {
		margin-top: 26px;
	}

	.stvo__person__info__txt span:first-of-type::after {
		content: "／";
	}

	.stvo__person__info__img {
		position: absolute;
		right: -50px;
		bottom: 0;
		width: 200px;
	}

	.stvo__person__txt {
		width: 240px;
		margin-top: 19px;
		letter-spacing: 0.025em;
		text-align: justify;
	}
}

/*	Lecture	*/
.lec {
	max-width: 880px;
	background: #2c9fa4;
	margin-top: 25px;
	margin-left: auto;
	margin-right: auto;
	padding: 10px 10px 17px;
}

.lec__upper {}

.lec__label {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 70px;
	background: #ffdf00;
	text-align: center;
}

.lec__label img {
	width: auto;
	height: 48px;
}

.lec__ttl {
	margin-top: 12px;
	letter-spacing: 0.03em;
	text-indent: 0.03em;
	text-align: center;
}

.lec__ttl__sub,
.lec__ttl__main {
	display: block;
}

.lec__ttl__sub {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.875;
	color: #fff;
}

.lec__ttl__main {
	font-size: 2.5rem;
	font-weight: 700;
	line-height: 1.5;
	color: #ffdf00;
}

.lec__txt {
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.714;
	letter-spacing: 0.025em;
	text-align: justify;
	color: #fff;
}

.lec__txt ._emp {
	color: #ffdf00;
}

@media screen and (max-width: 680px) {
	.lec__txt {
		border-top: 1px solid #fff;
		margin-top: 20px;
		padding: 14px 10px 0;
	}
}

@media screen and (min-width: 681px) {
	.lec {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		margin-top: 50px;
		padding: 30px 30px 24px;
	}

	.lec__upper {
		position: relative;
		width: 310px;
		margin-right: 60px;
	}

	.lec__upper::before {
		position: absolute;
		top: 0;
		right: -31px;
		display: block;
		width: 1px;
		height: calc(100% - 6px);
		background: #fff;
		content: "";
	}

	.lec__ttl {
		margin-top: 3px;
	}

	.lec__ttl__sub {
		font-size: 1.8rem;
	}

	.lec__ttl__main {
		margin-top: -5px;
		font-size: 3.0rem;
	}

	.lec__txt {
		flex: 1;
		margin-top: -6px;
	}
}