@charset "utf-8";

/*---------------------------------------------------------------
  富士通フォント
-----------------------------------------------------------------*/
@font-face {
	font-family: FujitsuInfinityPro-Regular;
	src: url(//www.fujitsu.com/fontv51/FujitsuInfinityPro-Regular.eot);
	src: url(//www.fujitsu.com/fontv51/FujitsuInfinityPro-Regular.eot) format("embedded-opentype"), url(//www.fujitsu.com/fontv51/FujitsuInfinityPro-Regular.woff) format("woff"), url(//www.fujitsu.com/fontv51/FujitsuInfinityPro-Regular.ttf) format("truetype")
}

@font-face {
	font-family: FujitsuInfinityPro-RegularB;
	src: url(//www.fujitsu.com/fontv51/FujitsuInfinityPro-Regular.eot);
	src: url(//www.fujitsu.com/fontv51/FujitsuInfinityPro-Regular.eot) format("embedded-opentype"), url(//www.fujitsu.com/fontv51/FujitsuInfinityPro-Regular.woff) format("woff"), url(//www.fujitsu.com/fontv51/FujitsuInfinityPro-Regular.ttf) format("truetype")
}

html:lang(ja) body, html:lang(ja) input, html:lang(ja) select, html:lang(ja) button, html:lang(ja) textarea {
	font-family: FujitsuInfinityPro-Regular, Arial, Verdana, Lucida Grande, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "ヒラギノ角ゴ Pro W3", sans-serif
}


/*---------------------------------------------------------------
  ヘッダー （fjcloud.css オーバーライド）
-----------------------------------------------------------------*/
.fsus_header_wrp *,
.fsus_header_wrp *::before,
.fsus_header_wrp *::after {
	box-sizing: border-box;
}
.fsus_header_wrp {
	background: #3e3a39;
}


.fsus_header_wrp .fsus_header .sitelogo {
	display: inline-block;
	padding: 20px 0 20px;
	vertical-align: top;
}
@media screen and (max-width: 1280px) {
	.fsus_header_wrp .fsus_header .sitelogo {
		width: 100%;
		padding-left: 16px;
		padding-right: 60px;
	}
}
.fsus_header_wrp .fsus_header .sitelogo a {
	text-decoration: none;
	color: #fff;
	font-size: 2.125rem;
	font-weight: 700;
	line-height: 1;
	display: flex;
	align-items: center;
}
.fsus_header_wrp .fsus_header .sitelogo a small {
	padding: 1px 13px 0;
	margin-left: 20px;
	color: #3e3a39;
	font-size: 1.375rem;
	font-weight: 700;
	background: #fff;
	letter-spacing: .05em;
}
.fsus_header_wrp .fsus_header .sitelogo span {
	margin-top: 6px;
	font-size: 0.8125rem;
	font-weight: 700;
}

@media screen and (max-width: 767px) {
	.fsus_header_wrp .fsus_header {
		height: auto !important;
	}
	.fsus_header_wrp .fsus_header .sitelogo a {
		font-size: 1.875rem;
	}
	.fsus_header_wrp .fsus_header .sitelogo a small {
		padding: 1px 6px 1px;
		margin-left: 10px;
		font-size: 1.25rem;
	}
	.fsus_header_wrp .fsus_header .sitelogo span {
		font-size: 0.687rem;
	}
}
@media screen and (max-width: 480px) {
	.fsus_header_wrp .fsus_header {
		height: auto !important;
	}
	.fsus_header_wrp .fsus_header .sitelogo a {
		font-size: calc(16vw * 100/320);
	}
	.fsus_header_wrp .fsus_header .sitelogo a small {
		padding: 1px 6px 1px;
		margin-left: 10px;
		font-size: calc(11vw * 100/320);
	}
	.fsus_header_wrp .fsus_header .sitelogo span {
		font-size: calc(7vw * 100/320);
	}
}

@media only screen and (max-width: 1280px) {
	.fsus_header_wrp .fsus_header .function {
		display: none;
	}
}
.fsus_header_wrp .fsus_header .function ul {
	display: flex;
	align-items: center;
	height: 34px;
	bottom: 0;
	top: 0;
	margin: auto;
}

.fsus_header_wrp .fsus_header .function li {
	margin-left: 20px;
}
.fsus_header_wrp .fsus_header .icon a {
	background-image: url(/image/icon-build);
	background-size: 26px 21px;
	padding-left: 31px;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: inherit;
}
.fsus_header_wrp .fsus_header .icon.corporation {
	background: #fff;
    border-radius: 100vh;
	padding: 0 15px 0 15px;
}
.fsus_header_wrp .fsus_header .icon.corporation a {
	color: #3e3a39;
}
.fsus_header_wrp .fsus_header .icon.guide a,
.fsus_header_wrp .fsus_header .icon.faq a,
.fsus_header_wrp .fsus_header .icon.use a,
.fsus_header_wrp .fsus_header .icon.tos a,
.fsus_header_wrp .fsus_header .icon.user a {
	background: none;
	padding-left: 0;
}
.fsus_header_wrp .fsus_header .icon.login a {
	background-image: url(/image/icon-door);
	background-size: 15px 19px;
	padding-left: 20px;
}
.fsus_header_wrp .fsus_header .icon.user {
}
.fsus_header_wrp .fsus_header .icon.user a {
	padding: 1px 6px 1px 16px;
	border: 1px solid #fff;
	border-radius: 100vh;
}
.fsus_header_wrp .fsus_header .icon.user a.mypage {
	padding: 1px 16px 1px 16px;
}
.fsus_header_wrp .fsus_header .icon.user a small {
	font-size: 0.8125rem;
	font-weight: 700;
}

@media screen and (max-width: 1280px) {
	.fsus_header_wrp .hum_menu, .fsus_header_wrp .hum_menu span {
		display: inline-block;
		transition: all .3s;
		box-sizing: border-box;
	}
	.fsus_header_wrp .hum_menu {
		display: block;
		position: absolute;
		top: 0;
		bottom: 0;
		margin: auto;
		right: 8px;
		width: 50px;
		height: 50px;
	}
	.fsus_header_wrp .hum_menu .menu_icon {
		position: relative;
		z-index: 300;
		padding: 0;
		padding-top: 30px;
		font-size: 12px;
		line-height: 20px;
		width: 100%;
		text-align: center;
	}
	.fsus_header_wrp .hum_menu span {
		position: absolute;
		left:0; right:0;
		margin:auto;
		width: 30px;
		height: 2px;
		background-color: #fff;
		border-radius: 1px;
	}
	.fsus_header_wrp .hum_menu span:nth-of-type(1) {
		top: 5px;
	}
	.fsus_header_wrp .hum_menu span:nth-of-type(2) {
		top: 14px;
	}
	.fsus_header_wrp .hum_menu span:nth-of-type(3) {
		top: 23px;
	}
	.fsus_header_wrp .hum_menu a {
		color: #fff;
		text-decoration: none;
		padding: 0;
		font-size: 100%;
		line-height: 1.4;
		border-bottom: none;
	}
	.fsus_header_wrp .hum_menu a .close {
		display: none;
	}
	.fsus_header_wrp .hum_menu.active a .close {
		display: block;
		color: #fff;
	}
	.fsus_header_wrp .hum_menu.active a .open {
		display: none;
	}
}

.fsus_sp_navigation {
	background: #f6f6f6;
	top: auto !important;
}
.fsus_sp_navigation .fsus_btns_area li a {
	position: relative;
	border-bottom: solid 1px #aaaaab;
	background: none !important;
	padding: 16px 60px 16px 16px;
	line-height: 1;
}
.fsus_sp_navigation .fsus_btns_area li a::before,
.fsus_sp_navigation .fsus_btns_area li a::after {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 16px;
	margin: auto;
	content: "";
	vertical-align: middle;
}
.fsus_sp_navigation .fsus_btns_area li a::before {
	width: 24px;
	height: 24px;
	border: 1px solid #8a8a8a;
	-webkit-border-radius: 50%;
	border-radius: 50%;
}
.fsus_sp_navigation .fsus_btns_area li a::after {
	right: 25px;
	width: 8px;
	height: 8px;
	border-top: 1px solid #8a8a8a;
	border-right: 1px solid #8a8a8a;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.fsus_sp_navigation .fsus_btns_area li a:hover {
	background: #ccc !important;
}


/*---------------------------------------------------------------
  フッター （fjcloud.css オーバーライド）
-----------------------------------------------------------------*/
.footer_copy_wrp *,
.footer_copy_wrp *::before,
.footer_copy_wrp *::after {
	box-sizing: border-box;
}
.footer_copy_wrp .content_width {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.footer_copy_wrp .footer_copy_inner {
	width: 100%;
	display: flex;
	justify-content: space-between;
}
.footer_copy_wrp .footer_link li a {
	font-weight: 700;
	font-size: 0.875rem;
}
.footer_wrp .section.contact .list-contact .notes-a.inquiry_text {
    text-align: left;
}
.footer_wrp .inquiry_link_wrp {
    display: block;
    margin-top: 8px;
}
.footer_wrp .inquiry_link {
	color: #FFF;
    display: flex;
    align-items: center;
	padding-top: 4px;
}
.footer_wrp .copyright {
	margin-left: auto;
	background: none;
	font-size: 0.875rem;
	font-weight: 700;
	text-align: left;
}
.footer_copy_wrp .f-logo {
	padding-bottom: 10px;
	margin-left: 30px;
}
@media screen and (max-width: 800px) {
	.footer_copy_wrp .footer_copy_inner {
		flex-direction: column;
	}
	.footer_wrp .copyright {
		margin: 10px 0 0 0;
	}
	.footer_copy_wrp .f-logo {
		padding-bottom: 0;
		margin-left: 0;
	}
}
@media screen and (max-width: 768px) {
	.footer_copy_wrp .footer_link {
		margin-top: 0;
	}
	.footer_copy_wrp .footer_link li {
		width: inherit;
		margin: 0 20px 0 0;
		font-size: 0.8125rem;
	}
	.footer_wrp .copyright {
		font-size: 0.8125rem;
	}
}

/* クッキー
---------------------------------------------------- */
.cookie-consent .btn-cookie {
    text-align: center;
    margin: 0 0 20px;
    justify-content: flex-end;
    border: none;
    border-radius: inherit;
    display: flex;
    min-width: inherit;
}

/*---------------------------------------------------------------
  共通パーツ
-----------------------------------------------------------------*/
/* ボタン
---------------------------------------------------- */
[class^="btn-"] {
	position:relative;
	padding: 14px 20px 13px 20px;
	color: #000;
	font-size: 1.25rem;
	text-decoration: none;
	text-align: center;
	min-width: 300px;
	background: #fff;
	border: 2px solid #cbcbcb;
	border-radius: 100vh;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
[class^="btn-"] > .text {
    padding-left: 14px;
    font-weight: 700;
    text-align: center;
    flex-grow: 1;
}
.btn-a:hover {
	color: #000;
}
.btn-b {
	padding: 20px 20px 19px 20px;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(49, 43, 129, 1), rgba(3, 183, 234, 1));
	border: transparent;
}
.btn-b.sm {
	padding: 10px 10px 9px 30px;
	min-width: 220px;
	font-size: 1.125rem;
}
@media only screen and (max-width: 480px) {
	.btn-b.sm {
		width: 100%;
		min-width: inherit;
	}
}
.btn-b:hover {
	color: #fff;
}
.btn-c {
	padding: 20px 20px 19px 20px;
	color: #fff;
	background-image: linear-gradient(90deg, rgba(224, 4, 14, 1), rgba(236, 123, 27, 1));
	border: transparent;
}
.btn-c.sm {
	padding: 10px 10px 9px 30px;
	min-width: 220px;
	font-size: 1.125rem;
}
@media only screen and (max-width: 480px) {
	.btn-c.sm {
		width: 100%;
		min-width: inherit;
	}
}
.btn-c:hover {
	color: #fff;
}
.btn-i {
	padding: 10px 20px 9px 10px;
	font-size: 1rem;
	min-width: 300px;
	border: 1px solid #cacaca;
	border-radius: 100vh;
}
.btn-i:hover {
	color: #000;
}
[class^="btn-"] > .desc {
	font-weight: 700;
	flex-grow: 1;
}
.btn-i > .desc {
	font-weight: 400;
}
[class^="btn-"] > .icon {
	position: relative;
	margin-left: 10px;
	display: inline-block;
	width: 40px;
	height: 40px;
	vertical-align: middle;
}
.btn-b > .icon {
	width: 30px;
	height: 30px;
}
.btn-b.sm > .icon {
	width: 20px;
	height: 20px;
}
.btn-c > .icon {
	width: 30px;
	height: 30px;
}
.btn-c.sm > .icon {
	width: 20px;
	height: 20px;
}

.btn-i > .icon {
	width: 13px;
	height: 13px;
	background: url(/image/icon-new-window) no-repeat;
	background-size: cover;
}
.btn-i > .icon.dl {
	width: 14px;
	height: 14px;
	background: url(/image/icon-dl) no-repeat;
	background-size: cover;
}
[class^="btn-"] .icon::before {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	border: 1px solid #5f5f5f;
	opacity: 0;
	z-index:0
}
.btn-i > .icon::before {
	display: none;
}
[class^="btn-"] .icon svg {
	fill: #5f5f5f;
	position: absolute;
	top: 0;
	left:0
}
.btn-b .icon svg .arrow {
	fill: #5097cb;
}
.btn-c .icon svg .arrow {
	fill: #ec691b;
}
[class^="btn-"] .icon svg .circle {
	fill: none;
	stroke: #5f5f5f;
	stroke-width: 1px;
	width: 100%;
	height: 100%;
	-webkit-transform-origin: center;
	-ms-transform-origin: center;
	transform-origin:center
}
.btn-b .icon svg .circle {
	fill: #fff;
	stroke: #fff;
}
.btn-c .icon svg .circle {
	fill: #fff;
	stroke: #fff;
}
[class^="btn-"] .icon svg .arrow {
	-webkit-transform: translateX(0);
	-ms-transform: translateX(0);
	transform: translateX(0);
	-webkit-transition: -webkit-transform .3s ease-in-out;
	transition: -webkit-transform .3s ease-in-out;
	-o-transition: transform .3s ease-in-out;
	transition: transform .3s ease-in-out;
	transition:transform .3s ease-in-out, -webkit-transform .3s ease-in-out
}
a:hover [class^="btn-"] .icon::before {
	opacity:.1
}
a:hover [class^="btn-"] .icon svg .arrow {
	-webkit-animation: arrow 1.5s forwards ease-in-out;
	animation:arrow 1.5s forwards ease-in-out
}
a:hover [class^="btn-"] .icon svg.circle {
	fill: transparent;
	stroke: #5f5f5f;
	stroke-width: 1;
	-webkit-animation: circle 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:circle 2s forwards cubic-bezier(.215, .61, .355, 1)
}
a:hover .btn-b .icon svg.circle {
	fill: #fff;
	stroke: #fff;
}
a:hover .btn-c .icon svg.circle {
	fill: #fff;
	stroke: #fff;
}
a[class^="btn-"]:hover .icon::before {
	opacity: .1;
	-webkit-animation: arrow_bg 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:arrow_bg 2s forwards cubic-bezier(.215, .61, .355, 1)
}
a[class^="btn-"]:hover .icon svg .arrow {
	-webkit-animation: arrow 1.5s forwards ease-in-out;
	animation:arrow 1.5s forwards ease-in-out
}

a[class^="btn-"]:hover .icon svg .circle {
	fill: transparent;
	stroke: #5f5f5f;
	stroke-width: 1;
	-webkit-animation: circle 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:circle 2s forwards cubic-bezier(.215, .61, .355, 1)
}
a.btn-b:hover .icon svg .circle {
	fill: #fff;
	stroke: #fff;
}
a.btn-c:hover .icon svg .circle {
	fill: #fff;
	stroke: #fff;
}

@keyframes arrow_bg {
	0% {
		opacity:.1
	}

	100% {
		opacity:0
	}
}
@keyframes arrow {
	0% {
		opacity: 1;
		-webkit-transform: translateX(0);
		transform:translateX(0)
	}
	10% {
		opacity: 0;
		-webkit-transform: translateX(50%);
		transform:translateX(50%)
	}
	25% {
		opacity: 0;
		-webkit-transform: translateX(-50%);
		transform:translateX(-50%)
	}
	40% {
		opacity: 1;
		-webkit-transform: translateX(0);
		transform:translateX(0)
	}
	100% {
		opacity: 1;
		-webkit-transform: translateX(0);
		transform:translateX(0)
	}
}
@keyframes circle {
	0% {
		stroke-dasharray: 0 300;
		-webkit-transform: rotate(0);
		transform:rotate(0)
	}
	10% {
		stroke-dasharray:50 100
	}
	20% {
		stroke-dasharray:100 200
	}
	30% {
		stroke-dasharray:150 300
	}
	40% {
		stroke-dasharray:200 300
	}
	60% {
		stroke-dasharray: 300 300;
		-webkit-transform: rotate(360deg);
		transform:rotate(360deg)
	}
}

.lyt-btn-a {
	margin-bottom: -16px;
	margin-left: -16px;
	text-align: center;
	display: flex;
	justify-content: center;
}
.lyt-btn-a.left {
	justify-content: flex-start;
}
.lyt-btn-a > li {
	margin-bottom: 16px;
	margin-left: 16px;
}
.lyt-btn-a > li:before {
	display: none;
}
@media only screen and (max-width: 480px) {
	.lyt-btn-a {
		flex-direction: column;
	}
	.lyt-btn-a > li a {
		min-width: inherit;
	}
}
.lyt-btn-a + * {
	margin-top: 34px;
}


.lyt-btn-a.color a {
    background-size: cover!important;
    background: url(/image/FJ_GRAD_H2A_RGB) center bottom no-repeat;
    color: #fff;
	border: none;
}
.lyt-btn-a.color [class^="btn-"] .icon svg {
    fill: #D80084;
    border-radius: 50%;
    background: #fff;
}
.lyt-btn-a.color [class^="btn-"] .icon svg .circle {
    stroke: #fff;
}
.lyt-btn-a.color a:hover [class^="btn-"] .icon svg.circle {
	stroke: #D80084;
}
.lyt-btn-a.color a:hover .btn-b .icon svg.circle {
	fill: #fff;
	stroke: #fff;
}
.lyt-btn-a.color a:hover .btn-c .icon svg.circle {
	fill: #fff;
	stroke: #fff;
}
.lyt-btn-a.color a[class^="btn-"]:hover .icon svg .circle {
	stroke: #fff;
}


/* アイコン付きリンク
---------------------------------------------------- */
.list-link-a {
	text-align: center;
	display: flex;
	justify-content: center;
}
.list-link-a.right {
	justify-content: flex-end;
}
.list-link-a + * {
	margin-top: 34px;
}
.list-link-a > li a {
	position:relative;
	color: #000;
	font-size: 1.25rem;
	text-decoration: none;
	text-align: center;
	display: flex;
	align-items: center;
}
.list-link-a > li a:hover {
	color: #000;
}

.list-link-a.right > li a {
	color: #afafaf;
	font-size: 0.9375rem;
	display: flex;
	align-items: center;
}
.list-link-a > li a .icon {
	position: relative;
	margin-right: 10px;
	display: inline-block;
	width: 40px;
	height: 40px;
	vertical-align: middle;
}
.list-link-a.right > li a .icon {
	margin-right: 8px;
	width: 30px;
	height: 30px;
}

.list-link-a > li a .icon::before {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	border: 1px solid #5f5f5f;
	opacity: 0;
	z-index:0
}
.list-link-a > li a .icon svg {
	fill: #5f5f5f;
	position: absolute;
	top: 0;
	left:0
}
.list-link-a > li a .icon svg .circle {
	fill: none;
	stroke: #5f5f5f;
	stroke-width: 1px;
	width: 100%;
	height: 100%;
	-webkit-transform-origin: center;
	-ms-transform-origin: center;
	transform-origin:center
}
.list-link-a > li a .icon svg .arrow {
	-webkit-transform: translateX(0);
	-ms-transform: translateX(0);
	transform: translateX(0);
	-webkit-transition: -webkit-transform .3s ease-in-out;
	transition: -webkit-transform .3s ease-in-out;
	-o-transition: transform .3s ease-in-out;
	transition: transform .3s ease-in-out;
	transition:transform .3s ease-in-out, -webkit-transform .3s ease-in-out
}
.list-link-a > li a:hover .icon::before {
	opacity:.1
}
.list-link-a > li a:hover .icon svg .arrow {
	-webkit-animation: arrow 1.5s forwards ease-in-out;
	animation:arrow 1.5s forwards ease-in-out
}
.list-link-a > li a:hover .icon svg.circle {
	fill: transparent;
	stroke: #5f5f5f;
	stroke-width: 1;
	-webkit-animation: circle 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:circle 2s forwards cubic-bezier(.215, .61, .355, 1)
}
.list-link-a > li a:hover .icon::before {
	opacity: .1;
	-webkit-animation: arrow_bg 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:arrow_bg 2s forwards cubic-bezier(.215, .61, .355, 1)
}
.list-link-a > li a:hover .icon svg .arrow {
	-webkit-animation: arrow 1.5s forwards ease-in-out;
	animation:arrow 1.5s forwards ease-in-out
}

.list-link-a > li a:hover .icon svg .circle {
	fill: transparent;
	stroke: #5f5f5f;
	stroke-width: 1;
	-webkit-animation: circle 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:circle 2s forwards cubic-bezier(.215, .61, .355, 1)
}



/* テキストのセンタリング
---------------------------------------------------- */
.center {
	text-align: center!important;
}


/* 見出し
---------------------------------------------------- */
.column h5 {
    font-size: 16px;
    font-weight: bold;
    text-align: left;
    margin-top: 30px;
}


/* リスト
---------------------------------------------------- */
.static_content .column li:before {
    content: ' ';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #3c3b36;
    position: absolute;
    left: 0px;
    top: 6px;
}

.locallink_box .locallink li:before {
    content: ' ';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #00E7EF;
    position: absolute;
    left: 0px;
    top: 9px;
}


/* list-notes-a
----------------------------------------------- */
.list-notes-a>li {
    display: table;
    width: 100%;
	font-size: 14px!important;
    padding: 0!important;
    margin: 0!important;
}
.list-notes-a>li:before {
    display: none
}
.list-notes-a>li>.mark {
    display: table-cell;
    padding-right: 12px;
    vertical-align: top;
    white-space: nowrap;
}
.list-notes-a>li>.item {
    display: table-cell;
    width: 100%;
    vertical-align: top;
}
.list-notes-a>li>.item .list-a > li {
    font-size: inherit;
	margin-top: 0;
}


/* レイアウト
----------------------------------------------- */
.lyt-item-a {
    display: table;
    width: 100%;
}
.lyt-item-a>* {
    display: table-cell;
    vertical-align: top;
    direction: ltr;
}
.lyt-item-a>.item {
    width: 100%;
}
.lyt-item-a>.item>*:first-child {
    margin-top: 0;
}
.lyt-item-a>.item>*:last-child {
    margin-bottom: 0;
}
.lyt-item-a>.img {
    text-align: center;
}
.lyt-item-a>.img>.img-inner {
    display: table;
    width: 200px;
	margin-top: 0;
}
.lyt-item-a>.img img {
    max-width: inherit;
}
.lyt-item-a>.img .caption {
    display: block;
    margin-top: 8px;
    font-size: 1.4rem;
}
@media only screen and (max-width: 1000px) {
.lyt-item-a>.img>.img-inner {
    max-width: 300px;
}
}
@media only screen and (max-width: 767px) {
.lyt-item-a {
    table-layout: fixed;
}
.lyt-item-a>.item {
    padding-top: 14px;
}
.lyt-item-a>.img {
    display: table-header-group;
}
.lyt-item-a>.img>.img-inner {
    display: block;
    width: auto;
    max-width: inherit;
}
.lyt-item-a>.img img {
    max-width: 100%;
}
}

/* レイアウト 画像右固定
----------------------------------------------- */
.lyt-item-a.is-img-r .img {
    padding-left: 40px!important;
}
@media only screen and (max-width: 767px) {
.lyt-item-a.is-img-r .img {
    padding-left: 0!important;
}
}

/* レイアウト 画像左固定
----------------------------------------------- */
.lyt-item-a.is-img-l {
    direction: rtl;
}
.lyt-item-a.is-img-l .img {
    padding-right: 40px!important;
}
@media only screen and (max-width: 767px) {
.lyt-item-a.is-img-l .img {
    padding-right: 0!important;
}
}


/* 枠線
----------------------------------------------- */
.box-a {
    padding: 16px;
    border: 1px solid #c6c6c0;
}
.box-b {
    background: #f2f2f2;
    padding: 16px;
}


/*---------------------------------------------------------------
  フッター お問い合わせ
-----------------------------------------------------------------*/
.section.contact *,
.section.contact *::before ,
.section.contact *::after {
	box-sizing:border-box;
}
.section.contact {
	padding-bottom: 130px;
	background: #fff;
	color: #000;
}
.section.contact h2 {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 16px 40px;
	font-size: 1.75rem;
	text-align: center;
	font-weight: 400;
}
@media only screen and (max-width: 480px) {
	.section.contact h2 {
		font-size: 1.375rem;
	}
}
.section.contact .section-inner {
	padding: 0 16px;
	background: url(/image/contact-bg) no-repeat right bottom /cover;
}
.section.contact .contact-wrapper {
	max-width: 1280px;
	margin: 0 auto;
	padding: 40px 0 40px;
}
.section.contact .list-contact {
	display: flex;
	justify-content: center;
	margin-bottom: -16px;
	margin-left: -60px;
}
@media only screen and (max-width: 767px) {
	.section.contact .list-contact {
		flex-direction: column;
	}
}
.section.contact .list-contact > li {
	width: 50%;
	max-width: 560px;
	padding-bottom: 16px;
	padding-left: 60px;
	display: flex;
	flex-direction: column;
}
@media only screen and (max-width: 767px) {
	.section.contact .list-contact > li {
		width: 100%;
		max-width: none;
	}
}
.section.contact .list-contact > li > *:nth-child(2) {
	padding: 24px 10px 24px;
	margin-bottom: 16px;
	background: #fff;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.section.contact .list-contact h3 {
	margin-bottom: 24px;
	color: #fff;
	font-size: 1.25rem;
	text-align: center;
}
.section.contact .list-contact .notes-a {
	margin-top: auto;
	color: #fff;
	min-height: 3em;
	text-align: center;
	font-weight: 700;
}
.section.contact .list-contact a#inquiryParam2 {
	position:relative;
	color: #000;
	font-size: 1.25rem;
	text-decoration: none;
	text-align: center;
	display: flex;
	flex-direction: row;
	align-items: center;
}
.section.contact .list-contact a:hover#inquiryParam2 {
	color: #000;
}
.section.contact .list-contact a#inquiryParam2 .icon {
	position: relative;
	margin-right: 10px;
	display: inline-block;
	width: 40px;
	height: 40px;
	vertical-align: middle;
}
.section.contact .list-contact a#inquiryParam2 .icon::before {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	border: 1px solid #5f5f5f;
	opacity: 0;
	z-index:0
}
.section.contact .list-contact a#inquiryParam2 .icon svg {
	fill: #5f5f5f;
	position: absolute;
	top: 0;
	left:0
}
.section.contact .list-contact a#inquiryParam2 .icon svg .circle {
	fill: none;
	stroke: #5f5f5f;
	stroke-width: 1px;
	width: 100%;
	height: 100%;
	-webkit-transform-origin: center;
	-ms-transform-origin: center;
	transform-origin:center
}
.section.contact .list-contact a#inquiryParam2 .icon svg .arrow {
	-webkit-transform: translateX(0);
	-ms-transform: translateX(0);
	transform: translateX(0);
	-webkit-transition: -webkit-transform .3s ease-in-out;
	transition: -webkit-transform .3s ease-in-out;
	-o-transition: transform .3s ease-in-out;
	transition: transform .3s ease-in-out;
	transition:transform .3s ease-in-out, -webkit-transform .3s ease-in-out
}
.section.contact .list-contact a:hover#inquiryParam2 .icon::before {
	opacity:.1
}
.section.contact .list-contact a:hover#inquiryParam2 .icon svg .arrow {
	-webkit-animation: arrow 1.5s forwards ease-in-out;
	animation:arrow 1.5s forwards ease-in-out
}
.section.contact .list-contact a:hover#inquiryParam2 .icon svg.circle {
	fill: transparent;
	stroke: #5f5f5f;
	stroke-width: 1;
	-webkit-animation: circle 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:circle 2s forwards cubic-bezier(.215, .61, .355, 1)
}
.section.contact .list-contact a:hover#inquiryParam2 .icon::before {
	opacity: .1;
	-webkit-animation: arrow_bg 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:arrow_bg 2s forwards cubic-bezier(.215, .61, .355, 1)
}
.section.contact .list-contact a:hover#inquiryParam2 .icon svg .arrow {
	-webkit-animation: arrow 1.5s forwards ease-in-out;
	animation:arrow 1.5s forwards ease-in-out
}

.section.contact .list-contact a:hover#inquiryParam2 .icon svg .circle {
	fill: transparent;
	stroke: #5f5f5f;
	stroke-width: 1;
	-webkit-animation: circle 2s forwards cubic-bezier(.215, .61, .355, 1);
	animation:circle 2s forwards cubic-bezier(.215, .61, .355, 1)
}
@media only screen and (max-width: 767px) {
	.section.contact .list-contact .type-tel {
		margin-top: 16px;
	}
}

.section.contact .list-contact .type-tel a {
	text-decoration: none;
	color: #000;
}
.section.contact .list-contact .type-tel .customer {
	margin-bottom: 10px;
	font-size: 0.9375rem;
}
.section.contact .list-contact .type-tel .contact-inner {
	position: relative;
	padding-left: 50px;
	font-size: 2rem;
}
.section.contact .list-contact .type-tel .contact-inner::before {
	display: inline-block;
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 1px;
	margin: auto;
	width: 46px;
	height: 26px;
	background: url(/image/icon-free-dial) no-repeat center center /cover;
}


/* マージン
----------------------------------------------- */
.mt-0 {
    margin-top: 0!important;
}