@charset "UTF-8";


/* ========================================================
  
  common

======================================================== */

/*-----------------------------------------------
 common - l-nav
-----------------------------------------------*/
.l-nav {
	bottom: 40px;
}

/*---------------------------------------------------------
 common - info
---------------------------------------------------------*/
.l-info {
	border-top: 1px solid rgb(204 204 204 / 0.8);
}



/* ========================================================
  
  FV

======================================================== */
.l-fv__img {
    width: 98.7%;
    max-height: 390px;
    margin-inline: auto;
    overflow: hidden;
}
.l-fv__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
	object-position: center center;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-fv__img {
    width: 94vw;
    height: 36vw;
}
}





/* ========================================================
  
  page_common

======================================================== */


/* ========================================================
  
  main

======================================================== */

/*---------------------------------------------------------
 Lead
---------------------------------------------------------*/
.lead {
    position: relative;
    text-align: center;
}

.lead__title {
    position: relative;
    margin-bottom: 5%;
}
.lead__title .c-heading--min {
    margin-bottom: .3em;
}
.lead__title::before {
	position: absolute;
	content: "";
	background: url(../images/common/obj-mark@2x.png) no-repeat;
	background-size: contain;
	width: 35vw;
    max-width: 4530px;
	aspect-ratio: 355/180;
	z-index: -1;
    inset: 0;
    margin: auto;
}

.lead .c-txt-center {
    color: var(--job-color);
    margin-top: 4%;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.lead__title::before {
	width: 50vw;
}

.lead .c-txt-center {
    margin-top: 6%;
}
}



/*---------------------------------------------------------
 Person
---------------------------------------------------------*/
.person {
    text-align: center;
    color: #FFF;
    background-color: rgb(76 160 140 / 0.9);
    margin-top: -70px;
}
.person__title span {
    color: var(--color-primary);
    font-size: 133%;
}

.person .c-list--check {
	row-gap: .5em;
    font-size: min(2.3vw,164%);
}
.person .c-list--check > li {
    padding-bottom: .4em;
    border-bottom: 1px dotted currentColor;
}
.person .c-list--check > li::before {
    color: var(--color-primary);
}

/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.person .c-list--check {
    max-width: 1010px;
    justify-content: space-between;
    grid-template-columns: 42% 52%;
    margin-inline: auto;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.person {
    margin-top: -40px;
}

.person .c-list--check {
    font-size: 105%;
}
}



/*---------------------------------------------------------
 Value
---------------------------------------------------------*/
.value {
    padding-bottom: 0;
}
.value .c-bg-img {
    max-height: 590px;
}
.value .c-title--enjp {
    color: #FFF;
    margin-bottom: min(20%,260px);
}
.value .l-box--wide {
    max-width: 1440px;
}
.value .l-box--wide > .c-heading--min {
    text-align: center;
    margin-bottom: 1.2em;
}
.value .l-box--wide > .c-heading--min span {
    color: var(--accent-color);
}

/* support */
.support__illust img {
    position: absolute;
    width: 14%;
    max-width: 200px;
    left: 5%;
    top: 0;
    translate: 0 -25%;
}
.support__illust img:nth-of-type(2) {
    left: auto;
    right: 5%;
}

/* environment */
.environment {
    background-color: rgb(255 255 255 / 0.9);
}
.page-staff .environment .l-item-list > * {
    background-color: var(--color-ppl-100);
}
.page-staff .environment .l-item-list > *:last-child .c-heading--min {
    letter-spacing: normal;
}
.page-staff .environment .l-item-list .c-list--check > li::before {
    color: var(--color-ppl);

}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.value .l-flt,
.value .l-boxlist {
    max-width: 1200px;
	margin-inline: auto;
}

.value .l-flt__img {
    width: 50%;
}
.value .l-flt .c-heading--min,
.value .l-boxlist .c-heading--min {
    line-height: 1.8;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.value .c-bg-img {
    height: 60vw;
}

/* support */
.support__illust img {
    width: 20%;
}
}

/* Value - value__col3
-----------------------------------------------*/
.value__col3 .c-heading--bld {
    color: var(--accent-color);
    text-align: center;
}
.value__col3 .c-heading--bld::before {
    display: block;
    content: "";
    background: url(../images/common/value-icon-skillup.svg) no-repeat center center;
    background-size: contain;
    width: 2.5em;
    height: 2.5em;
    margin: 0 auto .2em;
}
.value__col3 > li:nth-of-type(2) .c-heading--bld::before {
    background-image: url(../images/common/value-icon-manual.svg);}
.value__col3 > li:nth-of-type(3) .c-heading--bld::before {
    background-image: url(../images/common/value-icon-study.svg);}

/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.value__col3 {
    display: grid;
    grid-template-columns: repeat(3,33%);
    border-left: 1px solid var(--accent-color);
}
.value__col3 > li {
    border-right: 1px solid var(--accent-color);
    padding: 0 8.8%;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.value__col3 {
    border-bottom: 1px solid var(--accent-color);
}
.value__col3 > li {
    border-top: 1px solid var(--accent-color);
    padding: 6% 6% 8%;
}
}

