@charset "utf-8";
/*------------------------------------------------------------------------------------------
*
*
    index_pc.css
*
*
------------------------------------------------------------------------------------------ */
@media (min-width : 641px){ 
/*------------------------------------------------------------------------------------------
*
*
    min-width : 641px
*
*
------------------------------------------------------------------------------------------ */
#bg{
    width: 100%;
    height: 100vh;
    background-color: #fff;
    background-repeat: no-repeat;
    background-position: center;
    position: fixed;
    z-index: 0;
    top: 0;
    left: 0;
}

#wrap{
    position: relative;
    z-index: 2;
}

article{
    max-width: 740px;
    padding: 20px 40px;
    background-color: #fff;
    margin: 0 auto;
}

/* --------------------------------------------------
*
    #kv
*
-------------------------------------------------- */
#kv{
    margin: 0 0 50px 0;
    text-align: center;
    line-height: 0;
}

#kv img{ width: 100%;}



/* --------------------------------------------------
*
    #yodogawa
*
-------------------------------------------------- */
#yodogawa{
    padding: 40px 0 0 0;
    text-align: center;
}

/* #yodogawa.bd_t.bd_none{ margin-top: -50px !important;} */
#yodogawa.bd_t.bd_none{ margin-top: -50px;}

#yodogawa .inner{
    text-align: left;
    display: inline-block;
}

#yodogawa p{
    margin: 0 0 2em 0;
    line-height: 2em;
}

#yodogawa .btn_profile{
    margin: 0;
}

#yodogawa a{
    padding: 0 0 1px 0;
    border-width: 0;
    border-style: solid;
    transition: border .1s ease;
}

.is_pc #yodogawa a:hover,
.is_sp #yodogawa a.touch{
    border-bottom-width: 1px;
    border-bottom-style: solid;
    /* transition: border .15s ease; */
}

.profile_inner,
.modal_content_inner {
    max-width: 600px;
    margin: 20px auto;
    padding: 20px;
    background-color: #fff;
    text-align: left;
}

.profile_inner .pic,
.modal_content_inner .pic {
    margin: 0 0 40px 0;
}

.profile_inner .pic img,
.modal_content_inner .pic img {
    width: 100%;
}

.profile_inner .pic .caption,
.modal_content_inner .pic .caption {
    margin: 5px 0 0 0;
    display: block;
    font-size: 13px;
    color: #666;
    line-height: 1.6em;
    text-align: right;
}
.profile_inner .pic .caption.caption_left,
.modal_content_inner .pic .caption.caption_left {
    text-align: left;
}
.profile_inner .pic .caption.caption_center,
.modal_content_inner .pic .caption.caption_center {
    text-align: center;
}

.profile_inner h3,
.modal_content_inner h3 {
    max-width: 450px;
    margin: 0 auto 30px auto;
    font-size: 27px;
}

.profile_inner h3 .s,
.modal_content_inner h3 .s {
    margin: 0 0 0 5px;
    font-size: 18px;
}

.profile_inner .desc,
.modal_content_inner .desc {
    max-width: 450px;
    margin: 0 auto;
}

.profile_inner .desc p,
.modal_content_inner .desc p {
    margin: 0 0 1.5em 0;
    line-height: 2em;
}

.profile_inner .desc p a,
.modal_content_inner .desc p a {
    padding: 0 0 1px 0;
    border-width: 0;
    border-style: solid;
    transition: border .1s ease;
}

.is_pc .profile_inner .desc p a:hover,
.is_sp .profile_inner .desc p a.touch,
.is_pc .modal_content_inner .desc p a:hover,
.is_sp .modal_content_inner .desc p a.touch {
    border-bottom-width: 1px;
    border-bottom-style: solid;
    transition: border .15s ease;
}

/* --------------------------------------------------
*
    #index_nav
*
-------------------------------------------------- */
#index_nav{
    margin: 50px 0;
    text-align: center;
}
 
#index_nav a{
    padding: 50px 0;
    display: block;
    transition: opacity .1s ease;
}

.is_pc #index_nav a:hover,
.is_sp #index_nav a.touch{
    opacity: .7;
    transition: opacity .15s ease;
}

#index_nav .disabled a{ opacity: 1 !important; cursor: default;}
#index_nav .disabled a .title{ opacity: .3 !important; cursor: default;}

#index_nav .title{
    padding: 0 15%;
    margin: 0 0 35px 0;
    font-size: 200%;
    letter-spacing: .05em;
    line-height: .7em;
}
#index_nav .title:last-child {
    margin-bottom: 0px;
}

#index_nav .title .s{
    margin: 0 0 10px 0;
    font-size: 70%;
    display: block;
}

#index_nav .title img{
    width: 100%;
    opacity: 1;
}

