/*///////////////// style ////////////////*/

article h1 {
    font-size: 24px;
    text-align: center;
    font-weight: 700;
    padding: 30px 0 20px;
}

article h2 {
    font-size: 1.2rem;
    text-align: center;
    font-weight: 700;
    margin-bottom: 30px;
}
article h4 {
text-align: center;
}


article p{
font-size: .9rem;
line-height: 1.6;
text-align: justify;
font-feature-settings: "palt";
}

.cGold{
  background: linear-gradient(90deg, #C99B20 0%,  #AA7701 80%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}


.mitei_txt{
text-align: right;
padding: 10px 20px 0 0;
font-size: 10px;
color: #7b7b7b;
}

@media (min-width: 768px) {
main{
margin: auto;
width:90vw;
max-width:1200px;
}
article h1 {
  font-size: 32px;
  padding: 60px 0 20px;
}
#athlete p{font-size: 1rem;}

.mitei_txt{
font-size: 12px !important;
padding: 30px 10px 0 0;
}

.smp{display: none;}
}


/*///////////////// 選手紹介 ////////////////*/
#athlete div#con-body{
color:#000;
background-color:#ECECEC;
}

#athlete .sub_nav{
display: flex;
justify-content:space-around;
flex-wrap: wrap;
margin: auto;
max-width: 800px;
}
#athlete .sub_nav li{
width: 32%;
text-align: center;
}
#athlete .sub_nav li:last-child{
width: 70%;
margin-top: .5em;
}

#athlete .sub_nav li a
{
display: flex;
justify-content: center;
align-items: center;
color: #fff;
background:#745399;
aspect-ratio: 120/40;
border-radius: 4px;
text-decoration: none;
box-sizing: border-box;
transition: background-color 0.3s, color 0.3s;
}

#athlete .sub_nav li:last-child a
{
aspect-ratio: 120/20;
border-radius: 4px;
background: #A48B78;
/*background: linear-gradient(90deg, #C99B20 0%, #AA7701 100%);*/
border-image: initial;
}

#athlete #big7 .sub_nav li:last-child a,
#athlete .sub_nav li:last-child a:hover
{
color: #624834;
border:solid 2px #A48B78;
background: linear-gradient(90deg, #c2b0a2 0%,#ffffff 50%, #c2b0a2  100%);
border-image: initial;
}


#athlete .sub_nav li a span{
display: block;
font-size: .8em;
line-height: 1.2;
}


#athlete #m .sub_nav li:first-child a,
#athlete #f .sub_nav li:nth-child(2) a,
#athlete #w .sub_nav li:nth-child(3) a,
#athlete .sub_nav li a:hover
{
color: #A48B78;
border:solid 2px #A48B78;
background:#fff;
}


#athlete .in_box{
    background-color: #fff;
}
#athlete .in_box,
#athlete .in_box2
{
    margin: 20px 10px;
    border-radius: 15px;
    padding: 30px 0;
}
#athlete .eventbox{
margin: auto;
width: 90%;
max-width: 1080px;
}

@media (min-width: 768px) {
#athlete .in_box,
#athlete .in_box2{
    padding: 30px;
    margin: 30px auto;
    max-width: 1200px;
}
#athlete .sub_nav li a span{
display: block;
font-size: 1.1em;
}
}






/*///////////////// カテゴリボタン ////////////////*/


.event-categories {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px;
    margin-bottom: 40px;
}

.nolink .category-button {
opacity: .5;
}
.category-button {
    display: flex;
    align-items: center;
    gap: 10px;
    border: 2px solid #A48B78;
    border-radius: 4px;
    background-color: #fff;
    cursor: pointer;
    transition: all 0.2s;
    min-height: 60px;
}

a .category-button:hover {
    background-color: #745399;
    color: #fff;
    border-color: #745399;
    transition: background-color 0.3s, color 0.3s;
}

a .category-button:hover span{
    color: #fff;
}

.category-button img {
    width: 100%;
    vertical-align: middle;
}

.category-button:hover img {
    opacity: 1;
}

