@charset "utf-8";

html {
	overflow-y: scroll;
	-webkit-text-size-adjust: none;
	-ms-touch-action: manipulation;
	touch-action: manipulation;
	font-size: 62.5%;
}

html,body{
	width: 100%;
	height: 100%;
}

body {
	color: #212121;
	background: #fff;
	margin: 0px;
	padding: 0px;
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', "メイリオ", "Meiryo", "Yu Gothic Medium", "游ゴシック Medium", "ＭＳ Ｐゴシック", sans-serif;
	font-size: 1.0rem;
	line-height: 1.5;
	text-align: center;
}

article, aside, dialog, figure, footer, header, hgroup, nav, section, main {
	display: block;
}

body, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, article, aside, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
	margin: 0px;
	padding: 0px;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

address,caption,cite,code,dfn,em,strong,th,var {
	font-weight: normal;
	font-style: normal;
}

ul, ol, li {
	list-style: none;
}

h1, h2, h3, h4, h5, h6 {
	font-size: 100%;
}

h1 {
	font-weight: normal;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

img {
	border-style: none;
	vertical-align: top;
	font-size: 0;
	line-height: 0;
}

a {
	text-decoration: none;
	outline: none;
}

a:focus {
	outline: none;
}

/*----- .clearfix -----*/

.clearfix:after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
	height: 0;
}

/*--------------------------------------------------------------------------*/

