/* foundation--------------------------------------------------------- */

/*! destyle.css v1.0.13 | MIT License | https://github.com/nicolas-cusan/destyle.css */

/* Reset box-model
   ========================================================================== */

* {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

::before,
::after {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
}

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */

html {
	line-height: 1.15; /* 1 */
	-webkit-text-size-adjust: 100%; /* 2 */
	-webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers.
 */

body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */

main {
	display: block;
}

/* Vertical rhythm
   ========================================================================== */

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
	margin: 0;
}

/* Headings
   ========================================================================== */

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: inherit;
	line-height: inherit;
	font-weight: inherit;
	margin: 0;
}

/* Lists (enumeration)
   ========================================================================== */

ul,
ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

/* Lists (definition)
   ========================================================================== */

dt {
	font-weight: bold;
}

dd {
	margin-left: 0;
}

/* Grouping content
   ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
	-webkit-box-sizing: content-box;
	box-sizing: content-box; /* 1 */
	height: 0; /* 1 */
	overflow: visible; /* 2 */
	border: 0;
	border-top: 1px solid;
	margin: 0;
	clear: both;
	color: inherit;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
	font-family: monospace, monospace; /* 1 */
	font-size: inherit; /* 2 */
}

address {
	font-style: inherit;
}

/* Text-level semantics
   ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */

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

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
	border-bottom: none; /* 1 */
	text-decoration: underline; /* 2 */
	-webkit-text-decoration: underline dotted;
	text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
	font-family: monospace, monospace; /* 1 */
	font-size: inherit; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */

img {
	border-style: none;
	vertical-align: bottom;
}

embed,
object,
iframe {
	border: 0;
	vertical-align: bottom;
}

/* Forms
   ========================================================================== */

/**
 * Reset form fields to make them styleable
 * 1. Reset radio and checkbox to preserve their look in iOS.
 */

button,
input,
optgroup,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	vertical-align: middle;
	color: inherit;
	font: inherit;
	border: 0;
	background: transparent;
	padding: 0;
	margin: 0;
	outline: 0;
	border-radius: 0;
	text-align: inherit;
}

[type="checkbox"] { /* 1 */
	-webkit-appearance: checkbox;
	-moz-appearance: checkbox;
	appearance: checkbox;
}

