@charset "utf-8";

/*------------------------------------------------------------------------------

##　reset

--------------------------------------------------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-style:normal;
    font-weight: normal;
    font-size: 100%;
    vertical-align: baseline;
}
 
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
    display: block;
}
 
html{
    overflow-y: scroll;
	line-height: 1.0;
}
 
blockquote, q {
    quotes: none;
}
 
blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}
 
input, textarea{
    margin: 0;
    padding: 0;
}
 
ol, ul{
    list-style:none;
}
 
table{
    border-collapse: collapse;
    border-spacing:0;
}
 
caption, th{
    text-align: left;
}
 
a:focus {
    outline:none;
}
 
.clearfix:after {
    content: ".";
    display: block;
    clear: both;
    height: 0;
    visibility: hidden;
}
 
.clearfix {
    min-height: 1px;
}
 
* html .clearfix {
    height: 1px;
    /*¥*//*/
    height: auto;
    overflow: hidden;
    /**/
}
 
.both{
    clear:both;
}
 
.inline_block {  
    display: inline-block;  
    *display: inline;  
    *zoom: 1;  
}

img {
  vertical-align: middle;
  max-width: 100%;
  height: auto;
}

p { line-height: 1.7;}

.mt10   { margin-top: 10px !important;}
.mt20   { margin-top: 20px !important;}
.mt30   { margin-top: 30px !important;}
.mt40   { margin-top: 40px !important;}
.mt1em { margin-top: 1em !important;}
.text-L { text-align: left !important;}
.text-R { text-align: right !important;}
.text-C { text-align: right !important;}

/* グローバル変数 */
:root {
	--font-en: "Arvo", serif;
	--font-go: "Zen Kaku Gothic New", sans-serif;
	--font-jp: "Zen Kaku Gothic New", sans-serif;
	--font-color-base: #222;
	--font-color-link: #c40000;
}


/*------------------------------------------------------------------------------

　##　base layout

--------------------------------------------------------------------------------*/

/*body*/
body {
  color: #222;
	font-size: 14px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
	line-height: 1.7;
	-webkit-text-size-adjust: 100%;
}

a {
	color: #c40000;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}


.container {
	max-width: 100%;
	margin: 0 auto;
	padding: 0;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
	background-color: #fff;
	position: relative;
}
.container:before, .container:after {
    content: " ";
    display: table;
}
.container:after {
    clear: both;
}

.contentswrap:before, .contentswrap:after {
	content: " ";
    display: table;
}
.contentswrap:after {
    clear: both;
}



/*------------------------------------------------------------------------------
　　header
--------------------------------------------------------------------------------*/

.globalheader {
	width: 100%;
	/*height: 170px;*/
	background-color:  #fff;
	position: relative;
}
.globalheader .headerwrap {
	width: 1000px;
	margin: auto;
	padding: 20px 0;
}
.headerwrap:before,
.headerwrap:after {
	content: "";
	display: table;
}
.headerwrap:after {
	clear: both;
}
.headerwrap .h-logo {
	max-width: 170px;
	float: left;
	margin-top: 0;
}

@media only screen and (max-width:1000px) {


}
@media only screen and (max-width:768px) {
.globalheader .headerwrap {
	width: 100%;
	margin: auto;
	padding: 20px 10px;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
}

/*------------------------------------------------------------------------------
　　globalnav
--------------------------------------------------------------------------------*/
.globalheader .headerwrap .gnavi {
	width: 80%;
	box-sizing: content-box;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	/*position: relative;*/
	display: block;
	float: right;
	text-align: right;
}
.globalheader .gnavi:before,
.globalheader .gnavi:after {
	content: "";
	display: table;
}
.globalheader .gnavi:after {
	clear: both;
}

.globalheader .gnavi ul {
	transform: none !important;
	letter-spacing: -0.4em;
	text-align: right;
}
.globalheader .gnavi ul li {
	display: inline-block;
	margin: 0;
	padding: 0 20px;
	text-align: right;
	letter-spacing: normal;
	position: relative;
}
.globalheader .gnavi ul li:last-child {
	padding: 0 0 0 20px;
}
.globalheader .gnavi ul li:nth-child(n+2):before {
	width: 1px;
	height: 36px;
	content: "";
	display: inline-block;
	background-color: #a3c3d8;
	position: absolute;
	top: 50%;
	left: 0;
	margin-top: -18px;
	transform: rotate(15deg);
	-ms-transform: rotate(15deg);
	-moz-transform: rotate(15deg);
	-webkit-transform: rotate(15deg);
	-o-transform: rotate(15deg);
}
.globalheader .gnavi ul li a {
	color: #225e80;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.5;
}
.globalheader .gnavi ul li a:hover {
	color: #f6a200;
	text-decoration: none;
}

.globalheader .gnavi ul li.sp {
	display: none;
}

.globalheader .gnavi ul li.sub {
	position: relative;
}
.globalheader .gnavi ul li.sub a {
	padding: 10px 0 10px 23px;
	color: #221815;
}

.globalheader .gnavi ul li.sub:before {
	width: 17px;
	height: 14px;
	content: "";
	display: inline-block;
	background: url(images/common/icon_site.png) no-repeat left top;
	background-size: cover;
	position: absolute;
	top: 50%;
	left: 0;
	margin-top: -7px;
}

@media only screen and (max-width:768px) {
.globalheader .headerwrap .gnavi {
	width: 100%;
	box-sizing: content-box;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	/*position: relative;*/
	display: none;
	float: none;
	text-align: cener;
}


/*fatnav css*/
.hamburger {
  display: block;
  width: 50px;
  height: 50px;
  position: fixed;
  top: 5px;
  right: 0;
  z-index: 10000;
  padding: 12px;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
  -webkit-tap-highlight-color: transparent;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
}
.hamburger__icon {
  position: relative;
  margin-top: 7px;
  margin-bottom: 7px;
}
.hamburger__icon, .hamburger__icon:before, .hamburger__icon:after {
  display: block;
  width: 25px;
  height: 2px;
  background-color: #005484;
  -moz-transition-property: background-color, -moz-transform;
  -o-transition-property: background-color, -o-transform;
  -webkit-transition-property: background-color, -webkit-transform;
  transition-property: background-color, transform;
  -moz-transition-duration: 0.4s;
  -o-transition-duration: 0.4s;
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
}
.hamburger__icon:before, .hamburger__icon:after {
  position: absolute;
  content: "";
}
.hamburger__icon:before {
  top: -7px;
}
.hamburger__icon:after {
  top: 7px;
}
.hamburger.active .hamburger__icon {
  background-color: transparent;
}
.hamburger.active .hamburger__icon:before, .hamburger.active .hamburger__icon:after {
  background-color: #fff;
}
.hamburger.active .hamburger__icon:before {
  -moz-transform: translateY(7px) rotate(45deg);
  -ms-transform: translateY(7px) rotate(45deg);
  -webkit-transform: translateY(7px) rotate(45deg);
  transform: translateY(7px) rotate(45deg);
}
.hamburger.active .hamburger__icon:after {
  -moz-transform: translateY(-7px) rotate(-45deg);
  -ms-transform: translateY(-7px) rotate(-45deg);
  -webkit-transform: translateY(-7px) rotate(-45deg);
  transform: translateY(-7px) rotate(-45deg);
}

.fat-nav {
  top: 0;
  left: 0;
  z-index: 9999;
  position: fixed;
  display: none;
  width: 100%;
  height: 100%;
  background: rgba(0, 67, 106, 0.9);
  -moz-transform: scale(1.4);
  -ms-transform: scale(1.4);
  -webkit-transform: scale(1.4);
  transform: scale(1.4);
  -moz-transition-property: -moz-transform;
  -o-transition-property: -o-transform;
  -webkit-transition-property: -webkit-transform;
  transition-property: transform;
  -moz-transition-duration: 0.4s;
  -o-transition-duration: 0.4s;
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}
.fat-nav__wrapper {
  width: 100%;
  height: 100%;
  display: block;
  table-layout: fixed;
  text-align: center;
}
.fat-nav.active {
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -webkit-transform: scale(1);
  transform: scale(1);
}
.fat-nav ul {
  display: block;
  vertical-align: middle;
  margin: 0;
  padding: 50px 0 0;
}
.fat-nav ul:first-child {
  padding: 100px 0 50px;
}
.fat-nav ul.others {
  padding: 0;
}
.fat-nav li {
  list-style-type: none;
  text-align: center;
  padding: 0 10px;
  font-size: 18px;
  font-size: 4.2857vw;
}
.fat-nav li, .fat-nav li a {
  color: #fff;
}
.fat-nav li a {
  display: block;
  padding: 12px 0;
  font-weight: 700;
  text-decoration: none;
  border-bottom: 1px dotted #1d92d5;
}
.fat-nav li a:hover {
  color: #ffd02e;
}
.fat-nav ul.mainpage li:first-child a {
  border-top: 1px dotted #1d92d5;
}
/*.fat-nav ul.others li:nth-child(2) a {
  border-top: 1px dotted #1d92d5;
}*/
.fat-nav ul.others li.tit {
  padding: 15px 0;
  font-size: 18px;
  font-size: 4.2857vw;
  font-weight: 700;
  color: #bae6ff;
  background-color: #1d92d5;
}
.fat-nav ul.others li a {
  font-size: 16px;
  font-size: 3.8095vw;
}
}

@media screen and (orientation: landscape) {
.fat-nav li {
  font-size: 18px;
}
.fat-nav ul.others li.tit {
  font-size: 18px;
}
.fat-nav ul.others li a {
  font-size: 16px;
}
}



/*------------------------------------------------------------------------------
　　footer
--------------------------------------------------------------------------------*/

/*page-top btn
--------------------------------------*/
#page-top {
	width: 43px;
	height: 43px;
    position: fixed;
	bottom: 0;
    right: 10px;
}
#page-top a {
	display: block;
	width: 43px;
	height: 43px;
	transition: all 0.1s ease;
	-webkit-transition: all 0.1s ease;
	-moz-transition: all 0.1s ease;
}
#page-top a:hover {
	margin-top: -10px;
    transition: all 0.1s ease;
	-webkit-transition: all 0.1s ease;
	-moz-transition: all 0.1s ease;
}

