@charset "utf-8";

/* common
---------------------------------------------*/
* {margin:0;padding:0;}

a:link,a:visited {
	color: #ffffff;
	text-decoration:underline;
}
a:hover,a:active {
	color: #d90909;
	text-decoration:underline;
}

.impact   {font-size:20pt; font-weight:bold;}
.impact2  {color:red;}
.impact3  {background:yellow; color:#000;}
#impact4  {underline;}
.impact5  {background:#173B50; padding:2px 5px; color:#fff;}
.impact6  {background:#f4f4f4; padding:3px; line-height:1.1;}
.impact7  {background: #B60000; padding:2px 5px; color:#fff;}
.style2   {color: #FF0000}
.style3   {color: #333333}
.style4   {color: #000000}


img{ border: none;}

/* ボタンのマウスオーバーで明るくする */
.btn:hover {
  filter: brightness(115%);
}


/* animation
---------------------------------------------*/
.feedInUp {
	opacity: 0;
	transform: translate(0,30px); 
	-webkit-transform: translate(0,30px); 
	transition: 1.5s;
}
.feedInUp_On {
	opacity: 1.0;
	transform: translate(0,0); 
	-webkit-transform: translate(0,0);
}

/* layout
---------------------------------------------*/


/*TopIntro-Start*/
body {
	width: 100%;
	height: 100%;
	margin: 0px;
	padding: 0px;
	min-width: 1002px;
	
  background-image: url(../images/bg.jpg);
	background-repeat: repeat;
	background-attachment: fixed;
	background-position: top center;
	
-webkit-text-size-adjust:none;
	
  text-align:center;
  font-size:18px;
  font-family: 'meiryo', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
    color: #383d5c;
}

#header_01 { background: url("../images/header_01.png") no-repeat top center; height:    741px; } 
#header_02 { background: url("../images/header_02.png") no-repeat top center; height:    3px; } 
#header_03 { background: url("../images/header_03.png") no-repeat top center; height:    841px; } 
#header_03_1 { background: url("../images/header_03_1.png") no-repeat top center; height:    353px; } 
#header_04 { background: url("../images/header_04.png") no-repeat top center; height:    739px; } 
#header_05 { background: url("../images/header_05.png") no-repeat top center; height:    810px; } 
#header_06 { background: url("../images/header_06.png") no-repeat top center; height:    522px; } 
#header_07 { background: url("../images/header_07.png") no-repeat top center; height:    1076px; } 
#header_08 { background: url("../images/header_08.png") no-repeat top center; height:    1073px; } 
#header_09 { background: url("../images/header_09.png") no-repeat top center; height:    1283px; } 
#header_10 { background: url("../images/header_10.png") no-repeat top center; height:    256px; } 
#header_11 { background: url("../images/header_11.png") no-repeat top center; height:    922px; } 
#header_12 { background: url("../images/header_12.png") no-repeat top center; height:    428px; } 
#header_13 { background: url("../images/header_13.png") no-repeat top center; height:    639px; } 
#header_14 { background: url("../images/header_14.png") no-repeat top center; height:    996px; } 
#header_15 { background: url("../images/header_15.png") no-repeat top center; height:    1062px; } 
#header_16 { background: url("../images/header_16.png") no-repeat top center; height:    1046px; } 
#header_17 { background: url("../images/header_17.png") no-repeat top center; height:    978px; } 
#header_18 { background: url("../images/header_18.png") no-repeat top center; height:    1128px; } 
#header_19 { background: url("../images/header_19.png") no-repeat top center; height:    510px; } 
#header_20 { background: url("../images/header_20.png") no-repeat top center; height:    20px; } 
#header_21 { background: url("../images/header_21.png") no-repeat top center; height:    639px; } 
#header_22 { background: url("../images/header_22.png") no-repeat top center; height:    785px; } 
#header_23 { background: url("../images/header_23.png") no-repeat top center; height:    383px; } 
#header_24 { background: url("../images/header_24.png") no-repeat top center;height:    633px; } 
#header_25 { background: url("../images/header_25.png") no-repeat top center; height:    134px; margin-bottom: 10px;margin-top: 20px;} 
#header_26 { background: url("../images/header_26.png") no-repeat top center;height:    568px;} 
#header_27 { background: url("../images/header_27.png") no-repeat top center; height:    319px; } 
#header_28 { background: url("../images/header_28.png") no-repeat top center; height:    1093px; } 
#header_29 { background: url("../images/header_29.png") no-repeat top center; height:    1255px; } 
#header_30 { background: url("../images/header_30.png") no-repeat top center; height:    308px; } 
#header_31 { background: url("../images/header_31.png") no-repeat top center; height:    878px; } 
#header_32 { background: url("../images/header_32.png") no-repeat top center; height:    897px; } 
#header_33 { background: url("../images/header_33.png") no-repeat top center; height:    917px; } 
#header_34 { background: url("../images/header_34.png") no-repeat top center; height:    586px; } 
#header_35 { background: url("../images/header_35.png") no-repeat top center; height:    812px; } 
#header_36 { background: url("../images/header_36.png") no-repeat top center; height:    934px; } 
#header_37 { background: url("../images/header_37.png") no-repeat top center; height:    490px; } 
#header_38 { background: url("../images/header_38.png") no-repeat top center; height:    695px; } 
#header_39 { background: url("../images/header_39.png") no-repeat top center; height:    817px; } 
#header_40 { background: url("../images/header_40.png") no-repeat top center; height:    248px; } 
#header_41 { background: url("../images/header_41.png") no-repeat top center; height:    543px; } 
#header_42 { background: url("../images/header_42.png") no-repeat top center; height:    762px; } 
#header_43 { background: url("../images/header_43.png") no-repeat top center; height:    288px; } 
#header_44 { background: url("../images/header_44.png") no-repeat top center; height:    552px; } 
#header_45 { background: url("../images/header_45.png") no-repeat top center; height:    173px; } 



#wrap {

	background-image: url("../images/wrap.png");
	background-repeat: repeat-y;
	background-position: center top;
	background-position:50% 0%;
}

#wrapform {

	background-image: url("../images/wrapform.png");
	background-repeat: repeat-y;
	background-position: center top;
	background-position:50% 0%;
}


#container {

	text-align:left;
	width:1000px;
	margin:0 auto;
	
	
}

#text {

	text-align:left;
	width:850px;
	margin:0 auto;
	
	
}

#textwhite {

	text-align:left;
	width:850px;
	margin:0 auto;
	color: #fff;
	
}

#texts2 {

	text-align:left;
	width:750px;
	position: relative;
	margin-top:170px;
	margin-left:400px;
	
	
}

#texts3 {

	text-align:left;
	width:850px;
	margin-top:250px;
	margin-left:170px;
	
	
}


