@charset "UTF-8";

:root {
    /* グローバルのCSS Variablesを上書きする場合にはここに記述 */
}

body {
    animation-name:loading;
    animation-duration:1s;
    animation-fill-mode:forwards;
    animation-delay:0.4s;
    opacity:0;
}

@keyframes loading {
	0% {opacity: 0;}
	100% {opacity: 1;}
}

.hero{
    margin-top:0 !important;
    margin-bottom:0 !important;
}

.p-gh{
    margin-bottom:0 !important;
}
.p-gh__upper{
    border-bottom:none !important;
}

.p-gh__lower{
    border-bottom:none !important;
}

.p-gh__pr{
    text-align: right;
}

.p-gh__pr__logo:hover{
    opacity: 0.7;
}

.asm_logo{
    position: absolute;
    left:0;
    right:0;
    bottom:0;
    top:0;
    margin:9px auto 0;
    width: 250px;
    line-height: 0;
}

.asm_logo img{
    max-width: 100%;
    height:auto;
}

.asm_logo:hover{
    opacity: 0.7;
}

.kv_caption_pc{
    display:block !important;
    width:57.8125vw;
    text-align: center !important;
}

.kv_caption_sp{
    width:95vw;
}

.btn_website{
    display: block;
    /*width:140px;
    height:34px;
    margin:56px auto 40px;*/
    width:8.75rem;
    height:2.125rem;
    margin:3.5rem auto 2.5rem;
    background-color: #000;
    color: #fff;
    text-align: center;
    /*line-height: 34px;
    font-size: 13px;*/
    line-height: 2.125rem;
    font-size: 0.8125rem;
    position: relative;
    font-feature-settings: normal;
}

.btn_website:hover{
    opacity: 0.7;
}

.icon_newwindow{
    position: absolute;
/*    width:12px;
    right:7px;
    top:12px;*/
    width:0.75rem;
    right:0.4375rem;
    top:0.75rem;
}

.sns_link_heading{
    text-align: center;
    font-weight: 700;
    font-size: 1.125rem;
    margin-bottom:1.875rem;
}

.sns_link{
    display: flex;
    justify-content: center;
    gap:65px;
}

.sns_link li{
    width:65px;
    line-height: 0;
}

.sns_link li:nth-last-of-type(1){
    width:62px;
}

.sns_link li:hover{
    opacity: 0.7;
}

.logo_bottom{
    /*width:150px;*/
    width:9.375rem;
    text-align: center;
    line-height:0;
    margin-left:auto;
    margin-right:auto;
    /*margin-top:140px;
    margin-bottom:30px;*/
    margin-top:8.75rem;
    margin-bottom:1.875rem;
}
.logo_bottom img{
    max-width: 100%;
    height: auto;
}

.logo_bottom:hover{
    opacity: 0.7;
}

/*20251203-------------------------------------*/
.p-gf__main__menu ul {
  display: flex;
  flex-wrap: wrap;
}
.p-gf__main__menu a {
  display: inline-block;
  width: auto;
  margin: 10px auto 0;
  text-align: center;
  font-size: 12px;
  line-height: 1.4rem;
  font-weight: 400;
  color: #000;
}
.p-gf__main__menu a:hover {
  text-decoration: underline;
}
.p-gf__main__menu ul li {
  margin: 0 0 0 0.75rem;
}
.p-gf__main__menu ul li:nth-child(1) {
  margin: 0;
}
.p-gf__main__menu ul li::after {
  content: "|";
  color: rgba(0,0,0,0.3);
  margin: 0 0 0 0.75rem;
  padding: 0 0 0 0;
  font-size: 14px;
}
.p-gf__main__menu ul li:nth-last-child(1)::after {
  content: "";
}


.margin-copy {
    margin-top: 2rem !important;
}
@media (max-width: 768px) {
  .p-gf__main__menu ul {
    justify-content: space-between;
  }
  .p-gf__main__menu ul li {
    margin: 0;
  }
  .p-gf__main__menu ul li::after {
    content: "";
    margin: 0 0 0 0.75rem;
  }
  .p-gf__main__menu a {
    text-decoration: underline;
  }
}
/*---------------------------------------------*/

@media only screen and (min-device-width: 320px) and (max-width: 767px) {    
    .p-gh__upper{
        border-bottom:solid 1px #dadada !important;
    }

    .p-gh__pr span{
        transform: scale(85%);
        transform-origin: right center;
    }

    .sns_link{
        display: flex;
        justify-content: center;
        /*gap:50px;
        margin-bottom:70px;*/
        gap:13.33333333vw;
        margin-bottom:18.66666667vw;

    }

    .sns_link li{
        /*width:50px;*/
        width:13.33333333vw;
        line-height: 0;
    }

    .sns_link li:nth-last-of-type(1){
        /*width:48px;*/
        width:12.8vw;
    }

    .logo_bottom{
        /*margin-top:110px;
        margin-bottom:30px;*/
        margin-top:29.33333333vw;
        margin-bottom:8vw;
    }
}