.category-button span {
    font-size: .75rem;
    color:#A48B78;
    font-weight: bold;
    padding: 10px 0;
  font-feature-settings: "palt" 1;
}

.category-icon {
    width: 60px;
    height: auto;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}


/* genderボタン */

#w .event-gender {
display: flex;
justify-content:space-around;
align-items: center;
width: 80%;
max-width: 500px;
margin: auto;
}


#w .gender-button {
display: flex;
justify-content:center;
align-items:center;
aspect-ratio: 12/3;
max-width: 240px;
width:40%;
    color: rgb(255, 255, 255);
    font-weight: bold;
    font-size: 0.9rem;
    cursor: pointer;
    padding: 8px 0;
    border: solid 1px #C99B20 ;
    background: #C99B20 ;
    border-image: initial;
    border-radius: 5px;
    transition: 0.3s;
box-sizing: border-box;
}

#w .gender-button:hover{
color: #C99B20 ;
background: #ffedc2 ;
    border-radius: 5px;
    transition: all 0.3s;
box-sizing: border-box;
}



@media (min-width: 768px) {
    .event-categories{
        margin: 0 auto 40px;
        max-width: 880px;
    }
    .category-button span{
        font-size: 1rem;
    }
}



/*///////////////// 選手一覧 ////////////////*/
#athlete h3{
margin:2em 1% 1em;
background: #745399;
color: #fff;border-radius: 3px;
text-align: center;
padding:.5em 0;
border-radius: 50px;
}

.playerList .athlete_list{
display: flex;
flex-wrap: wrap;
justify-content: flex-start;
}
.playerList .athlete_list li{
width: 48%;
margin: 1%;
}

#big7.playerList .athlete_list li{
width: 100%;
}

.playerList .athlete_list li a{
 position: relative;
  display: block;
}
.playerList .athlete_list li a:hover{
opacity: .7;
transition: .5s;
}


.playerList .athlete_list li span,
.player_list li span{
display: block;
  word-break: keep-all;        /* 句読点での改行を促進 */
  overflow-wrap: anywhere;     /* 任意の場所での折り返しを許可 */
max-width: 100%;
line-height: 1.2;
text-align: center;
}

.playerList .athlete_list li span.catch{
background: #A48B78;
color: #fff;
font-size: .6rem;
padding:.5em;
min-height: 3em;
display: flex;
justify-content: center;
align-items: center;
}
#big7 .athlete_list li span.catch{
background: linear-gradient(90deg, #C99B20 0%, #AA7701 100%);
color: #fff;
font-size: .8rem;
}

.playerList .athlete_list li span.name,
.player_list li span.name{
margin:.5em 0;
font-size: .8rem;
}
#big7 .athlete_list li span.name{
font-size: 1rem;
}

.playerList .athlete_list li span.event,
.player_list li span.event{
color: #A48B78;
font-size: .6rem;
margin-bottom: 1em;
}
#big7 .athlete_list li span.event{
font-size: .8rem;
}

.playerList .athlete_list li .lazy{
display: block;
aspect-ratio: 1/1;
background-size:cover;
background-color: #e9d9cd;
}


@media (min-width: 768px) {
.playerList .athlete_list li{
width: 23%;
margin: 1%;
}

#big7.playerList .athlete_list li{
width: 48%;
margin: 1%;
}

.playerList .athlete_list li span.catch{
font-size: .8rem;
}
#big7 .athlete_list li span.catch{
font-size: 1rem;
}
.playerList .athlete_list li span.name,
.player_list li span.name{
font-size: 1rem;
}
#big7 .athlete_list li span.name{
font-size: 1.2rem;
}
.playerList .athlete_list li span.event,
.player_list li span.event{
font-size: .8rem;
}
#big7 .athlete_list li span.event{
font-size: 1rem;
}

}

/*///////////////// 個別ページ ////////////////*/

.player figure{
position: relative;
display: flex;
flex-wrap: wrap;
margin: auto;
}
.player .flag{
position: absolute;
top: 10px;
right: 10px;
max-width: 100px;
width: 10%;
z-index: 5;
}


