@charset "utf-8";

@media screen and (max-width: 767px) {
	
	.sp {
		display: block;
	}
	
	/*----- common -----*/
	
	header {
		width: 100%;
		background-color: #fff;
		left: 0px;
		top: 0px;
		z-index: 5000;
		position: fixed;
	}
	
	header.sc {
		box-shadow: 0px 1px 4px 2px #C6B29E;
	}
	
	header #headerH {
		padding: 0px 13px 0px 16px;
		text-align: left;
		height: 64px;
		align-items: center;
		display: flex;
		position: relative;
	}
	
	header #headerH h1 {
		width: 105px;
		font-size: 0;
		line-height: 0;
	}
	
	header #headerH h1 a {
		display: block;
	}
	
	header #headerH h1 img {
		width: 100%;
		height: auto;
	}
	
	header #headerH h2 {
		margin-left: 6px;
		width: 48px;
		font-size: 0;
		line-height: 0;
	}
	
	header #headerH h2 img {
		width: 100%;
		height: auto;
	}
	
	header #contactBt {
		width: 49px;
		right: 53px;
		top: 7px;
		position: absolute;
	}
	
	header #contactBt a {
		display: block;
	}
	
	header #contactBt img {
		width: 100%;
		height: auto;
	}
	
	header #menuBt {
		width: 16px;
		right: 19px;
		top: 26px;
		position: absolute;
	}
	
	header #menuBt a {
		width: 16px;
		height: 12px;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		overflow: visible;
		display: block;
		position: relative;
	}
	
	header #menuBt a::before,
	header #menuBt a::after {
		content: " ";
		width: 100%;
		height: 2px;
		background: #c6b29e;
		display: block;
		left: 0;
		position: absolute;
		transition-duration: 0.5s;
	}
	
	header #menuBt a::before {
		top: 0;
	}
	
	header #menuBt a::after {
		bottom: 0;
	}
	
	header.open #menuBt a::before {
		top: 5px;
		transform: rotate(45deg);
	}
	
	header.open #menuBt a::after {
		bottom: 5px;
		transform: rotate(-45deg);
	}
	
	
	header #gNavi {
		width: 0px;
		height: 0px;
		opacity: 0;
		transition-property: opacity,width,height;
		transition-duration: 0.5s,0s,0s;
		transition-delay: 0s,0.5s,0.5s;
		overflow: hidden;
		left: 0px;
		top: 64px;
		position: absolute;
	}
	
	header.open #gNavi {
		width: 100%;
		height: calc(100vh - 64px);
		opacity: 1;
		transition-duration: 0.5s,0s,0s;
		transition-delay: 0s,0s,0s;
		overflow-y: scroll;
	}
	
	header #gNavi nav {
		padding: 10px 0px 8px;
		position: relative;
	}

	header #gNavi nav::before {
		content: "";
		width: 100%;
		height: 8px;
		background: linear-gradient(to left, #ff6900 0%, #ff0066 50%, #ff6bbd 100%);
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		top: 0px;
		position: absolute;
	}

	header #gNavi nav::after {
		content: "";
		width: 100%;
		height: 8px;
		background: linear-gradient(to right, #ff6900 0%, #ff0066 50%, #ff6bbd 100%);
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		bottom: 0px;
		position: absolute;
	}

	header #gNavi nav > ul > li {
		margin: 0px 0px 2px;
		width: 100%;
	}
	
	header #gNavi nav > ul > li > a {
		background: rgba(198,178,158,0.9);
		color: #fff;
		display: block;
	}
	
	header #gNavi nav > ul > li > a dl {
		padding: 10px 30px 14px 24px;
		background: url("../img/arr_nav.svg") no-repeat right 18px center / 6px auto;
	}
	
	header #gNavi nav > ul > li > a > dl dt {
		margin: 0px 0px 8px;
		color: #89817c;
		font-family: 'Oswald', sans-serif;
		font-size: 1.1rem;
		font-weight: 500;
		line-height: 1.2;
	}
	
	header #gNavi nav > ul > li > a > dl dd {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.2;
	}
	
	/*----- footer -----*/
	
	footer ul {
	}
	
	footer ul li {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 2.0;
		text-align: left;
	}
	
	#ftNav {
		background-color: #218D53;
	}
	
	#ftNav ul {
		padding: 0px 0px;
		height: 72px;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	
	#ftNav ul li {
		margin-right: 20px;
		padding-right: 20px;
		border-right-width: 1px;
		border-right-style: solid;
		border-color: #fff;
		color: #fff;
	}
	
	#ftNav ul li:last-of-type {
		margin-right: 0px;
		padding-right: 0px;
		border-right: none;
	}
	
	#ftNav ul li a {
		color: #fff;
	}
	
	#ftMain {
		background-color: #f4f0e7;
	}
	
	#ftMain > div {
		padding: 32px 25px 25px;
	}
	
	#ftMain figure {
		margin: 0px auto 32px;
		width: 144px;
	}
	
	#ftMain figure img {
		width: 100%;
		height: auto;
		vertical-align: top;
	}
	
	#ftMain dl {
		color: #686868;
	}
	
	#ftMain a {
		color: #686868;
	}
	
	#ftMain dl dt {
		font-size: 1.4rem;
		font-weight: bold;
		line-height: 2.0;
		text-align: left;
	}
	
	#ftMain dl dd {
		margin: 0px 0px 32px;
	}
	
	#ftCopy {
		background: linear-gradient(to left, #ff6900 0%, #ff0066 50%, #ff6bbd 100%);
		position: relative;
	}
	
	#ftCopy > div {
		padding: 16px 0px 4px;
	}
	
	#ftCopy p {
		color: #fff;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
	}
	
	#ftCopy p small {
		font-size: 1.0em;
	}
	
	#ftCopy a {
		color: #fff;
	}
	
	#pageTop {
		display: none !important;
	}
	
	/*----- top -----*/

	#topKV figure,
	#topPoint .fade {
		opacity: 0;
		transform: translate(0,40px);
	}

	#topKV.loaded figure,
	#topPoint .fade.fadeOn {
		opacity: 1;
		transform: translate(0,0);
		transition-property: opacity,transform;
		transition-timing-function: linear,cubic-bezier(0.215, 0.61, 0.355, 1);
		transition-duration: 0.6s;
	}

	#topKV {
		margin: 64px 0px 0px;
		padding: 69px 0 87px;
		background: url("../img/bg_rain.png") no-repeat center center / 699px auto,
			url("../img/bg_kv.png") no-repeat center center / cover;
	}

	#topKV figure {
		margin: 0px auto;
		width: 266px;
	}

	#topKV figure img {
		width: 100%;
		height: auto;
	}

	#topDsc {
		padding: 24px 0;
		background: #fff;
		z-index: 2;
		position: relative;
	}

	#topDsc::after {
		content: " ";
		width: 0;
		height: 0;
		border-right: 28px solid transparent;
		border-top: 28px solid #fff;
		border-left: 28px solid transparent;
		display: block;
		left: 50%;
		bottom: -27px;
		position: absolute;
		transform: translateX(-50%);
	}
	
	#topDsc h1 {
		color: #fc638e;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 1.5;
		text-align: center;
	}

	#topPoint {
		background: #f4f0e7;
		z-index: 1;
		position: relative;
		overflow: hidden;
	}

	#topPoint > div {
		padding: 56px 0 50px;
		width: 100%;
	}

	#topPoint h1,
	#topServ h1 {
		padding: 0 0 22px;
		color: #663c16;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 3.2rem;
		text-align: center;
		position: relative;
	}

	#topPoint h1::after,
	#topServ h1::after {
		content: " ";
		width: 140px;
		height: 8px;
		background: #36ccc4;
		display: block;
		left: 50%;
		bottom: 0;
		position: absolute;
		transform: translateX(-50%);
	}

	#topPoint h1 {
		margin: 0 0 25px;
	}

	#topPoint ul {
		margin: 0px auto;
		max-width: 560px;
		height: 834px;
		position: relative;
	}

	#topPoint ul li {
		width: 318px;
		position: absolute;
	}

	#topPoint ul .point1 {
		left: -28px;
		top: 0;
	}

	#topPoint ul .point2 {
		right: -19px;
		top: 263px;
		transition-delay: 0.2s;
	}

	#topPoint ul .point3 {
		left: -18px;
		top: 553px;
		transition-delay: 0.4s;
	}

	#topPoint ul li img {
		width: 100%;
		height: auto;
	}

	#topServ > div {
		margin: 0px auto;
		padding: 48px 0 2px;
		max-width: 1024px;
		text-align: left;
	}

	#topServ h1 {
		margin: 0 0 35px;
	}

	#topServ .servSec {
		margin: 0 0 60px;
		background: url("../img/bg_dots_b.png") repeat left top / auto auto;
	}

	#topServ .servSec .servSecL {
		width: 100%;
		height: 360px;
		color: #fff;
		z-index: 2;
		position: relative;
	}

	#topServ .servSec .servSecL::before {
		content: " ";
		width: 357px;
		height: 366px;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: 100% 100%;
		display: block;
		left: 6px;
		top: 0;
		z-index: 2;
		position: absolute;
	}

	#topServ .servSec.service01 .servSecL::before {
		background-image: url("../img/bg_top_s01.png");
	}

	#topServ .servSec.service02 .servSecL::before {
		background-image: url("../img/bg_top_s02.png");
	}

	#topServ .servSec.service03 .servSecL::before {
		background-image: url("../img/bg_top_s03.png");
	}

	#topServ .servSec.service04 .servSecL::before {
		background-image: url("../img/bg_top_s04.png");
	}

	#topServ .servSec .servSecL > div {
		padding: 12px 0 12px 18px;
		z-index: 3;
		position: relative;
		align-items: center;
		display: flex;
	}

	#topServ .servSec .servSecL > div figure {
		margin-right: 18px;
		width: 153px;
		border: 2px #fff solid;
		border-radius: 3px;
		overflow: hidden;
	}

	#topServ .servSec .servSecL > div figure img {
		width: 100%;
		height: auto;
	}

	#topServ .servSec .servSecL > div dl dt,
	#topServ .servSec .servSecL > div dl dd {
		font-family: sans-serif;
		font-weight: bold;
		line-height: 3.2rem;
	}

	#topServ .servSec .servSecL > div dl dt {
		font-size: 2.4rem;
	}

	#topServ .servSec .servSecL > div dl dd {
		font-size: 3.6rem;
	}

	#topServ .servSec .servSecL > div h3 {
		font-size: 2.4rem;
		font-weight: bold;
		line-height: 1.5;
	}

	#topServ .servSec .servSecL h2 {
		margin-left: 18px;
		font-size: 3rem;
		font-weight: bold;
		line-height: 1.6;
		vertical-align: middle;
		z-index: 4;
		position: relative;
	}

	#topServ .servSec .servSecL h2 span {
		margin-left: 1em;
		font-size: 1.8rem;
		display: inline-block;
	}

	#topServ .servSec .servSecR {
		padding: 32px 10px 30px;
		background: #f4f0e7;
		z-index: 1;
		position: relative;
		flex: 1;
	}

	#topServ .servSec .servSecR h3 {
		margin: 0px auto 28px;
		padding: 20px 0;
		width: 100%;
		background: #fff;
		color: #663c16;
		font-family: "メイリオ", "Meiryo", sans-serif;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 3.2rem;
		text-align: center;
	}

	#topServ .servSec .servSecR p {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 3.2rem;
	}

	#topServ .servSec .servSecR .servLink {
		margin: 12px 0 0;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 3.2rem;
		text-align: right;
	}

	#topServ .servSec .servSecR .servLink a {
		color: #663c16;
		align-items: flex-start;
		justify-content: flex-end;
		display: flex;
	}

	#topServ .servSec .servSecR .servLink a::after {
		content: " ";
		margin: 2px 8px 0 20px;
		width: 24px;
		height: 24px;
		background: url("../img/arr_r.svg") no-repeat left 9px center / 8px auto,
			linear-gradient(to right, #ff6900 0%, #ff0066 10%, #ff6bbd 100%);
		border-radius: 50%;
		display: block;
	}

	#topServ .servSec .servSecR .servLink a span {
		display: block;
		flex: 1;
	}

	#topServ #topMsg {
		margin: 0px 10px 60px;
		padding: 24px 8px;
		border: 2px #fc638e solid;
	}

	#topServ #topMsg p {
		color: #663c16;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 3.2rem;
		text-align: center;
	}

	#topMainVisual {
		margin: 64px 0px 0px;
		background: url("../img/mv_top.jpg") no-repeat center center / cover;
	}
	
	#topMainVisual > div {
		padding: 0px 24px;
		height: 440px;
		position: relative;
	}
	
	#topMainVisual > div h1 {
		width: 100%;
		color: #fff;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.3;
		text-align: center;
		left: 0px;
		top: 94px;
		position: absolute;
	}
	
	#topMainVisual > div h2 {
		width: 100%;
		color: #fff;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.7;
		text-align: center;
		left: 0px;
		bottom: 56px;
		position: absolute;
	}
	
	#topService,
	#topCompany,
	#topInformation,
	#topVoice {
		background-color: #f4f0e7;
	}
	
	#topService > div,
	#topWorks > div,
	#topCompany > div,
	#topInhouse > div,
	#topInformation > div,
	#topVoice > div {
		padding: 0px 24px 1px;
	}
	
	#topService h1,
	#topWorks h1,
	#topCompany h1,
	#topInhouse h1,
	#topInformation h1,
	#topVoice h1 {
		margin: 0px auto;
		padding: 60px 0px 20px;
		color: #663c16;
		font-family: 'Oswald', sans-serif;
		font-size: 2.4rem;
		font-weight: 500;
		line-height: 1.2;
		text-align: center;
		letter-spacing: 0.3em;
		position: relative;
	}
	
	#topService h1 {
		margin-bottom: 12px;
	}
	
	#topWorks h1 {
		margin-bottom: 12px;
	}
	
	#topCompany h1 {
		margin-bottom: 12px;
	}
	
	#topInhouse h1 {
		margin-bottom: 12px;
	}
	
	#topVoice h1 {
		margin-bottom: 12px;
	}
	
	#topInformation h1 {
		margin-bottom: 24px;
		text-align: left;
		letter-spacing: 0.2em;
	}
	
	#topService h1::after,
	#topWorks h1::after,
	#topCompany h1::after,
	#topInhouse h1::after,
	#topInformation h1::after,
	#topVoice h1::after {
		content: "";
		margin-left: -98px;
		width: 196px;
		height: 4px;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		bottom: 0px;
		position: absolute;
	}
	
	#topService h1::after {
		background: linear-gradient(to right, #2196e0 0%, #eded4d 50%, #218d53 100%);
	}
	
	#topWorks h1::after {
		background: linear-gradient(to right, #6633ff 0%, #ff0066 50%, #ff6bbd 100%);
	}
	
	#topCompany h1::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	#topInhouse h1::after {
		background: linear-gradient(to right, #fce024 0%, #0fbf3b 50%, #5cc8ff 100%);
	}
	
	#topVoice h1::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	#topInformation h1::after {
		margin-left: 0px;
		background: #36ccc4;
		left: 0px;
	}
	
	#topService h2,
	#topWorks h2,
	#topCompany h2,
	#topInhouse h2,
	#topVoice h2 {
		margin: 0px auto;
		font-size: 1.2rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: center;
	}
	
	#topService h2 {
		margin-bottom: 30px;
	}
	
	#topWorks h2 {
		margin-bottom: 30px;
	}
	
	#topCompany h2 {
		margin-bottom: 30px;
	}
	
	#topInhouse h2 {
		margin-bottom: 24px;
	}
	
	#topVoice h2 {
		margin-bottom: 40px;
	}
	
	#topServiceMain {
		padding: 0px 0px 34px;
	}
	
	#topServiceMain a {
		margin: 0px auto 24px;
		width: 100%;
		max-width: 367px;
		display: block;
	}
	
	#topServiceMain a section {
		padding: 12px;
		background-color: #fff;
		border: 3px #218d53 solid;
		position: relative;
		align-items: flex-start;
		display: flex;
		border-radius: 6px;
	}
	
	#topServiceMain a section span {
		color: #663c16;
		font-family: 'Oswald', sans-serif;
		font-size: 2.4rem;
		font-weight: 500;
		line-height: 1.1;
		text-align: left;
		display: block;
		left: 12px;
		top: 12px;
		position: absolute;
	}
	
	#topServiceMain a section h3 {
		padding: 34px 10px 20px 0px;
		color: #212121;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.3;
		text-align: left;
		flex: 1;
	}
	
	#topServiceMain a section::after {
		content: "";
		width: 16px;
		height: 16px;
		border-radius: 50%;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		background: #ff0f72 url("../img/arr_nav.svg") no-repeat left 6px center / 6px auto;
		vertical-align: middle;
		left: 12px;
		bottom: 12px;
		position: absolute;
	}
	
	#topServiceMain a section figure {
		width: 114px;
	}
	
	#topServiceMain a section figure img {
		width: 100%;
		height: auto;
		vertical-align: top;
	}
	
	#topWorks ul {
		padding: 0px 0px 20px;
	}
	
	.linkW li {
		margin: 0px 0px 30px;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.3;
		text-align: left;
	}
	
	.linkW li a {
		padding: 14px 40px 14px 28px;
		background: #846a62 url("../img/arr_nav.svg") no-repeat right 24px center / 10px auto;
		border-radius: 6px;
		color: #fff;
		display: block;
	}