#index_nav .date{
    font-size: 13px;
    letter-spacing: .1em;
    color: #666;
}


/* --------------------------------------------------
*
    talk_nav
*
-------------------------------------------------- */
#talk_nav, .talk_nav{
    margin: 60px 0;
    padding: 30px 0;
}

#talk_nav ul, .talk_nav ul{
    padding: 0 50px 20px 50px;
    display: flex;
    justify-content: space-between;
}

#talk_nav .disabled, .talk_nav .disabled{
    visibility: hidden;
}

#talk_nav ul img, #talk_nav ul svg,
.talk_nav ul img, .talk_nav ul svg{
    width: 67px;
    height: 67px;
    opacity: 1 !important;
}

#talk_nav li a, .talk_nav li a{
    padding: 0 0 15px 0;
    transition: opacity .1s ease;
    position: relative;
}

.is_pc #talk_nav li a:hover,
.is_sp #talk_nav li a.touch,
.is_pc .talk_nav li a:hover,
.is_sp .talk_nav li a.touch{
    opacity: .7;
    transition: opacity .15s ease;
}

#talk_nav li a:after, .talk_nav li a:after{
    margin: 0 0 0 2px;
    display: block;
    font-size: 12px;
    color: #000;
    letter-spacing: .15em;
    text-align: center;
    white-space: nowrap;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

#talk_nav .prev a:after,
.talk_nav .prev a:after{
  content: '前へ';
}
#talk_nav .index a:after,
.talk_nav .index a:after{
  content: '目次ページへ';
}
#talk_nav .next a:after,
.talk_nav .next a:after{
  content: '次へ';
}


/* --------------------------------------------------
*
    #talk_wrap
*
-------------------------------------------------- */
#talk_wrap h2{
    margin: 0 0 60px 0;
    text-align: center;
    font-size: 200%;
    letter-spacing: .05em;
    line-height: .7em;
}

#talk_wrap h2 .s{
    margin: 0 0 10px 0;
    font-size: 70%;
    display: block;
}

#talk_wrap h2 img{
    width: 100%;
    max-width: 560px;
}

#talk_body .pic{
    max-width: 620px;
    margin: 0 auto 40px auto;
    text-align: center;
}

#talk_body .pic.v{
    max-width: 480px;
}

#talk_body .pic img{
    width: 100%;
}

#talk_body .pic .caption{
    margin: 5px 0 0 0;
    display: block;
    font-size: 13px;
    color: #666;
    line-height: 1.6em;
    text-align: right;
}
#talk_body .pic .caption.caption_left{
    text-align: left;
}
#talk_body .pic .caption.caption_center{
    text-align: center;
}

#talk_body dl,
.info_taidan_txt dl{
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
}

#talk_body dt,
.info_taidan_txt dt{
    width: 25%;
    padding: 0 5% 0 0;
    font-weight: bold;
    text-align: right;
    box-sizing: border-box;
    line-height: 2em;
    letter-spacing: .1em;
    white-space: nowrap;
}

#talk_body dt.t_h,
.info_taidan_txt dt.t_h,
#talk_body dt[data-name="──"],
.info_taidan_txt dt[data-name="──"] {
    letter-spacing: -.05em;
    position: relative;
    left: -.25em;
}

#talk_body dt[data-name="ーー"],
.info_taidan_txt dt[data-name="ーー"] {
    letter-spacing: -.2em;
    position: relative;
    left: -.4em;
}

#talk_body dd,
.info_taidan_txt dd{
    margin: 0 0 2em 0;
    width: 60%;
    line-height: 2em;
    white-space: nowrap;
    text-align: left;
}

#talk_body dd + dd,
.info_taidan_txt dd + dd{
    padding-left: 25%;
}

.info_plane_txt {
  text-align: left;
  width: 420px;
  max-width: 90%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2em;
  line-height: 2;
  white-space: nowrap;
}
.info_plane_txt p + p {
  margin-top: 2em;
}

#talk_body a{
    padding: 0 0 1px 0;
    border-width: 0;
    border-style: solid;
    transition: border .1s ease;
}

.is_pc #talk_body a:hover,
.is_sp #talk_body a.touch{
    border-bottom-width: 1px;
    border-bottom-style: solid;
    transition: border .15s ease;
}

#talk_body .txt_box{
    max-width: 700px;
    padding: 40px;
    margin: 20px auto 60px auto;
    box-sizing: border-box;
}

#talk_body .txt_box .pic{
    width: 100%;
    margin: 0 auto 40px auto;
}

#talk_body .txt_box .pic.v{
    max-width: 480px;
}

#talk_body .txt_box .pic img{
    width: 100%;
}

