@charset "utf-8";

@media only screen and (max-width:991px) {}
@media only screen and (max-width:767px) {}
@media only screen and (max-width:374px) {}

/*************************************************

 specialtalk page common

*************************************************/
.wrap1400 {
	max-width: 1400px;
	margin-right: auto;
	margin-left: auto;
}



/* index
--------------------------------------*/



/*************************************************

 mainVisual

*************************************************/
.mainVisual {
	box-sizing: border-box;
	max-width: 1400px;
	margin: 50px auto 0;
	padding-right: 180px;
}
.mainVisual .inner {
	position: relative;
	max-width: 1170px;
	padding-top: 160px;
}
.mainVisual .title {
	position: absolute;
	top: 0;
	right: 0;
	font-size: 60px;
	z-index: 2;
}
.mainVisual .inflex {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
.mainVisual .photo {
	width: calc(100% - 230px);
}
.mainVisual .info {
	box-sizing: border-box;
	width: 230px;
	padding-left: 40px;
}
.mainVisual .info dl + dl {
	margin-top: 30px;
}
.mainVisual .info dt {
	margin-bottom: 5px;
	font-size: 18px;
	font-weight: 500;
}
.mainVisual .info dt small {
	font-size: 12px;
}
.mainVisual .info dd {
	font-size: 12px;
	line-height: 1.5;
}
@media only screen and (max-width:1150px) and (min-width:768px) {
	.mainVisual .inner {
		padding-top: 15%;
	}
	.mainVisual .title {
		font-size: calc(45 / 1050 * 100vw);
	}
}
@media only screen and (max-width:767px) {
	.mainVisual {
		margin-top: 20px;
		padding-right: 0;
	}
	.mainVisual .inner {
		padding-top: 0;
	}
	.mainVisual .title {
		position: relative;
		/* margin: 0 calc(20 / 390 * 100vw); */
		/* font-size: calc(23 / 390 * 100vw); */
		margin: 0 20px;
		font-size: 30px;
		z-index: 2;
	}
	.mainVisual .title br {
		display: none;
	}
	.mainVisual .inflex {
		display: block;
	}
	.mainVisual .photo {
		width: auto;
		/* margin-top: calc(18 / 390 * -100vw); */
		margin-top: -23px;
	}
	.mainVisual .photo img {
		width: 100%;
	}
	.mainVisual .info {
		width: auto;
		padding: 30px 20px 0;
	}
}

@media only screen and (min-width:1590px) {
	#specialtalk01 .mainVisual .title {
		right: -160px;
	}
}
@media only screen and (min-width:1590px) {
	#specialtalk02 .mainVisual .title {
		right: -170px;
	}
}



/*************************************************

 theme common

*************************************************/
[class^="theme0"] .title {
	margin-bottom: 70px;
	color: #81B2B2;
}
[class^="theme0"] .title small {
	display: block;
	margin-bottom: 25px;
	font-size: 14px;
}
[class^="theme0"] .title span {
	display: block;
	font-size: 26px;
}
[class^="theme0"] .conversation li {
	display: table;
	width: 100%;
	font-size: 14px;
	line-height: 2.571;
	letter-spacing: 0;
}
[class^="theme0"] .conversation li + li {
	margin-top: 2.571em;
}
[class^="theme0"] .conversation li > * {
	box-sizing: border-box;
	display: table-cell;
}
[class^="theme0"] .conversation .name {
	width: 4em;
	font-weight: 700;
}
@media only screen and (max-width:767px) {
	[class^="theme0"] .title {
		margin-bottom: 20px;
		line-height: 1.6;
	}
	[class^="theme0"] .title small {
		margin-bottom: 15px;
		font-size: 14px;
	}
	[class^="theme0"] .photo img {
		width: 100%;
	}
	[class^="theme0"] .conversation {
		line-height: 2;
	}
	[class^="theme0"] .conversation li + li {
		margin-top: 2em;
	}
	[class^="theme0"] .conversation .name {
		width: 3em;
	}
}