/*
	.linkW li a div {
		min-height: 2.6em;
		align-items: center;
		display: flex;
	}
*/
	.linkW li {
		font-size: 1.4rem;
		font-weight: bold;
		line-height: 2;
		text-align: center;
	}

	.linkW li a {
		padding: 0;
		color: #663c16;
		background: none;
	}

	.linkW li a div {
		padding: 16px;
		background: #98e2b6 url("../img/bg_dots.png") repeat-x center center / 36px auto;
	}

	.linkW li a div span {
		padding: 24px 15px;
		background: #fff;
		border: 2px #f9caf6 solid;
		display: block;
		position: relative;
	}

	.linkW li a div span::after {
		content: " ";
		margin-left: 15px;
		width: 24px;
		height: 24px;
		background: url("../img/arr_r.svg") no-repeat left 9px center / 8px auto,
			linear-gradient(to right, #ff6900 0%, #ff0066 10%, #ff6bbd 100%);
		border-radius: 50%;
		display: inline-block;
		transform: translateY(4px);
	}

	#topCompanyMain {
		padding: 0px 0px 76px;
	}
	
	#topCompanyMain h3 {
		margin: 0px auto 18px;
		color: #ff4591;
		font-size: 1.6rem;
		font-weight: bold;
		line-height: 1.5;
		text-align: center;
	}
	
	#topCompanyMain p {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}
	
	#topInhouseMain {
		padding: 0px 0px 80px;
	}
	
	#topInhouseMain ul {
		padding: 0px 0px 6px;
	}
	
	#topInhouseMain ul li {
		margin: 0px 0px 24px;
	}
	
	#topInhouseMain ul li:last-of-type {
		margin: 0px 0px 0px;
	}
	
	#topInhouseMain ul li a {
		display: block;
	}
	
	#topInhouseMain ul li img {
		width: 100%;
		height: auto;
		border: 1px #898786 solid;
		vertical-align: top;
	}

	#topVoiceMain {
		padding: 0px 0px 66px;
	}
	
	#topVoiceMain dl {
		padding: 0px 0px 20px;
	}
	
	#topVoiceMain dl > div {
		margin: 0px 0px 80px;
		padding: 24px 0px 0px;
		border-top: 2px #ff4591 solid;
		position: relative;
		flex: 1;
	}
	
	#topVoiceMain dl > div:last-of-type {
		margin: 0px 0px 0px;
	}
	
	#topVoiceMain dl > div::before {
		content: "";
		margin-left: -24px;
		width: 48px;
		height: 24px;
		background: url("../img/icon_voice.svg") no-repeat center center / contain;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		top: -10px;
		position: absolute;
	}
	
	#topVoiceMain dl > div dt {
		margin: 0px 0px 4px;
		color: #ff4591;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: left;
	}
	
	#topVoiceMain dl > div dd {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}
	
	p.viewmoreBt {
		margin: 30px auto 0px;
		width: 202px;
		font-size: 1.5rem !important;
		font-weight: normal !important;
		line-height: 1.8 !important;
		text-align: center !important;
	}

	p.viewmoreBt a {
		padding: 6px 0px 7px;
		background: linear-gradient(to right, #ff6bbd 0%, #ff0066 100%);
		border-radius: 20px;
		color: #fff;
		display: block;
		position: relative;
	}

	p.viewmoreBt a::after {
		content: "";
		width: 6px;
		height: 10px;
		background-color: #888;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		right: 22px;
		top: 15px;
		position: absolute;
		background: url("../img/arr_nav.svg") no-repeat center center / contain;
	}
	
	#topInformation {
		padding: 0px 0px 100px;
	}
	
	#topInformationMain dl div {
		padding: 26px 0px 10px;
		border-bottom: 1px #36ccc4 solid;
	}
	
	#topInformationMain dl div dt,
	#topInformationMain dl div dd {
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: left;
	}
	
	#topInformationMain dl div dt {
		color: #663c16;
	}
	
	#topInformationMain dl div dd a {
		color: #212121;
		vertical-align: middle;
	}
	
	#topInformationMain dl div dd a::after {
		content: "";
		margin-left: 10px;
		width: 18px;
		height: 18px;
		border-radius: 50%;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: inline-block;
		background: #ff0f72 url("../img/arr_nav.svg") no-repeat left 6px center / 6px auto;
		vertical-align: middle;
	}
	
	
	/*----- under -----*/
	
	#mainHead {
		margin: 64px 0px 10px;
		position: relative;
	}
	
	.works.achievements #mainHead {
		background: url("../img/bg_works01.jpg") no-repeat center center / cover;
	}
	
	.works.gadgets #mainHead {
		background: url("../img/bg_works02.jpg") no-repeat center center / cover;
	}
	
	.inhouse #mainHead {
		background: url("../img/bg_inhouse.jpg") no-repeat center center / cover;
	}
	
	.company #mainHead {
		background: url("../img/mv_top.jpg") no-repeat center center / cover;
	}
	
	.essay #mainHead,
	.interview #mainHead,
	.policy #mainHead,
	.usercomments #mainHead,
	.contact #mainHead {
		background: url("../img/bg_mono.jpg") repeat center center / 96px 64px;
	}
	
	#mainHead::after {
	content: "";
	width: 100%;
	height: 8px;
	font-size: 0;
	line-height: 0;
	text-indent: -9999px;
	display: block;
	left: 0px;
	bottom: -6px;
	position: absolute;
	}
	
	.service #mainHead::after {
		background: linear-gradient(to right, #2196e0 0%, #eded4d 50%, #218d53 100%);
	}
	
	.works #mainHead::after {
		background: linear-gradient(to right, #6633ff 0%, #ff0066 50%, #ff6bbd 100%);
	}
	
	.company #mainHead::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	.inhouse #mainHead::after {
		background: linear-gradient(to right, #fce024 0%, #0fbf3b 50%, #5cc8ff 100%);
	}
	
	.usercomments #mainHead::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	.contact #mainHead::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	.policy #mainHead::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	.essay #mainHead::after {
		background: linear-gradient(to right, #fce024 0%, #0fbf3b 50%, #5cc8ff 100%);
	}
	
	.interview #mainHead::after {
		background: linear-gradient(to right, #fce024 0%, #0fbf3b 50%, #5cc8ff 100%);
	}
	
	#mainHead > div {
		padding: 26px 24px 30px;
	}
	
	/*
	.company #mainHead > div > div::after {
		margin: 0px auto 10px;
		content: "";
		width: 225px;
		height: 225px;
		background: url("../img/head_company.jpg") no-repeat center center / auto 288px;
		border-radius: 10px;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
	}
	*/
	
	#mainHead > div h1 {
		padding: 0px 0px 30px;
		width: 100%;
		color: #fff;
		font-size: 2.4rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: center;
	}
	
	#mainHead > div h1 span {
		margin: 0px 0px 16px;
		padding: 0px 0px 12px;
		font-family: 'Oswald', sans-serif;
		font-size: 2.0rem;
		font-weight: 500;
		display: block;
		position: relative;
	}
	
	#mainHead > div h1 span::after {
		content: "";
		margin-left: -70px;
		width: 140px;
		height: 8px;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		bottom: -4px;
		position: absolute;
		}
		
	.service #mainHead > div h1 span::after {
		background: linear-gradient(to right, #2196e0 0%, #eded4d 50%, #218d53 100%);
	}
	
	.works #mainHead > div h1 span::after {
		background: linear-gradient(to right, #6633ff 0%, #ff0066 50%, #ff6bbd 100%);
	}
	
	.company #mainHead > div h1 span::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	.inhouse #mainHead > div h1 span::after {
		background: linear-gradient(to right, #fce024 0%, #0fbf3b 50%, #5cc8ff 100%);
	}
	
	.usercomments #mainHead > div h1 span::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	.contact #mainHead > div h1 span::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	.policy #mainHead > div h1 span::after {
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
	}
	
	.essay #mainHead > div h1 span::after {
		background: linear-gradient(to right, #fce024 0%, #0fbf3b 50%, #5cc8ff 100%);
	}
	
	.interview #mainHead > div h1 span::after {
		background: linear-gradient(to right, #fce024 0%, #0fbf3b 50%, #5cc8ff 100%);
	}
	
	.mainSec > h1 {
		margin: 0px 0px 30px;
		padding: 20px 0px;
		color: #fff;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.6;
		text-align: center;
		position: relative;
	}
	
	.mainSec > h1::after {
		content: "";
		width: 0px;
		height: 0px;
		border-right: 50vw solid transparent;
		border-top-width: 30px;
		border-top-style: solid;
		border-left: 50vw solid transparent;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		bottom: -29.5px;
		position: absolute;
	}
	
	.service #mainHead {
		background-color: #f4f0e7;
	}
	
	.service #mainHead > div h1 {
		color: #663c16;
	}
	
	.service #mainHead > div h2 {
		padding: 0px 0px 30px;
		color: #212121;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
	}
	
	.service #mainHead > div figure {
		margin: 0px auto;
		width: 226px;
	}
	
	.service #mainHead > div figure img {
		width: 100%;
		height: auto;
		vertical-align: top;
		border-radius: 8px;
	}
	
	main.service .mainSec > h1 {
		margin: 0px 0px 0px;
		padding: 20px 0px 0px;
		background-color: #4CA748;
	}
	
	main.service .mainSec > h1::after {
		display: none;
	}
	
	.serviceSec {
		margin: 50px 0px 30px;
		background-color: #f4f0e7;
	}
	
	.serviceSec ul {
		margin: 0px 0px 30px;
		padding: 20px 8px 10px;
		background-color: #4CA748;
		flex-wrap: wrap;
		display: flex;
		position: relative;
	}
	
	.serviceSec ul::after {
		content: "";
		width: 0px;
		height: 0px;
		border-right: 50vw solid transparent;
		border-top-width: 30px;
		border-top-style: solid;
		border-top-color: #4CA748;
		border-left: 50vw solid transparent;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		bottom: -29px;
		position: absolute;
	}
	
	.serviceSec ul li {
		margin: 0px 8px 10px;
		padding: 3px 0px;
		width: calc(50% - 16px);
		background-color: #fff;
		color: #89817c;
		font-size: 1.2rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
	}

	.serviceSec dl {
		position: relative;
	}

	.serviceSec dl:not(:last-of-type) {
		padding: 0px 0px 30px;
	}

	.serviceSec dl::before {
		content: "";
		margin-left: -133px;
		width: 266px;
		height: 143px;
		background: url("../img/balloon.svg") no-repeat center center / contain;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		top: -30px;
		position: absolute;
	}

	.serviceSec dl:not(:last-of-type)::after {
		content: "";
		width: 100%;
		height: 30px;
		background: #fff;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		bottom: 0px;
		position: absolute;
	}

	.serviceSec dl dt {
		margin: 0px auto 50px;
		padding: 10px 0px 0px;
		width: 210px;
		color: #663c16;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
		z-index: 1;
		position: relative;
	}
	
	.serviceSec dl dd {
		padding: 0px 24px 30px;
		color: #212121;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}
	
	.serviceNote {
		margin: 0px 0px 30px;
		padding: 24px 12px 20px;
		background-color: #ec7a9d;
	}
	
	.serviceNote h1 {
		padding: 0px 0px 20px 40px;
		background: url("../img/icon_note.svg") no-repeat left 10px top / 20px auto;
		color: #fff;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: left;
	}
	
	.serviceNote > div > div {
		padding: 12px 18px;
		background-color: #fff;
	}
	
	.serviceNote ul li,
	.serviceNote p {
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}
	
	.serviceNote ul li {
		padding-left: 1em;
		text-indent: -1em;
	}
	
	.serviceNote ul li a,
	.serviceNote p a {
		color: #ec7a9d;
	}

	.serviceBtm {
		padding: 00px 24px 0px;
	}
	
	.serviceCom {
		padding: 30px 16px 1px;
		position: relative;
		overflow: hidden;
	}
	
	.serviceCom::before {
		content: "";
		width: 0px;
		height: 0px;
		border-right: 50vw solid transparent;
		border-top-width: 30px;
		border-top-style: solid;
		border-top-color: #4CA748;
		border-left: 50vw solid transparent;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		top: -1px;
		position: absolute;
	}
	
	.serviceComH {
		padding: 30px 10px 10px;
	}
	
	.serviceComH h2 {
		margin: 0px auto 30px;
		padding: 0px 0px 22px;
		color: #663c16;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 1.6;
		text-align: center;
		position: relative;
	}
	
	.serviceComH h2::after {
		content: "";
		margin-left: -70px;
		width: 140px;
		height: 8px;
		background: #36ccc4;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		bottom: 0px;
		position: absolute;
	}
	
	.serviceComH p {
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
		letter-spacing: 0.1em;
	}
	
	.serviceComBox {
		margin: 0px 0px 30px;
		padding: 10px 0px 0px;
	}
	
	.serviceComBoxT {
		position: relative;
	}
	
	.serviceComBoxT h4 {
		padding: 45px 0px 55px;
		color: #663c16;
		font-size: 1.5rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
		position: relative;
	}
	
	.serviceComBoxT h4::before {
		content: "";
		width: 277px;
		height: 146px;
		background: url(../img/balloon.svg) no-repeat center center / contain;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		top: 0px;
		position: absolute;
		z-index: -1;
		transform: translateX(-50%);
	}
	
	.serviceComBoxT div {
		padding: 0px 0px 10px;
		align-items: center;
		display: flex;
	}
	
	.serviceComBoxT div p {
		margin-right: 10px;
		font-family: 'Oswald', sans-serif;
		color: #fd4591;
		font-size: 6.4rem;
		font-weight: bold;
		line-height: 1.0;
		display: flex;
	}
	
	.serviceComBoxT div h3 {
		color: #663c16;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 1.2;
		text-align: left;
	}
	
	.serviceComBoxT div h3 span {
		margin-bottom: 6px;
		font-size: 1.4rem;
		font-weight: normal;
		display: block;
	}
	
	.serviceComBoxB {
		padding: 20px 16px 30px;
		background-color: #f4f0e7;
	}
	
	.serviceComBoxB p {
		margin-bottom: 12px;
		font-size: 1.5rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}
	
	.serviceComBoxB dl {
		padding: 18px 8px 12px;
		background-color: #fff;
		border-top: 3px #218d53 solid;
		box-sizing: border-box;
	}
	
	.serviceComBoxB dl dt {
		margin-bottom: 12px;
		color: #663c16;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 1.2;
		text-align: right;
	}
	
	.serviceComBoxB dl dt span {
		margin-top: 6px;
		color: #333;
		font-size: 1.0rem;
		font-weight: normal;
		text-align: right;
		display: block;
	}
	
	.serviceComBoxB dl dd {
		color: #333;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.8;
		text-align: left;
	}
	
	#servicePrice {
		margin: 0px 16px 30px;
	}
	
	#servicePrice > div {
		padding: 20px 17px 32px;
		background-color: #f4f0e7;
		border-top: 3px #218d53 solid;
	}
	
	#servicePrice #sPriceL {
		margin-bottom: 20px;
		color: #fd4591;
		font-weight: bold;
		line-height: 1.1;
		text-align: center;
		align-items: center;
		justify-content: center;
		display: flex;
	}
	
	#servicePrice #sPriceL dt {
		margin-right: 12px;
		font-size: 1.6rem;
	}
	
	#servicePrice #sPriceL dd {
		font-family: 'Oswald', sans-serif;
		font-size: 3.6rem;
		letter-spacing: 0.1em;
	}
	
	#servicePrice #sPriceR {
		padding: 12px 17px;
		background-color: #663c16;
		color: #fff;
		font-weight: normal;
		line-height: 1.6;
		letter-spacing: 0.1em;
	}
	
	#servicePrice #sPriceR dt {
		font-size: 1.4rem;
		text-align: left;
	}
	
	#servicePrice #sPriceR dd {
		font-size: 1.8rem;
		font-weight: bold;
		text-align: right;
	}
	
	#servicePrice #sPriceR dd:last-of-type {
		color: #fd4591;
		font-size: 1.0rem;
		font-weight: normal;
		text-align: right;
	}