/* Value - value__itemlist
-----------------------------------------------*/
.value__itemlist {
    max-width: 1280px;
    display: grid;
    row-gap: 2.5em;
    margin-inline: auto;
}
.value__itemlist > li {
    background-color: #fff;
    padding: 10% 8%;
    border-radius: 1.2em;
    box-shadow: 0 0 10px rgba(0,0,0,0.2);
}
.value__itemlist .c-heading--bld {
    margin: 0 auto .8em;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.value__itemlist {
    justify-content: space-between;
    grid-template-columns: repeat(3,31.2%);
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.value__itemlist {
    row-gap: 1em;
}
.value__itemlist > li {
    padding: 8%;
}
}


/*---------------------------------------------------------
 Voice
---------------------------------------------------------*/
.voice__item::after {
	display: block;
	content: "";
	background: linear-gradient(to right, rgba(204,204,204,0.05), rgba(204,204,204,1), rgba(204,204,204,0.05));
	width: 55%;
	height: 1px;
	margin: 7% auto;
}
.voice__item:last-of-type::after {
	display: none;
}

.voice__img {
    position: relative;
	max-width: 460px;
}
.voice__img img {
    width: 85%;
    max-width: 390px;
}
.voice__img figcaption {
    position: relative;
    width: 90%;
    max-width: 370px;
    color: #FFF;
    font-size: min(1.7vw,100%);
    line-height: 1.4;
    background-color: rgb(var(--job-color-rgb) / 0.7);
    padding: 9%;
    margin-left: auto;
    margin-top: -1.8em;
}
.voice__img .u-font-min {
    font-size: 117%;
    line-height: 1.5;
    letter-spacing: .2em;
}
.voice__img .u-font-min span {
    display: block;
    font-size: 175%;
    letter-spacing: .2em;
}
.voice__img figcaption p {
    margin-top: .5em;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.voice__inner {
    width: 96%;
    max-width: 1200px;
	display: grid;
	justify-content: space-between;
	align-items: flex-start;
	grid-template-columns: 38.4% 57%;
    margin-inline: auto;
}

.voice__item .c-heading--min {
    margin-bottom: 1em;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.voice__item::after {
	margin: 10% auto;
}


.voice__img {
    width: 80%;
    margin: 0 auto 6%;
}
.voice__img img {
    width: 85%;
}
.voice__img figcaption {
    font-size: 90%;
}
}



/*---------------------------------------------------------
 Schedule
---------------------------------------------------------*/
.schedule .c-bg-color {
    background-color: #eae8d3;
}
.schedule .c-heading--deco {
    background-color: #FFF;
}

.schedule__list {
    display: grid;
    grid-template-columns: repeat(5,20%);
}
.schedule__list > li {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 4;
	row-gap: 0;
    padding: 0 6%;
}

.schedule__img {
    position: relative;
    width: 75%;
    max-width: max-content;
    margin: 0 auto 5%;
}
.schedule__img img {
    border: 2px solid #FFF;
}
.schedule__img::before {
    position: absolute;
    content: "";
    background-color: #fff;
    width: 60%;
    height: 2px;
    left: 100%;
    top: 50%;
    z-index: -1;
}
.schedule__list > li:last-of-type .schedule__img::before {
    display: none;
}
.schedule__img::after {
	position: absolute;
	content: "";
	background-size: contain;
	background-color: var(--job-color);
	mask: url(../images/common/icon-accent.svg) no-repeat center;
	-webkit-mask: url(../images/common/icon-accent.svg) no-repeat center;
	mask-size: contain;
	-webkit-mask-size: contain;
    width: 12.8%;
    height: 13.7%;
    right: 1%;
    top: -4%;
}

.schedule__list .c-heading--bld {
    text-align: center;
    color: var(--job-color);
    font-size: min(2.2vw,147%);
}

.schedule__time {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    color: var(--job-color);
    font-size: min(1.3vw,100%);
    font-weight: var(--fw-bold);
    line-height: 1.3;
    letter-spacing: .1em;
    background-color: #fff;
    border-radius: 100vmax;
    padding: 1em;
    margin-bottom: .8em;
}
.schedule__time.has-row {
    row-gap: 4px;
    background-color: transparent;
    padding: 0;
}
.schedule__time.has-row div {
    display: flex;
    align-items: center;
    column-gap: 10%;
    background-color: #fff;
    border-radius: 100vmax;
}
.schedule__time.has-row div span {
    display: block;
    width: 7.2em;
    color: #FFF;
    font-size: 88%;
    background-color: var(--job-color);
    padding: .4em;
    border-radius: 2em 0 0 2em;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.schedule__list {
    width: 220vw;
    padding-top: 10px;
}
.schedule__list > li {
    padding: 0 5%;
}

.schedule__list .c-heading--bld {
    font-size: 110%;
}
.schedule__time {
    font-size: 80%;
}
.schedule__time.has-row div {
    column-gap: 6%;
}
}



/*---------------------------------------------------------
 Tour
---------------------------------------------------------*/
.tour .c-heading--bg {
    background-color: var(--job-color);
}



/*---------------------------------------------------------
 Message
---------------------------------------------------------*/
.message {
    padding-bottom: min(15vw,180px);
}
.message .c-bg-color {
    background-color: var(--color-primary-400);
}
.message .c-bg-img {
    width: 88%;
	max-width: 1380px;
    color: #FBF37C;
    opacity: 0.7;
}
.message .c-heading--en {
    color: #FFF;
}

.message__name {
    font: var(--font-min);
    font-size: 105%;
    line-height: 1.5;
    letter-spacing: .2em;
    margin-top: 2em;
}
.message__name dd {
    font-size: 155%;
    letter-spacing: .2em;
}
.message__name dd.u-font-en {
    color: var(--accent-color);
    font-size: 83%;
    letter-spacing: .2em;
    margin-top: .5em;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.message__inner {
    margin-left: 4%;
}
.message__title .c-heading--min {
    line-height: 1.8;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.message {
    padding-bottom: 20%;
}
.message__name {
    font-size: 95%;
}
}



/*---------------------------------------------------------
 Vision
---------------------------------------------------------*/
.vision .l-box--wide {
    background-color: rgb(255 255 255 / 0.9);
    margin-top: max(-100px,-10vw);
}
.vision__title {
    text-align: center;
    margin-bottom: 7%;
}
.vision__title .c-heading--min span {
    color: var(--accent-color);
}

.vision .l-item-list {
    max-width: 1100px;
}
.vision .l-item-list > li:nth-of-type(1) .c-heading--min::before {
    background-image: url(../images/common/vision-icon01.svg);
}
.vision .l-item-list > li:nth-of-type(2) .c-heading--min::before {
    background-image: url(../images/common/vision-icon02.svg);
}
.vision .l-item-list > li:nth-of-type(3) .c-heading--min::before {
    background-image: url(../images/common/vision-icon03.svg);
}

.vision__no {
    position: absolute;
    text-align: center;
    color: var(--accent-color);
    font: var(--font-no);
    font-size: min(4vw,294%);
    letter-spacing: .05em;
    inset: -0.4em 0 auto 0;
    margin: auto;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.vision .l-item-list .c-heading--min {
    font-size: min(2.2vw,164%);
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.vision__no {
    font-size: 8vw;
}
}



/*---------------------------------------------------------
 Guideline
---------------------------------------------------------*/
.guideline {
    background-color: #eae8d3;
}
.guideline .c-heading--deco {
    background-color: #fff;
}
.guideline .c-txt-center {
    color: var(--job-color);
    margin-bottom: 5%;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.guideline .c-txt-center {
    margin-bottom: 1.5em;
}
}

/* Guideline - guideline__table
-----------------------------------------------*/
.guideline__table {
	width: 100%;
	line-height: 1.6;
	border-collapse: separate;
    border-spacing: 0 2px;
}
.guideline__table th,
.guideline__table td {
	font-weight: normal;
	vertical-align: middle;
	box-sizing: border-box;
	padding: 2.4em 3.5%;
}
.guideline__table th {
	width: 23%;
    color: #FFF;
    font-weight: var(--fw-bold);
	letter-spacing: .12em;
	background-color: #b4b393;
    text-align: left;
    vertical-align: top;
}
.guideline__table td {
	width: 77%;
    background-color: #fff;
}
.guideline__table td > * {
	margin-top: 1.2em;
}
.guideline__table td > *:first-child {
	margin-top: 0;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.guideline__table th,
.guideline__table td {
	display: block;
	width: 100%;
}
.guideline__table th,
.guideline__table td {
	padding: 1em 5%;
}
.guideline__table th {
	text-align: center;
	font-size: 110%;
	letter-spacing: .1em;
}
.guideline__table td {
	padding-bottom: 1.5em;
}
.guideline__table td > * {
	margin-top: 1em;
}
}



/*---------------------------------------------------------
 Contact
---------------------------------------------------------*/
.contact {
    text-align: center;
}
.contact .c-bg-color {
    background-color: var(--color-primary-400);
}
.contact .c-heading--min {
    margin-bottom: 1em;
}

.contact .c-cta-wrap {
    width: 90%;
    margin-inline: auto;
}
.contact .c-cta-btn--entry {
    min-width: 14em;
}
.contact .c-cta-btn--entry div::after {
    content: "フォーム";
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.contact .c-cta-wrap {
    flex-wrap: wrap;
}
}



/*---------------------------------------------------------

---------------------------------------------------------*/

/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {


}



/*---------------------------------------------------------

---------------------------------------------------------*/

/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {


}