.player figure .lazy{
display: block;
width: 100%;
aspect-ratio: 1/1;
background-size:cover;
z-index: 1;
}

#big7 figure .lazy{
aspect-ratio: 4/3 !important;
background-size:cover;
}

.player figure.main_img .lazy{
display: flex;
align-items: flex-end;
}

.player figcaption{
display: block;
width: 100%;
background: linear-gradient(rgba(255, 255, 255, 0),rgba(255, 255, 255,.9),rgb(255, 255, 255));
}

.player figcaption div{
padding: 5em 1em 1em;
}


.player figcaption h2{
text-align: left;
font-size: 1.3rem;
line-height: 1.2;
margin:0 0 .5em !important;
color: #000;
}
.player figcaption .catch{
text-align: left;
font-size: 1.1rem;
line-height: 1.2;
color: #A48B78;
}

.player .player_data{
width: 90%;
max-width: 800px;
margin:0 auto;
}

.player .player_data li small{
    display: block;
    font-size: 1.8vw;
    width: 100%;
}

.player .player_data ul{
width: 100%;
border: solid 1px #A48B78;
margin-bottom: 2em;
border-radius: 10px;
padding-inline-start:0%;
}
.player .player_data li{
display: flex;
flex-wrap: wrap;
border-bottom:solid 1px #A48B78;
font-size: .8rem;
line-height: 1.6;
}
.player .player_data li:last-child{
border-bottom: none;
}

.player .player_data li span:first-child{
display: flex;
flex-wrap: wrap;
justify-content: center;
align-items: center;
align-content: center;
width: 25%;
color: #A48B78;
text-align: center;
box-sizing: border-box;
border-right:solid 1px #A48B78;
}
.player .player_data li span:last-child{
display: block;
width: 75%;
box-sizing: border-box;
padding: .5em;zw
}


@media all and (min-width:768px) {

.player .player_data{
margin:4em auto;
}
.player figure.main_img .lazy{
aspect-ratio: 4/3 !important;
background-size:contain !important;
}
.player figcaption div{
padding: 8em 2em 2em;
}
.player figcaption h2{
font-size: min(4vw, 3rem);
}
.player .player_data li small{
font-size:.7rem !important;
}
.player figcaption p.catch{
font-size: min(3vw, 2.4rem) !important;
}
.player .player_data li{
font-size: 1rem;
}
}

/*///////////////// mainvideo ////////////////*/

.player .movbox {
width: 90%;
max-width: 800px;
margin:0 auto 4em;
}

.player .main_mov:nth-child(2){
margin-top: 0;
}

.player .main_mov:last-child{
border-bottom:solid 1px #E1DFDF;
}

.player .main_mov .in_mov {
position:relative;
width:100%;
height:0;
padding-top:56.25%;
aspect-ratio:16/9;
margin:0 auto;
white-space:nowrap;
overflow:hidden;
text-indent:110%;
background-position:center;
background-repeat:no-repeat;
background-size:contain;
z-index:1;
}

.player .main_mov .in_mov iframe,
.player .main_mov .in_mov span {
background-size:100%;
display:block;
height:100%;
position:absolute;
left:0;
top:0;
width:100%;
}


.player .main_mov p span {
display:block;
}

.player .main_mov .in_mov a {
position:absolute;
left:0;
top:0;
display:block;
width:100%;
height:100%;
margin-bottom:0;
background-color:transparent;
}


.player .main_mov .cap {
width:100%;
background: #000;
color: #fff;
}

.player .main_mov .cap p{
background: #000;
color: #fff;
padding:1em;
}


@media (hover:hover) {
.player .main_mov .in_mov a :hover {
opacity:0.5;
}
}

