@charset "utf-8";
/*
Theme Name: ash18
*/

html.is-scroll-prevent {
    height: 100%;
    overflow: hidden;
}


* {
    margin: 0;
    padding: 0;
}

img {
    vertical-align: top;
    border: none;
    margin: 0;
    padding: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

figure{
    margin: 0;
}

ul {
    list-style: none;
}

a {
    overflow: hidden;
    cursor: pointer;
    color: #09132D;
    text-decoration: none;
    transition: 0.5s ease-out;
}

a:hover {
    text-decoration: underline;
}

a:focus,
*:focus {
    outline: none;
}

a img{
    position: relative;
    transition: 0.8s ease-out;
}

a:hover img{
    filter: grayscale(100%);
}

::-moz-selection {
    background: #09132D;
    color: #fff;
    text-shadow: none;
}

::selection {
    background: #09132D;
    color: #fff;
    text-shadow: none;
}

* {
    box-sizing: border-box;
}


html {
    height: 100%;
    font-size: 62.5%;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1;
    letter-spacing: 0.08em;
    font-weight: 500;
    color: #09132D;
    background: #a7a4a3;
    position: relative;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

input,
textarea,
button {
    font-family: 'Noto Sans JP', sans-serif;
    letter-spacing: 0.06em;
    font-weight: 500;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    background: none;
    border-radius: 0;
    transition: 0.3s ease-out;
    cursor: pointer;
    color: #09132D;
    border: none;
}

svg {
    vertical-align: middle;
    fill: currentcolor;
    transition: 0.5s ease-out;
}

.flex{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.en {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 500;
}

.link-box{
    width: 26rem;
    height: 7rem;
    border-radius: 50vmax;
    position: relative;
    margin: 6rem auto 0;
    text-align: center;
    border: 2px solid;
    font-size: 1.8rem;
    justify-content: center;
    align-items: center;
    overflow: visible;
    font-weight: 500;
}

.link-box span.en{
    font-size: 3.1rem;
    padding-right: 0.3rem;
}

.link-box div{
    width: 4rem;
    height: 2px;
    width: 0;
    height: 0;
    position: absolute;
    left: -2rem;
    top: 0;
    bottom: 0;
    margin: auto;
    z-index: 1;
    background: #09132D;
}

.link-box:hover{
    background: #09132D;
    color: #fff;
    border-color: #09132D;
    text-decoration: none;
}

.link-box:hover div,
.link-box:hover div::after{
    background: #fff;
}

.link-arrow {
    justify-content: flex-end;
    align-items: center;
    text-transform: uppercase;
}

.link-arrow div{
    width: 4rem;
    height: 2px;
    margin-right: 1.2rem;
    background: #555555;
}

.page-ttl {
    font-size: 5.4rem;
    line-height: 1.3;
    margin: 0;
    padding-bottom: 6rem;
    text-align: center;
    text-transform: uppercase;
}

.content-in {
    width: calc(1166 / 1366 * 100%);
    max-width: 1166px;
    margin-left: auto;
    margin-right: auto;
}

.content-in-sub {
    width: calc(920 / 1166 * 100%);
    margin-left: auto;
    margin-right: auto;
}

body:not(.home) .main-content-wapper{
    padding-top: 20rem;
    margin-bottom: 16rem;
}

.post-list img,
.thumbnail-img img,
.main-slider .swiper-slide img {
    width: 100%;
    height: auto;
}

.entry-content img {
    width: 100%;
    height: auto;
}

.shop-page-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -moz-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -ms-flex-pack: space-between;
    --ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.post-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    word-wrap: break-word;
}

.post-list-4{
    margin:0 -1.6rem;
}

.post-list-4 article {
    width: 25%;
    padding:0 1.6rem 3.2rem;
}

.post-list img{
    margin-bottom: 2rem;
}

body:not(.post-type-archive-stamprally).post-list img{
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.sub-main-content-in {
    width: 66%;
}

.side-menu {
    width: 24%
}

/*テキスト*/

.ttl-01{
    font-size: 6rem;
    line-height: 1.3;
}

.ttl-02{
    font-size: 4.8rem;
    line-height: 1.3;
}


/* ヘッダー */

.header-content-wrapper{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    padding-top: 3.6rem;
    z-index: 1;
}

.header-content-in{
    position: relative;
    padding-bottom: 3.6rem;
}

.header-ttl{
    width: 40rem;
    margin: 0;
}

.header-ttl img{
    width: 100%;
}

.header-search{
    position: absolute;
    right: 0;
    top: 1.6rem;
}

.header-search input{
    font-size: 1.4rem;
    vertical-align: middle;
}

.home .header-search input{
    color: #fff;
}

.header-search input::placeholder{
    color: inherit;
    opacity: .65;
}

.search_bar_container form{
    border-bottom: 1px solid;
    padding-bottom: 0.8rem;
}

.home .header-search{
    color: #fff;
}

.home .header-search svg{
    fill: #fff;
}

.search-ttl{
    font-weight: 500;
    padding-bottom: 6rem;
    font-size: 2rem;
}

.header-menu{
    justify-content: space-between;
    align-items: center;
}

.header-menu-main {
    align-items: center;
    width: 85%;
}

.header-menu-main li{
    padding-bottom: 0.4rem;
}

.header-menu-main li + li {
    margin-left: 2.4%;
}

.header-menu-main li > a{
    font-size: 2.2rem;
    padding: 0 .2rem .2rem;
    text-transform: uppercase;
    position: relative;
}


.home .header-menu-main li > a{
    color: #fff;
}

.header-menu li a svg{
    margin-top: -0.4rem;
}

.home .header-menu li a svg{
    fill: #fff;
}

.header-menu-main li > a:after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 0;
    height: 2px;
    background-color: #09132D;
    transition: .3s;
}

.home .header-menu-main li > a:after{
    background-color: #fff;
}

.header-menu-main li > a:hover{
    text-decoration: none;
}

.header-menu-main li > a:hover:after {
    width: 100%;
}

.sns-link{
    justify-content: flex-end;
    align-items: center;
}

.header-menu .sns-link{
    width: 15%;
}

.header-menu .sns-link li + li{
    padding-left: 2rem;
}

.header-menu .sns-link svg{
    width: auto;
    height: 2rem;
}

.home .header-menu .sns-link svg{
    fill: #fff;
}

.sns-link a:hover svg{
    fill: #09132D;
}


.top-fixed {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    height: 100vh;
    pointer-events: none;
    z-index: 2;
}

.top-date{
    position: absolute;
    right: 2.2rem;
    top: 0;
    bottom: 0;
    margin: auto;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 2rem;
    letter-spacing: 0.22rem;
    color: #fff;
}

/* フッター */

.footer-content{
    background: #09132D;
    color: #fff;
    padding: 14rem 0 10rem;
}

.footer-content a{
    color: #fff;
}

.footer-instagram-container{
    padding-bottom: 16rem;
    text-align: center;
}

.footer-instagram-ttl{
    padding-bottom: 2.8rem;
}

.footer-instagram-tag{
    padding-bottom: 7.2rem;
    font-size: 2.4rem;
}

#sb_instagram{
    width: 72% !important;
    margin: auto !important;
    padding: 0 !important;
}

#sbi_images{
    margin: -10px !important;
}