.container {

	text-align:left;
	width:1200px;
	margin:0 auto;
	
	
}

.white {
  color: #fff;
}

.text-center {
 text-align: center;
}

#footer {  
	background-color: #02448c;
}
--------------------------- */

ol,
ul{
	list-style-position: inside;
	padding-left:10px;
}
ol li,
ul li{
	text-align:left;
}

.btn_01 {
  transition: transform 0.3s ease;
}

.btn_01:hover {
  transform: scale(1.08);
  filter: brightness(102%);
}

.faq {
  max-width: 900px;
  margin: 0 auto 100px;
  padding: 0 20px;
}



.faq details {
  border-bottom: 1px solid #383939;
  padding: 25px 0;
}

.faq summary {
  font-size: 38px;
  font-weight: 500;
  cursor: pointer;
  position: relative;
  text-align: left;
}

.faq summary::after {
  content: "+";
  position: absolute;
  right: 0;
}

.faq details[open] summary::after {
  content: "-";
}

.faq p {
  margin-top: 15px;
  padding-left: 20px;
    padding-right: 40px;
  line-height: 1.8;
    font-size: 34px;
    text-align: left;
}

.faq details[open] summary {
  background-color: #dae4ed;
   transition: background-color 0.3s ease;
}

.scroll-section {
  position: relative; /* absoluteの基準 */
}


.image-scroll {
  position: absolute;      /* header内に固定 */
  left: 50%;
  transform: translateX(-50%);
  
  width: 930px;           /* 枠の幅 */
  max-width: 95%;
  
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;

}

.image-scroll img { 
  flex: 0 0 auto;
  scroll-snap-align: start;
}