@media screen and (min-width: 768px), print and (min-width: 0px) {
	
	.sp {
		display: none;
	}

	/*----- 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 #headerIn {
		margin: 0px auto;
		padding: 0px 10%;
		max-width: 1024px;
	}

	header #headerH {
		text-align: left;
		height: 90px;
		align-items: center;
		display: flex;
		position: relative;
	}

	header #headerH h1 {
		width: 209px;
		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: 21px;
		width: 86px;
		font-size: 0;
		line-height: 0;
	}

	header #headerH h2 img {
		width: 100%;
		height: auto;
	}

	header #contactBt {
		width: 81px;
		right: 86px;
		top: 14px;
		position: absolute;
	}

	header #contactBt a {
		display: block;
	}

	header #contactBt img {
		width: 100%;
		height: auto;
	}

	header #menuBt {
		width: 32px;
		right: 0px;
		top: 34px;
		position: absolute;
	}

	header #menuBt a {
		width: 32px;
		height: 22px;
		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: 4px;
		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: 9px;
		transform: rotate(45deg);
	}

	header.open #menuBt a::after {
		bottom: 9px;
		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: 90px;
		position: absolute;
	}

	header.open #gNavi {
		width: 100%;
		height: auto;
		opacity: 1;
		transition-duration: 0.5s,0s,0s;
		transition-delay: 0s,0s,0s;
	}

	header #gNavi nav {
		padding: 18px 0px 0px;
		position: relative;
	}

	header #gNavi nav::before {
		content: "";
		width: 100%;
		height: 16px;
		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 > ul {
		margin: 0px -1px;
		flex-wrap: wrap;
		display: flex;
	}

	header #gNavi nav > ul > li {
		margin: 0px 1px 2px;
		width: calc(33.33% - 2px);
	}

	header #gNavi nav > ul > li.liW {
		width: calc(50% - 2px);
	}

	header #gNavi nav > ul > li.liQ {
		width: calc(25% - 2px);
	}

	header #gNavi nav > ul > li > a {
		height: 100%;
		background: rgba(198,178,158,0.7);
		color: #fff;
		display: block;
		transition-property: background;
		transition-duration: 0.5s;
	}

	header #gNavi nav > ul > li > a:hover {
		background: linear-gradient(to right, #ff6900 0%, #ff0066 50%, #ff6bbd 100%);
	}

	header #gNavi nav > ul > li > a dl {
		padding: 19px 30px 19px 20px;
		background: url("../img/arr_nav.svg") no-repeat right 22px center / 8px auto;
		box-sizing: border-box;
	}

	header #gNavi nav > ul > li > a > dl dt {
		margin: 0px 0px 5px;
		font-family: 'Oswald', sans-serif;
		font-size: 1.4rem;
		font-weight: 500;
		line-height: 1.2;
	}

	header #gNavi nav > ul > li > a > dl dd {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.2;
		letter-spacing: -0.05em;
	}

	header #gNavi nav > ul > li.liW > a dl {
		padding: 19px 34px 19px 22px;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		height: 100%;
		min-height: 75px;
	}

	header #gNavi nav > ul > li.liW > a dl dt {
		margin: 0px 5px 0px 0px;
	}

	/*----- footer -----*/

	footer ul {
		flex-wrap: wrap;
		display: flex;
	}

	footer ul li {
		margin-right: 20px;
		padding-right: 20px;
		border-right-width: 1px;
		border-right-style: solid;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	footer ul li:last-of-type {
		margin-right: 0px;
		padding-right: 0px;
		border-right: none;
	}

	#ftNav {
		background-color: #218D53;
	}

	#ftNav > div {
		margin: 0px auto;
		padding: 0px 10%;
		max-width: 1024px;
	}

	#ftNav ul {
		padding: 0px 40px;
		height: 75px;
		align-items: center;
	}

	#ftNav ul li {
		border-color: #fff;
		color: #fff;
	}

	#ftNav ul li a {
		color: #fff;
	}

	#ftMain {
		background-color: #f4f0e7;
	}

	#ftMain > div {
		margin: 0px auto;
		padding: 30px 10% 10px;
		max-width: 1024px;
		display: flex;
	}

	#ftMain figure {
		margin: 0px 30px 0px 40px;
		width: 144px;
	}

	#ftMain figure img {
		width: 100%;
		height: auto;
		vertical-align: top;
	}

	#ftMain dl {
		margin-right: 40px;
		flex: 1;
		color: #686868;
	}

	#ftMain a {
		color: #686868;
	}

	#ftMain dl dt {
		font-size: 1.6rem;
		font-weight: bold;
		line-height: 1.75;
		text-align: left;
	}

	#ftMain dl dd {
		margin: 0px 0px 28px;
	}

	#ftNav a,
	#ftMain a {
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	#ftNav a:hover,
	#ftMain a:hover {
		opacity: 0.6;
	}

	#ftCopy {
		background: linear-gradient(to left, #ff6900 0%, #ff0066 50%, #ff6bbd 100%);
		position: relative;
	}

	#ftCopy > div {
		margin: 0px auto;
		padding: 15px 10%;
		height: 70px;
		max-width: 1024px;
	}

	#ftCopy p {
		color: #fff;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.3;
		text-align: center;
	}

	#ftCopy p small {
		font-size: 1.0em;
	}

	#ftCopy a {
		color: #fff;
	}

	#pageTop {
		display: none;
		width: 100px;
		position: fixed;
		right: 20px;
		bottom: 90px;
		z-index: 1000;
	}

	#pageTop a {
		display: block;
		width: 96px;
		height: 96px;
		background: linear-gradient(to left, #ff6900 0%, #ff0066 50%, #ff6bbd 100%);
		border: 2px #fff solid;
		border-radius: 50%;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		position: relative;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	#pageTop a:hover {
		opacity: 0.6;
	}

	#pageTop a::after {
		content: "";
		width: 33px;
		height: 20px;
		background-image: url("../img/arr_totop.svg");
		background-repeat: no-repeat;
		background-position: center center;
		background-size: contain;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		top: 50%;
		position: absolute;
		z-index: 1;
		transform: translate(-50%,-50%);
	}

	/*----- 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: 90px 0px 0px;
		padding: 106px 0 100px;
		background: url("../img/bg_rain.png") no-repeat center center / auto auto,
			url("../img/bg_kv.png") no-repeat center center / cover;
	}

	#topKV figure {
		margin: 0px auto;
		width: 362px;
	}

	#topKV figure img {
		width: 100%;
		height: auto;
	}

	#topDsc {
		padding: 20px 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: 2.4rem;
		font-weight: bold;
		line-height: 1.5;
		text-align: center;
	}

	#topPoint {
		background: #f4f0e7;
		z-index: 1;
		position: relative;
		overflow: hidden;
	}

	#topPoint > div {
		padding: 52px 0 42px;
	}

	#topPoint h1,
	#topServ h1 {
		padding: 0 0 24px;
		color: #663c16;
		font-size: 2.4rem;
		font-weight: bold;
		line-height: 1.5;
		text-align: center;
		position: relative;
	}

	#topPoint h1::after,
	#topServ h1::after {
		content: " ";
		width: 240px;
		height: 6px;
		background: #36ccc4;
		display: block;
		left: 50%;
		bottom: 0;
		position: absolute;
		transform: translateX(-50%);
	}

	#topPoint h1 {
		margin: 0 0 36px;
	}

	#topPoint ul {
		margin: 0px auto;
		width: 730px;
		height: 690px;
		position: relative;
	}

	#topPoint ul li {
		width: 382px;
		position: absolute;
	}

	#topPoint ul .point1 {
		left: -36px;
		top: 0;
	}

	#topPoint ul .point2 {
		right: -26px;
		top: 80px;
		transition-delay: 0.2s;
	}

	#topPoint ul .point3 {
		left: 56px;
		top: 351px;
		transition-delay: 0.4s;
	}

	#topPoint ul li img {
		width: 100%;
		height: auto;
	}

	#topServ > div {
		margin: 0px auto;
		padding: 48px 10% 2px;
		max-width: 1024px;
		text-align: left;
	}

	#topServ h1 {
		margin: 0 0 35px;
	}

	#topServ .servSec {
		margin: 0 0 90px;
		background: url("../img/bg_dots_b.png") repeat left top / auto auto;
		align-items: stretch;
		display: flex;
	}

	#topServ .servSec .servSecL {
		width: 324px;
		height: 366px;
		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: 0;
		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 12px;
		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: 12px;
		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: 18px 46px 20px 80px;
		background: #f4f0e7;
		z-index: 1;
		position: relative;
		flex: 1;
	}

	#topServ .servSec.service04 .servSecR {
		padding-top: 90px;
	}

	#topServ .servSec .servSecR h3 {
		margin: 0px auto 28px;
		padding: 20px 0;
		max-width: 304px;
		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;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	#topServ .servSec .servSecR .servLink a:hover {
		opacity: 0.5;
	}

	#topServ .servSec .servSecR .servLink a::after {
		content: " ";
		margin: 2px -12px 0 26px;
		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 0px 90px;
		padding: 24px 5%;
		border: 2px #fc638e solid;
	}

	#topServ #topMsg p {
		color: #663c16;
		font-size: 2.4rem;
		font-weight: bold;
		line-height: 5rem;
		text-align: center;
	}

	#topMainVisual {
		margin: 90px 0px 0px;
		background: url("../img/mv_top.jpg") no-repeat center center / cover;
	}

	#topMainVisual > div {
		margin: 0px auto;
		padding: 0px 10%;
		max-width: 1024px;
		height: 630px;
		position: relative;
	}

	#topMainVisual > div h1 {
		padding: 14px;
		color: #fff;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
		left: 50%;
		top: 256px;
		position: absolute;
	}

	#topMainVisual > div h2 {
		width: 100%;
		color: #fff;
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: center;
		left: 0px;
		bottom: 200px;
		position: absolute;
	}

	#topService,
	#topCompany,
	#topInformation,
	#topVoice {
		background-color: #f4f0e7;
	}

	#topService > div,
	#topWorks > div,
	#topCompany > div,
	#topInhouse > div,
	#topInformation > div,
	#topVoice > div {
		margin: 0px auto;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	#topService h1,
	#topWorks h1,
	#topCompany h1,
	#topInhouse h1,
	#topInformation h1,
	#topVoice h1 {
		margin: 0px auto;
		padding: 90px 0px 20px;
		color: #663c16;
		font-family: 'Oswald', sans-serif;
		font-size: 3.6rem;
		font-weight: 500;
		line-height: 1.2;
		text-align: center;
		letter-spacing: 0.3em;
		position: relative;
	}

	#topService h1 {
		margin-bottom: 18px;
	}

	#topWorks h1 {
		margin-bottom: 18px;
	}

	#topCompany h1 {
		margin-bottom: 18px;
	}

	#topInhouse h1 {
		margin-bottom: 18px;
	}

	#topVoice h1 {
		margin-bottom: 18px;
	}

	#topInformation h1 {
		margin-left: 48px;
		margin-bottom: 30px;
		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: -140px;
		width: 280px;
		height: 6px;
		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.4rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: center;
	}

	#topService h2 {
		margin-bottom: 66px;
	}

	#topWorks h2 {
		margin-bottom: 72px;
	}

	#topCompany h2 {
		margin-bottom: 64px;
	}

	#topInhouse h2 {
		margin-bottom: 64px;
	}

	#topVoice h2 {
		margin-bottom: 64px;
	}

	#topServiceMain {
		margin: 0px auto;
		padding: 0px 0px 60px;
		justify-content: center;
		flex-wrap: wrap;
		display: flex;
	}

	#topServiceMain a {
		margin: 0px 15px 50px;
		max-width: 414px;
		width: calc(50% - 30px);
		display: block;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	#topServiceMain a:hover {
		opacity: 0.5;
	}

	#topServiceMain a section {
		padding: 26px;
		background-color: #fff;
		border: 3px #218d53 solid;
		position: relative;
		align-items: center;
		display: flex;
		border-radius: 6px;
	}

	#topServiceMain a section span {
		color: #663c16;
		font-family: 'Oswald', sans-serif;
		font-size: 4.8rem;
		font-weight: 500;
		line-height: 1.1;
		text-align: center;
		display: block;
		left: 26px;
		top: 26px;
		position: absolute;
	}

	#topServiceMain a section h3 {
		padding: 50px 0px;
		color: #212121;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: left;
		flex: 1;
	}

	#topServiceMain a section::after {
		content: "";
		width: 23px;
		height: 23px;
		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 / 8px auto;
		vertical-align: middle;
		left: 26px;
		bottom: 26px;
		position: absolute;
	}

	#topServiceMain a section figure {
		width: 162px;
	}

	#topServiceMain a section figure img {
		width: 100%;
		height: auto;
		vertical-align: top;
	}

	#topWorks .linkW {
		padding: 0px 0px 130px;
	}

	.linkW {
		margin: 0px -8px;
		justify-content: center;
		flex-wrap: wrap;
		display: flex;
	}
	
	.linkW.half {
		justify-content: flex-start;
	}

	.linkW li {
		margin: 0px 8px;
		text-align: center;
		flex: 1;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 2;
	}
	
	.linkW li.service {
		width: calc(100% - 16px);
		margin: 0px 8px;
		flex: none;
	}
	
	.linkW.half li {
		width: calc(50% - 16px);
		margin: 0px 8px;
		flex: none;
	}
	
	.linkW li.service:nth-of-type(n+2) {
		margin: 90px 8px 0px 8px;
	}

	.linkW li a {
		height: 100%;
		padding: 20px;
		box-sizing: border-box;
		color: #663c16;
		background: #98e2b6 url("../img/bg_dots.png") repeat center center / 36px auto;
		display: block;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	.linkW li a:hover {
		opacity: 0.5;
	}
/*
	.linkW li a span {
		padding: 25px 54px 25px 0px;
		background: url("../img/arr_nav.svg") no-repeat right center / 8px auto;
		display: inline-block;
		vertical-align: top;
	}
*/

	.linkW li a div {
		height: 100%;
		background: #fff;
		border: 2px #f9caf6 solid;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.linkW li a div span {
		padding: 30px 15px;
		display: block;
		position: relative;
		vertical-align: middle;
	}

	.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 {
		margin: 0px auto;
		padding: 0px 0px 80px;
		width: 72%;
	}

	#topCompanyMain h3 {
		margin: 0px auto 50px;
		color: #ff4591;
		font-size: 2.4rem;
		font-weight: bold;
		line-height: 1.2;
		text-align: center;
	}

	#topCompanyMain h3 br {
		display: none;
	}

	#topCompanyMain p {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	#topInhouseMain {
		margin: 0px -15px;
		padding: 0px 0px 80px;
	}

	#topInhouseMain ul {
		padding: 0px 0px 18px;
		display: flex;
	}

	#topInhouseMain ul li {
		margin: 0px 15px;
		flex: 1;
	}

	#topInhouseMain ul li a {
		display: block;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	#topInhouseMain ul li a:hover {
		opacity: 0.5;
	}

	#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;
		display: flex;
	}

	#topVoiceMain dl > div {
		margin: 0px 30px;
		padding: 44px 0px 0px;
		border-top: 2px #ff4591 solid;
		position: relative;
		flex: 1;
	}

	#topVoiceMain dl > div::before {
		content: "";
		margin-left: -34px;
		width: 67px;
		height: 33px;
		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: -15px;
		position: absolute;
	}

	#topVoiceMain dl > div dt {
		margin: 0px 0px 4px;
		color: #ff4591;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	#topVoiceMain dl > div dd {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	p.viewmoreBt {
		margin: 50px auto 0px;
		width: 220px;
		font-size: 2.0rem !important;
		font-weight: normal !important;
		line-height: 1.8 !important;
		text-align: center !important;
	}

	p.viewmoreBt a {
		padding: 2px 0px;
		background: linear-gradient(to right, #ff6bbd 0%, #ff0066 100%);
		border-radius: 20px;
		color: #fff;
		display: block;
		position: relative;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	p.viewmoreBt a:hover {
		opacity: 0.5;
	}

	p.viewmoreBt a::after {
		content: "";
		width: 8px;
		height: 14px;
		background-color: #888;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		right: 22px;
		top: 13px;
		position: absolute;
		background: url("../img/arr_nav.svg") no-repeat center center / contain;
	}

	#topInformation {
		padding: 0px 0px 100px;
	}

	#topInformationMain dl {
		margin-left: 48px;
	}

	#topInformationMain dl div {
		padding: 26px 0px 10px;
		border-bottom: 1px #36ccc4 solid;
		align-items: center;
		display: flex;
	}

	#topInformationMain dl div dt,
	#topInformationMain dl div dd {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.3;
		text-align: left;
	}

	#topInformationMain dl div dt {
		width: 140px;
		color: #663c16;
	}

	#topInformationMain dl div dd {
		flex: 1;
	}

	#topInformationMain dl div dd a {
		color: #212121;
		vertical-align: middle;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	#topInformationMain dl div dd a:hover {
		opacity: 0.5;
	}

	#topInformationMain dl div dd a::after {
		content: "";
		margin-left: 12px;
		width: 23px;
		height: 23px;
		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 8px center / 8px auto;
		vertical-align: middle;
	}

	/*----- under -----*/

	#mainHead {
		margin: 90px 0px 32px;
		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 / auto auto;
	}

	#mainHead::after {
	content: "";
	width: 100%;
	height: 16px;
	font-size: 0;
	line-height: 0;
	text-indent: -9999px;
	display: block;
	left: 0px;
	bottom: -16px;
	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 {
		margin: 0px auto;
		padding: 0px 10% 1px;
		max-width: 1024px;
		align-items: stretch;
		display: flex;
	}

	.works #mainHead > div,
	.company #mainHead > div,
	.inhouse #mainHead > div {
		height: 512px;
	}

	.essay #mainHead > div,
	.interview #mainHead > div,
	.policy #mainHead > div,
	.usercomments #mainHead > div,
	.contact #mainHead > div {
		height: 256px;
	}

	#mainHead > div > div {
		margin: 0px;
		width: 50%;
		position: relative;
	}

	/*
	.company #mainHead > div > div::before {
		content: "";
		width: 200%;
		height: 412px;
		background: url("../img/head_company.jpg") no-repeat center center / cover;
		border-radius: 16px;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		top: 50px;
		position: absolute;
	}
	*/
	
	#mainHead > div h1 {
		width: 100%;
		color: #fff;
		font-size: 3.0rem;
		font-weight: bold;
		line-height: 1.2;
		text-align: center;
		left: 0px;
		top: 50%;
		position: absolute;
		transform: translateY(-50%);
	}

	#mainHead > div h1 span {
		margin: 0px auto 20px;
		font-family: 'Oswald', sans-serif;
		font-size: 3.0rem;
		font-weight: 500;
		display: block;
	}

	.mainSec > h1 {
		margin: 0px 0px 30px;
		color: #fff;
		font-size: 2.4rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: center;
	}

	.mainSec > h1 > span {
		margin: 0px auto;
		padding: 20px 10% 21px;
		max-width: 1024px;
		display: block;
		position: relative;
	}

	.mainSec > h1 > span::after {
		content: "";
		margin-left: -30px;
		width: 0px;
		height: 0px;
		border-right: 30px solid transparent;
		border-top-width: 32px;
		border-top-style: solid;
		border-left: 30px solid transparent;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		bottom: -30px;
		position: absolute;
	}

	.mainSec > h1 br {
		display: none;
	}

	.service #mainHead {
		background-color: #f4f0e7;
	}

	.service #mainHead > div h1 {
		padding: 0px 0px 32px;
		color: #663c16;
		top: auto;
		bottom: 50%;
		transform: translateY(0);
	}

	.service #mainHead > div h2 {
		padding: 12px 0px 0px;
		width: 100%;
		color: #212121;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.8;
		text-align: center;
		left: 0px;
		top: 50%;
		position: absolute;
	}

	.service #mainHead > div figure {
		padding: 31px;
		width: 50%;
		box-sizing: border-box;
	}

	.service #mainHead > div figure img {
		width: 100%;
		height: auto;
		vertical-align: top;
		border-radius: 16px;
	}

	.service .mainSec > h1 {
		background-color: #218d53;
	}

	.service .mainSec > h1 > span::after {
		border-top-color: #218d53;
	}

	.serviceSec {
		margin: 0px auto;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	.serviceSec ul {
		margin: 0px -15px;
		padding: 20px 0px 34px;
		display: flex;
	}

	.serviceSec ul li {
		margin: 0px 15px;
		padding: 6px 0px;
		border: 2px #218d53 solid;
		color: #89817c;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
		flex: 1;
	}

	.serviceSec dl {
		margin: 0px 0px 14px;
		padding: 0px 0px 56px 368px;
		min-height: 185px;
		border-bottom: 1px #e6e6e6 solid;
		position: relative;
	}

	.serviceSec dl:last-of-type {
		margin: 0px 0px 0px;
		padding: 0px 0px 90px 368px;
		border-bottom: none;
	}

	.serviceSec dl::before {
		content: "";
		width: 380px;
		height: 202px;
		background: url("../img/balloon.svg") no-repeat center center / contain;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 0px;
		top: 0px;
		position: absolute;
	}

	.serviceSec dl dt {
		width: 260px;
		color: #663c16;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: center;
		left: 60px;
		top: 60px;
		position: absolute;
	}

	.serviceSec dl dd {
		padding: 32px 28px;
		background-color: #f4f0e7;
		color: #212121;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	.serviceNote {
		margin: 0px auto 90px;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	.serviceNote > div {
		padding: 16px 40px;
		border: 2px #ec7a9d solid;
	}

	.serviceNote h1 {
		padding: 0px 0px 18px 40px;
		background: url("../img/icon_note.svg") no-repeat left top / 28px auto;
		color: #dd2668;
		font-size: 2.0rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	.serviceNote ul li,
	.serviceNote p {
		font-size: 1.8rem;
		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 {
		margin: 0px auto;
		padding: 0px 10% 0px;
		max-width: 1024px;
	}

	.serviceBtm .linkW {
		padding: 0px 0px 90px 0px;
	}

	.serviceCom {
		margin: 0px auto;
		padding: 0px 10% 20px;
		max-width: 1024px;
	}

	.serviceComH {
		padding: 50px 14% 40px;
	}

	.serviceComH h2 {
		margin: 0px auto 50px;
		padding: 0px 0px 22px;
		color: #663c16;
		font-size: 2.4rem;
		font-weight: bold;
		line-height: 1.4;
		text-align: center;
		letter-spacing: 0.1em;
		position: relative;
	}

	.serviceComH h2::after {
		content: "";
		margin-left: -120px;
		width: 240px;
		height: 6px;
		background: #36ccc4;
		font-size: 0;
		line-height: 0;
		text-indent: -9999px;
		display: block;
		left: 50%;
		bottom: 0px;
		position: absolute;
	}

	.serviceComH p {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
		letter-spacing: 0.1em;
	}

	.serviceComBox {
		margin: 0px auto 50px;
	}

	.serviceComBoxT {
		align-items: center;
		display: flex;
		z-index: 2;
		position: relative;
	}

	.serviceComBoxT h4 {
		padding: 60px 0px 20px;
		width: 50%;
		color: #663c16;
		font-size: 2.0rem;
		font-weight: normal;
		line-height: 1.5;
		text-align: center;
		position: relative;
	}

	.serviceComBoxT h4::before {
		content: "";
		width: 380px;
		height: 202px;
		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: 55px 0px 20px;
		width: 50%;
		align-items: center;
		display: flex;
	}

	.serviceComBoxT div p {
		margin-right: 12px;
		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: 2.4rem;
		font-weight: bold;
		line-height: 1.2;
		text-align: left;
	}

	.serviceComBoxT div h3 span {
		margin-bottom: 12px;
		font-size: 1.6rem;
		font-weight: normal;
		display: block;
	}

	.serviceComBoxB {
		padding: 60px 45px 35px;
		min-height: 184px;
		background-color: #f4f0e7;
		align-items: flex-start;
		display: flex;
		z-index: 1;
		position: relative;
	}

	.serviceComBoxB p {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.66;
		text-align: left;
		flex: 1;
	}

	.serviceComBoxB dl {
		margin-left: 30px;
		padding: 16px 20px;
		width: 53%;
		background-color: #fff;
		border-top: 3px #218d53 solid;
		box-sizing: border-box;
	}

	.serviceComBoxB dl dt {
		margin-bottom: 6px;
		color: #663c16;
		font-size: 2.4rem;
		font-weight: bold;
		line-height: 1.2;
		text-align: left;
	}

	.serviceComBoxB dl dt span {
		color: #333;
		font-size: 1.4rem;
		font-weight: normal;
	}

	.serviceComBoxB dl dd {
		color: #333;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.9;
		text-align: left;
	}

	.serviceComBoxB dl dd.sub {
		font-size: 1.4rem;
		line-height: 2.1;
	}

	#servicePrice {
		margin: -30px auto 80px;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	#servicePrice > div {
		padding: 25px 45px;
		background-color: #f4f0e7;
		border-top: 3px #218d53 solid;
		align-items: flex-end;
		display: flex;
	}

	#servicePrice #sPriceL {
		margin-right: 30px;
		color: #fd4591;
		font-weight: bold;
		line-height: 1.1;
		text-align: center;
	}

	#servicePrice #sPriceL dt {
		font-size: 2.4rem;
	}

	#servicePrice #sPriceL dd {
		font-family: 'Oswald', sans-serif;
		font-size: 6.4rem;
		letter-spacing: 0.1em;
	}

	#servicePrice #sPriceR {
		padding: 16px 6px;
		background-color: #663c16;
		color: #fff;
		font-weight: normal;
		line-height: 1.3;
		letter-spacing: 0.1em;
		flex: 1;
		align-items: baseline;
		justify-content: center;
		flex-wrap: wrap;
		display: flex;
	}

	#servicePrice #sPriceR dt {
		font-size: 1.6rem;
	}

	#servicePrice #sPriceR dd {
		font-size: 2.4rem;
		font-weight: bold;
	}

	#servicePrice #sPriceR dd:last-of-type {
		color: #fd4591;
		font-size: 1.4rem;
		font-weight: normal;
	}
