﻿@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@100;400;700;900&display=swap"); /*! destyle.css v1.0.15 | MIT License | https://github.com/nicolas-cusan/destyle.css */ * {
  box-sizing: border-box
}
::before, ::after {
  box-sizing: inherit
}
html {
  height: 100%;
  width: 100%;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility

}
body {color:#000;font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;-webkit-text-size-adjust:100%;width:100%; overflow-x:hidden;margin: 0;word-break: break-all;}

#primary{
	width: 100%;
	background-color: #000000;
	font-size: 95%;
}
#wrap{
	max-width: 1000px;
	background-color: #FFFFFF;
	margin: 0 auto;
	padding: 30px 50px;
}

p {margin-block-start:0px;
   margin-block-end:0px;
}

ul,ol {margin-block-start:5px;
   margin-block-end:5px;
}

h2 {font-size: 120%;
	background-color: #000000;
	font-weight: bold;
	padding: 10px 15px;
	color: #ffffff;
	margin-top: 30px;
	}
h3 {
	font-size: 110%;
	text-align: left;
	font-weight: bold;
	padding: 0;
	margin: 20px 0 5px 0;
}

h4 {
  padding: 10px 1rem;
  border-left: 5px solid #000;
  background: #f4f4f4;
}

#payment table{
	width: 100%;
	border-collapse: collapse;
}
#payment table th,td{
	border: 1px solid #004996;
}

#payment table th{
	background-color: #0560AB;
	color: #FFFFFF;
	text-align: center;
	padding: 10px;
}
#payment table td{
	background-color: #FFFFFF;
	color: #000000;
	text-align: center;
	padding: 10px;
}

#payment ul{
	text-align: left;
}

#jyoho dl{
	display: flex;
	width: 100%;
	flex-wrap: wrap;
}
#jyoho dt{
	font-weight: bold;
	width: 13%;
	padding: 15px 0;
	margin: 0;
	border-bottom: 1px solid #878787;
}
#jyoho dd{
	width: 87%;
	padding: 15px 0;
	margin: 0;
	border-bottom: 1px solid #878787;
}

.sch{
	width: 100%;
	min-width: 650px;
	border-collapse: collapse;
	font-size: 90%;
}

