@charset "UTF-8";
/*------ 国一覧のマージン ------*/
.count-list {
	margin: 40px 0;
}
/* -------------------------------
	titleWrap
---------------------------------- */
.titleWrap {
	background-color: #fff;
	padding: 24px;
	margin-bottom: 72px;
}

.title {
	height: 24px;
	display: block;
	outline: none;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	margin-bottom: 16px;
}

.about-title {
	background: url(../../images/title_about.png) no-repeat;
}
.company-title {
	background: url(../../images/title_company.png) no-repeat;
}
.company-access {
	background: url(../../images/title_company2.png) no-repeat;
}
.flow-title {
	background: url(../../images/title_flow.png) no-repeat;
}
.first-title {
	background: url(../../images/title_first.png) no-repeat;
}

.col-left {
	float: left;
	width: 570px;
}

.titleWrap>img {
	margin-left: 32px;
}

.text p {
	margin-bottom: 10px;
}

.about-title-link {
	text-align: right;
}

.about-title-link>li {
	display: inline-block;
	margin-right: 10px;
}

.about-title-link>li>a {
	display: block;
	margin-left: 12px;
	color: #734A26;
}

.about-title-link>li>a:hover {
	color: #FF7F74;
}

.about-title-link>li>a::before {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 3px 0 3px 8px;
	border-color: transparent transparent transparent #734A26;
	position: relative;
	top: 9px;
	left: -11px;
}

.about-title-link>li>a:hover::before{
	border-color: transparent transparent transparent #FF7F74;
}


/* -------------------------------
	company
---------------------------------- */
/* ---------- company-detail ---------- */
.company-detail {
	border: solid 1px #754C24;
	width: 744px;
	line-height: 19px;
	margin: 36px auto 96px;
}

.company-detail tr {
	border-bottom: solid 1px #754C24;
}

.company-detail th {
	border-right: solid 1px #754C24;
	width: 20%;
	white-space: nowrap;
	vertical-align: middle;
	background-color: #FFF8D7;
}

.company-detail td {
	padding: 8px 16px;
}

.company-detail ul>li {
	list-style-type: disc;
	list-style-position: inside;
	text-indent: -1em;
	margin-left: 1em;
}

/* ---------- access ---------- */

.access-inner {
	text-align: center;
	margin: 32px 0;
}


.access-inner>div {
	display: inline-block;
	text-align: left;
	border-left: solid 1px #ccc;
	padding: 8px 32px;
}

.access-inner>div:first-child {
	border-left: none;
}

.access-inner ul {
	margin-bottom: 8px;
}

.access-inner ul>li {
	list-style: disc;
	list-style-position: inside;
}


/* -------------------------------
	about
---------------------------------- */

/* ---------- doubleBorder ---------- */
.doubleBorder {
	border-top: solid 1px #F7EADF;
	box-shadow:0 1px 0px 0px #fff inset;
	margin-bottom: 72px;
	padding-top: 40px;
}

.doubleBorder h3 {
	text-align: center;
	margin-bottom: 24px;
}

/* ---------- featureWrap ---------- */
.featureWrap {
	display: flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -webkit-flex;
	-webkit-flex-wrap: wrap; 
  	flex-wrap: wrap;
	background-color: #fff;
	outline: solid 1px #F7EADF;
	padding: 24px;
}

.featureWrap>div {
	width: 48%;
}

.featureWrap>div:nth-child(1),
.featureWrap>div:nth-child(2) {
	border-bottom: dashed 1px #F7EADF;
	margin-bottom: 8px;
	padding-bottom: 13px;
}

.featureWrap>div:nth-child(odd){
	border-right: dashed 1px #F7EADF;
	padding-right: 14px;
}

.featureWrap>div:nth-child(even){
	padding-left: 17px;
}

.featureWrap h4 {
	background: url(../../images/about_ribbon.png) no-repeat center;
	text-align: center;
	padding-top: 24px;
	color: #fff;
	font-size: 16px;
	height: 55px;
	margin-bottom: 4px;

}

