@charset "UTF-8";
html{
    scroll-behavior: smooth;
}
*{
    box-sizing: border-box; /* 余白や線を幅や高さに含める */
}

body{
    font-family:"M PLUS 1p", sans-serif;
    margin:0px;
}

/* 画面サイズ対応 */
@media screen and (max-width: 480px) {
	/* スマホ */
    .fontsizeLarge{
        font-size: 30pt;
    }
    .fontsizeMedium{
        font-size: 20pt;
    }
    .fontsizeHeader{
        font-size: 10pt;
    }
    .fontsizeSmall{
        font-size: 7pt;
    }
    .fontsizeTeamRole{
        font-size: 7pt;
    }
    .fontsizeTeamName{
        font-size: 13pt;
    }
    .fontsizeTeamComment{
        font-size: 8pt;
    }
    .fontsizeTopMovie{
        font-size:20pt;
    }
    footer{
        color:white;
    }
    .page_top_btn{
        width:50px;
        height:50px;
        right: 37px;
        background: rgb(226,144,71, 1);
    }
    #page_top::before {
        color:white;
    }
    #meltimage{
        right:-60px;
        height:94.5vh;
        visibility:collapse;
    }
}
@media screen and (min-width: 480px) and (max-width: 768px) {
	/* タブレット */
    .fontsizeLarge{
        font-size: 45pt;
    }
    .fontsizeMedium{
        font-size: 30pt;
    }
    .fontsizeHeader{
        font-size: 15pt;
    }
    .fontsizeSmall{
        font-size: 11pt;
    }
    .fontsizeTeamRole{
        font-size: 10pt;
    }
    .fontsizeTeamName{
        font-size: 20pt;
    }
    .fontsizeTeamComment{
        font-size: 12.1pt;
    }
    .fontsizeTopMovie{
        font-size:30pt;
    }
    footer{
        color:white;
    }
    .page_top_btn{
        width:75px;
        height:75px;
        right: 25px;
        background: rgb(226,144,71, 1);
    }
    #page_top::before {
        color:white;
    }
    #meltimage{
        right:-60px;
        height:93vh;
        visibility:collapse;
    }
}
@media screen and (min-width: 769px) {
	/* PC */
    .fontsizeLarge{
        font-size: 60pt;
    }
    .fontsizeMedium{
        font-size: 40pt;
    }
    .fontsizeHeader{
        font-size: 20pt;
    }
    .fontsizeSmall{
        font-size: 18.5pt;
    }
    .fontsizeTeamRole{
        font-size: 15pt;
    }
    .fontsizeTeamName{
        font-size: 30pt;
    }
    .fontsizeTeamComment{
        font-size: 20px;
    }
    .fontsizeTopMovie{
        font-size:40pt;
    }
    footer{
        color:white;
    }
    .page_top_btn{
        width:100px;
        height:100px;
        right: 21px;
        background: rgb(226,144,71, 0);
    }
    #page_top::before {
        color:rgba(0,0,0,0);
    }
    #meltimage{
        right:-60px;
        height:92vh;
        visibility:inherit;
    }
}

.header{
    position: fixed;        /* 位置を固定する */
    top: 0;                 /* 固定する位置を指定 */
    left: 0;                /* 固定する位置を指定 */
    width: 100%;            /* ヘッダーの幅 */
    height: 100px;          /* ヘッダーの高さ */
    background-color: rgba(255,255,255,0);    /* 背景色 */
    padding: 0 2%;          /* 左右に2%の余白 */
    display:flex;           /* ロゴとulを横に並べる */
    justify-content:space-between;  /* imgとulの要素を両端に配置する */
    align-items: center;
    transition: .3s;
    z-index: 10;
    padding: 10px 10px;
}
/* マウスオーバー時に背景色を変える */
.header:hover{
    background-color:rgb(226,144,71);
}
/* ヘッダー（ムービー以下にスクロール時）の背景用 */
.header.header.scroll-nav{
    background-color:rgb(226,144,71);
}
.header.header:hover img#meltimage{
    opacity:100%;
}
.header.header.scroll-nav img#meltimage{
    opacity:100%;
}

.dropdown__lists {
    display: none;
    padding-top:0;
    padding-left:0;
}
.caption_header{
    padding-top:0px;
    text-align:center;
    padding-left:0px;
}
.caption_header:hover{
    padding-top:360px;
}
.caption_header:hover .dropdown__lists {
    display: block;/*Gナビメニューにホバーしたら表示*/
}
.dropdown__list {
    background-color: rgb(226,144,71);
    height: 60px;
    line-height:60px;
    width:100%;
    transition: all .3s;
    position: relative;
    list-style:none;    /* 項目の頭につく・を消す */
    padding:0;
    top:0;
}
.dropdown__list:not(:first-child)::before{
    content: "";
    height: 1px;
    background-color: rgb(226,144,71);
    top: 0;
    left: 0;
}
.dropdown__list:hover {
    background-color:rgb(226,154,91);
}
.dropdown__list a {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    text-decoration: none;
    position: relative;
}

#meltimage{
    max-width:100%;
    transition: .3s;
    opacity:0%;
    position:absolute;
    top:98px;
}


a{
    color:white;
    text-decoration:none;
    transition:0.5s;
    font-size:110%;
}
a:hover{
    opacity:0.5;
}

.contents{
    padding-top:100px;
}
.contents_inner{
    padding-top:100px;
    margin-top:-100px;
}

/* 各項目の見出し */
.contents_header{
    padding-left:3rem;
    font-weight:bold;
    text-wrap:nowrap;
}