.sch th{background-color: #0560AB;
	color: #FFFFFF;
	text-align: center;
border: 1px solid #004996;}
.sch td{
	border: 1px solid #004996;
	padding: 5px 10px;
	vertical-align: top;
}
.t-c{
	text-align: center;
}
.t-r{
	text-align: right;
}

.stepnum{
	font-size: 115%;
	background-color: #0560AB;
	color: #FFFFFF;
	text-align: center;
	font-weight: bold;
	padding: 10px;
	margin-top: 30px auto;
}

.step{
	border: 1px solid #000000;
	margin: 0 auto 15px auto;
	padding: 15px;
}
.slide-img {
  width: 100%;         /* 親コンテナが画面幅に応じて可変 */
  height: auto;        /* 必要なら指定してもOK */
  overflow: hidden;    /* はみ出た場合にカット（任意） */
}

.for_pc{
		display: block;
	}
.for_sp{
display: none;	
}


.slide-img img {
  width: 100%;         /* 常に親要素の幅いっぱいに表示 */
  height: auto;        /* 画像のアスペクト比を維持 */
  display: block;      /* 下の余白対策（インライン要素の隙間） */
}
.arrow{ width: 0; height: 0;border: 20px solid transparent;border-top: 20px solid #333;margin: auto;}

.app {display: inline-block;width: 90%;height: 54px;text-align: center;text-decoration: none;line-height: 54px;outline: none;position: relative;z-index: 2;background-color: #fff;border: 2px solid #333;color: #333;line-height: 50px;overflow: hidden; margin:25px 0 5px}
	.app::before,.app::after {position: absolute;z-index: -1;	display: block;content: '';}
	.app,.app::before,.app::after {-webkit-box-sizing: border-box;	-moz-box-sizing: border-box;box-sizing: border-box;	-webkit-transition: all .3s;transition: all .3s;}
	.app:hover {color: #fff;}
	.app::after {top: 0;left: 0;width: 100%;height: 100%;}
	.app:hover::after {-webkit-transform: scale(2) rotate(180deg);transform: scale(2) rotate(180deg);background: #333;}

.bank {
	border-style:solid;	border-width:1px;
	padding: 1%;
	margin:2% 1%; }
footer{
	text-align: center;
	color: #FFFFFF;
	padding: 20px;
	background-color: gray;
}

.red{
	font-weight: bold;
	color:red;
}

#menu{width: 100%;position: fixed;top: 0;left: 0;z-index: 2; font-size: 16px;background-color: rgba(34,48,85,0.7);padding: 5px;}
	#menu ul{list-style-type: none;display: flex;justify-content: flex-end;padding-right: 20px;}
	#menu ul li{margin: 0 10px}
	#menu ul li a{color: #E1E1E1;text-decoration: none;transition: .5s}
	#menu ul li a:hover{opacity: .5} /*! destyle.css v1.0.15 | MIT License | https://github.com/nicolas-cusan/destyle.css */ * {
  box-sizing: border-box
}
::before, ::after {
  box-sizing: inherit
}


@media (max-width: 480px) {
	#menu ul{list-style-type: none;display: flex;justify-content: flex-end;padding-right: 5px;
	padding-inline-start: 0px;}
	#menu{font-size: 8pt;}
	#menu ul li{margin: 0 5px}
}














.taisensha1,
.taisensha2,
.taisensha3,
.taisensha4{
position: relative;
display: block;
margin: 0 auto;
text-align: center;
}

.taisensha3:before{
position: absolute;
/*content: "対局者";
font-size: 16px;
font-weight: bold;
padding: 2px 15px 0;
text-shadow: 1px 1px 2px #000;
background: #c1a470;
background: linear-gradient(45deg, #B67B03 0%, #DAAF08 45%, #FEE9A0 70%, #DAAF08 85%, #B67B03 90% 100%);
color: #fff;
border-left: 3px solid #000;
top: -15px;*/
}
.taisensha1:before,
.taisensha4:before{
position: absolute;
content: "挑戦者";
font-size: 16px;
font-weight: bold;
padding: 2px 15px 0;
text-shadow: 1px 1px 2px #000;
background: #ddd;
background: linear-gradient(45deg, #757575 0%, #9E9E9E 45%, #E8E8E8 70%, #9E9E9E 85%, #757575 90% 100%);
color: #fff;
border-left: 3px solid #000;
top: -15px;
}
.taisensha1:after{
position: absolute;
content: "羽生 善治 \A 九段";
white-space: pre-wrap;
font-size: 16px;
}
.taisensha2:after{
position: absolute;
content: "広瀬 章人";
white-space: pre-wrap;
font-size: 16px;
}
.taisensha3:after{
position: absolute;
content: "藤井 聡太 \A 王座";
white-space: pre-wrap;
font-size: 16px;
}
.taisensha4:after{
position: absolute;
content: "伊藤 匠 \A 叡王";
white-space: pre-wrap;
font-size: 16px;
}
@media (min-width: 481px) {
.flex{
display: flex;
justify-content: space-between;
gap:5px;
}
.flex .taisensha1,
.flex .taisensha2,
.flex .taisensha3,
.flex .taisensha4/*.flex img*/{
width: calc(100% / 3);/*width: calc(100% / 4);*/
}
.taisensha1:after{
top: 100%;
left: 35%;
}
.taisensha2:after{
top: 100%;
left: 35%;
}
.taisensha3:after{
top: 100%;
left: 35%;
}
.taisensha4:after{
top: 100%;
left: 40%;
}
.taisensha1 img,
.taisensha2 img,
.taisensha3 img,
.taisensha4 img{
width: 100%;
height: 100%;
}
}

@media (max-width: 480px) {
.flex{
display:block;
}
  html {
    font-size: 13px
  }
.taisensha1:after{
bottom: 0;
left: 40%;
}
.taisensha2:after{
bottom: 0;
left: 40%;
}
.taisensha3:after{
bottom: 0;
left: 40%;
}
.taisensha4:after{
bottom: 0;
left: 42%;
}
.taisensha1 img,
.taisensha2 img,
.taisensha3 img,
.taisensha4 img{
margin-bottom: 25px;
}
}
body {
  line-height: 1.8;
  word-break: break-all;
  color: #000000;
  width: 100%;
  height: 100%;
  
  overflow-x: hidden
}
table {
  border-collapse: collapse;
  border-color: #ccc;
  border: 1px solid #ccc !important
}

.swiper-container {
  width: 100%;
  height: 100%;
}
@media (max-width: 480px) {

@media(max-width: 768px){
	
	.swiper-container {
  width: 100%;

	
}

	
}
.swiper-slide {
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden
}

.ttl-wrap {
	width: auto;
  position: absolute;
  z-index: 3;
  top: 30%;
left: 3%;
 
}
.ttl1 {
    font-size: 3rem;
    font-weight: bold;
	line-height: 1.2;
	text-align: center;
color: #fff;
padding: 30px;
background-color: rgba(0,0,0,0.70);
}
.ttl1 span{
	font-size: 40%;
}

@media(max-width: 1000px){

	
.ttl-wrap {
	width: 100%;
  position: absolute;
  z-index: 3;
  top: 20%;
left: 0%;
}	
.ttl1{ font-size:2rem;
	}	
}

@media(max-width: 768px){

	
.ttl-wrap {
	width: 100%;
  position: absolute;
  z-index: 3;
  top: 20%;
left: 0%;
}	
.ttl1{ font-size:2rem;
	}	
}

@media(max-width: 540px){
	
.ttl-wrap {
	width: 100%;
  position: absolute;
  z-index: 3;
  top: 20%;
left: 0%;
}	
.ttl1{ font-size:1.5rem;
	}	
}

@media(max-width: 420px){
	
.ttl-wrap {
	width: 100%;
  position: absolute;
  z-index: 3;
  top:20%;
	left: 0%;
}	
.ttl1{ font-size:1.4rem;
	}	
}

@media(max-width: 600px){
#jyoho dl{
	display: block;
	width: 100%;
	flex-wrap: wrap;
}
#jyoho dt{
	font-weight: bold;
	width: 100%;
	padding: 10px 0 0 0;
	margin: 0;
	border-bottom: none;
}
#jyoho dd{
	width: 100%;
	margin: 0;
	border-bottom: 1px solid #878787;
	padding: 5px 0;
}
	#wrap{
		padding: 15px;
	}
	ul,ol{padding-inline-start: 25px;
	}
}


.table_sc{
  overflow-x: scroll;
}

.caption{
	background-color: black;
	font-size: 90%;
	color: #FFFFFF;
	text-align: right;
	margin-right: 2em;
}
	


.fs115{
	font-size: 115%;
	font-weight: bold;
}

.t-l{
	text-align: left;
}

.ml-2{
	margin-left: -2rem;
}
.mt-30{margin-top: 30px;
	
}

/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc { display: block !important; }
.sp { display: none !important; }
 
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 680px) {
    .pc { display: none !important; }
    .sp { display: block !important; }
}