#talk_body .txt_box .pic .caption{
    font-size: 13px;
    color: #666 !important;
    display: block;
}

#talk_body .txt_box span{
    line-height: 1.6em;
}

#talk_body .txt_box .desc{
    max-width: calc(100% - 160px);
    margin: 0 auto;
}

#talk_body .txt_box .desc p{
    margin: 0 0 2em 0;
    line-height: 1.8em;
}

#talk_body .txt_box .desc p:last-child{ margin: 0;}

#talk_wrap .talk_end{
    margin: 60px 0;
    text-align: center;
}

#talk_wrap .talk_end p{
    margin: 0 0 30px 0;
}


/* --------------------------------------------------
*
    #information
*
-------------------------------------------------- */
#information, #information_free{
    text-align: center;
}

#information li, #information_free li{
    margin: 0 0 50px 0;
    padding: 0 0 50px 0;
}

#information li .info_desc ul, #information_free li .info_desc ul{
    list-style: disc;
    margin-left: 1.5rem;
}

#information li .info_desc li, #information_free li .info_desc li{
    margin-bottom: 1rem;
    padding: 0;
}

#information .info_title, #information_free .info_title{
    padding: 0 0 0 0;
    display: inline-block;
    text-align: left;
}

#information .info_title, #information_free .info_title{
    margin: 0 0 25px 0;
    line-height: 2.3em;
}

#information ul, #information_free ul{
}

#information li .info_img, #information_free li .info_img:not(:last-child){
    margin: 0 0 20px 0;
}

#information li .info_img img, #information_free li .info_img img{
    width: 100%;
    max-width: 540px;
}

#information li .info_desc, #information_free li .info_desc{
    max-width: 360px;
    margin: 0 auto;
    text-align: left;
}
#information li .info_desc.information_default, #information_free li .info_desc.information_default {
    max-width: 27em;
}

#information li .info_desc p, #information_free li .info_desc p{
    margin: 0 0 1em 0;
    line-height: 2em;
}

#information li .info_desc a, #information_free li .info_desc a{
    padding: 0 0 1px 0;
    border-width: 0;
    border-style: solid;
    transition: border .1s ease;
}

.is_pc #information li .info_desc a:hover,
.is_sp #information li .info_desc a.touch,
.is_pc #information_free li .info_desc a:hover,
.is_sp #information_free li .info_desc a.touch{
    border-bottom-width: 1px;
    border-bottom-style: solid;
    transition: border .15s ease;
}



/* --------------------------------------------------
*
    footer
*
-------------------------------------------------- */
footer{
    position: relative;
    z-index: 2;
}

footer .inner{
    max-width: 820px;
    padding: 0 50px;
    box-sizing: border-box;
    margin: 0 auto;
    position: relative;
}

footer li span{
    display: block;
    vertical-align: middle;
}

footer li a{
    transform: opacity .1s ease;
}

footer li a:hover{
    opacity: .7;
    transform: opacity .15s ease;
}

footer .share{
    display: flex;
    padding-top: 6px;
}

footer .share li{
    margin: 0 35px 0 0;
    line-height: 0;
}

footer .hobo{
    display: flex;
    position: absolute;
    align-items: center;
    top: 6px;
    right: 50px;
}

footer .hobo li{
    margin: 0 0 0 35px;
}

footer .hobo img{
    width: auto;
    height: 24px;
}

footer .copyright{
    padding: 60px 0 40px 0;
    text-align: center;
    font-size: 12px;
    color: #888;
    letter-spacing: .1em;
}

footer .share_title{
    border-top: 1px solid #0a1464;
    border-bottom: 1px solid #0a1464;
    font-size: 12px;
    font-weight: bold;
    color: #0a1464;
}

footer .share_title span{
    display: block;
    line-height: 1em;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
}

footer .share li a{
    font-size: 38px;
}

footer .email span{
    display: inline-block;
    margin: -4px 5px 0 0;
    font-size: 30px;
}

footer .email{
    margin: 3px 0 0 0;
    font-size: 13px;
    font-weight: bold;
    color: #0a1464;
}

footer .ico_home span{
    margin: -8px 0 0 0;
    display: block;
    font-size: 38px;
}

} /* ----- min-width : 641px ----- */



@media (max-width: 800px) and (min-width: 641px){

/* --------------------------------------------------
*
    footer
*
-------------------------------------------------- */

footer{
    text-align: center;
}

footer .share{
    max-width: 300px;
    justify-content: space-between;
    margin: 0 auto 40px auto;
}

footer .share li{ margin: 0;}

footer .hobo{
    max-width: 300px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    margin: 0 auto;
    top: 0;
    right: 0;
}

footer .hobo li{ margin: 0;}

} /* ----- max-width : 800px ----- */