@media only screen and (max-width:768px) {
#page-top {
	width: 30px;
	height: 30px;
    position: fixed;
	bottom: 0;
    right: 5px;
}
#page-top a {
	display: block;
	width: 30px;
	height: 30px;
	transition: all 0.1s ease;
	-webkit-transition: all 0.1s ease;
	-moz-transition: all 0.1s ease;
}
#page-top a:hover {
	margin-top: -10px;
    transition: all 0.1s ease;
	-webkit-transition: all 0.1s ease;
	-moz-transition: all 0.1s ease;
}
}

/*footerArea
--------------------------------------*/
.footerArea {
	width: 100%;
	padding-top: 0;
	background-color: #fff;
	border-top: 1px solid #e5e5e5;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

/*footernav*/
.footerArea .footernav {
	width: 1000px;
	margin: 0 auto;
	padding: 0 10px;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	letter-spacing: -0.4em;
}
.footerArea .footernav:before,
.footerArea .footernav:after {
	content: "";
	display: table;
}
.footerArea .footernav:after {
	clear: both;
}
.footerArea .footernav .col01 {
	width: 210px;
	padding-top: 35px;
	letter-spacing: normal;
	vertical-align: top;
	float: left;
}
.footerArea .footernav .col01 .en {
	width: 210px;
}
.footerArea .footernav .col01 .logo {
	width: 160px;
	margin-top: 12px;
}

/*footer navi*/
.footerArea .footernav .col02 {
	width: 770px;
	display: inline-block;
	padding: 45px 0 0;
	letter-spacing: normal;
	vertical-align: top;
	float: right;
}
.footerArea .footernav .col02 ul {
	letter-spacing: -0.4em;
	padding-bottom: 10px;
}
.footerArea .footernav .col02 ul li {
	padding: 0 20px;
	letter-spacing: 0.05em;
	vertical-align: top;
	font-weight: 700;
	font-size: 14px;
	line-height: 1.7;
	display: inline-block;
}
.footerArea .footernav .col02 ul li:nth-child(n+2) {
	border-left: 1px solid #d1d1d1;
}
.footerArea .footernav .col02 ul li a {
	font-weight: 700;
	color: #000;
}
.footerArea .footernav .col02 ul li a:hover {
	text-decoration: none;
}
.footerArea .footernav .col02 ul li a:hover {
	color: #0075c1;
}

@media only screen and (max-width:768px) {
.footerArea .footernav {
	width: 100%;
	padding: 0 10px;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	letter-spacing: -0.4em;
}
.footerArea .footernav .col01 {
	width: 100%;
	padding-top: 20px;
	letter-spacing: normal;
	vertical-align: top;
	float: none;
	text-align: center;
}
.footerArea .footernav .col01 .en {
	width: 210px;
	margin: 0 auto;
}
.footerArea .footernav .col01 .logo {
	width: 160px;
	margin: 12px auto 0;
}
/*footer navi*/
.footerArea .footernav .col02 {
	width: 100%;
	display: block;
	padding: 20px 0 0;
	letter-spacing: normal;
	vertical-align: top;
	float: none;
	text-align: center;
}
.footerArea .footernav .col02 ul {
	letter-spacing: -0.4em;
	padding-bottom: 0;
	text-align: left;
}
.footerArea .footernav .col02 ul li {
	padding: 0;
	letter-spacing: normal;
	vertical-align: top;
	line-height: 1.2;
	font-weight: 700;
	display: block;
	border-bottom: 1px dotted #0075c1;
	/*background: url(images/common/sp_navi_line.png) repeat-x left bottom;*/
}
.footerArea .footernav .col02 ul li:nth-child(n+2) {
	border-left: none;
}
.footerArea .footernav .col02 ul li a {
	display: block; 
	padding: 15px 0;
}
}

/*copyright
--------------------------------------*/
.copyright {
	max-width: 1000px;
	margin: 0 auto;
}
.copyright p {
	margin: 0 auto;
	padding: 20px 0;
	text-align: left;
	font-size: 12px;
	font-family: "Roboto Condensed",sans-serif;
	letter-spacing: 0.05em;
}
@media only screen and (max-width:768px) {
.copyright p {
	margin: 0 auto;
	padding: 15px 0;
	text-align: center;
	font-size: 12px;
	font-size: 2.8571vw;
	font-family: "Roboto Condensed",sans-serif;
	letter-spacing: 0.05em;
}
}
@media screen and (orientation: landscape) {
.copyright p {
	font-size: 12px;
}
}

/*------------------------------------------------------------------------------

　##　共通

--------------------------------------------------------------------------------*/

/*見出しタイトル共通*/
.md {
	position: relative;
	text-align: center;
}
.md .en {
	color: #c40000;
  font-size: 48px;
  font-family: var(--font-en);
	font-weight: 500;
  letter-spacing: normal;
  line-height: 1.0;
	position: relative;
	display: flex;
  align-items: center;
}
.md h2 {
	margin: 5px 0 0;
	display: block;
	color: #222;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.0;
}
.md .en:before,
.md .en:after{
	content: "";
  height: 1px;
  flex-grow: 1;
  background-color: #c40000;
}
.md .en:before{
	margin-right: 2rem;
}
.md .en:after{
	margin-left: 2rem;
}
@media only screen and (max-width:1023px) {
  .md .en {
    font-size: 36px;
  }
  .md h2 {
    font-size: 16px;
  }
}


/*btn共通*/
.btn01 {
	margin: 0 0 0;
	text-align: center;
}
.btn01 a {
	width: 100%;
	height: 87px;
	margin: 0 auto;
	background-color: #ec0000;
	border: 1px solid #ec0000;
	border-radius: 4px;
    display: inline-block;
    line-height: 87px;
    overflow: hidden;
    position: relative;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s ease 0s;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.btn01 a span {
	padding: 0;
	display: block;
    color: #fff;
    font-size: 20px;
	font-weight: 700;
    letter-spacing: 0.1em;
    position: relative;
    transition: all 0.3s ease 0s;
    z-index: 9000;
}
.btn01 a::after {
	background-color: #fff;
	border: 1px solid #fff;
    content: "";
    height: 0;
    left: 50%;
    opacity: 0;
    position: absolute;
    top: 50%;
    transform: translateX(-50%) translateY(-50%) rotate(90deg);
    transition: all 0.3s ease 0s;
    width: 200%;
    z-index: -1;
}
.btn01 a:hover {
    text-decoration: none;
	border: 1px solid #ec0000;
	background: #fff none;
	transition: all 0.3s ease 0s;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.btn01 a:hover span {
    color: #ec0000;
	transition: all 0.3s ease 0s;
}
.btn01 a:hover::after {
    height: 400%;
    opacity: 1;
    z-index: 100;
}
.btn01 a:before {
	width: 18px;
	height: 18px;
	content: "";
	display: inline-block;
	background-size: cover;
	position: absolute;
	top: 50%;
	left: 14px;
	margin-top: -9px;
	z-index: 101;
}
.btn01 a span:before {
	width: 50px;
	height: 14px;
	content: "";
	display: inline-block;
	background: url(images/arrow_btn.png) no-repeat left top / cover;
	position: absolute;
	top: 50%;
	left: 10px;
	margin-top: -7px;
	transition: all 0.3s ease 0s;
}
.btn01 a:hover span:before {
	width: 50px;
	height: 14px;
	content: "";
	display: inline-block;
	background: url(images/arrow_btn_red.png) no-repeat left bottom / cover;
	position: absolute;
	top: 50%;
	left: 15px;
	margin-top: -7px;
	transition: all 0.3s ease 0s;
}

@media only screen and (max-width:768px) {
.btn01 {
	margin: 0 0 0;
	text-align: center;
}
.btn01 a {
	width: 100%;
	height: inherit;
	margin: 0 auto;
	padding: 15px 12px;
	background-color: #ec0000;
	border: 1px solid #ec0000;
	border-radius: 4px;
    display: inline-block;
    line-height: inherit;
    overflow: inherit;
    position: relative;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s ease 0s;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.btn01 a span {
	padding: 0;
	display: block;
    color: #fff;
    font-size: 16px;
	font-size: 3.8095vw;
	font-weight: 700;
    letter-spacing: 0.1em;
    position: relative;
    transition: all 0.3s ease 0s;
    z-index: 9000;
}
.btn01 a::after {
	display: none;
}
.btn01 a:hover {
    text-decoration: none;
	border: 1px solid #ec0000;
	background: #fff none;
	transition: all 0.3s ease 0s;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.btn01 a:hover span {
    color: #ec0000;
	transition: all 0.3s ease 0s;
}
.btn01 a:hover::after {
    height: 400%;
    opacity: 1;
    z-index: 100;
}
.btn01 a:before {
	display: none;
}
.btn01 a span:before {
	width: 50px;
	height: 14px;
	content: "";
	display: inline-block;
	background: url(images/arrow_btn.png) no-repeat left top / cover;
	position: absolute;
	top: 50%;
	left: -35px;
	margin-top: -7px;
	transition: all 0.3s ease 0s;
}
.btn01 a:hover span:before {
	width: 50px;
	height: 14px;
	content: "";
	display: inline-block;
	background: url(images/arrow_btn_red.png) no-repeat left bottom / cover;
	position: absolute;
	top: 50%;
	left: -35px;
	margin-top: -7px;
	transition: all 0.3s ease 0s;
}
}


/*inview css*/
.in-mv01{
	opacity: 0;
	transform: translate(0,60px); 
	-webkit-transform: translate(0,60px); 
}
.mv01{
	opacity: 1.0;
	transform: translate(0,0); 
	-webkit-transform: translate(0,0);
}


/*bnrArea*/
.bnrArea {
	width: 1000px;
	margin: 0 auto;
	padding: 20px 0 30px;
	text-align: center;
}
@media only screen and (max-width:768px) {
.bnrArea {
	width: 100%;
	padding: 20px 10px 20px;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
}

/*sp br削除*/
.br-pc {
	display: inline;
}
.br-sp {
	display: none;
}
@media only screen and (max-width:768px) {
.br-pc {
	display: none;
}
.br-sp {
	display: inline;
}
}

/*------------------------------------------------------------------------------

/*! Lity - v1.6.6 - 2016-04-22
* http://sorgalla.com/lity/
* Copyright (c) 2016 Jan Sorgalla; Licensed MIT
/*画像拡大

--------------------------------------------------------------------------------*/
.lity {
  width: 100%;
  height: 100%;
  z-index: 99990;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  white-space: nowrap;
  background: #0b0b0b;
  background: rgba(39, 39, 39, 0.9);
  outline: none !important;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
       -o-transition: opacity 0.3s ease;
          transition: opacity 0.3s ease;
}
.lity.lity-opened {
  opacity: 1;
}
.lity.lity-closed {
  opacity: 0;
}
.lity * {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
}
.lity-wrap {
  width: 100%;
  height: 100%;
  padding: 0;
  z-index: 99990;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  text-align: center;
  outline: none !important;
  overflow-y: auto;
  overflow-x: hidden;
}
.lity-wrap:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle;
  margin-right: -0.25em;
}
.lity-loader {
  z-index: 99991;
  color: #fff;
  position: absolute;
  top: 50%;
  margin-top: -0.8em;
  width: 100%;
  text-align: center;
  font-size: 14px;
  font-family: Arial, Helvetica, sans-serif;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
       -o-transition: opacity 0.3s ease;
          transition: opacity 0.3s ease;
}
.lity-loading .lity-loader {
  opacity: 1;
}
.lity-container {
  z-index: 99992;
  position: relative;
  text-align: left;
  vertical-align: middle;
  display: inline-block;
  white-space: normal;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  outline: none !important;
}
.lity-content {
  z-index: 99993;
  width: 100%;
  height: 100%;
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
       -o-transform: scale(1);
          transform: scale(1);
  -webkit-transition: -webkit-transform 0.3s ease;
       -o-transition: -o-transform 0.3s ease;
          transition: transform 0.3s ease;
}
.lity-loading .lity-content,
.lity-closed .lity-content {
  -webkit-transform: scale(0.8);
      -ms-transform: scale(0.8);
       -o-transform: scale(0.8);
          transform: scale(0.8);
}
.lity-content:after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  display: block;
  right: 0;
  width: auto;
  height: auto;
  z-index: -1;
  /*-webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
          box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);*/
}
.lity-close {
  z-index: 99994;
  width: 60px;
  height: 60px;
  position: fixed;
  right: 10px;
  top: 10px;
  -webkit-appearance: none;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  padding: 0;
  color: #fff;
  font-style: normal;
  font-size: 60px;
  font-family: Arial, Baskerville, monospace;
  line-height: 60px;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
  border: 0;
  background: none;
  outline: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.lity-close::-moz-focus-inner {
  border: 0;
  padding: 0;
}
.lity-close:hover,
.lity-close:focus,
.lity-close:active,
.lity-close:visited {
  text-decoration: none;
  text-align: center;
  padding: 0;
  color: #fff;
  font-style: normal;
  font-size: 60px;
  font-family: Arial, Baskerville, monospace;
  line-height: 60px;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
  border: 0;
  background: none;
  outline: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.lity-close:active {
  right: 10px;
  top: 10px;
}
/* Image */
.lity-image img {
  max-width: 100%;
  display: block;
  line-height: 0;
  border: 0;
}
/* iFrame */
.lity-iframe .lity-container {
  width: 100%;
  max-width: 800px;
}
.lity-iframe-container {
  width: 100%;
  height: 0;
  padding-top: 56.25%;
  overflow: auto;
  pointer-events: auto;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-overflow-scrolling: touch;
  position: absolute;
  top: 50%;
  -webkit-transform : translateY(-50%);
  transform: translateY(-50%);
}
.lity-iframe-container iframe {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
          box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  background: #000;
}
.lity-hide {
  display: none;
}

/*------------------------------------------------------------------------------

　##　toppage

--------------------------------------------------------------------------------*/

/*mainvisual
--------------------------------------*/
.mainvisual {
	width: 100%;
	background: #c1cacc no-repeat center top;
}
.mainvisual .mv-wrap {
	max-width: 1600px;
	margin: 0 auto;
	position: relative;
}
.mainvisual .mainitem .pc {
	display: inline;
}
.mainvisual .mainitem .sp {
	display: none;
}
.mainvisual .mv-wrap h1 {
	position: absolute;
	top: 10px;
	left: 20px;
	color: #fff;
	font-family: var(--font-jp);
}

.mainvisual .mv-wrap .btn {
	display: inline-block;
	position: absolute;
	top: 372px;
	left: 50%;
	-webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.mainvisual .mv-wrap .btn a {
  padding: 15px 42px 17px;
	display: block;
  font-size: 18px;
  font-weight: 400;
  font-family: 'Noto Serif JP', serif;
  letter-spacing: 0.1em;
  line-height: 1.0;
  color: #fff;
  background-color: #ff9000;
  border-radius: 40px;
  transition: all 0.3s ease;
}
.mainvisual .mv-wrap .btn a:hover {
  text-decoration: none;
  background-color: #ffae00;
  border-radius: 40px;
  transition: all 0.3s ease;
}
@media only screen and (max-width:767px) {
.mainvisual .mv-wrap h1 {
	top: 5px;
	left: 10px;
	font-size: 12px;
}
}


/* features
----------------------------*/
.sec__features {
  min-width: 1000px;
	background: #fff;
}
.sec__features .secwrap {
	width: 1000px;
	margin: 0 auto;
	padding: 100px 0 80px;
	position: relative;
}
.sec__features .secwrap .innerwrap {
	margin: 65px 0 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.sec__features .secwrap .innerwrap .col01 {
	width: 550px;
	order: 2;
}
.sec__features .secwrap .innerwrap:nth-of-type(2) .col01 {
	order: 1;
}
.sec__features .secwrap .innerwrap .col01 .num {
	width: 120px;
}
.sec__features .secwrap .innerwrap .col01 h3 {
  padding: 15px 0 0;
	color: #222;
	font-size: 26px;
	font-weight: 700;
  font-family: var(--font-jp);
	letter-spacing: 0.1em;
	line-height: 1.5;
}
.sec__features .secwrap .innerwrap .col01 h3 span {
	color: #c40000;
	font-weight: 700;
}
.sec__features .secwrap .innerwrap .col01 p {
	padding-top: 15px;
	color: #333;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 2.2;
}
.sec__features .secwrap .innerwrap figure {
	width: 400px;
	order: 1;
	overflow: hidden;
	border-radius: 10px;
}
.sec__features .secwrap .innerwrap figure img {
	width: 100%;
}
.sec__features .secwrap .innerwrap:nth-of-type(2) figure {
	order: 2;
}
@media only screen and (max-width:1023px) {
.sec__features {
  min-width: inherit;
	background: #fff;
	padding: 0 20px;
	box-sizing: border-box;
}
.sec__features .secwrap {
	width: 100%;
	padding: 100px 0 80px;
	position: relative;
	box-sizing: border-box;
}
.sec__features .secwrap .innerwrap {
	margin: 65px 0 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.sec__features .secwrap .innerwrap .col01 {
	width: 56%;
	order: 2;
}
.sec__features .secwrap .innerwrap .col01 .num {
	width: 90px;
}
.sec__features .secwrap .innerwrap .col01 h3 {
	font-size: 20px;
}
.sec__features .secwrap .innerwrap .col01 p {
	padding-top: 15px;
	color: #333;
	font-size: 16px;
}
.sec__features .secwrap .innerwrap figure {
	width: 40%;
}
}
@media only screen and (max-width:1023px) {
.sec__features .secwrap {
	padding: 60px 0 40px;
}
.sec__features .secwrap .innerwrap {
	margin: 50px 0 0;
	display: block;
}
.sec__features .secwrap .innerwrap .col01 {
	width: 100%;
	order: 2;
}
.sec__features .secwrap .innerwrap .col01 .num {
	width: 90px;
	margin: 0 auto;
}
.sec__features .secwrap .innerwrap .col01 h3 {
  padding: 10px 0 0;
	font-size: 18px;
	text-align: center;
}
.sec__features .secwrap .innerwrap .col01 p {
	padding-top: 15px;
	color: #333;
	font-size: 16px;
}
.sec__features .secwrap .innerwrap figure {
	width: 100%;
	margin: 15px 0 0;
}
}



/* 製品詳細
----------------------------*/
.sec__detail {
  min-width: 1000px;
	padding: 120px 0;
	background: #ebfbff url(images/cos_bg.jpg) repeat left top;
}
.sec__detail .secwrap {
	width: 1000px;
	margin: 0 auto;
}
.sec__detail .secwrap .innerwrap {
	margin: 20px 0 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.sec__detail .secwrap .innerwrap .outline {
  width: 500px;
	padding: 20px 0 0;
}
.sec__detail .secwrap .innerwrap .outline dl {
	border-bottom: 1px solid #555;
	display: flex;
}
.sec__detail .secwrap .innerwrap .outline dl dt {
	width: 30%;
	padding: 20px 0;
	display: inline-block;
	letter-spacing: 0.05em;
	font-size: 14px;
	font-weight: 700;
	color: #333;
	line-height: 1.7;
	vertical-align: top;
	box-sizing: border-box;
}
.sec__detail .secwrap .innerwrap .outline dl dd {
	width: 70%;
	padding: 20px 0 20px 10px;
	display: inline-block;
	letter-spacing: 0.05em;
	font-size: 14px;
	font-weight: 500;
	color: #333;
	line-height: 1.7;
	vertical-align: top;
	box-sizing: border-box;
}
.sec__detail .secwrap .innerwrap figure {
	width: 360px;
	box-shadow: 0 0 15px rgba(0, 0, 0, .1);
}
.sec__detail .secwrap .innerwrap figure img {
	width: 100%;
}

.sec__detail .secwrap .price {
  width: 100%;
	padding: 60px 0 0;
}
.sec__detail .secwrap .price h3 {
  padding: 3px 15px;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.7;
	color: #fff;
	background-color: #ed0101;
	display: inline-block;
	border-radius: 6px;
}
.sec__detail .secwrap .price dl {
	width: 100%;
	border-bottom: 1px solid #555;
	display: table;
	align-content: center;
}
.sec__detail .secwrap .price dl dt {
	width: 50%;
	padding: 20px 0;
	letter-spacing: 0.05em;
	font-size: 14px;
	font-weight: 700;
	color: #222;
	line-height: 1.7;
	box-sizing: border-box;
	display: table-cell;
}
.sec__detail .secwrap .price dl dd {
	width: 50%;
	padding: 20px;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.5;
  color: #ed0101;
	box-sizing: border-box;
	text-align: right;
	display: table-cell;
}
.sec__detail .secwrap .price dl dd span {
  font-size: 18px;
  font-weight: 700;
}
.sec__detail .secwrap .price .anno {
  padding: 10px 0 0;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.7;
	color: #c40000;
}
.sec__detail .secwrap .price .anno a {
	text-decoration: underline;
	font-weight: 500;
}

.sec__detail .secwrap .howtouse {
  margin: 50px 0 0;
}
.sec__detail .secwrap .howtouse h3 {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
.sec__detail .secwrap .howtouse p {
  margin: 10px 0 0;
  padding: 15px 0;
  border-top: 1px solid #000;
  font-size: 14px;
	font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2.2;
}

.sec__detail .secwrap .caution {
  margin: 75px 0 0;
}
.sec__detail .secwrap .caution h3 {
  font-size: 18px;
  font-weight: 700;
  color: #ed0101;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
.sec__detail .secwrap .caution ul {
  margin: 10px 0 0;
  padding: 20px 25px;
  border: 1px solid #ed0101;
	border-radius: 6px;
}
.sec__detail .secwrap .caution ul li {
  padding: 8px 0 8px 1em;
  text-indent: -1em;
  font-size: 14px;
	font-weight: 700;
  color: #ed0101;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
.sec__detail .secwrap .caution ul li::before {
  content: "・";
}
@media only screen and (max-width:1023px) {
  .sec__detail {
    min-width: inherit;
    padding: 100px 20px;
		box-sizing: border-box;
  }
  .sec__detail .secwrap {
    width: 100%;
  }
  .sec__detail .secwrap .innerwrap {
    margin: 20px 0 0;
    display: block;
  }
  .sec__detail .secwrap .innerwrap .outline {
    width: 100%;
    padding: 20px 0 0;
  }
  .sec__detail .secwrap .innerwrap .outline dl {
    border-bottom: 1px solid #555;
    display: flex;
  }
  .sec__detail .secwrap .innerwrap .outline dl dt {
    width: 30%;
    padding: 20px 0;
    font-size: 14px;
  }
  .sec__detail .secwrap .innerwrap .outline dl dd {
    width: 70%;
    padding: 20px 0 20px 10px;
    font-size: 14px;
  }
  .sec__detail .secwrap .innerwrap figure {
    width: 100%;
		max-width: 360px;
		margin: 0 auto;
  }
  .sec__detail .secwrap .innerwrap figure img {
    width: 100%;
  }

  .sec__detail .secwrap .price {
    width: 100%;
    padding: 60px 0 0;
  }
  .sec__detail .secwrap .price h3 {
    padding: 3px 15px;
    font-size: 20px;
  }
  .sec__detail .secwrap .price dl dt {
    width: 50%;
    padding: 20px 0;
    font-size: 14px;
  }
  .sec__detail .secwrap .price dl dd {
    width: 50%;
    padding: 20px;
    font-size: 24px;
  }
  .sec__detail .secwrap .price dl dd span {
    font-size: 18px;
    font-weight: 700;
  }

  .sec__detail .secwrap .howtouse {
    margin: 50px 0 0;
  }
  .sec__detail .secwrap .howtouse h3 {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.7;
  }
  .sec__detail .secwrap .howtouse p {
    margin: 10px 0 0;
    padding: 15px 0;
  }

  .sec__detail .secwrap .caution {
    margin: 30px 0 0;
  }
  .sec__detail .secwrap .caution h3 {
    font-size: 18px;
    font-weight: 700;
    color: #ed0101;
    letter-spacing: 0.1em;
    line-height: 1.7;
  }
  .sec__detail .secwrap .caution ul {
    margin: 10px 0 0;
    padding: 20px 25px;
  }
}
@media only screen and (max-width:767px) {
	.sec__detail {
    min-width: inherit;
    padding: 50px 20px;
		box-sizing: border-box;
  }
  .sec__detail .secwrap {
    width: 100%;
  }
  .sec__detail .secwrap .innerwrap {
    margin: 20px 0 0;
    display: block;
  }
  .sec__detail .secwrap .innerwrap .outline {
    width: 100%;
    padding: 20px 0 0;
  }
  .sec__detail .secwrap .innerwrap .outline dl {
    border-bottom: 1px solid #555;
    display: block;
  }
  .sec__detail .secwrap .innerwrap .outline dl dt {
    width: 100%;
    padding: 20px 0;
    font-size: 14px;
  }
  .sec__detail .secwrap .innerwrap .outline dl dd {
    width: 100%;
    padding: 0 0 20px 0;
    font-size: 14px;
  }
  .sec__detail .secwrap .innerwrap figure {
    width: 80%;
		max-width: 360px;
		margin: 0 auto;
  }
  .sec__detail .secwrap .innerwrap figure img {
    width: 100%;
  }

  .sec__detail .secwrap .price {
    width: 100%;
    padding: 60px 0 0;
  }
  .sec__detail .secwrap .price h3 {
    padding: 3px 15px;
    font-size: 20px;
  }
	.sec__detail .secwrap .price dl {
    display: block;
  }
  .sec__detail .secwrap .price dl dt {
    width: 100%;
    padding: 20px 0;
    font-size: 14px;
		display: block;
  }
  .sec__detail .secwrap .price dl dd {
    width: 100%;
    padding: 0 0 20px;
    font-size: 24px;
		display: block;
  }
  .sec__detail .secwrap .price dl dd span {
    font-size: 18px;
    font-weight: 700;
  }

  .sec__detail .secwrap .howtouse {
    margin: 50px 0 0;
  }
  .sec__detail .secwrap .howtouse h3 {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.7;
  }
  .sec__detail .secwrap .howtouse p {
    margin: 10px 0 0;
    padding: 15px 0;
  }

  .sec__detail .secwrap .caution {
    margin: 30px 0 0;
  }
  .sec__detail .secwrap .caution h3 {
    font-size: 18px;
    font-weight: 700;
    color: #ed0101;
    letter-spacing: 0.1em;
    line-height: 1.7;
  }
  .sec__detail .secwrap .caution ul {
    margin: 10px 0 0;
    padding: 20px 25px;
  }
}


/* お問い合わせ
----------------------------*/
.sec__contact {
	padding: 150px 0 30px;
  background-color: #fff;
}
.sec__contact .secwrap {
	width: 1000px;
	margin: 0 auto;
}
.sec__contact .secwrap .txt {
	margin: 30px 0 0;
	font-size: 14px;
	font-weight: 500;
	line-height: 2.4;
	letter-spacing: 0.05em;
	text-align: center;
}

.sec__contact .secwrap .numArea {
	margin-top: 35px;
	padding: 28px 0;
	border-top: 1px solid #b7b7b7;
	border-bottom: 1px solid #b7b7b7;
}
.sec__contact .secwrap .numArea:before,
.sec__contact .secwrap .numArea:after {
	content: "";
	display: table;
}
.sec__contact .secwrap .numArea:after {
	clear: both;
}
.sec__contact .secwrap .numArea .col01 {
	width: 376px;
	padding: 0 25px;
	border-right: 1px solid #b7b7b7;
	float: left;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.sec__contact .secwrap .numArea .col01 h3 {
	font-size: 28px;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.5;
	color: #000;
}
.sec__contact .secwrap .numArea .col01 p {
	padding-top: 5px;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.7;
	color: #000;
}
.sec__contact .secwrap .numArea .col02 {
	width: 624px;
	padding: 0 0 0 25px;
	float: right;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.sec__contact .secwrap .numArea .col02 ul {
	letter-spacing: -0.4em;
}
.sec__contact .secwrap .numArea .col02 ul li {
	font-size: 32px;
	font-weight: 700;
	font-family: "Roboto Condensed",sans-serif;
	color: #0078dd;
	line-height: 1.5;
	letter-spacing: normal;
	display: inline-block;
}
.sec__contact .secwrap .numArea .col02 ul li:last-child {
	margin-left: 20px;
}
.sec__contact .secwrap .numArea .col02 ul li span {
	font-weight: 700;
	line-height: 1.5;
}
.sec__contact .secwrap .numArea .col02 ul li span.tit {
	font-size: 24px;
}
.sec__contact .secwrap .numArea .col02 ul li a {
	color: #0078dd;
	text-decoration: none;
}
.sec__contact .secwrap .numArea .col02 p {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.05em;
}
.sec__contact .secwrap .annowrap {
  margin: 20px 0 0;
  padding: 0 0 30px;
  border-bottom: 1px solid #ddd;
}
.sec__contact .secwrap .annowrap h3 {
  font-size: 14px;
  font-weight: 700;
  color: #ed0101;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
.sec__contact .secwrap .annowrap ul {
  margin: 0;
  padding: 10px 0;
}
.sec__contact .secwrap .annowrap ul li {
  padding: 5px 0 5px 1em;
  text-indent: -1em;
  font-size: 14px;
	font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
.sec__contact .secwrap .annowrap ul li::before {
  content: "・";
}

.sec__contact .secwrap .flow {
  margin: 20px 0 0;
}
.sec__contact .secwrap .flow ul {
  display: flex;
	justify-content: space-between;
}
.sec__contact .secwrap .flow ul li {
  width: 290px;
  padding: 30px 25px 25px;
  text-align: center;
  vertical-align: top;
  background-color: #f4f7f6;
  box-sizing: border-box;
  position: relative;
}
.sec__contact .secwrap .flow ul li:nth-child(n+2) {
  margin-left: 65px;
}
.sec__contact .secwrap .flow ul li:nth-child(1)::after,
.sec__contact .secwrap .flow ul li:nth-child(2)::after{
  width: 52px;
  height: 12px;
  content: "";
  display: inline-block;
  background: url("images/flow_arr.png") no-repeat left top / cover;
  position: absolute;
  top: calc(50% - 6px);
  right: -60px;
}
.sec__contact .secwrap .flow ul li h3 {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
.sec__contact .secwrap .flow ul li p {
  margin: 10px 0 0;
  font-size: 14px;
  font-weight: 400;
  text-align: left;
  letter-spacing: 0.05em;
  line-height: 2.0;
}

@media only screen and (max-width:1023px) {
.sec__contact {
	padding: 80px 0 30px;
}
.sec__contact .secwrap {
	width: 100%;
	padding: 0 20px;
	box-sizing: border-box;
}
.sec__contact .secwrap .txt {
	font-size: 14px;
	font-weight: 500;
	line-height: 2.4;
	letter-spacing: 0.05em;
	text-align: left;
}

.sec__contact .secwrap .numArea {
	margin-top: 25px;
	padding: 22px 0;
	border-top: 1px solid #b7b7b7;
	border-bottom: 1px solid #b7b7b7;
}
.sec__contact .secwrap .numArea .col01 {
	width: 100%;
	padding: 0 0 20px;
	border-right: none;
	border-bottom: 1px solid #b7b7b7;
	float: none;
	box-sizing: border-box;
}
.sec__contact .secwrap .numArea .col01 h3 {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.5;
	color: #000;
	text-align: center;
}
.sec__contact .secwrap .numArea .col01 p {
	padding-top: 5px;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.7;
	color: #000;
	text-align: center;
}
.sec__contact .secwrap .numArea .col02 {
	width: 100%;
	padding: 15px 0 0;
	box-sizing: border-box;
}
.sec__contact .secwrap .numArea .col02 ul {
	text-align: center;
}
.sec__contact .secwrap .numArea .col02 ul li {
	font-size: 28px;
	font-weight: 700;
	color: #0078dd;
	line-height: 1.5;
	letter-spacing: normal;
	display: block;
}
.sec__contact .secwrap .numArea .col02 ul li:last-child {
	margin-left: 0;
}
.sec__contact .secwrap .numArea .col02 ul li span {
	font-weight: 700;
	line-height: 1.5;
}
.sec__contact .secwrap .numArea .col02 ul li span.tit {
	font-size: 24px;
}
.sec__contact .secwrap .numArea .col02 ul li a {
	color: #0078dd;
	font-weight: 700;
	text-decoration: none;
}
.sec__contact .secwrap .numArea .col02 p {
	font-size: 14px;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.05em;
  text-align: center;
}
.sec__contact .secwrap .flow {
  margin: 20px 0 0;
}
.sec__contact .secwrap .flow ul {
  width: 100%;
  display: block;
}
.sec__contact .secwrap .flow ul li {
  width: 85%;
  margin: 0 auto;
  padding: 20px;
  text-align: center;
  box-sizing: border-box;
  display: block;
  position: relative;
}
.sec__contact .secwrap .flow ul li:nth-child(n+2) {
  margin: 65px auto 0;
}
.sec__contact .secwrap .flow ul li:nth-child(1)::after,
.sec__contact .secwrap .flow ul li:nth-child(2)::after{
  width: 52px;
  height: 12px;
  content: "";
  display: inline-block;
  background: url("images/flow_arr.png") no-repeat left top / cover;
  position: absolute;
  top: inherit;
  bottom: -37px;
  right: calc(50% - 26px);
  transform: rotate(90deg);
}
.sec__contact .secwrap .flow ul li h3 {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
.sec__contact .secwrap .flow ul li p {
  margin: 10px 0 0;
  font-size: 14px;
  font-weight: 400;
  text-align: left;
  letter-spacing: 0.1em;
  line-height: 2.0;
}
}

/* メールフォーム
-----------------------------------------------*/
.sec__contact .mailwrap {
	width: 1000px;
	margin: 0 auto;
	padding: 100px 0 10px;
	letter-spacing: -0.4em;
	text-align: center;
}
.sec__contact .mailwrap h3 {
	padding: 0 0 0 20px;
	color: #c40000;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-align: center;
	position: relative;
	display: inline-block;
}
.sec__contact .mailwrap h3:before {
	width: 17px;
	height: 12px;
	content: "";
	display: inline-block;
	background: url(images/icon_mail.png) no-repeat left top / cover;
	position: absolute;
	top: 50%;
	left: -5px;
	margin-top: -6px;
}


table.formTable{
	width:100%;
	margin: 50px auto 0;
	border-collapse:collapse;
	text-align: left;
	letter-spacing: normal;
}
table.formTable tr:first-child{
	border-top: 1px dotted #d7d9db;
}
table.formTable td,table.formTable th{
	border-bottom: 1px dotted #d7d9db;
	padding:28px;
}
table.formTable th{
	width:30%;
	font-weight: 700;
	text-align:left;
	color: #000;
	font-size: 14px;
	vertical-align: middle;
}
table.formTable th span{
	color: #e60000;
}
table.formTable td{
	color: #000;
	font-size: 14px;
}
table.formTable td span.txt {
	padding: 0 10px 0 0;
}
table.formTable td .item {
	padding: 5px 0;
	display: block;
	font-weight: 500;
}
table.formTable td .item p {
	display: inline;
}
table.formTable td .item input {
	margin: 0 0 0 10px;
	width: 3em;
}
table.formTable td div{
	padding-bottom: 15px;
}
p.error_messe{
	margin:10px 0;
	color:red;
}

#formWrap {
	padding: 50px 0;
}

.form-bt01 {
	margin-top: 15px;
	text-align: center;
}
input {
  background-color: #f4f4f4;
  padding: 15px 5px;
  border: 1px solid #fff;
	font-weight: 500;
	box-sizing: border-box;
}
/*input:nth-child(n+2) {
  margin-left: 2em;
}*/
textarea {
  background-color: #f4f4f4;
  padding: 15px 10px;
  border: 1px solid #fff;
}
select {
  background-color: #f4f4f4;
  padding: 15px 5px;
  border: 1px solid #fff;
}
input#submit_button,
input#submit_reset,
input#submit_back {
    padding: 12px 35px;
    font-size: 22px;
    background-color: #eba429;
    color: #fff;
    border-style: none;
	border-radius: 4px;
	cursor: pointer;
}
input#submit_button:hover,
input#submit_reset:hover,
input#submit_back:hover {
    background-color: #f58623;
    color: #fff;
}
.g-recaptcha {
	width: 304px;
  margin: 0 auto 15px;
}

/*confirm*/
.sec_confirm {
	width: 1000px;
	margin: 0 auto;
}
.sec_confirm h2{
	padding: 20px 0;
	font-size: 16px;
	text-align: center;
	font-weight: 700;
}
.sec_confirm input:nth-child(n+2) {
	margin-left: 0;
}

/*thanks*/
.sec_thanks {
	width: 1000px;
	margin: 0 auto;
	padding: 80px 0;
	text-align: center;
}
.sec_thanks h2{
	padding: 20px 0;
	font-size: 16px;
	text-align: center;
	font-weight: 700;
}
.sec_thanks p{
	line-height: 2.2;
}
.sec_thanks .btn {
	margin: 15px 0 0;
	padding: 5px 0;
}

@media only screen and (max-width:768px) {
.sec__contact .mailwrap {
	width: 100%;
	padding: 60px 20px 20px;
	letter-spacing: -0.4em;
	text-align: center;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.sec__contact .mailwrap h3 {
	padding: 0 0 0 20px;
	color: #c40000;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-align: center;
	position: relative;
	display: inline-block;
}
.sec__contact .mailwrap h3:before {
	width: 17px;
	height: 12px;
	content: "";
	display: inline-block;
	background: url(images/icon_mail.png) no-repeat left top / cover;
	position: absolute;
	top: 50%;
	left: -5px;
	margin-top: -6px;
}


table.formTable{
	width: 100%;
	margin: 30px 0 0;
	border-collapse:collapse;
	text-align: left;
	letter-spacing: normal;
}
table.formTable tr:first-child{
	border-top: 1px dotted #d7d9db;
}
table.formTable th{
	padding: 20px 0 5px;
	border-bottom: none;
}
table.formTable td {
	border-bottom: 1px dotted #d7d9db;
	padding: 15px 0;
}
table.formTable th{
	width: 100%;
	font-weight: 700;
	text-align:left;
	color: #000;
	font-size: 14px;
	vertical-align: middle;
	display: block;
}
table.formTable th span{
	color: #e60000;
}
table.formTable td{
	width: 100%;
	color: #000;
	font-size: 14px;
	display: block;
}
table.formTable td div{
	padding-bottom: 15px;
}
table.formTable td span {
	display: block;
	padding: 10px 0;
}
table.formTable td .item p {
	display: block;
}
table.formTable td.radio {
	line-height: 1.0;
}

#formWrap {
	padding: 20px 10px;
}

p.error_messe{
	margin:10px 0;
	color:red;
}

.form-bt01 {
	margin-top: 15px;
	text-align: center;
}
input {
  padding: 10px 5px;
  font-size: 14px;
}
input[type=radio] {
  width: 20px;
	height: 20px;
	position: relative;
	top: 4px;
}
input[type=text] {
	width: 100%;
  padding: 10px 5px;
  font-size: 14px;
}
/*input:nth-child(n+2) {
  margin-left: 2em;
}*/
textarea {
  width: 100%;
	box-sizing: border-box;
  font-size: 14px;
}
select {
  border: none;
  padding: 10px 5px;
  font-size: 14px;
}
input#submit_button,
input#submit_reset,
input#submit_back {
	margin-top: 5px;
    padding: 12px 15px;
    font-size: 16px;
	font-weight: 700;
    background-color: #eba429;
    color: #fff;
    border-style: none;
	border-radius: 4px;
	cursor: pointer;
}
input#submit_button:hover,
input#submit_reset:hover,
input#submit_back:hover {
    background-color: #f58623;
    color: #fff;
}

/*confirm*/
.sec_confirm {
	width: 100%;
}
.sec_confirm h2{
	padding: 20px 0;
	font-size: 16px;
	text-align: center;
	font-weight: 700;
}
.sec_confirm input:nth-child(n+2) {
	margin-left: 0;
}

/*thanks*/
.sec_thanks {
	width: 100%;
	padding: 25px 0;
	text-align: center;
}
.sec_thanks h2{
	padding: 20px 0;
	font-size: 16px;
	text-align: center;
	font-weight: 700;
}
.sec_thanks p{
	line-height: 2.2;
}
.sec_thanks .btn {
	margin: 15px 0 0;
	padding: 5px 0;
}
}