.video-box{
    position:relative;
    overflow:hidden;
    width:100%;
    height:100vh;
}
.TopMovie{
    position:absolute;
    top: 50%;
    left:50%;
    min-width:100%;
    min-height:100%;
    -webkit-transform:translate(-50%, -50%);
    -moz-transform:translate(-50%,-50%);
    transform:translate(-50%, -50%);
}
.video-overlay{
    position:absolute;
    top:0;
    left:0;
    display:block;
    width:100%;
    height:100%;
    content:"";
    background:rgba(0,0,0,0.5);
    color:white;
}
.video-overlay-text{
    position:absolute;
    top:40%;
    left:0;
    display:block;
    width:100%;
    height:100%;
    content:"";
    color:white;
    padding-left:50px;
}
.video-overlay-text h1{
    font-size:60pt;
    white-space:nowrap;
}


iframe{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
}
.addHeaderMergin{
    padding: 100px 0px 0px 0px;
}

/* History セクション専用に限定 */
#History .Contents_table{
  width:100%;
  max-width:1000px;
  margin:0 auto;
  border-collapse: separate;     /* 行同士に“すき間”を作れるように */
  border-spacing: 0 12px;        /* 行間：12px（好みで調整） */
}

#History .Contents_table td{
  vertical-align: top;           /* ① 各セルの上揃え */
  text-align: left;              /* align 属性よりこちらが優先されます */
  line-height: 1.7;              /* ② セル内の行間（複数行のリンク等に効く） */
  padding: 2px 0;                /* ② さらに上下にゆとり（任意） */
}

#History .Contents_table td:first-child{
  width: 10%;                    /* 日付列の幅（任意） */
  white-space: nowrap;           /* 日付が折り返されないように */
  color:#444;                    /* 任意：日付の色 */
  padding-right: 2rem;           /* 右にスペース */
}

/* 右列（説明列）だけ縦中央揃えに */
#History .Contents_table td:nth-child(2){
  vertical-align: middle;
}

/* 任意：リンクの装飾を統一（各 a に style を直書きしない場合） */
#History a{
  color: coral;
  text-decoration: none;
}

/* 任意：この <ul> の余白のせいで全体が右にズレる場合は消す */
#History ul{ list-style:none; padding-left:0; margin:0; }

.games_contents_centering{
    /*outline:dashed 1px black;*/
    padding:0px;
    margin:0px;
    max-width:940px;
}
.games_contents_item{
    /*outline:dashed 1px black;*/
    margin:0 3rem;
}
img.games_image{
    max-width:"960px";
    max-height:"540px";
}
img.games_sub_image{
    max-width:192px;
    max-height:108px;
    width:100%;
}
img.games_sns_image{
    padding-left:15px;
    width:65px;
}
.btn{
    border:0px;
    padding:0px;
}

.contents_aboutus_centering{
    text-align:center;
}


/* 灰色の下敷き位置制御 */
.UnderlayPosControll{
    text-align:center;
    margin-bottom:40px;
    margin-left:3rem;
    margin-right:3rem;
}
/* 灰色の下敷き */
.underlay_gray{
    margin:auto;
    max-width:700px;
    padding-bottom:1rem;
    border-radius:20px;
    background-color:rgb(241, 239, 236);
}
/* ボタン */
.contents_contact_button{
    cursor:pointer;
    padding-top:0px;
    border:0px;
    border-radius:10px;
    font-weight:bold;
    max-width:100%;
    height:60px;
    color:white;
    background-color:rgb(226,144,71);
}
.contents_ir_item_root{
    border-top:dashed 1px black;
    padding-inline-start:100px;
    padding-inline-end:100px;
}
.contents_ir_item{
    border-bottom:dashed 1px black;
    display:flex;
    place-items:center;
    padding-inline-start:100px;
}
.contents_ir_item_ul{
    display: flex;      /* 項目を横に並べる */
    align-items:center;
    padding-inline-start:0px;
}
.contents_ir_item_li{
    list-style:none;    /* 項目の頭につく・を消す */
    padding-right:20px; /* 項目の間隔、右にXpxずらして次項目 */
}
a.contents_ir_pdf_link{
    text-decoration:underline;
    color:rgb(226,144,71);
}

li.games_contents_main_image{
    list-style:none;    /* 項目の頭につく・を消す */
}
li.games_contents_sub_image{
    list-style:none;    /* 項目の頭につく・を消す */
    display:inline;
}
.games_contents_sns_image{
    float:left;
}

button.btn{
    background:rgba(255,255,255,0);
    filter:opacity(55%);
}

button.btn.show{
    color:rgba(255,255,255,50);
    filter:opacity(100%);
}



.video_wrapper {
    position: relative;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
}

.video_wrapper > video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    min-width: 100%;
    min-height: 100%;
}

/* IRテーブル */
.IR_table{
    margin:0 auto 3rem auto;
    width:100%;
    text-align:center;
}
.IR_table td{
    border-style:dashed;
    border-color:rgba(80,80,80,0.5);
    border-top:0px;
    border-left:0px;
    border-right:0px;
}

/* トップへ戻るボタン */
.page_top_btn {
    position: fixed;
    bottom: 10px;
    border-radius: 50%;
    opacity: 0;
    transition: .3s;
    z-index: 15;
    pointer-events:none;
}
.page_top_btn.show{
    opacity: 1;
    pointer-events:auto;
}
/* 「↑」設定 */
#page_top::before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f106';
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
}

/* フッター */
footer{
    background-color:rgb(74,54,36);
    text-align:center;
    padding-top:10px;
    padding-bottom:30px;
}
.CorporateInfo{
    padding:0 2rem;
    text-wrap:nowrap;
}