@media all and (min-width:768px) {



.player .main_mov {
width:90%;
margin:2em auto 0;
padding-bottom:4em;
display:flex;
justify-content:space-between;
flex-wrap:wrap;
}

.player .main_mov .in_mov {
width:100%;
height:auto;
padding-top:0;
margin:0;
white-space:normal;
overflow:visible;
text-indent:0;
background-position:none;
background-repeat:none;
background-size:auto;
z-index:auto;
}

.player .main_mov .in_mov iframe,
.player .main_mov .in_mov span {
background-size:auto;
display:block;
height:100%;
position:static;
left:auto;
top:auto;
width:100%;
}

.player .main_mov {
width:100%;
}

}

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

.player .main_mov {
width:100%;
margin:0 auto;
padding-bottom:2em;
flex-wrap:wrap;
}

.player .main_mov .in_mov {
width:100%;
}

.player .movbox {
padding-bottom:1em;
}

.player .main_mov {
margin:2em auto 0;
}

.player .main_mov .cap p{
line-height:1.4;
font-size: .8rem;
}

}

/*///////////////// SliderList ////////////////*/

#athlete .SliderList {
	width:100%;
	max-width: 800px;
	margin:20px auto;
	padding:0 50px;
	 /* for space */ font-size:0;
}
#athlete .SliderList { margin-bottom:20px; padding:0 50px; /* for space */ font-size:0; }
#athlete .list-item { display:inline-block; width:200px; margin:0 7px; vertical-align:middle; /* for space */ font-size:1rem; }
#athlete .SliderList .slick-arrow { position:absolute; top:0; width:100px; height:100%; background-position:center center; background-repeat:no-repeat; background-size:50% auto; text-indent:-9999px; /* reset */ background-color:transparent; border:none; cursor:pointer; outline:none; padding:0; appearance:none; text-indent: -9999px; }
#athlete .SliderList .slick-prev { left:-50px; z-index:12; background-image:url(/seriku/img/arrow_left_white.png); }
#athlete .SliderList .slick-next { right:-50px; z-index:13; background-image:url(/seriku/img/arrow_right_white.png); }
#athlete .SliderList .slick-arrow:hover {opacity:0.5; }

@media all and (max-width: 1079px) {

/* SliderList */
#athlete  .SliderList {
	width:80%;
	margin:20px auto;
	padding:0;
	 }
	#athlete  .list-item { width:29vw; margin:0 1vw; }
#athlete .SliderList .slick-arrow {width:80px;}
#athlete .SliderList .slick-prev { left:-40px; }
#athlete .SliderList .slick-next { right:-40px; }
}

/*///////////////// lazy ////////////////*/
.btnArea{
margin:2em auto 0;
text-align: center;
}
a.btn-link {
    display: inline-block;
    padding:1em 2em;
    background-color: #ffffff;
    border: 4px solid #745399;
    border-radius: 50px;
    color: rgb(116, 83, 153);
    text-decoration: none;
    font-weight: bold;
    transition: background-color 0.3s, color 0.3s;
    cursor: pointer;
  font-size: .9rem;
}
a.btn-link:hover {
    background-color: rgba(141,83,153,0.5);
}

@media (min-width: 768px) {
a.btn-link {
font-size: 1rem;
}
}

/*///////////////// recommend ////////////////*/

.more-info h4{
text-align: center;
color: #fff;
font-size:18px ;
margin-bottom: 1em;
}
@media (min-width: 768px) {
.more-info h4{
font-size:24px ;
}
}

/*///////////////// lazy ////////////////*/
.lazy {
  position:relative;
  display:block;
  background:center top no-repeat;
  background-size:cover;
  margin:0 auto;
}
.lazy img{
  position:absolute;
  top:0;
  left:0;
}




/********* Uniweb ***********/
[data-uniweb--contrast-modified] #athlete #big7 .sub_nav li:last-child a{
    border: solid 2px #A48B78;
    background: rgb(0 0 0 / 0);

}

.accessibility--FIH .category-icon .uniweb--itt-text,.accessibility--FITT .category-button span.uniweb--itt-text{
    font-size: .7rem;
}

.accessibility--FIH .event-categories a:hover .uniweb--itt-text,.accessibility--FITT .event-categories a:hover span.uniweb--itt-text{
    color: #A48B78;
}