[type="radio"] { /* 1 */
	-webkit-appearance: radio;
	-moz-appearance: radio;
	appearance: radio;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

button,
[type="button"],
[type="reset"],
[type="submit"] {
	cursor: pointer;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

button[disabled],
[type="button"][disabled],
[type="reset"][disabled],
[type="submit"][disabled] {
	cursor: default;
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Remove padding
 */

option {
	padding: 0;
}

/**
 * Reset to invisible
 */

fieldset {
	margin: 0;
	padding: 0;
	border: 0;
	min-width: 0;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
	color: inherit; /* 2 */
	display: table; /* 1 */
	max-width: 100%; /* 1 */
	padding: 0; /* 3 */
	white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea {
	overflow: auto;
}

/**
 * 1. Remove the padding in IE 10.
 */

[type="checkbox"],
[type="radio"] {
	padding: 0; /* 1 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the outline style in Safari.
 */

[type="search"] {
	outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
	-webkit-appearance: button; /* 1 */
	font: inherit; /* 2 */
}

/**
 * Clickable labels
 */

label[for] {
	cursor: pointer;
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
	display: list-item;
}

/* Table
   ========================================================================== */

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

caption {
	text-align: left;
}

td,
th {
	vertical-align: top;
	padding: 0;
}

th {
	text-align: left;
	font-weight: bold;
}

/* Misc
   ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */

template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */

[hidden] {
	display: none;
}

html {
	font-size: 62.5%;
}

body {
	color: #54585a;
	font-size: 1.4rem;
	font-family: source-han-sans-japanese, sans-serif;
	min-width: 1024px;
	overflow: visible;
}

body.have_curtain {
	overflow: hidden;
}

p {
	margin: 0 0 2rem;
	color: #54585A;
	line-height: 1.7;
}

a {
	color: #54585a;
	text-decoration: none;
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
	-webkit-transition-property: color,opacity;
	transition-property: color,opacity;
}

a:hover {
	-webkit-transition: .5s;
	transition: .5s;
	-webkit-transition-property: color,opacity;
	transition-property: color,opacity;
	opacity: .6;
}

img {
	width: 100%;
	height: auto;
	vertical-align: top;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
}

.clearfix::after {
	content: "";
	display: block;
	clear: both;
}

input[type="submit"],
input[type="button"],
button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border-radius: 0;
	outline: none;
	cursor: pointer;
}

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

/* layout------------------------------------------------------------ */

.l-header,
.l-contentsTop,
.l-contents,
.l-contentsBottom,
.l-footer {
	margin: 0 auto;
	width: 100%;
}

.l-contents {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	margin: 0 auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	overflow: hidden;
}

.l-main {
	width: 100%;
	display: block;
	position: relative;
}

.l-sideLeft {
	margin-left: auto;
	margin-right: 48px;
	width: 221px;
}

.l-sideLeft + .l-mainWithColumn {
	display: block;
	margin-left: 0;
	margin-right: auto;
	width: 831px;
}

.l-mainWithColumn {
	display: block;
	margin-left: auto;
	width: calc(100% - 220px - 48px);
}

.l-mainWithColumn + .l-right {
	margin-right: auto;
	margin-left: 128px;
	width: 250px;
}

.l-drawer {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1000;
	background: transparent;
	overflow-y: scroll;
	-webkit-transition: all .3s;
	transition: all .3s;
	visibility: hidden;
	opacity: 0;
}

.l-drawer.is-active {
	background-color: rgba(255, 255, 255, 0.7);
	-webkit-backdrop-filter: blur(15px);
	backdrop-filter: blur(15px);
	-webkit-transform: translateX(0);
	transform: translateX(0);
	-webkit-transition: all .3s;
	transition: all .3s;
	visibility: visible;
	opacity: 1;
}

.l-drawerClose {
	display: none;
	width: 56px;
	height: 75px;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 100000;
	cursor: pointer;
	visibility: hidden;
	font-size: 2.4rem;
}

.l-drawerClose.is-active {
	visibility: visible;
}

.l-drawerClose div {
	width: 1.6rem;
	height: 1px;
	background-color: #707070;
	border-radius: 1px;
	position: absolute;
	top: calc(50% - 1px);
	right: calc(50% - 10px);
	-webkit-transition: .3s;
	transition: .3s;
}

.l-drawerClose div:first-child {
	-webkit-transform: translateY(-7px);
	transform: translateY(-7px);
}

.l-drawerClose div:nth-child(2) {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

.l-drawerClose div:last-child {
	-webkit-transform: translateY(7px);
	transform: translateY(7px);
}

.l-drawerClose.is-active div {
	background-color: #707070;
}

.l-drawerClose.is-active div:first-child {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.l-drawerClose.is-active div:nth-child(2) {
	display: none;
}

.l-drawerClose.is-active div:last-child {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.l-overlay {
	display: none;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
	z-index: 1000;
	opacity: 0;
	background: transparent;
	-webkit-transform: translateX(0);
	transform: translateX(0);
	-webkit-transition: all .3s;
	transition: all .3s;
	visibility: hidden;
}

.have_curtain .l-overlay {
	display: none;
	opacity: 1;
	visibility: visible;
}

.margintop {
	margin-top: 7rem;
}

@media screen and (max-width: 480px) {
	.margintop {
		margin-top: 0;
	}
}

/* object------------------------------------------------------------ */

/* object/component ボタンなど、再利用できる小さな単位のモジュールを定義します ---------------------------- */

.c-col2 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.c-col2.-reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.c-col2__item {
	width: 50%;
}

.c-container {
	width: 100%;
	overflow: visible;
}

.c-wrapper {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	margin: 0 auto;
	width: 100%;
	max-width: 1280px;
	padding: 0;
	position: static;
}

.c-wrapper.-w1100 {
	max-width: 1100px;
}

.c-wrapper.-w1000 {
	max-width: 1000px;
}

.c-wrapper.-w800 {
	max-width: 800px;
}

.c-wrapper.-left {
	margin-left: auto;
	margin-right: 0;
}

.c-wrapper.-right {
	margin-left: 0;
	margin-right: auto;
}

.c-inner {
	padding: 0 20px;
	position: static;
}

.c-inner.-w1100 {
	max-width: 1140px;
}

.c-inner.-w1000 {
	max-width: 1040px;
}

.c-inner.-w800 {
	max-width: 840px;
}

.c-btn {
	display: inline-block;
	width: auto;
}

.c-btn .c-btn__inner {
	height: 100%;
	padding: 1.5rem 4rem 1.4rem;
	border-radius: 40px;
	display: block;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.5;
	text-align: center;
	background: -webkit-gradient(linear, left top, right top, from(#4A87C5), color-stop(#BC5FC9), to(#FE1B84));
	background: -webkit-linear-gradient(left, #4A87C5, #BC5FC9, #FE1B84);
	background: linear-gradient(90deg, #4A87C5, #BC5FC9, #FE1B84);
}

.c-btn.-orange .c-btn__inner {
	background: -webkit-gradient(linear, left top, right top, from(#FF8A41), to(#F81D4F));
	background: -webkit-linear-gradient(left, #FF8A41, #F81D4F);
	background: linear-gradient(90deg, #FF8A41, #F81D4F);
}

.c-title1 {
	color: #000;
	font-size: 3.6rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.4;
}

.c-title1::after {
	margin: 2rem auto 0;
	display: block;
	content: '';
	width: 6rem;
	height: .8rem;
	background: -webkit-gradient(linear, left top, right top, from(#4A87C5), color-stop(#BC5FC9), to(#FE1B84));
	background: -webkit-linear-gradient(left, #4A87C5, #BC5FC9, #FE1B84);
	background: linear-gradient(90deg, #4A87C5, #BC5FC9, #FE1B84);
}

.c-title1.-left {
	text-align: left;
}

.c-title1.-left::after {
	margin-left: 0;
}

.c-paper {
	-webkit-box-shadow: 3px 3px 30px rgba(0, 0, 0, 0.15);
	box-shadow: 3px 3px 30px rgba(0, 0, 0, 0.15);
	border-radius: 4rem;
	background-color: #fff;
}

.c-burger {
	width: 56px;
	height: 60px;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 100000;
	cursor: pointer;
}

.c-burger div {
	width: 22px;
	height: 2px;
	background-color: #707070;
	border-radius: 2px;
	position: absolute;
	top: calc(50% - 1px);
	right: calc(50% - 10px);
	-webkit-transition: .3s;
	transition: .3s;
}

.c-burger div:first-child {
	-webkit-transform: translateY(-7px);
	transform: translateY(-7px);
}

.c-burger div:nth-child(2) {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

.c-burger div:last-child {
	-webkit-transform: translateY(7px);
	transform: translateY(7px);
}

.c-burger.is-active div:first-child {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.c-burger.is-active div:nth-child(2) {
	display: none;
}

.c-burger.is-active div:last-child {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.c-relative {
	position: relative;
}

/* object/project 記事一覧や、ユーザープロフィール、画像ギャラリーなど、繰り返し登場するコンテンツを構成する要素 ------------------------------ */

.p-footer {
	padding: 3rem 0;
	background-color: #000;
	min-width: 1024px;
}

.p-footer__menu {
	margin-bottom: 9rem;
}

.p-footer__menu ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: distribute;
	justify-content: space-around;
}

.p-footer__menu ul li {
	padding: .8rem;
}

.p-footer__menu ul li a {
	color: #fff;
	font-size: 1.3rem;
	font-weight: 400;
}

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

.p-footer__sns img {
	margin-right: 2rem;
	width: auto;
	height: 25px;
}

.p-copyright p {
	color: #868893;
	text-align: center;
}

.p-copyright p small {
	font-size: 1.2rem;
}

.p-header {
	padding: 1.4rem 0 1.1rem;
	min-width: 1024px;
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 1000;
	background: #fff;
	border-bottom: 1px solid #f9f9f9;
}

.l-top {
	margin-top: 61px;
}

.p-header__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.p-header__logo {
	height: 4.4rem;
}

.p-header__logo img {
	width:216px;
}

.p-header__menu {
	width: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.p-header__menu ul li {
	margin-left: 2rem;
	padding: .8rem 0;
	display: inline-block;
}

.p-header__menu .btn {
	margin-left: 3rem;
	width: 210px;
}

.p-header__menu .btn__inner {
	padding: 1rem 0 .9rem;
}

.p-header .c-burger {
	display: none;
}

.p-banner {
	padding: 3rem 0;
	background-color: #F9F5FF;
}

.p-banner__contents {
	overflow: hidden;
	text-align: center;
}

.p-cta {
	padding: 6rem 0;
	background: no-repeat url(../img/home/home_cta_bg.png) center center/cover;
}

.p-cta .title {
	margin-bottom: 5rem;
	color: #fff;
	font-size: 3.6rem;
	font-weight: 700;
	text-align: center;
	max-width: 800px;
}

.p-cta__img {
	width: 276px;
	position: absolute;
	bottom: -6rem;
	right: 0;
}

.p-cta__btn {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.p-cta__btn .btn {
	margin-right: 3rem;
}

.p-cta__btn .btn__inner {
	width: 370px;
}

.p-cta__btn .btn.-a .btn__inner {
	padding: 2.1rem 0;
	background: #ff007f;
}

.p-cta__btn .btn.-a .btn__txt {
	color: #fff;
	/*
	background: -webkit-gradient(linear, left top, right top, from(#2DC9F0), to(#5841B3));
	background: -webkit-linear-gradient(left, #2DC9F0, #5841B3);
	background: linear-gradient(90deg, #2DC9F0, #5841B3);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	*/
	font-size: 1.9rem;
}

.p-cta__btn .btn.-b .btn__inner {
	padding: .8rem 0 1.4rem;
	background: transparent;
	border: 1px solid #fff;
}

.p-cta__btn .btn.-b .btn__txt1 {
	display: block;
	font-size: 1.4rem;
	line-height: 2.2rem;
}

.p-cta__btn .btn.-b .btn__txt2 {
	display: block;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 2.4rem;
}

.p-cta__btn .btn .note {
	margin-top: 1rem;
	color: #fff;
	font-size: 1.3rem;
	text-align: center;
}

.p-cycle {
	padding: 7rem 0 5rem;
}

.p-cycle__bg--before {
	display: block;
	width: 503px;
	height: 550px;
	background: no-repeat url(../img/about/bg_before_cycle.png) center center/contain;
	position: absolute;
	top: -140px;
	left: -140px;
}

.p-cycle__bg--after {
	display: block;
	width: 503px;
	height: 550px;
	background: no-repeat url(../img/about/bg_between_cycle_lineup.png) center center/contain;
	position: absolute;
	bottom: -310px;
	right: -140px;
}

.p-cycle__paper {
	padding: 6rem 6% 5rem;
}

.p-cycle__head {
	margin-bottom: 6rem;
}

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

.p-cycle__item {
	margin-top: 3.5rem;
	margin-bottom: 3rem;
	width: 30.681818%;
}

.p-cycle-item {
	height: 100%;
	padding: 0 11% 10%;
	border: 5px solid #EFE7FC;
}

.p-cycle-item.-summary {
	border: none;
	padding: 0;
}

.p-cycle-item.-summary .img {
	margin: -7rem auto 2.5rem;
}

.p-cycle-item .day {
	margin: -4rem auto 0;
	width: 7rem;
	height: 7rem;
	background: -webkit-gradient(linear, left top, right top, from(#4A87C5), color-stop(#BC5FC9), to(#FE1B84));
	background: -webkit-linear-gradient(left, #4A87C5, #BC5FC9, #FE1B84);
	background: linear-gradient(90deg, #4A87C5, #BC5FC9, #FE1B84);
	border-radius: 50%;
	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;
	color: #fff;
}

.p-cycle-item .day__day {
	font-size: 1.2rem;
	font-weight: 400;
}

.p-cycle-item .day__no {
	font-size: 3.1rem;
	font-weight: 500;
}

.p-cycle-item .title {
	color: #000;
	margin-top: .5rem;
	margin-bottom: 1.9rem;
	text-align: center;
}

.p-cycle-item .title__en {
	color: #918FC3;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.7;
}

.p-cycle-item .title__ja {
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.3;
}

.p-cycle-item .img {
	margin-bottom: 2rem;
}

.p-cycle-item p {
	color: #54585A;
	font-size: 1.4rem;
	line-height: 1.7;
}

.p-cycle-item p:last-child {
	margin-bottom: 0;
}

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

.p-lineup {
	padding: 5rem 0 8rem;
}

.p-lineup__bg--after {
	display: block;
	width: 737px;
	height: 573px;
	background: no-repeat url(../img/about/bg_after_lineup.png) center center/contain;
	position: absolute;
	bottom: -340px;
	left: -260px;
}

.p-lineup__paper {
	padding: 5.5rem 6%;
}

.p-lineup__head {
	margin-bottom: 3rem;
	text-align: center;
}

.p-lineup__head .title {
	margin-bottom: 4.5rem;
	color: #000;
}

.p-lineup__head p {
	font-size: 1.4rem;
	color: #54585A;
}

.p-lineup__img {
	margin: 0 auto 4rem;
	max-width: 534px;
	width: 96%;
}

.p-lineup__desc p {
	text-align: center;
	font-size: 1.6rem;
}

.p-lineup__desc p strong {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6d7bc7;
}

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

.r-cv h1 {
	font-size: 36px;
	font-weight: bold;
	color: #010101;
	text-align: center;
	margin-top: 40px;
	padding: 50px 0 94px;
}

.r-cv {
	position: relative;
	-webkit-box-shadow: 2.83px 2.83px 23px rgba(0, 0, 0, 0.15);
	box-shadow: 2.83px 2.83px 23px rgba(0, 0, 0, 0.15);
	background-color: #fff;
}

.r-cv:before {
	position: absolute;
	left: 0;
	right: 0;
	top: -24px;
	content: "";
	display: block;
	width: 100%;
	height: 24px;
	background-color: #fff;
	z-index: 1;
}

.r-cv img {
	position: absolute;
	width: 225px;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}

.r-breadcrumbs p {
	max-width: 1000px;
	margin: 0 auto;
	font-size: 12px;
	color: #666666;
	padding: 4px 0;
}

/* object/page 各ページ固有のクラスなど------------------------------ */

.home-mv {
	height: 61.1rem;
	padding: 3.2rem 0;
	background: no-repeat url(../img/home/home_mv_bg.png) center bottom/auto 100%;
}

.home-mv__txt {
	padding-top: 2.8rem;
	position: relative;
}

.home-mv__txt .txt02 {
	height: 19.3rem;
}

.home-mv__txt .txt02 img {
	height: 100%;
	width: auto;
}

.home-mv2 .txt01 {
	position: absolute;
	top: 10rem;
	right: 80px;
	height: 8.4rem;
}

.home-mv2 .txt01 img {
	height: 100%;
	width: auto;
}

.home-about {
	padding: 7rem 0 9rem;
	background: no-repeat url(../img/home/home_about_bg.png) top 12rem center/1545px;
}

.home-about .c-col2 {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-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;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.home-about .c-col2__item:first-child {
	margin-left: 4.5454%;
	width: 39.4545%;
}

.home-about .c-col2__item:last-child {
	width: 43.6363%;
}

.home-about__txt {
	text-align: center;
	padding-top: 4rem;
}

.home-about__txt .title {
	margin-bottom: 4rem;
	color: #000;
}

.home-future {
	padding: 5rem 0 6rem;
	background: no-repeat url(../img/home/home_future_bg.png) center center/cover;
}

.home-future__head {
	margin-bottom: 6rem;
}

.home-future__head .title {
	color: #fff;
}

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

.home-future__item {
	margin-bottom: 4rem;
	width: 30%;
	border-radius: 4rem;
}

.home-future-item {
	padding: 0 10% 10%;
}

.home-future-item .img {
	margin: -1rem auto 1.5rem;
	width: 89%;
}

.home-future-item .title {
	margin-bottom: 1rem;
	font-size: 2rem;
	color: #000;
	font-weight: 700;
	text-align: center;
	line-height: 1.5;
}

.home-future-item p {
	margin: 0;
}

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

.home-target {
	padding: 6rem 0;
	background: no-repeat url(../img/home/home_target_bg.png) bottom -90px center/1736px;
}

.home-target__paper {
	padding: 6% 6% 4%;
}

.home-target__head {
	margin-bottom: 5rem;
}

.home-target__contents .c-col2 {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.home-target__contents .c-col2__item {
	width: 47.7272%;
}

.home-target__contents .img {
	margin-bottom: 3rem;
	height: 14rem;
	text-align: center;
}

.home-target__contents .img img {
	height: 100%;
	width: auto;
}

.home-target__contents .list li {
	margin-bottom: 1.5rem;
	padding: 1.6rem 0;
	background-color: #EDF1FF;
	border-radius: 1.3rem;
	color: #5B3A7B;
	font-size: 1.5rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.6;
}

.home-reason {
	padding: 8rem 0;
	background: no-repeat url(../img/home/home_reason_bg.png) center center/cover;
}

.home-reason__head {
	margin-bottom: 4rem;
}

.home-reason__head .title {
	color: #fff;
	letter-spacing: -.5px;
}

.home-reason__paper {
	padding: 4.5rem 7.5%;
}

.home-reason__contents {
	margin-bottom: 3rem;
}

.home-reason__contents .c-col2 {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.home-reason__contents .c-col2__item:first-child {
	padding-top: 1rem;
	width: 54.4%;
}

.home-reason__contents .c-col2__item:last-child {
	width: 39.7%;
}

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

.home-voice {
	padding: 6rem 0;
	background: no-repeat url(../img/home/home_reason_bg.png) center center/cover;
}

.home-voice__head {
	margin-bottom: 8rem;
}

.home-voice__head .title {
	color: #fff;
}

.home-voice__list {
	margin-bottom: 1rem;
	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;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.home-voice__item {
	margin-bottom: 3rem;
	width: 31%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.home-voice__item:first-child,
.home-voice__item:last-child {
	margin-top: -5rem;
}

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

.home-course {
	padding: 5rem 0;
}

.home-course__head {
	margin-bottom: 5rem;
}

.home-course__list {
	margin-bottom: 1rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.home-course__item {
	margin-bottom: 2rem;
	width: 47%;
	padding: 4% 5%;
}

.home-course__item .title {
	color: #000;
	margin-bottom: 3rem;
	height: 2.3rem;
	text-align: center;
}

.home-course__item .title img {
	height: 100%;
	width: auto;
}

.home-course__item dl {
	margin-bottom: 1rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.home-course__item dl dt {
	width: 23.8%;
	color: #000;
}

.home-course__item dl dd {
	width: 67.4%;
}

.home-staff {
	padding: 6rem 0;
	background-color: #EDF1FF;
}

.home-staff__head {
	margin-bottom: 5rem;
}

.home-staff__item {
	margin-bottom: 5rem;
}

.home-staff-item {
	padding: 4.5% 5% 5.5%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.home-staff-item.-reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.home-staff-item__img {
	width: 30%;
}

.home-staff-item__txt {
	width: 66.6666%;
}

.home-staff-item__txt .title {
	margin-bottom: 1rem;
	color: #000;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.5;
}

.home-staff-item__txt .name {
	text-align: right;
}

.home-access {
	padding: 6rem 0;
}
.home-access__row{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: 40px;
}
.address_wrap{
	width: 49%;
}
@media screen and (max-width: 768px) {
	.address_wrap{
		width: 100%;
	}
	.address_second{
		width: 100%;
		margin-top: 50px;
	}
}



.home-access__head {
	margin-bottom: 3rem;
}

.home-access__address {
	margin-bottom: 3rem;
	text-align: center;
}

.home-access__address .title {
	margin-bottom: 1.5rem;
	color: #000;
	font-size: 2.2rem;
	font-weight: 700;
}

.home-access__address p {
	font-size: 1.6rem;
	line-height: 1.5;
}

.home-access__map {
	margin-bottom: 3rem;
}

.home-access__map iframe {
	width: 100%;
	height: 39rem;
}

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

.home-access__btn .btn__inner {
	background: transparent;
	border: 1px solid #E139A3;
	color: #E139A3;
}

.home-gallery {
	padding: 2rem 0 5rem;
}

.home-gallery__head {
	margin-bottom: 3.5rem;
}

.home-gallery__row {
	overflow-x: scroll;
}

.home-gallery__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.home-gallery__list .img {
	padding: 5px;
}

.home-bg {
	position: relative;
	overflow: hidden;
}

.home-bg.-a {
	background: no-repeat url(../img/home/home_bg_a.png) top -460px center/1580px;
}

.home-bg.-b .home-bg__item {
	width: 100%;
	height: 100%;
	background: no-repeat url(../img/home/home_bg_b.png) top 731px center/1426px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
}

.about-sectionA__paper {
	padding: 7rem 6%;
	width: calc(100% - (100% - 800px) / 2);
	margin-left: auto;
	margin-right: 0;
	border-radius: 40px 0 0 40px;
}

.about-sectionA.-left .about-sectionA__paper {
	margin-left: 0;
	margin-right: auto;
	border-radius: 0 40px 40px 0;
}

.about-sectionA__wrapper {
	width: 100%;
	max-width: 800px;
	margin-right: auto;
	margin-left: 0;
}

.about-sectionA.-left .about-sectionA__wrapper {
	margin-left: auto;
	margin-right: 0;
}

.about-sectionA__txt .title {
	margin-bottom: 5rem;
}

.about-sectionA__txt p {
	font-size: 1.6rem;
}

.about-sectionA__txt p strong {
	color: #e139a3;
	font-size: 1.8rem;
}

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

.about-sectionA__col2.-reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.about-sectionA__col2 .about-sectionA__img {
	width: 35%;
}

.about-sectionA__col2 .about-sectionA__txt {
	width: 63%;
}

.about-sectionA__list {
	margin: 4rem auto 3rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.about-sectionA__list .item {
	margin: 0 0 1.5rem 2%;
	width: 49%;
	-webkit-box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.15);
	box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.15);
	border-radius: 20px;
	min-height: 60px;
	font-size: 1.6rem;
    font-weight: 700;
    padding: 1.5em 0 1.5em 100px;
}
.about-sectionA__list .stage01 {
	background: url(../img/about/about_training_stage1.png) 1em 1.25em no-repeat;
	background-size: 70px auto;
}
.about-sectionA__list .stage02 {
	background: url(../img/about/about_training_stage2.png) 1em 1.25em no-repeat;
	background-size: 70px auto;
}
.about-sectionA__list .stage03 {
	background: url(../img/about/about_training_stage3.png) 1em 1.25em no-repeat;
	background-size: 70px auto;
}
.about-sectionA__list .stage04 {
	background: url(../img/about/about_training_stage4.png) 1em 1.25em no-repeat;
	background-size: 70px auto;
}
.about-sectionA__list .stage05 {
	background: url(../img/about/about_training_stage5.png) 1em 1.25em no-repeat;
	background-size: 70px auto;
}

.about-sectionA__list .item:nth-child(2n-1) {
	margin-left: 0;
}

.about-intro {
	padding-top: 3rem;
	text-align: center;
}

.about-intro .img {
	margin: 0 auto;
	width: 100%;
	max-width: 700px;
}

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

.about-five__head .title {
	margin-bottom: 5rem;
}

.about-five__img {
	margin: 0 auto 8rem;
	width: 800px;
}

.about-five__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	width: 100%;
}

.about-five__list .item {
	margin: 1.6666%;
	width: 30%;
	-webkit-box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.15);
	box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.15);
	border-radius: 30px;
	text-align: left;
	padding: 25px;
	font-size: 1.6rem;
	font-weight: 500;
}
.about-five__list .item h3 {
	font-size: 2.8rem;
	font-weight: 700;
	margin: 0 0 1.6rem 80px;;
}
.about-five__list .item p {
	margin-bottom: 0;
}

.about-five__list .conception01 {
	background: no-repeat url(../img/about/about_five_item01.png) 20px 20px;
	background-size: 60px auto;
}
.about-five__list .conception01 span {
	color: #ed88c8;
}
.about-five__list .conception02 {
	background: no-repeat url(../img/about/about_five_item02.png) 20px 20px;
	background-size: 60px auto;
}
.about-five__list .conception02 span {
	color: #e1a1d6;
}
.about-five__list .conception03 {
	background: no-repeat url(../img/about/about_five_item03.png) 20px 20px;
	background-size: 60px auto;
}
.about-five__list .conception03 span {
	color: #c79fde;
}
.about-five__list .conception04 {
	background: no-repeat url(../img/about/about_five_item04.png) 20px 20px;
	background-size: 60px auto;
}
.about-five__list .conception04 span {
	color: #9399e6;
}
.about-five__list .conception05 {
	background: no-repeat url(../img/about/about_five_item05.png) 20px 20px;
	background-size: 60px auto;
}
.about-five__list .conception05 span {
	color: #96baea;
}

.about-tool__bg--after {
	display: block;
	width: 525px;
	height: 486px;
	background: no-repeat url(../img/about/bg_after_tool.png) center center/contain;
	position: absolute;
	bottom: -340px;
	right: -140px;
}

.about-training__bg--after {
	display: block;
	width: 507px;
	height: 291px;
	background: no-repeat url(../img/about/bg_after_training.png) center center/contain;
	position: absolute;
	bottom: -40px;
	left: -90px;
}

#about_intro,
#about_note,
#about_tool,
#about_training,
#about_training2 {
	margin-bottom: 8rem;
}

/* object/utility わずかなスタイルの調整のための便利クラスなど ------------------------------ */

.u-block--768 {
	display: none;
}

.u-block--480 {
	display: none;
}

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

.l-mainWithColumn + .l-right {
	margin-left: auto;
}

}

@media (max-width: 1160px) {

.l-sideLeft {
	margin-right: 4%;
}

.l-sideLeft + .l-mainWithColumn {
	width: calc(100% - 221px - 4% - 60px);
}

}

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

.l-mainWithColumn + .l-right {
	width: 100%;
}

.c-col2.-pconly .c-col2__item {
	width: 100%;
}

}

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

body {
	min-width: none;
	min-width: initial;
	min-width: auto;
}

.l-sideLeft {
	width: 100%;
	margin: 0;
}

.l-sideLeft + .l-mainWithColumn {
	width: 100%;
}

.l-mainWithColumn {
	margin: 0 auto;
	width: 100%;
}

.l-drawer {
	display: block;
}

.l-drawerClose {
	display: block;
	text-align: center;
	line-height: 5rem;
}

.l-overlay {
	display: block;
}

.have_curtain .l-overlay {
	display: block;
}

.c-inner {
	padding: 0 5.333%;
}

.c-btn .c-btn__inner {
	font-size: 1.6rem;
	padding: 1.8rem 4rem;
}

.c-title1 {
	font-size: 2.6rem;
}

.c-title1::after {
	margin-top: 1.8rem;
	width: 4rem;
	height: 0.6rem;
}

.p-footer {
	min-width: none;
	min-width: initial;
	min-width: auto;
}

.p-footer__menu ul {
	display: block;
	padding-left: 1.5rem;
}

.p-footer__flex {
	display: block;
}

.p-footer__sns {
	margin-bottom: 3rem;
	text-align: center;
}

.p-footer__sns img {
	margin: 0 1rem;
}

.p-header {
	min-width: none;
	min-width: initial;
	min-width: auto;
}

.p-header__logo {
	height: 3.5rem;
}

.p-header__menu {
	display: none;
}

.p-header .c-burger {
	display: block;
}

.p-banner {
	padding: 1.5rem 0 2.5rem;
}

.p-banner__contents img {
	max-width: 395px;
	width: 100%;
}

.p-cta {
	padding: 3rem 0 2rem;
	background: no-repeat url(../img/home/home_cta_bg_sp.png) center center/cover;
}

.p-cta .title {
	margin-bottom: 2.5rem;
	text-align: left;
	font-size: 2.6rem;
	line-height: 1.5;
}

.p-cta .title::after {
	margin: 2rem auto 0 0;
	display: block;
	content: '';
	margin-top: 1.8rem;
	width: 4rem;
	height: 0.6rem;
	background: -webkit-gradient(linear, left top, right top, from(#4A87C5), color-stop(#BC5FC9), to(#FE1B84));
	background: -webkit-linear-gradient(left, #4A87C5, #BC5FC9, #FE1B84);
	background: linear-gradient(90deg, #4A87C5, #BC5FC9, #FE1B84);
}

.p-cta__img {
	width: 40%;
	max-width: 150px;
	bottom: 20.5rem;
}

.p-cta__btn .btn {
	width: 100%;
	margin: 0 auto 2rem;
}

.p-cta__btn .btn__inner {
	width: 100%;
}

.p-cta__btn .btn.-a .btn__txt {
	font-size: 1.7rem;
}

.p-cycle {
	padding: 6.5rem 0 2rem;
}

.p-cycle__paper {
	border-radius: 0;
	padding: 3rem 5.333% 5rem;
}

.p-cycle__head {
	margin-bottom: 2rem;
}

.p-cycle__list {
	padding: 0 10%;
}

.p-cycle__item {
	margin-top: 3rem;
	margin-bottom: 3rem;
	width: 100%;
}

.p-cycle-item {
	padding: 0 9% 8.5%;
}

.p-cycle-item.-summary .img {
	margin-top: 0;
	max-width: 274px;
}

.p-cycle-item.-summary p {
	padding-left: 2rem;
}

.p-cycle-item .title {
	margin-bottom: 1.4rem;
}

.p-cycle__btn .btn {
	width: 100%;
}

.p-lineup {
	padding: 4rem 0 5rem;
}

.p-lineup__paper {
	padding: 3rem 5.333% 5rem;
	border-radius: 0;
}

.p-lineup__head {
	margin-bottom: 2rem;
}

.p-lineup__btn .btn {
	width: 100%;
}

.r-cv h1 {
	font-size: 2.6rem;
}

.r-cv img {
	width: 180px;
}

.r-breadcrumbs {
	padding: 10px 20px;
}

.home-mv {
	height: 79vw;
	padding: 1.8rem 0;
	background: no-repeat url(../img/home/home_mv_bg_sp.png) right bottom/86.666%;
}

.home-mv__txt {
	padding-top: 0;
}

.home-mv__txt .txt02 {
	width: 100%;
	max-width: 331px;
	height: auto;
}

.home-mv__txt .txt02 img {
	width: 100%;
	height: auto;
}

.home-mv2 .txt01 {
	position: static;
	width: 100%;
	max-width: 269px;
	height: auto;
	margin: 2rem auto;
}

.home-mv2 .txt01 img {
	width: 100%;
	height: auto;
}

.home-about {
	padding: 0 0 6rem;
}

.home-about .c-col2__item:first-child {
	margin-bottom: 3rem;
	margin-left: auto;
	width: 100%;
}

.home-about .c-col2__item:last-child {
	width: 100%;
}

.home-about__txt .title {
	margin-bottom: 3rem;
}

.home-about__txt .btn {
	margin-top: 1rem;
	width: 100%;
}

.home-future {
	padding: 3rem 0 4rem;
}

.home-future__head {
	margin-bottom: 3rem;
}

.home-future__item {
	width: 100%;
}

.home-future-item .img {
	width: 75%;
}

.home-target {
	padding: 5.5rem 0;
}

.home-target__paper {
	padding: 3rem 5.333%;
	border-radius: 0;
}

.home-target__head {
	margin-bottom: 3rem;
}

.home-target__contents .c-col2__item {
	width: 100%;
}

.home-target__contents .img {
	width: 100%;
	height: auto;
}

.home-target__contents .img img {
	width: 100%;
	height: auto;
}

.home-reason {
	padding: 3rem 0 4.5rem;
}

.home-reason__paper {
	padding: 1.5rem 7.5% 3rem;
}

.home-reason__contents .c-col2__item:first-child {
	margin-bottom: 1rem;
	width: 100%;
}

.home-reason__contents .c-col2__item:last-child {
	width: 100%;
}

.home-reason__btn .btn {
	width: 100%;
}

.home-reason__btn .btn__inner {
	padding-left: 0;
	padding-right: 0;
	font-size: 1.3rem;
}

.home-voice {
	padding: 4rem 0;
}

.home-voice__head {
	margin-bottom: 2rem;
}

.home-voice__list {
	padding: 0 5.333%;
}

.home-voice__item {
	width: 100%;
}

.home-voice__item:first-child,
.home-voice__item:last-child {
	margin-top: 0;
}

.home-voice__btn .btn {
	width: 100%;
}

.home-voice__btn .btn__inner {
	padding-left: 0;
	padding-right: 0;
	font-size: 1.3rem;
}

.home-course {
	padding: 4rem 0 3rem;
}

.home-course__head {
	margin-bottom: 2rem;
}

.home-course__item {
	width: 100%;
	padding: 10% 12%;
}

.home-course__item dl {
	margin-bottom: 2rem;
}

.home-course__item dl dt {
	width: 100%;
	margin-bottom: .6rem;
}

.home-course__item dl dd {
	width: 100%;
}

.home-staff {
	padding: 2rem 0 1.5rem;
}

.home-staff__head {
	margin-bottom: 3rem;
}

.home-staff__item {
	margin-bottom: 3rem;
}

.home-staff-item {
	padding: 4rem 10% .5rem;
}

.home-staff-item__img {
	width: 100%;
	margin-bottom: 2rem;
}

.home-staff-item__txt {
	width: 100%;
}

.home-access {
	padding: 5.5rem 0 3rem;
}

.home-access__map iframe {
	height: 31rem;
}

.home-access__btn .btn {
	width: 100%;
}

.home-gallery {
	padding: 2.5rem 0 5rem;
	overflow: hidden;
	white-space: nowrap;
}

.home-gallery__head {
	margin-bottom: 2.5rem;
}

.home-gallery__list {
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	-ms-scroll-snap-type: x mandatory;
	scroll-snap-type: x mandatory;
}

.home-gallery__list .img {
	width: 260px;
	height: 260px;
	scroll-snap-align: start;
}

.about-sectionA__paper {
	border-radius: 0;
	width: 100%;
	padding: 5rem 5.333%;
}

.about-sectionA.-left .about-sectionA__paper {
	border-radius: 0;
}

.about-sectionA__wrapper {
	margin: 0 auto;
}

.about-sectionA.-left .about-sectionA__wrapper {
	margin: 0 auto;
}

.about-sectionA__txt .title {
	margin-bottom: 3rem;
}

.about-sectionA__col2 {
	display: block;
}

.about-sectionA__col2 .about-sectionA__img {
	width: 100%;
	max-width: 280px;
	margin: 0 auto;
}

.about-sectionA__col2 .about-sectionA__txt {
	width: 100%;
}

.about-five {
	text-align: left;
}

.about-five__img {
	margin-bottom: 4rem;
}

.about-five__list .item {
	width: 46.6666%;
}

#about_intro,
#about_note,
#about_tool,
#about_training,
#about_training2 {
	margin-bottom: 5rem;
}

}

@media (max-width: 768px) {

.u-none--768 {
	display: none;
}

.u-block--768 {
	display: block;
}

}

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

.l-header,
.l-contentsTop,
.l-contents,
.l-contentsBottom,
.l-footer {
	min-width: auto;
}

.about-sectionA__list .item {
	margin-left: 0;
	width: 100%;
}

.about-intro {
	text-align: left;
}

.about-five__list .item {
	width: 96.666%;
}

}

@media (max-width: 480px) {

.u-block--480 {
	display: block;
}

}

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

.p-cta .title {
	font-size: 2.2rem;
}

}

/*# sourceMappingURL=maps/style.css.map */


/* add by Hassy840 */  

@media screen and (max-width: 768px) {
	.l-header {
		position: relative;
	}
	.p-header {
		position: relative;
	}

	.l-top {
		margin-top: 0;
	}
	.p-header .p-header__menu {
		display: block;
		position: fixed;
		right: -100%;
		top: 0;
		width: 100%;
		height: 100vh;
  		background-color: #F9F5FF;
  		z-index: 10000;
  		transition: .3s;
	}
	.p-header .p-header__menu ul {
		display:-webkit-box;
  		display:-ms-flexbox;
  		display:flex;
  		-webkit-box-orient: vertical;
  		-webkit-box-direction: normal;
  		-ms-flex-direction: column;
  		flex-direction: column;
  		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		margin-top: 30vw;
	}
	.p-header .p-header__menu ul li {
		text-align: center;
		font-size: 1.8rem;
		margin-left: 0;
		padding: 2rem;
	}
	.p-header__menu .btn {
		margin-left: 0;
		padding: 15vw 10vw 0;
		width: 100%;
	}
	.p-header__menu .c-btn .c-btn__inner {
		font-size: 1.8rem;
	}
	.p-header .p-header__menu ul li a {
	}
	.p-header.open .p-header__menu {
		right: 0;
  		transition: .3s;
	}
	.p-header.open .c-burger div:first-child {
		transform: rotate(45deg);
	}
	.p-header.open .c-burger div:nth-child(2) {
		background-color: transparent;
	}
	.p-header.open .c-burger div:last-child {
		transform: rotate(-45deg);
	}
	.p-header.open .p-header__logo {
		z-index: 30000;
	}
	.r-cv h1 {
		margin-top: 20px;
	}
}

.p-banner {
	background-color: #FFFAD1;
}
.p-cycle__bg--before,
.p-lineup__bg--after {
	left: 0;
}
.p-cycle__bg--after,
.about-tool__bg--after {
	right: 0;
}



br.pcbr {
	display: block;
}
br.spbr {
	display: none;
}
.onlysp {
	display: none;
}

@media screen and (max-width: 480px) {
	.p-header {
		width: 100%;
		background: #fff;
		z-index: 1000;
		top: 0;
	}
	.p-cycle__list {
    	padding: 0;
	}
	.about-intro .img {
		margin-bottom: 1em;
	}
	.about-five__img {
		width: 100%;
	}
	.about-five__list .item {
		margin-bottom: 1em;
		font-size: 1.4rem;
		border-radius: 15px;
	}
	.about-five__list .item h3 {
		font-size: 2.4rem;
		margin-left: 70px;
	}
	.about .p-cycle__bg--before {
		display: none;
	}
	.p-cycle-item.-summary p {
		padding-left: 0;
	}
	br.pcbr {
		display: none;
	}
	br.spbr {
		display: block;
	}
	.onlysp {
		display: block;
	}
	.p-footer {
		padding: 3rem 0 70px;
	}
	.p-footer__menu {
		margin-bottom: 4em;
	}
	.home-about .c-col2__item p,
	.p-lineup__head p {
		text-align: left;
	}
}

.about .r-cta {
	width: 700px;
    margin: 2rem auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.about .r-cta a {
    background: #e139a3;
    border-radius: 30px;
    color: #fff;
    width: 220px;
    height: 60px;
    display: inline-block;
    text-align: center;
    line-height: 60px;
    font-size: 16px;
    margin: 0.5rem 0;
}
.about .r-cta a::after {
    content: "";
    display: inline-block;
    background-image: url(../img/reason/btn_arrow.png);
    background-repeat: no-repeat;
    width: 18px;
    height: 10px;
    margin-left: 15px;
}

@media screen and (max-width: 480px) {
	.about .r-cta {
    	width: 100%;
    	padding: 0 5.333%;
	}
	.about .r-cta a {
    	width: 47%;
    	margin: 0 auto 10px!important;
    	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;
    	line-height: 1.3;
    	font-size: 14px;
    	text-align: left;
    	height: 50px;
    	border-radius: 25px;
    	padding: 1.5vw 3vw;
	}
	.about .r-cta a::after {
	}
}

.floating {
	display: none;
}
@media screen and (max-width: 480px) {
	.floating {
		display: block;
		width: 96vw;
		background: rgba(255,0,127,0.9);
		position: fixed;
		bottom: 2vw;
		left: 2vw;
		z-index: 2000;
		padding: 0;
	}
	.floating ul {
    	display: -webkit-box;
    	display: -ms-flexbox;
    	display: flex;
    	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
    	width: 100%;
	}
	.floating ul li {
		width: 33.33%;
		min-height: 16vw;
		text-align: center;
		padding: 2vw;
		font-size: 1.2rem;
	}
	.floating ul li:first-child {
		border-right: 1px solid #fff;
	}
	.floating ul li:last-child {
		border-left: 1px solid #fff;
	}
	.floating ul li a {
		display: block;
		color: #fff;
	}
	.floating ul li a i {
		display: block;
		font-size: 2.4rem;
		margin-bottom: 1vw;
	}
}



.home-voice__item {
	width: 310px;
	height: 160px;
	padding: 20px 25px 0 120px;
}
.home-voice__item.voice-01 {
	background: url(../img/home/home_voice01.png) no-repeat;
	background-size: 100%;
}
.home-voice__item.voice-02 {
	background: url(../img/home/home_voice02.png) no-repeat;
	background-size: 100%;
}
.home-voice__item.voice-03 {
	background: url(../img/home/home_voice03.png) no-repeat;
	background-size: 100%;
}
.home-voice__item p {
	line-height: 1.5;
	font-weight: 500;
}
.home-voice__item p span {
	display: block;
	margin-top: 0.5em;
	font-weight: 300;
}

.c-wrapper.-w800 {
	text-align: center;
}
.c-wrapper.-w800 iframe {
	margin: 20px auto 0;
}
@media screen and (max-width: 480px) {
	.c-wrapper.-w800 iframe {
		width: 90%;
		height: 95vw;
		margin: 10px auto 20px;
	}
	.peatix-widget-event-name {
		font-size: 20px;
	}
}