.sbi_info{
    display: none;
}

.footer-instagram-link{
    margin-top: 6rem;
    font-size: 2.8rem;
}

.footer-instagram-link div,
.footer-instagram-link div::after{
    background: #fff;
}

.footer-instagram-link:hover{
    background: #fff;
    color: #09132D;
    border-collapse: #fff;
}

.footer-instagram-link:hover div,
.footer-instagram-link:hover div::after{
    background: #09132D;
}

/**/

.footer-inner{
    justify-content: space-between;
    align-items: flex-end;
}

.footer-ttl-archive{
    width: 50%;
}

.footer-ttl{
    color: #fff;
    display: block;
    width: 30rem;
    margin: 0;
    padding-bottom: 4.4rem;
}

.footer-ttl img{
    width: 100%;
}

.footer-archive{
    font-size: 2rem;
}

.footer-archive li{
    padding-left: .7rem;
}

.footer-archive li + li::before{
    content:"/";
    padding-right: 0.2rem;
}


.footer-inner .sns-link ul{
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.footer-inner .sns-link li + li{
    padding-left: 2.6rem;
}

.footer-inner .sns-link svg{
    width: auto;
    height: 2.2rem;
}


.footer-sns-copyright{
    width: 50%;
    flex-direction: column;
}

.footer-copyright{
    font-size: 1.6rem;
    line-height: 1.3;
    text-align: right;
    padding-top: 3.6rem;
}



/* トップへ戻るボタン */
.link-to-top {
    display: none;
    z-index: 9;
    position: fixed;
    right: 2.8rem;
    bottom: 0;
}

.link-to-top .link-arrow{
    color: #fff;
    font-size: 1.7rem;
    cursor: pointer;
    padding: 2rem 0.6rem 2rem;
    position: relative;
}

.link-to-top .link-arrow::after{
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transition: 0.8s ease-out;
    width: 100%;
    z-index: -1;
    background: #09132D;
    opacity: 0.3;
}

.link-to-top .link-arrow:hover::after{
    opacity: 1;
}

.link-to-top .link-arrow div{
    width: 1px;
    height: 4.8rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1rem;
}

.link-to-top .link-arrow div::after {
    top: 0;
    left: 0;
    bottom: unset;
    right: unset;
    transform-origin: left top;
    transform: rotate(45deg);
}

.link-to-top .link-arrow div,
.link-to-top .link-arrow div::after{
    background: #fff;
}


/*トップページ*/
/*トップページ　メインビジュアル*/

.top-visual-container{
    height: 100vh;
    height: 100svh;
    background-size: cover;
    background-position: center;
}

.top-visual-1{
    background-image: url(images/main_bg-1_pc.jpg);
}

.top-visual-2{
    background-image: url(images/main_bg-2_pc.jpg);
}

.top-visual-inner{
    height: 100vh;
    height: 100svh;
    position: relative;
}

.top-visual-container-body{
    position: absolute;
    bottom: 8vh;
    left: 0;
}

.top-visual-container-date{
    width: 45rem;
    padding-bottom: 3rem;
}

.top-visual-container-numbers{
    width: 40rem;
    padding-bottom: 3.2rem;
}

.top-visual-container-text{
    font-size: 1.6rem;
    line-height: 1.75;
    color: #fff;
}

/*トップページ　イントロ*/

.top-intro-container{
    color: #fff;
    background: #09132D;
    padding-top: 18rem;
    padding-bottom: 18rem;
}

.top-intro-inner{
    padding-left: 10%;
    padding-right: 10%;
}

.top-intro-container-header{
    padding-bottom: 4.8rem;
}

.top-intro-number-inner{
    font-size: 9rem;
    line-height: 1.05;
}

.top-intro-number-inner span{
    font-size: 6rem;
    text-transform: uppercase;
    padding-left: 1rem;
}

.top-intro-container-body{
    position: relative;
}

.top-intro-statement{
    font-size: 1.9rem;
    line-height: 2.2;
    font-weight: 500;
}

.top-intro-statement + .top-intro-statement{
    padding-top: 2.4rem;
}

.top-intro-link{
    font-size: 2.8rem;
    color: #fff;
    position: absolute;
    right: 0;
    bottom: 0.4rem;
}

.top-intro-link div{
    background: #fff;
}

/*トップページ　オフィシャルイベント*/
.top-event-container{
    padding-top: 10rem;
    padding-bottom: 10rem;
}

.top-event-inner{
    border-bottom: 1px solid;
    padding-bottom: 10rem;
}

.top-event-ttl{
    padding-bottom: 7.2rem;
    text-align: left;
}

.top-event-list{
    justify-content: space-between;
}

.top-event-item{
    position: relative;
    width: 47%;
    background: #fff;
    text-align: center;
    padding: 3.2rem 4%; 
}

.top-event-item::after{
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 0 6.4rem 6.4rem 0;
    border-color: transparent #1677B8 transparent transparent;
    transform: rotate(0deg);
}

.top-event-link::after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 100%;
    height: .5rem;
    background: #09132D;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .5s;
}