/*
	.linkContact {
		margin: 0px 16px 30px;
	}
	
	.linkContact a {
		display: block;
	}
	
	.linkContact h1 {
		padding: 12px 46px 6px 16px;
		background-color: #36ccc4;
		color: #fff;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.4;
		text-align: left;
		position: relative;
	}
	
	.linkContact h1::after {
		content: "＞";
		color: #fff;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.7;
		display: block;
		right: 16px;
		top: 50%;
		position: absolute;
		transform: translateY(-50%);
	}
	
	.linkContact h1 span {
		font-size: 2.1rem;
		font-weight: bold;
		margin-bottom: 6px;
		display: block;
	}
	
	.linkContact div {
		padding: 16px 13px;
		border: 3px #36ccc4 solid;
		color: #36ccc4;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}
	
	.linkContact div p span {
		margin-top: 6px;
		font-size: 1.4rem;
		line-height: 1.66;
		display: block;
	}
*/
	.linkContact {
		padding: 0px 24px 30px;
	}

	.linkContact > div {
		font-size: 1.4rem;
		font-weight: bold;
		line-height: 2;
		text-align: center;
	}

	.linkContact > div a {
		color: #663c16;
		display: block;
	}

	.linkContact > div a div {
		padding: 16px;
		background: #abdfef url("../img/bg_dots.png") repeat-x center center / 36px auto;
	}

	.linkContact > div a div span {
		padding: 24px 15px;
		background: #fff;
		border: 2px #f9caf6 solid;
		display: block;
		position: relative;
	}

	.linkContact > div a div span::after {
		content: " ";
		margin-left: 15px;
		width: 24px;
		height: 24px;
		background: url("../img/arr_r.svg") no-repeat left 9px center / 8px auto,
			linear-gradient(to right, #ff6900 0%, #ff0066 10%, #ff6bbd 100%);
		border-radius: 50%;
		display: inline-block;
		transform: translateY(4px);
	}

	.works .mainSec > h1 {
		padding-bottom: 10px;
		background-color: #2880c9;
	}
	
	.works .mainSec > h1::after {
		border-top-color: #2880c9;
	}
	
	.worksSec {
		padding: 20px 12px 20px;
	}
	
	.mainSec:last-of-type .worksSec {
		padding-bottom: 40px;
	}
	
	.worksSec p {
		padding: 0px 12px 20px;
		color: #89817c;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: center;
	}
	
	.worksSec .listT li,
	.worksSec .listW li {
		color: #3b47e0;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.3;
		text-align: left;
	}
	
	.worksSec .listW li,
	.worksSec .listT li {
		margin: 0px 0px 45px;
		width: 100%;
	}
	
	.worksSec .listT li a,
	.worksSec .listW li a {
		color: #3b47e0;
		display: block;
	}
	
	.worksSec .listT li img,
	.worksSec .listW li img {
		margin-top: 8px;
		width: 100%;
		height: auto;
		vertical-align: top;
		display: block;
	}
	
	.inhouse #mainHead > div h2 {
		padding: 0px 0px 30px;
		color: #fff;
		font-size: 1.2rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
	}
	
	.inhouse .mainSec > h1 {
		background-color: #ffae40;
	}
	
	.inhouse .mainSec > h1::after {
		border-top-color: #ffae40;
		z-index: 1;
	}
	
	.inhouse .mainSec {
		background-color: #f4f0e7;
	}
	
	.inhouseSec {
		margin: 0px 37px 30px;
	}
	
	.inhouseT dl {
		margin: -40px 0px 0px;
		padding: 0px 0px 15px;
		position: relative;
		z-index: 2;
	}
	
	.inhouseT dl dt {
		margin: 0px auto 5px;
		padding: 40px 30px;
		width: 268px;
		height: 144px;
		box-sizing: border-box;
		background: url("../img/balloon.svg") no-repeat left top / contain;
		color: #663c16;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
	}
	
	.inhouseT dl dd {
		color: #663c16;
		font-family: 'Oswald', sans-serif;
		font-size: 1.8rem;
		font-weight: 500;
		text-align: center;
	}
	
	.inhouseT dl dd a {
		color: #663c16;
	}
	
	.inhouseT figure {
		margin: 0px 0px 20px;
	}

	.inhouseT figure a {
		display: block;
	}
	
	.inhouseT figure img {
		width: 100%;
		height: auto;
		border: 1px #e6e6e6 solid;
		vertical-align: top;
	}

	.inhouseB {
		padding: 10px 0px 30px;
		color: #212121;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	.inhouseBtm {
		padding: 0px 37px 30px;
	}
	
	.usercomments .mainSec,
	#usercommentsFt {
		background-color: #f4f0e7;
	}
	
	.usercommentsSec {
		padding: 30px 37px 30px;
	}
	
	.usercommentsSec dl > div {
		margin: 0px 0px 80px;
		padding: 24px 0px 0px;
		border-top: 2px #ff4591 solid;
		position: relative;
	}
	
	.usercommentsSec dl > div::before {
		content: "";
		margin-left: -24px;
		width: 48px;
		height: 24px;
		background: url("../img/icon_voice.svg") no-repeat center center / contain;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		top: -10px;
		position: absolute;
	}
	
	.usercommentsSec dl > div dt {
		margin: 0px 0px 4px;
		color: #ff4591;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: left;
	}
	
	.usercommentsSec dl > div dd {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	.usercommentsBtm {
		padding: 0px 37px 1px;
	}
	
	.company .mainSec > h1 {
		padding-bottom: 10px;
		background-color: #36ccc4;
	}
	
	.company .mainSec > h1::after {
		border-top-color: #36ccc4;
	}
	
	.company .last {
		margin: 0px 0px 30px 0px;
	}
	
	main.company > section:nth-of-type(even) {
		background-color: #f4f0e7;
	}
	
	.companySec {
		padding: 30px 37px 0px;
	}
	
	.companySec h2 {
		margin: 0px auto 0px;
		padding: 0px 0px 22px;
		width: 196px;
		color: #663c16;
		font-family: 'Oswald', sans-serif;
		font-size: 2.4rem;
		font-weight: 500;
		line-height: 1.2;
		text-align: center;
		letter-spacing: 0.3em;
		position: relative;
	}
	
	.companySec h2::after {
		content: "";
		width: 100%;
		height: 8px;
		background: linear-gradient(to right, #ffae40 0%, #ffeb61 50%, #ff4591 100%);
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		bottom: 0px;
		position: absolute;
	}
	
	.companySec .message {
		padding: 0px 0px 40px;
		text-align: left;
	}
	
	.companySec .message h3 {
		margin: 40px 0px 16px;
		color: #ff4591;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
	}
	
	.companySec .message p {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}
	
	.companySec .message .name {
		padding: 20px 0px 0px;
		text-align: right;
	}
	
	.companySec .history {
		padding: 10px 0px 35px;
	}
	
	.companySec .history > section {
		padding: 20px 10px;
		min-height: 256px;
		box-sizing: border-box;
		text-align: center;
	}
	
	.companySec .history > section:nth-of-type(odd) {
		background-color: #fff;
	}
	
	.companySec .history > section:nth-of-type(even) {
		background-color: #f4f0e7;
	}
	
	.companySec .history > section p {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.7;
	}
	
	.companySec .history > section .date {
		margin: 0px auto 12px;
		padding: 0px 0px 12px;
		width: 192px;
		border-bottom: 2px #36ccc4 solid;
		color: #846a62;
		font-size: 1.6rem;
		font-weight: bold;
		line-height: 1.3;
	}
	
	.companySec .history > section .note {
		padding: 20px 0px 0px 1em;
		font-size: 1.0rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
		text-indent: -1em;
		display: inline-block;
	}
	
	.companySec .history > section h3 {
		margin: 0px auto 20px;
		color: #846a62;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 2.4rem;
	}
	
	.companySec .history > section h3 span {
		font-size: 1.4rem;
		display: block;
	}
	
	.companySec .profile {
		padding: 36px 0px 54px;
		text-align: left;
	}
	
	.companySec .profile > section {
		padding: 0px 0px 36px;
	}
	
	.companySec .profile > section h3 {
		margin: 0px auto 16px;
		color: #846a62;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: center;
	}
	
	.companySec .profile > section p,
	.companySec .profile > section ul li {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.7;
	}
	
	.companySec .profile > section ul li::after {
		visibility: hidden;
		display: block;
		font-size: 0;
		content: " ";
		clear: both;
		height: 0;
	}
	
	.companySec .profile > section a {
		color: #212121;
	}
	
	.companySec .profile > section a.map {
		display: block;
		float: right;
	}
	
	.contact .mainSec {
		background-color: #f4f0e7;
	}
	
	.contactSec {
		padding: 30px 37px 30px;
		text-align: left;
	}
	
	.contactSec dl div {
		margin: 0px 0px 30px;
	}
	
	.contactSec h2 {
		margin: 0px 0px 20px;
		font-size: 2.0rem;
		font-weight: bold;
		line-height: 1.2;
	}
	
	.contactSec .errmsg {
		margin: 20px 0px 0px;
	}
	
	.contactSec .errmsg li,
	.contactSec p,
	.contactSec dl div dt,
	.contactSec dl div dd,
	.contactSec dl div dd input,
	.contactSec dl div dd textarea {
		font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', "メイリオ", "Meiryo", "Yu Gothic Medium", "游ゴシック Medium", "ＭＳ Ｐゴシック", sans-serif;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 2.4rem;
	}
	
	.contactSec dl div dt {
		font-weight: bold;
	}
	
	.contactSec .reqtxt {
		padding: 0px 0px 20px 30px;
		color: #ff4591;
	}
	
	.contactSec dl div dt.req,
	.contactSec .reqtxt {
		background: url("../img/icon_req.svg") no-repeat 0px 1px / 22px auto;
	}
	
	.contactSec dl div dt {
		padding: 0px 0px 20px 0px;
	}
	
	.contactSec dl div dt.req {
		padding: 0px 0px 20px 30px;
	}
	
	.contactSec dl div dd ul li {
		margin: 0px 0px 14px;
	}
	
	.contactSec dl div dd input[type="email"],
	.contactSec dl div dd input[type="tel"],
	.contactSec dl div dd input[type="url"],
	.contactSec dl div dd input[type="text"],
	.contactSec dl div dd textarea {
		-webkit-appearance: none;
		outline: none;
		padding: 16px 10px;
		width: 100%;
		border: 1px #e6e6e6 solid;
		border-radius: 0px;
		box-sizing: border-box;
	}

	.contactSec dl div dd textarea {
		height: 200px;
	}
	
	.contactSec dl div dd ul li input[type="text"] {
		padding: 10px 10px;
	}
	
	.contactSec dl div dd input[type="radio"],
	.contactSec dl div dd input[type="checkbox"] {
		margin-right: 10px;
	}
	
	.contactSec dl div dd p {
		color:#666;
	}

	.contactSec dl div dd input::-webkit-input-placeholder { /* WebKit, Blink, Edge */
		color:#bfb8b8;
	}
	.contactSec dl div dd input:-ms-input-placeholder { /* Internet Explorer 10-11 */
		color:#bfb8b8;
	}
	.contactSec dl div dd input::placeholder{ /* Others */
		color:#bfb8b8;
	}
	
	.contactSec .bt {
		padding: 0px 0px 1px;
	}
	
	.contactSec .bt.end {
		padding-top: 30px;
	}
	
	.contactSec .bt li {
		margin: 0px 0px 30px;
	}
	
	.contactSec .bt li input[type="submit"],
	.contactSec .bt li input[type="button"] {
		-webkit-appearance: none;
		margin: 0px;
		padding: 25px 20%;
		width: 60%;
		border: none;
		border-radius: 0px;
		outline: none;
		box-sizing: content-box;
		color: #fff;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: center;
		display: block;
	}
	
	.contactSec .bt li input[type="submit"] {
		background: #218d53 url("../img/arr_nav.svg") no-repeat right 18% center / 10px auto;
	}
	
	.contactSec .bt li input[type="button"] {
		background: #846a62 url("../img/arr_nav_r.svg") no-repeat left 18% center / 10px auto;
	}
	
	.policy .mainSec > h1 {
		background-color: #ffae40;
	}
	
	.policy .mainSec > h1::after {
		border-top-color: #ffae40;
		z-index: 1;
	}
	
	.policySec {
		padding: 30px 30px 60px;
		text-align: left;
	}
	
	.policySec dl dt a {
		color: #EC7A9D;
	}
	
	.policySec dl dt {
		color: #218D53;
		font-size: 1.4rem;
		font-weight: bold;
		line-height: 1.75;
	}
	
	.policySec dl dt a:hover {
		opacity: 0.7;
	}
	
	.policySec dl dt a:visited {
		color: #ffa5c1;
	}
	
	.policySec dl dd {
		margin: 0px 0px 1.75em;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
	}
	
	.essay .mainSec > h1 {
		background-color: #ffae40;
	}
	
	.essay .mainSec > h1::after {
		border-top-color: #ffae40;
		z-index: 1;
	}
	
	.essaySec {
		padding: 30px 0px 60px;
		text-align: left;
	}
	
	.essayH {
		padding: 15px 0px 15px;
		background-color: #f4f0e7;
		border-bottom: 8px #bedd4b solid;
	}
	
	.essayH h2 {
		margin: 0px auto 5px;
		padding: 40px 30px;
		width: 268px;
		height: 144px;
		box-sizing: border-box;
		background: url("../img/balloon.svg") no-repeat left top / contain;
		color: #663c16;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
	}
	
	.essayH figure {
		margin: 0px auto;
		width: 100%;
		max-width: 227px;
	}
	
	.essayH figure img {
		width: 100%;
		height: auto;
		vertical-align: top;
	}
	
	.essayM ul li {
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: left;
	}
	
	.essayM ul li:nth-of-type(even) {
		background-color: #f4f0e7;
	}
	
	.essayM ul li a {
		display: block;
		position: relative;
	}
	
	.essayM ul li a::after {
		content: "";
		width: 20px;
		height: 20px;
		border-radius: 50%;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		background: #ff0f72 url("../img/arr_nav.svg") no-repeat left 8px center / 6px auto;
		right: 16px;
		bottom: 16px;
		position: absolute;
	}
	
	.essayM ul li dl {
		padding: 14px 40px 14px 16px;
		flex-wrap: wrap;
		display: flex;
	}
	
	.essayM ul li dl dt {
		margin-right: 1em;
		color: #663c16;
	}
	
	.essayM ul li dl dd {
		color: #212121;
		width: 100%;
	}
	
	.essayBtm {
		padding: 0px 37px 30px;
	}
	
	.interview .mainSec > h1 {
		background-color: #ffae40;
	}
	
	.interview .mainSec > h1::after {
		border-top-color: #ffae40;
		z-index: 1;
	}
	
	.interviewSec {
		padding: 30px 0px 0px;
		text-align: left;
	}
	
	.interviewH {
		margin: 0px 0px 15px;
		padding: 15px 30px 15px;
		background-color: #f4f0e7;
		border-bottom: 8px #218d53 solid;
	}
	
	.interviewH > div {
		padding: 0px 0px 15px;
		text-align: left;
	}
	
	.interviewH h2 {
		margin: 0px 0px 14px;
		color: #663c16;
		font-size: 2.0rem;
		font-weight: bold;
		line-height: 1.5;
	}
	
	.interviewH p {
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.7;
	}
	
	.interviewH > dl {
		padding: 0px 0px 0px;
	}
	
	.interviewH dl dt {
		margin: 0px auto 5px;
		padding: 40px 20px;
		width: 268px;
		height: 144px;
		box-sizing: border-box;
		background: url("../img/balloon.svg") no-repeat left top / contain;
		color: #218d53;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
	}
	
	.interviewH dl dd {
		margin: 0px auto;
		width: 320px;
	}
	
	.interviewH dl dd img {
		width: 100%;
		height: auto;
		vertical-align: top;
	}
	
	.interviewM h3 {
		padding: 8px 16px;
		background-color: #d5d1c7;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.77;
	}
	
	.interviewM > div {
		padding: 16px 32px;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.66;
	}
	
	.interviewM > div span {
		margin-right: 1em;
		color: #218d53;
	}
	
	.interviewBtm {
		padding: 0px 37px 30px;
	}
	
	.flgP {
		display: none !important;
	}
	
	.flgS {
		display: block !important;
	}
	
}