.tour-points {
  background-color: #f9f9f9;
  border-left: 6px solid #d32f2f;
  padding: 5px 20px;
  margin: 30px 0;
  border-radius: 8px;
  font-family: 'Noto Sans JP', sans-serif;
}

.tour-points h2 {
  font-size: 1.7em;
  color: yellow;
  margin-bottom: 15px;
}

.tour-points ul {
  list-style: none;
  padding-left: 0;
}

.tour-points li {
  margin-bottom: 15px;
  padding-left: 35px;
  position: relative;
  line-height: 1.6;
  font-size: 1.4rem;
font-weight: bold;
color: red;
}

.tour-points .point-icon {
  position: absolute;
  left: 0;
  top: 0;
  color: #d32f2f;
  font-weight: bold;
  font-size: 1.2em;
}

.tour-points small {
  display: block;
  font-size: 0.9em;
  color: #555;
  margin-top: 4px;
}
@media (max-width:1024px) {

	.for_pc{display: none;
	}
	.for_sp{
		display: block;
	}
}
}

h3.player {
font-size: 1.5rem;
border-bottom: 6px double #565656;
margin: 25px auto;
}

.btn_yesno{	margin:0 auto; width:500px; text-align: center; }

@media(max-width: 500px){
	.btn_yesno{	margin:0 auto; width:100%; text-align: center; }
	}

.btn { -moz-transition: border-color 0.2s ease-in-out, color 0.2s ease-in-out, opacity 0.5s ease, -moz-transform 0.5s ease, visibility 0.5s;　-webkit-transition: border-color 0.2s ease-in-out, color 0.2s ease-in-out, opacity 0.5s ease, -webkit-transform 0.5s ease, visibility 0.5s;
	-ms-transition: border-color 0.2s ease-in-out, color 0.2s ease-in-out, opacity 0.5s ease, -ms-transform 0.5s ease, visibility 0.5s;	transition: border-color 0.2s ease-in-out, color 0.2s ease-in-out, opacity 0.5s ease, transform 0.5s ease, visibility 0.5s;
	display: inline-block;width: 200px;height: 80px;text-align: center;text-decoration: none;line-height: 54px;outline: none;position: relative;z-index: 2;background-color: #fff;border: 2px solid #333;color: #333;overflow: hidden; margin:0 auto;	border-style: solid; border-color: #333; border-width: 2px !important;
			font-family: 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'MS UI Gothic', sans-serif; font-size: 1.75rem;	font-weight: 800; letter-spacing: 0.075em; line-height: 1.4em;	padding: 20px 30px;	text-transform: uppercase;
			visibility: visible;
		margin-left: 1%;}
.btn:hover {border-color: #4C74A3 !important; color: #4C74A3; }	