.top-event-link:hover::after{
    transform-origin: left top;
    transform: scale(1, 1);
}

.top-event-link:hover{
    text-decoration: none;
}

.top-event-link:hover img{
    filter: none;
}

.top-event-party-visual{
    width: 83%;
    margin-top: 1.6rem;
    margin-bottom: 2.4rem;
}

.top-event-party-detail{
    width: 77%;
}

.top-event-stamp-visual{
    width: 90%;
    margin-top: 1.4rem;
    margin-bottom: 1.6rem;
}

.top-event-stamp-catch{
    font-size: 2rem;
    line-height: 1.3;
    font-weight: 700;
}

.top-event-stamp-text{
    font-size: 1.5rem;
    line-height: 1.6;
    text-align: justify;
    padding-top: 1.2rem;
}


/*トップページ　CREATOR・SHOP一覧*/

.top-list{
    padding-bottom: 10rem;
    margin-bottom: 10rem;
    border-bottom: 1px solid #09132D;
}

.top-category-ttl{
    padding-bottom: 6rem;
}

.post-list article{
    position: relative;
}

.post-list-count{
    position: absolute;
    z-index: 1;
    top: -1.2rem;
    left: 2.8rem;
    font-size: 2.6rem;
    color: #1677b8;
}

.post-list .post-list-ttl {
    font-size: 1.9rem;
    line-height: 1.3;
    padding-bottom: 1.2rem;
}

.main-content-in-stamprally .post-list-ttl{
    font-size: 1.6rem;
}

.post-list-genre{
    color: #555555;
    line-height: 1.3;
    font-size: 1.3rem;
}

.post-list-genre a{
    color: #555555;
}

.post-list-date{
    line-height: 1.3;
    font-size: 1.6rem;
    font-weight: 500;
    padding-bottom: .8rem;
}

.post-list-time{
    line-height: 1.3;
    font-size: 1.7rem;
    font-weight: 500;
    padding-bottom: .8rem;
}


.post-list .post-list-genre{
    padding-bottom: .8rem;
}

.entry-header .post-list-genre{
    padding-right: 2rem;
    font-size: 1.4rem;
    margin-bottom: 1rem;
}

.entry-header .post-list-date{
    font-size: 2rem;
    padding-right: 1.2rem;
}

.entry-header .post-list-time{
    font-size: 1.9rem;
}

.side-menu .post-list-date{
    color: #555555;
    font-size: 1.3rem;
    padding-bottom: 0.4rem;
}

.post-list-link{
    position: relative;
    font-size: 1.4rem;
    line-height: 1.3;
}

.entry-header .post-list-link{
    margin-bottom: 1rem;
}

.post-list-link-inner{
    margin-left: calc(12px + .6rem);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    white-space: normal;
}

.post-list-link-inner a{
    word-break: break-word;
}