/*************************************************

 theme01

*************************************************/
.theme01 {
	margin: 100px auto 200px;
}
.theme01 .inner {
	display: flex;
	justify-content: space-between;
	max-width: 1170px;
	padding-right: 180px;
}
.theme01 .inhead {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: calc(500 / 1170 * 100%);
}
.theme01 .title {
	box-sizing: border-box;
	width: 100%;
	max-width: 375px;
	margin-left: auto;
	padding: 0 20px;
}
.theme01 .photo {
	max-width: 87%;
}
.theme01 .conversation {
	width: calc(670 / 1170 * 100%);
	padding-top: 50px;
}
@media only screen and (max-width:767px) {
	.theme01 {
		margin: 50px auto;
	}
	.theme01 .inner {
		display: block;
		padding-right: 0;
	}
	.theme01 .inhead {
		width: auto;
	}
	.theme01 .title {
		max-width: none;
	}
	.theme01 .photo {
		max-width: none;
	}
	.theme01 .conversation {
		width: auto;
		padding: 30px 20px 0;
	}
}

/*************************************************

 theme02

*************************************************/
.theme02 {
	margin: 100px auto 200px;
}
.theme02 .inner {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	max-width: 1250px;
	margin-left: auto;
	padding-left: 20px;
}
.theme02 .inhead {
	width: calc(610 / 1250 * 100%);
}
.theme02 .conversation {
	width: calc(510 / 1250 * 100%);
}
@media only screen and (max-width:767px) {
	.theme02 {
		margin: 50px auto;
	}
	.theme02 .inner {
		display: block;
		padding-left: 0;
	}
	.theme02 .inhead {
		width: auto;
	}
	.theme02 .conversation {
		width: auto;
		padding: 30px 20px;
	}
}



/*************************************************

 theme03

*************************************************/
.theme03 {
	margin: 100px auto 200px;
}
.theme03 .inner {
	display: flex;
	justify-content: space-between;
	max-width: 1170px;
	padding-right: 180px;
}
.theme03 .inhead {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: calc(500 / 1170 * 100%);
}
.theme03 .title {
	box-sizing: border-box;
	width: 100%;
	max-width: 375px;
	margin-left: auto;
	padding: 0 20px;
}
.theme03 .photo {
	max-width: 87%;
}
.theme03 .conversation {
	width: calc(670 / 1170 * 100%);
}
@media only screen and (max-width:767px) {
	.theme03 {
		margin: 50px auto;
	}
	.theme03 .inner {
		display: block;
		padding-right: 0;
	}
	.theme03 .inhead {
		width: auto;
	}
	.theme03 .inhead .title {
		order: 2;
	}
	.theme03 .inhead .photo {
		margin-bottom: 30px;
		order: 1;
	}
	.theme03 .title {
		max-width: none;
	}
	.theme03 .photo {
		max-width: none;
	}
	.theme03 .conversation {
		width: auto;
		padding: 0 20px;
	}
}


/*************************************************

 column

*************************************************/
.column {
	box-sizing: border-box;
	max-width: 1400px;
	margin: 0 auto;
	padding-right: 180px;
}
.column .ajust {
	max-width: 1070px;
	margin-left: auto;
	padding-left: 20px;
}
.column .inner {
	max-width: 1020px;
}
.column .title {
	margin-bottom: 10px;
	color: #81B2B2;
	font-size: 40px;
}
.column .box {
	display: flex;
	background-color: #ECF2E9;
}
.column .box + .box {
	margin-top: 20px;
}
.column .box .photo {
	width: calc(393 / 1020 * 100%);
}
.column .box .detail {
	box-sizing: border-box;
	align-self: center;
	width: calc(627 / 1020 * 100%);
	padding: 40px 60px;
}
.column .box .detail .area {
	color: #81B2B2;
	font-size: 16px;
}
.column .box .detail .name {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	margin-bottom: 10px;
	color: #81B2B2;
	font-size: 30px;
}
.column .box .detail .name span {
	display: block;
	margin-left: 0.3em;
	font-size: 22px;
}
.column .box .detail .name small {
	display: block;
	font-size: 16px;
}
.column .box .detail .txt {
	font-size: 14px;
	letter-spacing: 0;
	line-height: 2.2;
}
@media only screen and (max-width:767px) {
	.column {
		padding: 0 20px;
	}
	.column .ajust {
		padding-left: 0;
	}
	.column .inner {
		max-width: none;
	}
	.column .title {
		font-size: 30px;
	}
	.column .box {
		display: block;
		padding: 20px 20px 30px;
	}
	.column .box .photo {
		width: auto;
	}
	.column .box .photo img {
		width: 100%;
	}
	.column .box .detail {
		width: auto;
		margin-top: 20px;
		padding: 0;
	}
	.column .box .detail .area {
		font-size: 14px;
	}
	.column .box .detail .name {
		font-size: 26px;
	}
	.column .box .detail .name span {
		font-size: 20px;
	}
	.column .box .detail .name small {
		font-size: 12px;
	}
}