/*
	.linkContact {
		margin: 0px auto 90px;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	.linkContact a {
		display: block;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	.linkContact a:hover {
		opacity: 0.5;
	}

	.linkContact h1 {
		padding: 16px 10px;
		background-color: #36ccc4;
		color: #fff;
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 1.7;
		text-align: center;
	}

	.linkContact h1::after {
		content: "＞";
		color: #fff;
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 1.7;
		margin-left: 2em;
		display: inline-block;
	}

	.linkContact h1 span {
		font-weight: bold;
		margin-right: 1em;
		display: inline-block;
	}

	.linkContact div {
		padding: 12px 10px;
		border: 3px #36ccc4 solid;
		color: #36ccc4;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.4;
		text-align: center;
	}

	.linkContact div p span {
		font-size: 1.4rem;
		line-height: 1.85;
		display: block;
	}
*/
	.linkContact {
		margin: 0px auto 90px;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	.linkContact > div {
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 2;
		text-align: center;
	}

	.linkContact > div a {
		color: #663c16;
		display: block;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	.linkContact > div a:hover {
		opacity: 0.5;
	}

	.linkContact > div a div {
		padding: 20px;
		background: #abdfef url("../img/bg_dots.png") repeat-x center center / 36px auto;
	}

	.linkContact > div a div span {
		padding: 30px 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 {
		background-color: #2880c9;
	}

	.works .mainSec > h1 > span::after {
		border-top-color: #2880c9;
	}

	.worksSec {
		margin: 0px auto;
		padding: 20px 10% 40px;
		max-width: 1024px;
	}

	.mainSec:last-of-type .worksSec {
		padding-bottom: 120px;
	}

	.worksSec p {
		padding: 0px 0px 30px;
		color: #89817c;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: center;
	}

	.worksSec .listT,
	.worksSec .listW {
		flex-wrap: wrap;
		display: flex;
	}

	.worksSec .listW {
		margin: 0px -30px;
	}

	.worksSec .listT {
		margin: 0px -15px;
	}

	.worksSec .listT li,
	.worksSec .listW li {
		color: #3b47e0;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: left;
	}

	.worksSec .listW li {
		margin: 0px 30px 55px;
		width: calc(50% - 60px);
	}

	.worksSec .listT li {
		margin: 0px 15px 55px;
		width: calc(33.3% - 30px);
	}

	.worksSec .listT li a,
	.worksSec .listW li a {
		color: #3b47e0;
		display: block;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	.worksSec .listT li a:hover,
	.worksSec .listW li a:hover {
		opacity: 0.5;
	}

	.worksSec .listT li img,
	.worksSec .listW li img {
		margin-top: 4px;
		width: 100%;
		height: auto;
		vertical-align: top;
		display: block;
	}

	.inhouse #mainHead > div h1 {
		padding: 0px 0px 32px;
		top: auto;
		bottom: 50%;
		transform: translateY(0);
	}

	.inhouse #mainHead > div h2 {
		padding: 12px 0px 0px;
		width: 100%;
		color: #fff;
		font-size: 1.6rem;
		font-weight: normal;
		line-height: 1.8;
		text-align: center;
		left: 0px;
		top: 50%;
		position: absolute;
	}

	.inhouse .mainSec > h1 {
		background-color: #ffae40;
	}

	.inhouse .mainSec > h1 > span::after {
		border-top-color: #ffae40;
	}

	.inhouseSec {
		margin: 0px auto;
		padding: 20px 10% 90px;
		max-width: 1024px;
	}

	.inhouseT {
		padding: 0px 0px 30px;
		display: flex;
	}

	.inhouseT dl {
		width: 380px;
	}

	.inhouseT dl dt {
		margin: 0px auto 18px;
		padding: 60px 30px;
		width: 380px;
		height: 202px;
		box-sizing: border-box;
		background: url("../img/balloon.svg") no-repeat left top / contain;
		color: #663c16;
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: center;
	}

	.inhouseT dl dd {
		color: #663c16;
		font-family: 'Oswald', sans-serif;
		font-size: 2.4rem;
		font-weight: 500;
		text-align: center;
	}

	.inhouseT dl dd a {
		color: #663c16;
	}

	.inhouseT figure {
		margin: 0px 0px 0px 8px;
		flex: 1;
	}

	.inhouseT figure a {
		display: block;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	.inhouseT figure a:hover {
		opacity: 0.5;
	}

	.inhouseT figure img {
		width: 100%;
		height: auto;
		border: 1px #e6e6e6 solid;
		vertical-align: top;
	}

	.inhouseB {
		padding: 30px;
		background-color: #f4f0e7;
		color: #212121;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.8;
		text-align: left;
	}

	.inhouseBtm {
		margin: 0px auto;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	.inhouseBtm .linkW {
		padding: 0px 0px 80px;
	}

	.usercomments .mainSec,
	#usercommentsFt {
		background-color: #f4f0e7;
	}

	.usercommentsSec {
		margin: 0px auto;
		padding: 90px 10% 10px;
		max-width: 1024px;
	}

	.usercommentsSec dl {
		flex-wrap: wrap;
		display: flex;
	}

	.usercommentsSec dl > div {
		margin: 0px 30px 70px;
		padding: 44px 0px 0px;
		width: calc(50% - 60px);
		border-top: 2px #ff4591 solid;
		position: relative;
	}

	.usercommentsSec dl > div::before {
		content: "";
		margin-left: -34px;
		width: 67px;
		height: 33px;
		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: -15px;
		position: absolute;
	}

	.usercommentsSec dl > div dt {
		margin: 0px 0px 4px;
		color: #ff4591;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	.usercommentsSec dl > div dd {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	.usercommentsBtm {
		margin: 0px auto;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	.usercommentsBtm .linkW {
		padding: 0px 0px 80px;
	}
	
	.company #mainHead > div h1 {
		padding: 35px 0px;
		background-color: rgba(133,106,99,0.4);
	}

	.company .mainSec > h1 {
		background-color: #36ccc4;
	}

	.company .mainSec > h1 > span::after {
		border-top-color: #36ccc4;
	}

	main.company > section:nth-of-type(even) {
		background-color: #f4f0e7;
	}
	
	main.company > section.last {
		margin: 0px 0px 90px 0px;
	}

	.companySec {
		margin: 0px auto;
		padding: 40px 10% 1px;
		max-width: 1024px;
	}

	.companySec h2 {
		margin: 0px auto 0px;
		padding: 0px 0px 30px 0.3em;
		width: 240px;
		box-sizing: border-box;
		color: #663c16;
		font-family: 'Oswald', sans-serif;
		font-size: 3.6rem;
		font-weight: 500;
		line-height: 1.2;
		text-align: center;
		letter-spacing: 0.3em;
		position: relative;
	}

	.companySec h2::after {
		content: "";
		width: 100%;
		height: 6px;
		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: 10px 50px 80px;
		text-align: left;
	}

	.companySec .message h3 {
		margin: 40px 0px 16px;
		color: #ff4591;
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 1.5;
	}

	.companySec .message h3 br {
		display: none;
	}

	.companySec .message p {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
	}

	.companySec .message .name {
		padding: 40px 40px 0px;
		text-align: right;
	}

	.companySec .history {
		padding: 36px 0px 90px;
		justify-content: center;
		flex-wrap: wrap;
		display: flex;
	}

	.companySec .history > section {
		padding: 20px 15px;
		width: calc(100% / 3);
		min-height: 341px;
		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.6rem;
		font-weight: normal;
		line-height: 1.6;
	}

	.companySec .history > section .date {
		margin: 0px auto 16px;
		padding: 0px 0px 16px;
		width: 74%;
		border-bottom: 2px #36ccc4 solid;
		color: #846a62;
		font-size: 2.4rem;
		font-weight: bold;
		line-height: 1.3;
	}

	.companySec .history > section .note {
		padding: 20px 0px 0px 1em;
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.75;
		text-align: left;
		text-indent: -1em;
		display: inline-block;
	}

	.companySec .history > section .note br {
		display: none;
	}

	.companySec .history > section h3 {
		margin: 0px auto 20px;
		color: #846a62;
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 3.0rem;
	}

	.companySec .history > section h3 span {
		font-size: 1.8rem;
		display: block;
	}

	.companySec .profile {
		padding: 36px 0px 110px;
		text-align: left;
	}

	.companySec .profile > section {
		padding: 0px 50px 36px;
		display: flex;
	}

	.companySec .profile > section h3 {
		width: 6em;
		color: #846a62;
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 1.7;
	}

	.companySec .profile > section p,
	.companySec .profile > section ul {
		flex: 1;
	}

	.companySec .profile > section p,
	.companySec .profile > section ul li {
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 1.7;
	}

	.companySec .profile > section a {
		color: #212121;
	}

	.contact .mainSec {
		background-color: #f4f0e7;
	}

	.contactSec {
		margin: 0px auto;
		padding: 30px 10% 110px;
		max-width: 1024px;
		text-align: left;
	}

	.contactSec dl div {
		margin: 0px 0px 40px;
		display: flex;
	}

	.contactSec h2 {
		margin: 0px 0px 30px;
		font-size: 2.4rem;
		font-weight: bold;
		line-height: 1.2;
	}

	.contactSec .errmsg {
		margin: 30px 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: 2.0rem;
		font-weight: normal;
		line-height: 3.0rem;
	}

	.contactSec .reqtxt {
		padding: 20px 0px 20px 48px;
		color: #ff4591;
	}

	.contactSec dl div dt.req,
	.contactSec .reqtxt {
		background: url("../img/icon_req.svg") no-repeat 8px 21px / 28px auto;
	}

	.contactSec dl div dt {
		padding: 20px 0px 20px 48px;
		width: 256px;
		box-sizing: border-box;
	}

	.contactSec dl div dt span {
		margin: 7px 0px 0px;
		display: block;
	}

	.contactSec dl div dd {
		padding: 0px 40px 0px 20px;
		flex: 1;
	}

	.contactSec dl div dd ul {
		padding: 20px 0px 0px;
	}

	.contactSec dl div dd ul li {
		margin: 0px 0px 18px;
	}

	.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: 20px 30px;
		width: 100%;
		border: 1px #e6e6e6 solid;
		border-radius: 0px;
		box-sizing: border-box;
	}

	.contactSec dl div dd textarea {
		height: 490px;
	}

	.contactSec dl div dd ul li input[type="text"] {
		padding: 10px 30px;
	}

	.contactSec dl div dd input[type="radio"],
	.contactSec dl div dd input[type="checkbox"] {
		margin-right: 10px;
	}

	.contactSec dl div dd p {
		padding: 20px 0px;
		color:#000;
		font-weight: bold;
	}

	.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 {
		margin: 0px -16px;
		justify-content: center;
		flex-direction: row-reverse;
		display: flex;
	}

	.contactSec .bt.end {
		padding-top: 50px;
	}

	.contactSec .bt li {
		margin: 0px 16px;
		width: calc(50% - 32px);
	}

	.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: 2.0rem;
		font-weight: normal;
		line-height: 1.2;
		text-align: center;
		display: block;
		cursor: pointer;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	.contactSec .bt li input[type="submit"]:hover,
	.contactSec .bt li input[type="button"]:hover {
		opacity: 0.5;
	}

	.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 > span::after {
		border-top-color: #ffae40;
	}

	.policySec {
		margin: 0px auto;
		padding: 30px 10% 50px;
		max-width: 1024px;
		text-align: left;
	}

	.policySec dl {
		padding: 0px 50px;
	}

	.policySec dl dt {
		color: #218D53;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 1.75;
	}

	.policySec dl dt a {
		color: #EC7A9D;
	}

	.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.8rem;
		font-weight: normal;
		line-height: 1.75;
	}

	.essay .mainSec > h1 {
		background-color: #ffae40;
	}

	.essay .mainSec > h1 > span::after {
		border-top-color: #ffae40;
	}

	.essaySec {
		margin: 0px auto;
		padding: 30px 10% 90px;
		max-width: 1024px;
		text-align: left;
	}

	.essayH {
		padding: 7px 0px 6px;
		background-color: #f4f0e7;
		border-bottom: 8px #bedd4b solid;
		align-items: center;
		display: flex;
	}

	.essayH > div {
		flex: 1;
	}

	.essayH h2 {
		margin: 0px auto;
		padding: 60px 30px;
		width: 380px;
		height: 202px;
		box-sizing: border-box;
		background: url("../img/balloon.svg") no-repeat left top / contain;
		color: #663c16;
		font-size: 2.1rem;
		font-weight: normal;
		line-height: 1.75;
		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.8rem;
		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;
		transition-property: opacity;
		transition-duration: 0.5s;
	}

	.essayM ul li a:hover {
		opacity: 0.7;
	}

	.essayM ul li a::after {
		content: "";
		width: 23px;
		height: 23px;
		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 / 8px auto;
		right: 32px;
		bottom: 26px;
		position: absolute;
	}

	.essayM ul li dl {
		padding: 24px 64px 24px 48px;
		display: flex;
	}

	.essayM ul li dl dt {
		color: #663c16;
	}

	.essayM ul li dl dt.no {
		width: 74px;
	}

	.essayM ul li dl dt.date {
		width: 140px;
	}

	.essayM ul li dl dd {
		color: #212121;
		flex: 1;
	}

	.essayBtm {
		margin: 0px auto;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	.essayBtm .linkW {
		padding: 0px 0px 90px;
	}

	.interview .mainSec > h1 {
		background-color: #ffae40;
	}

	.interview .mainSec > h1 > span::after {
		border-top-color: #ffae40;
	}

	.interviewSec {
		margin: 0px auto;
		padding: 30px 10% 0px;
		max-width: 1024px;
		text-align: left;
	}

	.interviewH {
		margin: 0px 0px 65px;
		padding: 0px 32px 0px 48px;
		background-color: #f4f0e7;
		border-bottom: 8px #218d53 solid;
		display: flex;
	}

	.interviewH > div {
		padding: 28px 0px 28px;
		flex: 1;
		text-align: left;
	}

	.interviewH h2 {
		margin: 0px 0px 28px;
		color: #663c16;
		font-size: 3.2rem;
		font-weight: bold;
		line-height: 1.5;
	}

	.interviewH p {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.7;
	}

	.interviewH > dl {
		padding: 200px 0px 28px;
		width: 388px;
		position: relative;
	}

	.interviewH dl dt {
		margin: 0px auto;
		padding: 60px 30px;
		width: 380px;
		height: 202px;
		box-sizing: border-box;
		background: url("../img/balloon.svg") no-repeat left top / contain;
		color: #218d53;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.67;
		text-align: center;
		right: 4px;
		top: 20px;
		position: absolute;
	}

	.interviewH dl dd {
		margin: 0px auto;
		width: 320px;
	}

	.interviewH dl dd img {
		width: 100%;
		height: auto;
		vertical-align: top;
	}

	.interviewM h3 {
		padding: 16px 32px 16px 48px;
		background-color: #d5d1c7;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.77;
	}

	.interviewM > div {
		padding: 36px 32px 48px 48px;
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.66;
	}

	.interviewM > div span {
		margin-right: 1em;
		color: #218d53;
	}

	.interviewBtm {
		margin: 0px auto;
		padding: 0px 10% 1px;
		max-width: 1024px;
	}

	.interviewBtm .linkW {
		padding: 0px 0px 90px;
	}

	.flgP {
		display: block !important;
	}

	.flgS {
		display: none !important;
	}

}
@media screen and (min-width: 768px) and (max-width: 1200px) {
	.interviewH {
		display: block;
	}

	.interviewH > div {
		margin: 0px 0px 15px;
		flex: auto;
	}

	.interviewH > dl {
		margin: 0px auto;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	#topServiceMain {
		display: block;
	}

	#topServiceMain a {
		margin: 0px auto 50px;
		max-width: 414px;
		width: 100%;
	}

	.serviceComBoxT {
		display: block;
	}

	.serviceComBoxT h4 {
		width: 100%;
	}

	.serviceComBoxT div {
		width: 100%;
		justify-content: center;
	}

	.serviceComBoxB {
		display: block;
	}

	.serviceComBoxB p {
		flex: none;
	}

	.serviceComBoxB dl {
		margin-top: 20px;
		margin-left: 0px;
		width: auto;
	}

}
@media screen and (min-width: 1024px) {
	#pageTop {
		width: 100px;
		left: 50%;
		margin: 0px 0px 0px 412px;
	}
}