

/*================================================
 *  共通
 ================================================*/

html{
  scroll-behavior: smooth;/* スムーススクロール */
}

body { 
	font-family: 'Noto Serif JP', serif; 
	margin: 0;
    color: #333;
}

.container-fluid {
margin-right: auto;
margin-left: auto;
max-width: 890px;
}

.w600 {
margin-right: auto;
margin-left: auto;
max-width: 600px;
}

.w750 {
margin-right: auto;
margin-left: auto;
max-width: 750px;
}

h1 {
	display: none;
}

h2 {
	text-align: center;
	line-height: 0.7;
	letter-spacing: 4px;
	margin: 0;
}

h2 small {
	font-size: 12px;
	color: #c74d22;
}

strong { 
font-weight: 300}

.img-responsive {
	display:block;
	max-width:100%;
	height:auto
}

.center-block {
	display:block;
	margin-right:auto;
	margin-left:auto
}

a.overwhite:hover img {
    cursor:pointer;
    filter: alpha(opacity=80);        /* ie lt 8 */
    -ms-filter: "alpha(opacity=80)";  /* ie 8 */
    -moz-opacity:0.8;                 /* FF lt 1.5, Netscape */
    -khtml-opacity: 0.8;              /* Safari 1.x */
    opacity:0.8;
    zoom:1;
}

@media screen and (max-width:767px) {
	
h2 {
	font-size: 24px;
}

h2 small {
	font-size: 10px;
}
	
}

/*================================================
 *  スクロールしてフェードイン
 ================================================*/

.effect-fade {
  opacity: 0;
  transform: translate(0, 100px); /* フェードインで動く高さを指定 */
  transition: all 3500ms; /* フェードインにかかる時間を指定 */
}
.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}

/* 以下が追加の部分 */
/* 2つ目の要素に400msのdelayをかける */
.effect-fade:nth-of-type(2) {
  -moz-transition-delay: 400ms;
  -webkit-transition-delay: 400ms;
  -o-transition-delay: 400ms;
  -ms-transition-delay: 400ms;
}
/* 3つ目の要素に800msのdelayをかける */
.effect-fade:nth-of-type(3) {
  -moz-transition-delay: 800ms;
  -webkit-transition-delay: 800ms;
  -o-transition-delay: 800ms;
  -ms-transition-delay: 800ms;
}

/*================================================
 *  フェードイン
 ================================================*/


body {
    animation: fadeIn 2s ease 0s 1 normal;
    -webkit-animation: fadeIn 2s ease 0s 1 normal;
}

@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}


/*================================================
 *  top
 ================================================*/

@media screen and (max-width: 767px) {
	
#top {
	padding-top: 30px;
	background-color: #000;
			}
		
#top img.top-pconly {
	display:none;
			}
			
#top img.top-tabonly {
	display:none;
}

}

@media (min-width: 767px) and (max-width: 1276px) {
  
#top img.top-pconly {
	display:none;
			}
			
#top img.top-mbonly {
	display:none;
}
	
}
	
@media print, screen and (min-width: 1276px) {
	
	#top {
	background-image: url("../images/top_bg.png");
    background-repeat: no-repeat;
    background-position: top center;
}
	
#top img.top-tabonly {
	display:none;
}
	
#top img.top-mbonly {
	display:none;
}

}

/*================================================
 *  summary
 ================================================*/

#summary {
	padding: 0 0 110px 0;
	background-image: url("../images/summary_bg.png");
	background-size: cover;
	background-attachment: fixed;
}

#summary .container-fluid {
max-width: 700px;
}

#summary h2 {
	margin: 100px 0 0 0;
}

#summary p {
	font-size: 20px;
	line-height: 2;
	margin: 0 0 25px 0;
}

#summary p.pdf-dl {
	font-size: 16px;
	text-align: center;
	line-height: 1.4;
	font-weight: bold;
}

#summary .moushikomi {
	padding-top: 0px;
	padding-bottom: 20px;
}

#summary table {
	width: 100%;
	margin-top: 20px;
}