.post-list-link svg{
    fill: #09132D;
    margin-right: .6rem;
    position: absolute;
    top: 2px;
    left: 0;
}

.post-list-link li:not(:last-child)::after{
    content:"/";
    padding: 0 .3rem;
    color: #555555;
}

.top-list-link{
    margin-top: 6rem;
}

/*トップページ　EVENT*/

.top-info-container{
    padding-bottom: 12rem;
}

.top-info-list{
}

.top-info-item{
    position: relative;
    padding: 5rem 6rem;
    background: #d0cecd;
}

.top-info-item + .top-info-item{
    margin-top: 3rem;
}

.top-info-link{
    justify-content: space-between;
    align-items: center;
}

.top-info-item:nth-child(2) .top-info-link{
    flex-direction: row-reverse;
}

.top-info-link::after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 100%;
    height: .5rem;
    background: #09132D;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .5s;
}

.top-info-link:hover::after{
    transform-origin: left top;
    transform: scale(1, 1);
}

.top-info-link:hover{
    text-decoration: none;
}

.top-info-link:hover img{
    filter: none;
}

.top-info-body{
    width: 35%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.top-info-ttl-container{
    padding-bottom: 2.8rem;
}

.top-info-catch{
    font-size: 1.6rem;
    padding-bottom: 0.6rem;
}

.top-info-more{
    font-size: 2rem;
    color: #555555;
}

.top-info-more::after{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    pointer-events: auto;
    content: "";
}

.top-info-img{
    width: 60%;
}

.top-info-img img{
    width: 100%;
}


/*広告*/
.top-sponsor-list{
    margin-top: 10rem;
    justify-content: space-between;
}

.top-sponsor-bbc{
    width: 64%;
}

.top-sponsor-kcic{
    width: 33.3%;
}

/*パンくず*/
.breadcrumbs {
    padding-bottom: 4.4rem;
    font-size: 1.2rem;
    line-height: 1.4;
    color: #555555;
}

.breadcrumbs a{
    text-decoration: underline;
    color: #555555;
}

/* アーカイブページ */
.archive-map{
    margin-bottom: 6rem;
}

.archive-map iframe{
    height: 48rem;
}

iframe{
    filter: saturate(0.8);
    border: none;
}

.archive-intro-container{
    padding-bottom: 4.8rem;
}

.archive-intro-ttl{
    padding-bottom: 2rem;
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 1.4;
}

.archive-intro-text{
    font-size: 1.8rem;
    line-height: 1.85;
}

.archive-shops-text{
    font-size: 1.4rem;
    line-height: 2;
    padding-top: 4.8rem;
}

/* スタンプラリー */
.stamprally-intro-container{
    justify-content: space-between;
    padding-bottom: 10rem;
}

.stamprally-intro-img{
    width: 40%;
}

.stamprally-intro-img img{
    width: 100%;
}

.stamprally-intro-body{
    width: 52%;
}

.stamprally-intro-ttl{
    padding-bottom: 3.6rem;
    font-size: 1.8rem;
    line-height: 1.85;
}

.post-type-archive-stamprally .post-list .post-list-genre{
    line-height: 1.2;
    padding-bottom: 0.8rem;
}

.stamprally-memo{
    font-size: 1.4rem;
    line-height: 1.85;
}


/* 個別ページ */
.single-category-ttl{
    background: #09132D;
    color: #fff;
    font-size: 2rem;
    padding: 0.4rem 0.8rem 0.5rem;
    margin-bottom: 2.4rem;
    display: inline-block;
    text-transform: uppercase;
}

.entry-header{
    padding-bottom: 4rem;
}

.entry-header > .flex{
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
}

.single-ttl{
    font-size: 3.8rem;
    line-height: 1.3;
    margin: 0;
    font-weight: 700;
}

.single-ttl + *{
    padding-top: 2.8rem;
}

.entry-body{
    font-size: 1.6rem;
    line-height: 1.85;
    text-align: left;
    margin: 5.2rem 0;
}

.entry-body a{
    text-decoration: underline;
}

.entry-body p + p{
    margin-top: 2.4rem;
}

.entry-body hr{
    margin-top: 2.8rem;
    margin-bottom: 2.8rem;
    border-top: 1px solid #555555;
}

.single-other-img{
    margin: 3.2rem -1.6rem 0;
}

.single-other-img > li{
    padding: 0 1.6rem;
    text-align: center;
}

.single-other-img-1 > li{
    width: 100%;
}

.single-other-img-2 > li{
    width: 50%;
}

.single-other-img-3 > li{
    width: calc(100% / 3);
}

.sub-content {
    margin-top: 4.8rem;
}

.sub-content dl{
    margin: 0;
}

.sub-content dt{
    width: 18%;
    font-size: 1.6rem;
    line-height: 1.5;
    display: inline-block;
    font-weight: 500;
    margin-bottom: 1.2rem;
    color: #555555;
}

.sub-content dt.en{
    font-size: 1.8rem;
}

.sub-content dd{
    width: 82%;
    font-size: 1.6rem;
    line-height: 1.5;
    margin-bottom: 1.2rem;
}

.sub-content a{
    text-decoration: underline;
    word-break: break-all;
}

.single-link{
    margin-top: 6rem;
    padding: 5.6rem 0;
    border-top: 1px solid;
    border-bottom: 1px solid;
}

.single-link-inner{
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.single-link-inner + .single-link-inner{
    margin-top: 2.8rem;
}

.single-link-text-container{
    width: 60%;
    padding-right: 10%;
}

.single-link-category{
    font-size: 1.6rem;
    font-weight: 500;
    padding-bottom: 1rem;
}

.single-link-category span{
    font-size: 3.6rem;
    vertical-align: middle;
    text-transform: uppercase;
    margin: 0 1rem 0 1rem;
    margin-top: -0.5rem;
    display: inline-block;
}

.single-link-ttl{
    font-size: 2.6rem;
    line-height: 1.3;
    font-weight: 700;
}

.single-link-link{
    margin-top: 2.8rem;
    font-size: 2rem;
    justify-content: flex-start;
    color: #555555;
}

.single-link-img{
    width: 40%;
}

.map-iframe{
    height: 36rem;
    margin-top: 6rem;
}

.map-link{
    margin-top: 1.2rem;
    font-size: 1.4rem;
    text-align: right;
}

.map-link a{
    text-decoration: underline;
}

.food-menu-ttl{
    margin: 4.8rem 0 -2.8rem;
    font-size: 2rem;
    line-height: 1.5;
}

/*ash公式イベント　サムネ調整*/
#post-1049 .thumbnail-img,
#post-1055 .thumbnail-img{
    display: none;
}

#post-1049 .entry-body,
#post-1055 .entry-body{
    margin-top: 0;
}