/*************************************************

 specialTalkBnr

*************************************************/
#specialTalkBnr {
	margin-top: 170px;
	padding: 40px 0;
	background-color: #F4F3F2;
}
#specialTalkBnr .btnsWrap {
	max-width: 1400px;
	margin: 0 auto;
	padding-right: 30px;
}
#specialTalkBnr [class^="isBtn"] {
	position: relative;
	display: block;
	max-width: 1170px;
	color: #000;
	text-decoration: none;
}
#specialTalkBnr [class^="isBtn"] .photo {
	position: relative;
	width: 67.521%;
	height: 333px;
	background: no-repeat center center / cover;
	z-index: 1;
}
#specialTalkBnr [class^="isBtn"] .photo .label {
	position: absolute;
	top: 0;
	left: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 200px;
	height: 40px;
	font-size: 14px;
	background-color: #F4F3F2;
	border-radius: 30px;
	transform: translate(-50%,-50%);
	z-index: 2;
}
#specialTalkBnr [class^="isBtn"] + [class^="isBtn"] {
	margin-top: 70px;
}
#specialTalkBnr .isBtn01 .photo {
	background-image: url(../images/top/special_talk01.jpg);
}
#specialTalkBnr .isBtn02 .photo {
	background-image: url(../images/top/special_talk02.jpg);
}
#specialTalkBnr [class^="isBtn"] .texts {
	position: absolute;
	top: 50%;
	right: 0;
	width: 445px;
	font-size: 30px;
	transform: translateY(-50%);
	z-index: 2;
}
#specialTalkBnr [class^="isBtn"] .texts .inbtn {
	position: relative;
	display: table;
	margin: 25px 0 0 auto;
	padding-right: 23px;
	color: #000;
	text-decoration: underline;
	transition: color 0.2s;
	font-size: 22px;
}
#specialTalkBnr [class^="isBtn"] .texts .inbtn:before,
#specialTalkBnr [class^="isBtn"] .texts .inbtn:after {
	position: absolute;
	top: 0;
	right: 0;
	display: block;
	content: '';
	width: 13px;
	height: 100%;
	background: no-repeat center center / 100% auto;
	transition: opacity 0.2s;
}
#specialTalkBnr [class^="isBtn"] .texts .inbtn:before {
	background-image: url(../images/common/icon_arrow.svg);
}
#specialTalkBnr [class^="isBtn"] .texts .inbtn:after {
	background-image: url(../images/common/icon_arrow_g.svg);
	opacity: 0;
}

@media only screen and (min-width:768px) {
	#specialTalkBnr [class^="isBtn"] .texts .inbtn:hover {
		color: #81B2B2;
	}
	#specialTalkBnr [class^="isBtn"] .texts .inbtn:hover:before {
		opacity: 0;
	}
	#specialTalkBnr [class^="isBtn"] .texts .inbtn:hover:after {
		opacity: 1;
	}
}

@media only screen and (max-width:767px) {
	#specialTalkBnr {
		padding: 50px 0;
	}
	#specialTalkBnr .btnsWrap {
		padding-right: 0;
	}
	#specialTalkBnr [class^="isBtn"] {
		position: relative;
		display: block;
		max-width: 1170px;
		color: #000;
		text-decoration: none;
	}
	#specialTalkBnr [class^="isBtn"] .photo {
		width: auto;
		height: auto;
		background: none;
	}
	#specialTalkBnr [class^="isBtn"] + [class^="isBtn"] {
		margin-top: 80px;
	}
	#specialTalkBnr [class^="isBtn"] .photo img {
		width: 100%;
	}
	#specialTalkBnr [class^="isBtn"] .texts {
		position: static;
		width: auto;
		padding: 20px 20px 0;
		font-size: 22px;
		transform: translateY(0);
	}
	#specialTalkBnr [class^="isBtn"] .texts .inbtn {
		margin: 15px 0 0;
		font-size: 18px;
	}
}