#summary table tr th {
	padding: 20px 0;
	width: 120px;
	font-weight: normal;
	border-bottom: 1px solid #AAA;
	vertical-align: top;
	font-size: 14px;
	color: #c74d22;
}

#summary table tr td {
	padding: 20px 20px;
	border-bottom: 1px solid #AAA;
	vertical-align: top;
	line-height: 1.6;
	font-size: 16px;
}

#summary table tr td small {
	font-size: 12px;
}

#summary table tr td p.note {
	font-size: 12px;
	margin: 3px 0 0 0;
	line-height: 1.4;
}

@media screen and (max-width: 767px) {
	
#summary {
	padding: 40px 0 60px 0;
}
	
#summary p {
	font-size: 14px;
}
	
#summary table tr th {
	padding: 15px 15px;
	width: 80px;
	font-size: 12px;
	text-align: left;
}

#summary table tr td {
	padding: 15px 15px;
	line-height: 1.5;
	font-size: 14px;
}

#summary table tr td small {
	font-size: 10px;
}
	
}

/*================================================
 *  #prg
 ================================================*/

#prg {
	padding: 100px 0 100px 0;
		background-image: url("../images/prg_bg.png");
	background-size: 100% auto;
	background-position: bottom center;
	background-attachment: fixed;
	background-repeat: no-repeat;
}

#prg h3 {
	color: #c74d22;
	font-size: 24px;
	margin: 0;
	line-height: 1.3;
	font-weight: normal;
}

#prg h3 small {
	font-size: 14px;
}

#prg h4 {
	font-size: 16px;
	font-weight: normal;
	margin: 10px 0 0 0;
	line-height: 1.5;
}

#prg h5 {
	font-size: 12px;
	margin: 0 0 0 0;
	line-height: 1;
	background-color: #c74d22;
	display: inline-block;
	padding: 6px 8px 5px 10px;
	color: #fff;
	font-weight: normal;
	letter-spacing: 3px;
}

#prg .orange {
	color: #c74d22;
}

#prg p {
	font-size: 18px;
	margin-top: 10px;
	line-height: 2;
}

#prg p.note {
	font-size: 12px;
	margin-top: 20px;
	line-height: 1.4;
}

#prg p.resastoha {
	font-size: 22px;
	margin-top: 70px;
	line-height: 1;
	color: #c74d22;
	text-align: center;
}

#prg table {
	width: 100%;
	margin-top: 40px;
}

#prg table tr th {
	background-color: #f2f2f2;
	padding: 15px 0;
	width: 130px;
	font-weight: normal;
	border: 1px solid #aaa;  /* ボーダーの設定 */
	vertical-align: top;
	font-size: 14px;
	text-align: center;
	line-height: 1.6;
}

#prg table tr td {
	background-color: #fff;
	padding: 15px 20px;
	border: 1px solid #aaa;  /* ボーダーの設定 */
	vertical-align: top;
	line-height: 1.6;
	font-size: 16px;
}

#prg table.panelist {
	width: 100%;
	margin-top: 0px;
}

#prg table.panelist tr th {
	background-color: #fff;
	padding: 0 0 4px 0;
	width: 90px;
	border: none;  /* ボーダーの設定 */
	text-align: left;
	line-height: 1.6;
	vertical-align: top;
}

#prg table.panelist tr td {
	padding: 0 0 4px 0;
	border: none;  /* ボーダーの設定 */
	vertical-align: top;
	line-height: 1.6;
}

#prg table.panelist tr td h4 {
	margin: 0 0 2px 0;
}

#prg table.kouen {
	width: 100%;
	margin-top: 8px;
}

#prg table.kouen tr th {
	background-color: #fff;
	padding: 0 0 4px 0;
	width: 90px;
	border: none;  /* ボーダーの設定 */
	text-align: left;
	line-height: 1.6;
}

#prg table.kouen tr td {
	padding: 0 0 4px 0;
	border: none;  /* ボーダーの設定 */
	vertical-align: top;
}

#prg table.kouen tr td h4 {
	margin-top: 0;
}