.wp-block-group{
    margin-top: 4rem;
}


/* サイドメニュー */

.side-menu {
}

.side-menu-category {
    font-size: 3.2rem;
    text-transform: uppercase;
    margin-bottom: 3.2rem;
}

.side-menu ul li {
    border-bottom: 1px solid;
    padding: 1.2rem 0;
}

.side-menu ul li a{
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.side-menu-ttl {
    font-weight: 500;
    font-size: 1.5rem;
    line-height: 1.3;
}

/*ページ*/
.page-body{
    font-size: 1.8rem;
    line-height: 2;
}

/*ページ アバウト*/

.page-id-58 .page-body {
    text-align: center;
}

.page-id-58 .page-body p + p{
    padding-top: 3.2rem;
}

.page-id-58 .page-body .en{
    font-size: 124%;
    line-height: 1.7;
}

/*404*/
.error404 .archive-intro-text{
    text-align: center;
}


/*ページネーション*/
.posts-navigation{
    width: 100%;
}

.nav-links{
    font-size: 1.6rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.nav-links > div{
    margin: 4rem 2rem 0;
}

/*----------------------------------------------------

PCのみ、中間地点

----------------------------------------------------*/

@media print,
    screen and (min-width: 768px) {
        .display-sp {
            display: none !important;
        }
}

@media print,
    screen and (max-width: 1180px) and (min-width: 1001px) {
        html {
            font-size: 56%;
        }

        .top-main-number-inner{
            font-size: 9rem;
        }

        .top-main-number-inner span{
            font-size: 6.5rem;
        }

        .top-main-area {
            font-size: 2.8rem;
        }
}

@media print,
    screen and (max-width: 1000px) and (min-width: 768px) {
        html {
            font-size: 52%;
        }
        
        .content-in{
            width: 86%;
        }

        .content-in-sub{
            width: 100%;
        }
        
        .side-menu{
            width: 28%;
        }
        
        .top-date {
            left: 2rem;
        }
        
        .top-sns {
            right: 1.4rem;
        }
        
        .top-main-container{
            width: 50%;
            margin-top: 0;
        }
        
        .top-main-container-header{
            width: 100%;
        }
        
        .top-main-container-header::after{
            display: none;
        }
        
        .top-main-container-body {
            width: 100%;
        }

        .post-list-4{
            margin:0 -2.2%;
        }

        .post-list-4 article {
            width: calc(100% / 3);
            padding:0 2.2% 2.8rem;
        }
}
/*----------------------------------------------------

スマートフォンのみ

----------------------------------------------------*/

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

    .display-pc {
        display: none !important;
    }
    
    .content-in{
        width: 100%;
        padding-left: 2.2rem;
        padding-right: 2.2rem;
    }

    .content-in-sub{
        width: 100%;
    }

    .page-ttl {
        font-size: 4rem;
        padding-bottom: 3.2rem;
    }
    
    .post-list-4{
        margin:0 -2.8%;
    }

    .post-list-4 article {
        width: 50%;
        padding: 0 2.8% 2.4rem;
    }

    .post-list img{
        margin-bottom: 1.2rem;
    }

    .sub-main-content-in {
        width: 100%;
    }

    .side-menu {
        width: 100%;
    }
    
    body:not(.home) .main-content-wapper {
        padding-top: 8rem;
        margin-bottom: 6rem;
    }

    .link-box{
        width: 22rem;
        height: 6rem;
        margin: 4rem auto 0;
        font-size: 1.6rem;
        padding: 1.2rem 0;
    }

    .link-box span.en{
        font-size: 2.6rem;
        padding-right: 0.2rem;
    }

    .link-box div{
        width: 3.2rem;
        left: -1.6rem;
    }

    .link-arrow div{
        width: 3.2rem;
        margin-right: 1rem;
    }

    /*テキスト*/

    .ttl-01{
        font-size: 4.2rem;
    }

    .ttl-02{
        font-size: 3.6rem;
    }


    /* ヘッダー */
    
    .header-content-wrapper{
        padding-top: 2rem;
        padding-bottom: 3.6rem;
    }
    
    .header-content-in {
        padding-bottom: 0;
    }

    .header-ttl{
        width: 24rem;
    }
    
    .drawer_hamburger {
        position: fixed;
        top: .7rem;
        right: 0;
        width: 7.6rem;
        height: 6rem;
        padding: 2rem 2.2rem;
        z-index: 999;
        mix-blend-mode: difference;
    }

    .drawer_hamburger_icon,
    .drawer_hamburger_icon:after,
    .drawer_hamburger_icon:before {
        transition: all .3s cubic-bezier(.19, 1, .22, 1);
    }

    .drawer_hamburger_icon {
        position: relative;
        display: block;
        width: 100% !important;
        height: 1px;
        margin-top: 0 !important;
        background-color: #fff;
    }

    .drawer_hamburger_icon:after,
    .drawer_hamburger_icon:before {
        position: absolute;
        content: " ";
        height: 1px;
        width: 100% !important;
        background-color: #fff;
        left: 0;
        right: 0;
        margin: auto;
    }

    .drawer_hamburger_icon:before {
        top: -.7rem !important;
    }

    .drawer_hamburger_icon:after {
        top: .7rem !important;
    }
    
    .is-opened .drawer_hamburger_icon{
        background: transparent;
    }

    .is-opened .drawer_hamburger_icon:before {
        transform: rotate(45deg);
        top: 0 !important;
        background: #fff;
    }

    .is-opened .drawer_hamburger_icon:after {
        transform: rotate(-45deg);
        top: 0 !important;
        background: #fff;
    }

    .drawer_container{
        position: fixed;
        top: 0;
        right: -100%;
        z-index: 100;
        overflow-y: scroll;
        width: 100%;
        height: 100vh;
        height: 100dvh;
        max-height: 100%;
        background: #09132D;
        color: #fff;
        transition: right .3s ease-in-out;
        -webkit-overflow-scrolling: touch;
    }

    .is-opened .drawer_container{
        right: 0;
        transition: right .3s ease-in-out;
    }
    
    .drawer_container a{
        color: #fff;
    }

    .drawer_inner {
        min-height: 100vh;
        min-height: 100dvh;
        padding: 3rem 16% 5rem;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }
    
    .sp-menu-search{
        margin-bottom: 4rem;
        width: 100%;
    }
    
    .sp-menu-search input{
        width: calc(100% - 2.4rem);
        color: #fff;
        font-size: 1.5rem;
    }
    
    .sp-menu-search svg{
        fill: #fff;
    }

    .search-ttl{
        padding-bottom: 4rem;
        font-size: 1.6rem;
    }
    
    .drawer-nav{
        width: 100%;
        padding-bottom: 4.8rem;
    }
    
    .sp-header-menu-list li{
        text-align: left;
    }
    
    .sp-header-menu-list li + li{
        padding-top: 2rem;
    }

    .sp-header-menu-list a{
        font-size: 2.4rem;
        text-transform: uppercase;
    }

    .sp-header-menu-list li a svg{
        margin-right: 0.2rem;
        margin-top: -0.4rem;
    }

    .sp-header-menu-list > li > a:hover,
    .sp-header-menu-list > li.header-current > a{
        text-decoration: underline;
    }
    
    .drawer_container .sns-link{
        width: 100%;
        justify-content: flex-start;
    }

    .drawer_container .sns-link li + li {
        padding-left: 2.4rem;
    }

    /* フッター */

    .footer-content{
        padding: 7.2rem 0 4.4rem;
    }

    .footer-instagram-container{
        padding-bottom: 8rem;
    }

    .footer-instagram-ttl{
        padding-bottom: 2rem;
    }

    .footer-instagram-tag{
        padding-bottom: 4rem;
        font-size: 1.8rem;
    }

    .footer-instagram-link{
        margin-top: 4rem;
    }
    
    #sbi_images{
        margin: auto !important;
    }

    /**/

    
    .footer-ttl-archive{
        width: 100%;
        padding-bottom: 4rem;
    }

    .footer-ttl{
        width: 62%;
        padding-bottom: 2.8rem;
    }
    
    .footer-archive{
        width: 100%;
        font-size: 1.6rem;
        justify-content: center;
    }

    .footer-archive li{
        padding-left: .5rem;
    }
    
    .footer-sns-copyright{
        width: 100%;
    }

    .footer-inner .sns-link{
        width: 100%;
        justify-content: center;
    }

    .footer-inner .sns-link li + li{
        padding-left: 2.8rem;
    }

    .footer-copyright{
        padding-top: 4rem;
        font-size: 1.3rem;
        text-align: center;
    }


    /* トップへ戻るボタン */
    .link-to-top {
        right: 2.4rem;
    }

    .link-to-top .link-arrow{
        font-size: 1.3rem;
        padding: 1.6rem 0.5rem 1.4rem;
        position: relative;
    }

    .link-to-top .link-arrow div{
        height: 3.8rem;
        margin-bottom: .6rem;
    }


    /*トップページ*/


    /*トップページ　メインビジュアル*/
    .top-visual-1{
        background-image: url(images/main_bg-1_sp.jpg);
    }

    .top-visual-2{
        background-image: url(images/main_bg-2_sp.jpg);
    }
    
    .top-visual-container-body{
        bottom: 5.2vh;
        left: 2.2rem;
        right: 2.2rem;
    }

    .top-visual-container-date{
        width: 90%;
        padding-bottom: 2rem;
    }

    .top-visual-container-numbers{
        width: 80%;
        padding-bottom: 2.2rem;
    }

    .top-visual-container-text{
        font-size: 1.3rem;
    }
    

    /*トップページ　イントロ*/

    .top-intro-container{
        padding-top: 14rem;
        padding-bottom: 8rem;
    }

    .top-intro-inner{
        padding-left: 2.4rem;
        padding-right: 2.4rem;
    }

    .top-intro-container-header{
        padding-bottom: 3.2rem;
    }

    .top-intro-number-inner{
        font-size: 6.6rem;
    }

    .top-intro-number-inner span{
        font-size: 4.8rem;
        padding-left: .6rem;
    }

    .top-intro-statement{
        font-size: 1.5rem;
        line-height: 1.8;
        text-align: justify;
    }

    .top-intro-statement + .top-intro-statement{
        padding-top: 1.2rem;
    }

    .top-intro-link{
        font-size: 2.2rem;
        position: relative;
        margin-top: 4rem;
    }

    /*トップページ　オフィシャルイベント*/
    .top-event-container{
        padding-top: 6rem;
        padding-bottom: 6rem;
    }
    
    .top-event-inner{
        padding-bottom: 6rem;
    }

    .top-event-ttl{
        padding-bottom: 3.2rem;
    }

    .top-event-item{
        width: 100%;
        padding: 2.4rem 2.8rem; 
    }
    
    .top-event-item + .top-event-item{
        margin-top: 2.4rem;
    }

    .top-event-item::after{
        border-width: 0 4.8rem 4.8rem 0;
    }

    .top-event-party-visual{
        width: 90%;
        margin-top: 1rem;
        margin-bottom: 1.6rem;
    }

    .top-event-party-detail{
        width: 81%;
    }

    .top-event-stamp-visual{
        width: 96%;
        margin-top: .6rem;
        margin-bottom: .8rem;
    }

    .top-event-stamp-catch{
        font-size: 1.7rem;
    }

    .top-event-stamp-text{
        font-size: 1.3rem;
        padding-top: 1.2rem;
    }


    /*トップページ　CREATOR・SHOP一覧*/

    .top-list{
        padding-bottom: 6rem;
        margin-bottom: 6rem;
    }

    .top-category-ttl{
        padding-bottom: 3.2rem;
    }

    .post-list-count{
        top: -1rem;
        left: 1.8rem;
        font-size: 2.1rem;
    }

    .post-list .post-list-ttl {
        font-size: 1.5rem;
        padding-bottom: .7rem;
    }

    .main-content-in-stamprally .post-list-ttl{
        font-size: 1.5rem;
    }

    .post-list-genre{
        font-size: 1.2rem;
    }

    .post-list-date{
        font-size: 1.3rem;
        padding-bottom: 0.6rem;
    }

    .post-list-time{
        font-size: 1.6rem;
        padding-bottom: 0.6rem;
    }

    .post-list .post-list-genre{
        padding-bottom: .7rem;
    }

    .entry-header .post-list-genre{
        padding-right: 1.6rem;
        font-size: 1.3rem;
    }

    .entry-header .post-list-date{
        font-size: 1.8rem;
        padding-right: .8rem;
    }

    .entry-header .post-list-time{
        font-size: 1.6rem;
    }

    .side-menu .post-list-date{
        padding-bottom: 0.4rem;
    }

    .post-list-link{
        font-size: 1.3rem;
    }

    .post-list-link svg{
        margin-right: .4rem;
    }

    .top-list-link{
        margin-top: 2rem;
    }

    /*トップページ　EVENT*/

    .top-info-container{
        padding-bottom: 8rem;
    }

    .top-info-item{
        padding: 4.8rem 2.8rem 3.2rem;
    }

    .top-info-item + .top-info-item{
        margin-top: 2rem;
    }

    .top-info-body{
        width: 100%;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        padding-bottom: 2.4rem;
    }

    .top-info-ttl-container{
        padding-bottom: 1.6rem;
    }

    .top-info-catch{
        font-size: 1.5rem;
        padding-bottom: 0.4rem;
    }
    
    .top-info-ttl{
        font-size: 4rem;
    }

    .top-info-link{
        font-size: 1.8rem;
    }
    
    .top-info-more{
        font-size: 1.8rem;
    }

    .top-info-img{
        width: 100%;
    }
    
    .top-info-body-inner{
        width: 100%;
    }

    /*広告*/
    .top-sponsor-list{
        margin-top: 6rem;
        justify-content: center;
    }

    .top-sponsor-bbc{
        width: 100%;
        margin-bottom: 2.8rem;
    }

    .top-sponsor-kcic{
        width: 52%;
    }


    /*パンくず*/
    .breadcrumbs {
        padding-bottom: 3.2rem;
        font-size: 1.1rem;
    }


    /* アーカイブページ */
    .archive-map{
        margin-bottom: 4rem;
    }
    
    .archive-map iframe{
        height: 33rem;
    }

    .archive-intro-container{
        padding-bottom: 4rem;
    }

    .archive-intro-ttl{
        font-size: 1.8rem;
    }

    .archive-intro-text{
        font-size: 1.4rem;
    }
    
    .archive-shops-text{
        font-size: 1.2rem;
        padding-top: 3.2rem;
    }


    /* スタンプラリー */
    .stamprally-intro-container{
        padding-bottom: 6rem;
    }

    .stamprally-intro-img{
        width: 100%;
        margin: 0 0 2.8rem;
    }

    .stamprally-intro-body{
        width: 100%;
    }

    .stamprally-intro-ttl{
        padding-bottom: 3rem;
        font-size: 1.6rem;
    }
    
    .post-type-archive-stamprally .post-list .post-list-genre{
        padding-bottom: 0.5rem;
    }


    /* 個別ページ */
    .single-category-ttl{
        font-size: 1.7rem;
        padding: 0.3rem 0.8rem 0.4rem;
        margin-bottom: 1.6rem;
    }

    .entry-header{
        padding-bottom: 2rem;
    }

    .single-ttl{
        font-size: 2.8rem;
    }
    
    .single-ttl + *{
        padding-top: 1.6rem;
    }

    .main-content-in-event .single-ttl{
        padding-bottom: 2rem;
    }

    .entry-body{
        font-size: 1.5rem;
        margin: 4.8rem 0;
    }

    .single-other-img{
        margin: 1.6rem 0 0;
    }

    .single-other-img > li{
        padding: 0;
    }
    .single-other-img > li + li{
        padding-top: 1.6rem;
    }

    .single-other-img-2 > li{
        width: 100%;
    }

    .single-other-img-3 > li{
        width: 100%;
    }

    .sub-content {
        margin-top: 5.2rem;
    }

    .sub-content dt{
        width: 100%;
        font-size: 1.3rem;
        margin-bottom: 0.8rem;
    }

    .sub-content dt.en{
        font-size: 1.5rem;
    }
    
    .sub-content dd{
        width: 100%;
        font-size: 1.5rem;
        margin-bottom: 2.4rem;
    }

    .single-link{
        margin-top: 5.2rem;
    }
    
    .single-link-inner{
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    }
    
    .single-link-inner + .single-link-inner{
        margin-top: 3.6rem;
    }

    .single-link-text-container{
        width: 100%;
        padding-right: 0;
        padding-top: 2.2rem;
    }

    .single-link-category{
        font-size: 1.4rem;
        padding-bottom: 2.4rem;
    }

    .single-link-category span{
        font-size: 2.8rem;
        margin-top: -0.4rem;
    }

    .single-link-ttl{
        font-size: 1.9rem;
    }

    .single-link-link{
        margin-top: 1.6rem;
        font-size: 1.7rem;
    }

    .single-link-img{
        width: 100%;
    }

    .map-iframe{
        height: 28rem;
        margin-top: 4rem;
    }

    .food-menu-ttl{
        margin: 3.2rem 0 -1.6rem;
    }

    /*ash公式イベント　サムネ調整*/
    .wp-block-group{
        margin-top: 2.8rem;
    }


    /* サイドメニュー */

    .side-menu {
        padding-top: 8rem;
    }

    .side-menu-category {
        margin-bottom: 2rem;
    }
    

    /*ページ*/
    .page-body{
        font-size: 1.5rem;
    }

    /*ページ アバウト*/
    
    .page-id-58 .page-body{
        text-align: justify;
    }

    .page-id-58 .page-body p + p{
        padding-top: 2.4rem;
    }
    
    .page-id-58 .page-body br{
        display: none;
    }
    
    .page-id-58 .page-body .en br{
        display: block;
    }

    /*ページネーション*/
    .nav-links{
        font-size: 1.4rem;
    }

    .nav-links > div{
        margin: 2rem 1.4rem 0;
    }

}

@media print,
    screen and (max-width: 320px){
        html {
            font-size: 56%;
        }
}