.naname {
	background: url(../../images/naname.png) no-repeat center;
	-webkit-transform: rotate(5deg);
	   -moz-transform: rotate(5deg);
	    -ms-transform: rotate(5deg);
	     -o-transform: rotate(5deg);
	        transform: rotate(5deg);

	display: block;
	outline: none;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
}

/* -------------------------------
	flow
---------------------------------- */
.flow-wrap {
	overflow: hidden;
	margin-bottom: 72px;
}

.flow-wrap>div {
	float: left;
	background-color: #fff;
	outline: solid 1px #F7EADF;
	width: 436px;
	min-height: 163px;
	padding: 16px 24px;
	margin: 8px;
}

.flow-wrap>div:nth-last-child(-n+2) {
	min-height: 80px;
}

.flow-wrap h3 {
	font-weight: bold;
	font-size: 15px;
	margin-bottom: 8px;
}

.flow-wrap h3>span {
	font-family: 'Noto Serif', serif;
	font-weight: normal;
	font-style: italic;
	font-size: 28px;
	padding-right: 8px;
	color: #F23558;
}

/* ---------- flow-cotegory ---------- */
.flow-categoly {
	font-size: 11px;
	padding: 8px;
	display: inline-block;
	color: #fff;
	margin: 8px 0;
}

.flow-cate-lang{background-color: #31C5DD;}
.flow-cate-college{background-color: #FF7F74;}
.flow-cate-workingh{background-color: #57CDC3;}

/* ---------- flowno3 ---------- */
.flowno3 {
	width: auto !important;
}

.flowno3>div {
	float: left;
	width: 296px;
	margin-right: 24px;
}

.flowno3>div:last-child {
	margin-right: 0;
}

.flowno4>div {
	float: left;
	border-right: solid 1px #ccc;
	margin-right: 56px;
	padding-right: 56px;
}

.flowno4>div:last-child {
	margin-right: 0;
	padding-right: 0;
	border-right: none;
}

/* -------------------------------
	privacyWrap
---------------------------------- */
.privacyWrap h3 {
	font-weight: bold;
	font-size: 14px;
	margin-bottom: 8px;
}

.privacyWrap>div {
	margin-bottom: 24px;
}

.privacyWrap ol {
	margin-top: 8px;
}
.privacyWrap ol>li {
	list-style-type: decimal;
	list-style-position: inside;
	line-height: 19px;
	margin-bottom: 3px;
	text-indent: -1em;
	margin-left: 2em;
}

/* -------------------------------
	firstWrap
---------------------------------- */
.firstWrap>section {
	margin-bottom: 48px;
}


.first-flow {
	text-align: center;
	margin-bottom: 8px;
}

.first-flow>li {
	display: inline-block;
	margin-right: 12px;
}

/* ---------- introWrap ---------- */
.introWrap {
	text-align: center;
	vertical-align: top;
	letter-spacing: -.40em;
}

.introWrap div {
	letter-spacing: normal;
	padding: 16px;
	background-color: #fff;
	outline: solid 1px #ccc;
	float: left;
	width: 310px;
	min-height: 213px;
	margin-right: 16px;
	-webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
    text-align: justify;
    position: relative;
}

.introWrap div:last-child {
	margin-right: 0;
}

.introWrap h4 {
	font-weight: bold;
	font-size: 14px;
	padding-bottom: 11px;
	margin-bottom: 8px;
	background: url(../../images/bg_str.gif) repeat-x bottom; 
}

.introWrap p {
	margin-bottom: 8px;
}

.introWrap a {
	display: block;
	width: 113px;
	font-size: 12px;
	padding: 6px 0;
	background-color: #FF7F74;
	color: #fff;
	border-radius: 15px;
	text-align: center;
	position: absolute;
	bottom: 16px;
	right: 16px;
}

.introWrap div:hover {
	cursor: pointer;
}
.introWrap div:hover a {
	background-color: #FA6F62;
}

/* ---------- first-apply ---------- */
.first-apply {
	outline: solid 1px #ccc;
	background-color: #fff;
	padding: 8px 16px 16px;
	margin-right: 16px;
	margin: 0 16px 56px 0;
	float: left;
	width: 460px;
	min-height: 133px;
	position: relative;
}

.first-apply:last-child {
	margin-right: 0;
}

.first-apply>h4 {
	font-weight: bold;
	font-size: 14px;
	margin-bottom: 8px;
}

.first-apply>h4::before {
	position: relative;
	top: 5px;
	padding-right: 8px;
}

.chat-icon::before {
	content: url(../../images/chat_icon.png);
}

.mail-icon::before {
	content: url(../../images/mail_icon.png);
	padding-bottom: 2px;
}

.first-apply>p {
	float: left;
	width: 330px;
	text-align: justify;
}

.apply-cercle {
	margin-left: 343px;
	color: #fff;
	text-align: center;
	width:107px;
	height:107px;
	background-color:#57CDC3;
	border-radius: 50%;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	-webkit-transform: rotate(10deg);
	   -moz-transform: rotate(10deg);
	    -ms-transform: rotate(10deg);
	     -o-transform: rotate(10deg);
	        transform: rotate(10deg);
	position: absolute;
	top: 27px;
}

.apply-cercle:hover {
	cursor: pointer;
	background-color: #52C6B8;
}
.apply-cercle>a {
	display: block;
	color: #fff;
	padding-top: 25px;
	line-height: 19px;
}

.topchou {
	padding-top: 35px !important;
}

/* -------------------------------
	programWrap
---------------------------------- */
.programWrap,.mapWrap-sp {
	margin-bottom: 48px;
}

.programWrap div {
	border-color: #F7EADF;
}


/* -------------------------------
	apply-ichiran
---------------------------------- */
.apply-ichiran {
	overflow: hidden;
	margin-bottom: 48px;
}

.apply-ichiran div {
	background-color: #fff;
    float: left;
    width: 158px;
    padding: 16px;
    margin: 4px;
    color: #303030;
    border: solid 1px #F7EADF;
}

.apply-ichiran div:hover{
	background-color: #FFF7F4;
}

.apply-ichiran h3 {
	margin-left: 14px;
}

.apply-ichiran>p {
	margin-bottom: 18px;
}

.apply-ichiran h3::before {
	content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 3px 0 3px 8px;
    border-color: transparent transparent transparent #303030;
    position: relative;
    top: 9px;
    left: -14px;
}

/* -------------------------------
	error
---------------------------------- */
.error {
	text-align: center;
}

.error .bold {
	font-size: 17px;
	margin-bottom: 8px;
}

.error ul {
	margin-top: 24px;
}


/* -------------------------------
	 900px以下
---------------------------------- */
@media screen and (max-width: 900px){
	/* -------------------------------
		 900px以下スタイル
	---------------------------------- */
	

	/* ---------- titleWrap ---------- */
	.titleWrap{
		margin: 0 16px 72px;
		width: auto;
	}


	/* ---------- featureWrap ---------- */
	.featureWrap {
		margin: 0 16px;
		padding: 16px;
	}

	.featureWrap>div {
		float: none;
		width: auto;
		min-height: 0;
		margin-bottom: 24px !important;
	}

	.featureWrap>div:nth-child(odd) {
		border: none;
		padding: 0;
	}

	.featureWrap>div:nth-child(even){
		padding-left: 0;
	}

	.featureWrap>div:nth-child(1),
	.featureWrap>div:nth-child(2) {
		border: none;
		margin-bottom: 0;
	}

	.naname {
		display: none;
	}

	/* -------------------------------
	company
	---------------------------------- */
	.titleWrap>img {
		margin-left: 0;
		margin: 0 auto;
		display: block;
	}

	.col-left {
		float: none;
		width: auto;
	}

	.company-detail {
		width: auto;
	}
	
	/*------ access ------*/
	.access-inner>div {
		padding: 8px 13px;
	}

	.g-map {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
	}
	 
	.g-map iframe,
	.g-mapr object,
	.g-map embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	}

	/* -------------------------------
	flow
	---------------------------------- */
	.flow-wrap>div {
		float: none;
		width: auto;
		min-height: 0;
		margin: 8px 16px;
	}
	
	/*------ flowno3 ------*/
	.flowno3>div {
		float: none;
		width: auto;
		margin-right: 0;
		margin-bottom: 24px;
	}

	.flowno4 {
		text-align: center;
	}

	.flowno4>div {
		float: none;
		display: inline-block;
	}

	.flowno4>h3 {
		text-align: left;
	}

	/* -------------------------------
	first
	---------------------------------- */
	.introWrap {
		margin: 0 15px;
	}
	.introWrap div {
		float: none;
		width: 70%;
		margin: 0 auto 25px;
	}
	.introWrap div:last-child {
		margin-right: auto;
	}

	.introWrap a {
		bottom: 24px;
	}

	.applyWrap {
		text-align: center;
	}

	.first-apply {
		float: none;
		display: inline-block;
		margin: 16px 0;
	}

	.first-apply-wrap .subtitle,
	.first-apply-wrap .apply-cercle {
		display: block;
	}

	.apply-ichiran {
		padding: 0 16px;
	}

	.applyWrap div {
		float: none;
		display: inline-block;
		vertical-align: top;
		margin-bottom: 16px;
	}

	/* -------------------------------
		 900px以下スタイル-end-
	---------------------------------- */
}



/* -------------------------------
	smart phone 640px以下
---------------------------------- */
@media screen and (max-width:640px){
	/* -------------------------------
		 640px以下スタイル
	---------------------------------- */
	.titleWrap h2 {
		font-family: 'Noto Serif', serif;
		background-image: none;
		height: auto;
		color: #F23558;
		font-size: 1.7em;
		text-indent: 0;
		white-space: normal;
		overflow: visible;
	}

	.about-title-link {
		text-align: left;
	}

	.about-title-link>li {
		display: block;
		margin-right: 0;
		margin-bottom: 8px;
	}

	.about-title-link>li>a {
		font-size: 15px;
		padding: 8px;
	}

	.about-title-link>li>a::before {
		top: 11px;
		left: -14px;
	}
	/* ---------- featureWrap ---------- */
	.featureWrap h4 {
		background-image: none;
		background-color: #FF7F74;
		height: auto;
		padding: 14px 0;
		margin-bottom: 12px;
	}

	.doubleBorder h3 {
		margin: 0 16px 24px; 
	}

	/* -------------------------------
	company
	---------------------------------- */
	.company-detail th,
	.company-detail td {
		display: block;
	}

	.company-detail th {
		width: auto;
		border-right: none;
		border-bottom: solid 1px #754C24;
	}

	/* ---------- access ---------- */
	.access-inner>div {
		display: block;
		border-left: none;
		padding: 16px 0;
	}

	.access-inner ul>li {
		text-indent: -1em;
		margin-left: 1em;
	}

	/* -------------------------------
	flow
	---------------------------------- */
	.flow-categoly {
		display: block;
		text-align: center;
	}

	.flowno4>div {
		display: block;
		padding: 0 0 16px;
		margin: 0 0 16px;
		border-right: none;
	}

	.flowno4>div:last-child {
		margin: 0;
		padding: 0;
	}

	/* -------------------------------
	first
	---------------------------------- */
	.first-flow>li {
		margin-right: 0;
	}

	.introWrap div {
		width: auto;
	}

	.introWrap a {
		position: static;
	}

	.first-apply {
		width: auto;
		margin: 16px 16px;
	}

	.first-apply:last-child {
		margin-right: 16px;
	}

	.first-apply>p {
		float: none;
		width: auto;
	}

	.apply-cercle {
		position: static;
		margin-left: 0;
		margin-top: 8px;
		border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
		-webkit-transform: none;
	   -moz-transform: none;
	    -ms-transform: none;
	     -o-transform: none;
	        transform: none;
	    width: auto;
	    height: auto;
	}

	.apply-cercle br {
		display: none;
	}

	.apply-cercle>a,.topchou {
		padding: 8px !important;
	}

	.apply-ichiran div {
		float: none;
		width: auto;
		margin-bottom: 24px;
	}
	/* -------------------------------
		 640px以下スタイル-end-
	---------------------------------- */

}
































































