@media screen and (max-width:767px) {
	
#prg {
	padding: 60px 0 60px 0;
}

#prg h3 {
	font-size: 18px;
}

#prg h3 small {
	font-size: 12px;
}

#prg h4 {
	font-size: 14px;
}

#prg h4 small {
	font-size: 10px;
}
	
#prg p {
	font-size: 14px;
}

#prg p.resastoha {
	font-size: 20px;
}

#prg p.note {
	font-size: 10px;
}

#prg table tr th {
	width: 55px;
	font-size: 12px;
	vertical-align: middle;
	line-height: 1.2;
}

#prg table tr td {
	padding: 15px 15px;
}
	
#prg table.panelist tr th {
	width: 75px;
}
	
#prg table.kouen tr th {
	width: 75px;
}
	
#prg table.kouen tr th img {
	width: 60px;
}
	
#prg table.panelist tr th img {
	width: 60px;
}

}

/*================================================
 *  footer
 ================================================*/
 
footer {
	padding:20px 0 20px 0;
	 background-color: #000;
	font-weight: 700;
	color:#FFFFFF;
	clear:both;
	line-height: 1.2;
}

footer small {
	font-size: 11px;
}

footer a {
	color:#FFFFFF;
	text-decoration: underline;
}

footer a:hover {
	color:#FFFFFF;
	text-decoration: none;
}

footer ul li {
	display: inline-block;
	list-style: none;
	vertical-align: top;
}

footer ul li img {
	width: 50px;
	margin-right: 20px;
}

@media screen and (max-width:767px) {
	
.copyright {
	font-size:12px;}
	
footer {
	line-height: 1.3;
}
	
footer small {
	font-size: 10px;
}
	
footer ul {
	margin-left: -40px;
	margin-bottom: 0;
}
	
footer ul li {
	font-size:12px;
}
	
footer ul li img {
	width: 30px;
	margin-right: 10px;
}
	
footer .sp {
	margin-top: 10px;
}
	
}

@media print, screen and (min-width: 767px) {
	
footer .sp {
	text-align: right;
}

.copyright {
	padding-top: 40px;
}
	
}

/*================================================
 *  ボタン
 ================================================*/ 

.moushikomi {
	width: 100%;
	text-align: center;
	padding-top: 70px;
	padding-bottom: 0px;
}

.btn-sf-like {
  display: inline-block;
  text-decoration: none;
  color: #FFF;
  text-shadow: 0 0 5px rgba(255, 255, 255, 0.73);
	background-color: #c74d22;
	background-image: url("2021_btn_bg.png");
	background-repeat: no-repeat;
	background-position: right;
  transition: .4s;
	width: 450px;
	line-height: 1;
	padding: 30px;
	font-size: 20px;
}

.btn-sf-like:hover {
	text-decoration: none;
	color: #fff;
  text-shadow: -6px 0px 15px rgba(255, 255, 240, 0.83),
               6px 0px 15px rgba(255, 255, 240, 0.83);
}

.moushikomi p.app-close {
	font-size: 16px!important;
	color: #c74d22;
	font-weight: bold;
	line-height: 1.5!important;
}

@media screen and (max-width:767px) {
	
.moushikomi {
	padding-top: 20px;
}

.btn-sf-like {
	width: 80%;
	font-size: 16px;
	padding: 25px 0;
}
	
}

/*================================================
 *  home
 ================================================*/

 #fixEntry {
    width: 110px;
	 height: 110px;
    position: fixed;
    right: 1%;
    top: 88%;
}

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

 #fixEntry {
    width: 70px;
	 height: 70px;
	 right: 1%;
	 top: 89%;
}
	
 #fixEntry img {
    width: 60px;
	 height: 60px;
}	
	
}

/*================================================
 *  スマートフォン向けデザイン
 ================================================*/

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

img.pconly {
	display:none;
}
	
.pconly {
	display:none;
}

}

/*================================================
 *  スマートフォン以外向けデザイン
 ================================================*/

@media print, screen and (min-width: 767px) {
	
img.mbonly {
	display:none;
}
	
.mbonly {
	display:none;
}

}