@charset "utf-8";
html {
}
body {
	font-size: 16px;
/*	font-family: "Noto Sans Japanese" , "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	text-align: left;
	-webkit-text-size-adjust: 100%;
	color: #000;
	width: 100%;
	word-break: break-all;
	line-height: 1.5;
	letter-spacing: 0;
/*	min-width: 1040px;*/
	background-attachment: fixed;
	background-size: cover;
	background-color: #fff;
}
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box !important;
	-moz-box-sizing: border-box !important;
	-webkit-box-sizing: border-box !important;
}
img {
	border: none;
	vertical-align: top;
	max-width: 100%;
	height: auto;
/*	display: block;*/
/*	margin: 0 auto;*/
}
a {
	text-decoration: none;
}
p, dt, dd, li, th, td {
	line-height: 1.7;
}
ul, ol {
	margin: 0;
	padding: 0;
	list-style: none;
}
li {
	margin: 0px;
	padding: 0px;
}
span.tset {
	display: inline-block;
}

.fs12 {font-size: 12px;}
.fs16 {font-size: 16px;}
.fs28 {font-size: 28px;}

.mt10 {margin-top: 10px;}
.mt15 {margin-top: 15px;}
.mt20 {margin-top: 20px;}
.mt25 {margin-top: 25px;}
.mt30 {margin-top: 30px;}
.mt35 {margin-top: 35px;}
.mt40 {margin-top: 40px;}

.ts_b {
	text-shadow: 0px 4px 0px rgba(0,0,0,0.16);
}

.op0 {
	opacity: 0;
}

.opening_p {
	text-align: center;
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
	z-index:10;
}
.opening_m {
}
.container {
/*	display: none;*/
}

.center {
	width: 100%;
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform : translate(-50%,-50%);
	transform : translate(-50%,-50%);
}
.center img {
/*	margin: 0 auto;*/
}
a.btn {
	padding: 7px 45px;
	background-color: #DC000C;
	border-radius: 100px;
	color: #fff;
	display: inline-block;
	text-align: center;
	margin-right: auto;
	margin-left: auto;
}
footer {
	position: relative;
	height: 81px;
}

/*******************
	topmain
*******************/
#topmain {
    width: 100vw;
    height: 100vh;
	position: relative;
}
#topmain .bg {
    background-image: url("../img/sunpro/bg_01.jpg");
	background-position: center;
    background-size: cover;
    width: 100%;
    height: 100%;
    position: absolute;
	opacity: 0.3;
}
.bgo {
    background-image: url("../img/sunpro/bg_01.jpg");
	background-position: center;
    background-size: cover;
    width: 100%;
    height: 100%;
    position: fixed;
	opacity: 1;
	z-index: 20;
}

.logo_sumpro {
	position: absolute;
	width: 300px;
	top: 50%;
	left: 50%;
	-webkit-transform : translate(-50%,-50%);
	transform : translate(-50%,-50%);
}
a.scroll {
	font-family: 'Lato', sans-serif;
	padding-top: 60px;
	position: absolute;
	bottom: 40px;
	z-index: 2;
	display: inline-block;
	left: 50%;
	-webkit-transform: translate(-50%,0);
	transform: translate(-50%,0);
	color: #222;
	font-size: 18px;
	letter-spacing: .1em;
	transition: opacity .3s;
}
a.scroll span {
  position: absolute;
  top: 0;
  left: 50%;
  width: 30px;
  height: 50px;
  margin-left: -15px;
  border: 2px solid #222;
  border-radius: 50px;
  box-sizing: border-box;
}
a.scroll span::before {
  position: absolute;
  top: 10px;
  left: 50%;
  content: '';
  width: 6px;
  height: 6px;
  margin-left: -3px;
  background-color: #222;
  border-radius: 100%;
  -webkit-animation: sdb 2s infinite;
  animation: sdb 2s infinite;
  box-sizing: border-box;
}
@-webkit-keyframes sdb {
  0% {
    -webkit-transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    -webkit-transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes sdb {
  0% {
    transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

/*******************
	tobari
*******************/
#tobari {
	width: 100vw;
	height: 880px;
	background-color: #CDCECF;
/*	background-size: cover;*/
	position: relative;
/*	text-align: center;*/
	overflow: hidden;
}
#tobari .bg {
	max-width: 901px;
	width: 100%;
	position: absolute;
/*
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
*/
	left:  0;                    /* 位置指定 */
	right:  0;                   /* 位置指定 */
	margin-right: auto;
	margin-left: auto;
}
.red_triangle {
	position: absolute;
	left: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 230px 510px 0 0;
	border-color: #ba0016 transparent transparent transparent;
}
.blue_triangle {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 0 230px 510px;
	border-color: transparent transparent #2e3488 transparent;
}
.logo_tobari {
	margin-left: -130px;
}
.copy_tobari {
	color: #fff;
	text-shadow: 0px 2px 0px #808080;
	font-size: 32px;
	font-weight: 600;
}
.copy_tobari rt {
	font-size: 13px;
}

/*******************
	zix
*******************/
#zix {
	width: 100vw;
	height: 880px;
	position: relative;
	overflow: hidden;
}
#zix .bg {
	width: 100%;
	height: 100%;
	background-image: url("../img/zix/bg_01.jpg");
	background-position: center;
/*	background-size: cover;*/
}
#zix .center {
	padding-left: 20px;
	padding-right: 20px;
}
#zix .center img {
	display: block;
	margin-left: auto;
	margin-right: auto;
}
.logo_zix {
	width: 411px;
}
.mainimg_zix {
	width: 370px;
}

/*******************
	responsive
*******************/
@media (max-width: 1199px) {

body {
	font-size: 14px;
}
#tobari {
	height: 738px;
}
#tobari .bg {
	max-width: 601px;
}
.red_triangle {
	border-width: 143px 308px 0 0;
}
.blue_triangle {
	border-width: 0 0 143px 308px;
}
.logo_tobari {
	width: 306px;
	margin-left: -50px;
}
.copy_tobari {
	font-size: 25px;
}
.copy_tobari rt {
	font-size: 10px;
}
	
}

@media (max-width: 860px) {

.red_triangle {
	border-width: 84px 179px 0 0;
}
.blue_triangle {
	border-width: 0 0 84px 179px;
}
	
.logo_zix {
	width: 257px;
}
.mainimg_zix {
	width: 318px;
}
	
}

@media (max-width: 767px) {

.logo_sumpro {
	width: 190px;
}

}

@media (max-width: 400px) {
	
body {
	font-size: 12px;
}
a.scroll {
	bottom: 10px;
}
#tobari {
	height: 650px;
}
.red_triangle {
	border-width: 63px 131px 0 0;
}
.blue_triangle {
	border-width: 0 0 63px 131px;
}
#zix {
	height: 738px;
}
#zix .center p {
	/* font-size: 18px; */
}
	
}


@media (max-width: 330px) {
	
body {
	font-size: 11px;
}
	
}
