html, body {
    color: #333;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 20px;
    font-weight: 500;
    position: relative;
    margin: 0;
    padding: 0;
    width: 100%;
    overflow: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    text-rendering: optimizeLegibility !important;
    -webkit-font-smoothing: antialiased !important;
    animation: fadeIn 1.5s ease 0s 1 normal;
    -webkit-animation: fadeIn 1.5s ease 0s 1 normal;
    scroll-behavior: auto!important;
}
body::before {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    content: "";
    z-index: -1;
    background-color: #fff;
    background-image: url(../../common/img/bg00.jpg);
    background-size: 900px 820px;
    background-repeat: repeat;
    background-position: center;
}
html::before,
html::after,
body::after {
    content: "";
    position: fixed;
    z-index: 1000;
    background-color: #000;
}
html::before, html::after { width: 4px; height: 100vh; }
html::before { top: 0; left: 0; }
html::after { top: 0; right: 0; }
body::after { width: 100vw; height: 4px; bottom: 0; left: 0; }
.other-content.en-wrap .sec-inline > main > div {
    position: relative;
    margin-top: auto;
    margin-bottom: auto;
    padding-top: 4rem;
    padding-bottom: 4rem;
    z-index: 10;
}
.other-content.en-wrap .sec-inline > main > div::before {
    content: "";
    width: 100vw;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background-position: center;
    z-index: -1;
}
.other-content.en-wrap .sec-inline > main > div:nth-child(odd)::before {
    background: #FFFFFF;
}
.other-content.en-wrap .sec-inline > main > div:nth-child(even)::before {
    background: #F7F7F2;
}
a.anchorpoint {
    display: block;
    padding-top: 120px;
    margin-top: -120px;
}
/*--- 画面全体をフェードイン(animation設定) ---*/
@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

h1, h2, h3, h4, h5, h6 {
    color: #000;
    font-family: m-plus-1p, 'Noto Sans JP', sans-serif;
    font-weight: 900;
    line-height: 1.5;
    letter-spacing: 0.025em;
    margin: 0 auto 1.5rem;
    padding: 0;
}
h1 { font-size: 2.5em; }
h2 { font-size: 2.1em; }
h3 { font-size: 1.6em; }
h4 { font-size: 1.4em; }
h5 { font-size: 1.2em; }
h6 { font-size: 1.1em; }

.txt-ja, span[lang='ja']{  font-family: "Noto Sans JP", sans-serif;}
.txt-en, span[lang='en'] {  font-family: bebas-neue, m-plus-1p, 'Noto Sans JP', sans-serif}

.tit-hashtag { margin-bottom: 3rem; }
.tit-hashtag .hashtag-point {
    position: relative;
    z-index: 10;
}
.tit-hashtag .hashtag-point::before {
    content: "";
    position: absolute;
    bottom: 15%;
    right: 68%;
    z-index: -1;
    display: block;
    width: 1.8em;
    height: 1.9em;
    -webkit-mask: url(../../common/img/svg-hashtag.svg);
    mask: url(../../common/img/svg-hashtag.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    vertical-align: middle;
    background-color: #B82E29;
}

.tit-ramen, .tit-men , .tit-map {
    position: relative;
    text-align: center;
    margin-bottom: 3rem;
}
.tit-ramen::before, .tit-men::before , .tit-map::before {
    content: "";
    position: relative;
    display: block;
    width: 6.5rem;
    height: 6.5rem;
    margin: 0 auto 1rem;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}
.tit-ramen::before { background-image: url(../../common/img/titicon-ramen.png); }
.tit-men::before { background-image: url(../../common/img/titicon-men.png); }
.tit-map::before { background-image: url(../../common/img/titicon-map.png); }

.tit-icon01 { position: relative; text-align: center; margin-bottom: 3rem; }
.tit-icon01::after {
    content: "";
    position: relative;
    display: block;
    width: 4.5rem;
    height: 1rem;
    margin: 1rem auto 0;
    background: no-repeat 50%;
    background-size: contain;
    background-image: url(../../common/img/titicon-pattern01.png);
    transition-property: width,background-color,border-color,color,fill,opacity;
}
.tit-line { border-bottom: 6px solid #B82E29; }
.bd-left { border-left: 7px solid #B82E29; padding-left: 10px; }
.tit-bg {
    color: #fff;
    padding: 10px 25px;
    background-color: #B82E29;
}
.tit-point {
    display: flex;
}
.tit-point::before {
    content: "▶";
    font-size: 1em;
    font-weight: 900;
    margin-top: -0.02em;
    padding-right: 0.2em;
    color: #B82E29;
}
.titsub {
    display: block;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.025em;
    text-align: center;
}

.tit-icon {
    position: relative;
    z-index: 10;
    color: #B82E29;
    font-family: 'Noto Sans JP', sans-serif;
    display: table;
    padding: 1.3em 1.5em 0;
}
.tit-icon::before {
    content: '';
    display: block;
    width: 100%;
    height: 5em;
    position: absolute;
    left: 50%;
    bottom: 0;
    z-index: -1;
    transform: translateX(-50%);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: bottom center;
    background-image: url(../../common/img/titicon01.png);
}

/*--- aタグ ---*/
a, a:hover, a:focus { text-decoration: none; outline: none; }
a {
    color: #B82E29;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
a:hover { color: #931915; }
p > a { text-decoration: underline; padding: 0 0.2em; }
p > a:hover { text-decoration: underline; }

/*--- 文字共通 ---*/
p {
    margin: 0 auto 1.5em;
	padding: 0;
    line-height: 1.8;
    letter-spacing: 0.02em;
}
.ja-txt {
    font-family: m-plus-1p, 'Noto Sans JP', sans-serif;
    font-weight: 800;
}
.en-txt {
    font-family: bebas-neue, 'Noto Sans JP', sans-serif;
    font-weight: normal;
    letter-spacing: 0.1em;
}
.pop-txt {
    font-family: vdl-linegrpop-shadow, 'Noto Sans JP', sans-serif;
    font-weight: normal;
}
.color-wh { color: #fff; }
.color-bk { color: #333; }
.color-red { color: #B82E29; }

/*--- background ---*/
.bg-wh { background-color: #fff; }
.bg-bk { background-color: #000; }
.bg-ye { background-color: #FFFDE4!important; }
.bg-ye { background-color: #F0F0E2!important; }
.bg-gray { background-color: #F7F7F2!important; }
.bg-yamagata, .bg-men {
    background-size: cover;
    background-repeat: no-repeat;
    
    background-color: #fff;
}
.bg-yamagata { background-position: bottom center; background-image: url(../../common/img/bg-yamagata.jpg); }
.bg-yamagata::after {
    content: "";
    position: absolute;
    top: 7rem;
    left: 62%;
    z-index: 0;
    display: block;
    width: 29%;
    height: 100%;
    background-color: #fff;
    -webkit-mask: url(../../common/img/svg-yamagata.svg);
    mask: url(../../common/img/svg-yamagata.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: top center;
    mask-position: top center;
    vertical-align: middle;
    opacity: 0.3;
}
.bg-men { background-position: center; background-image: url(../../common/img/bg-men.jpg); }
.bg-men::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    display: block;
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: 0.2;
    mix-blend-mode: multiply;
}

.bg-txt-lets::before {
    content: 'let’s ramen!';
    color: #FEFFE3;
    font-family: bebas-neue, m-plus-1p, 'Noto Sans JP', sans-serif;
    font-size: 19.2vw;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    position: absolute;
    top: 3rem;
    left: 0;
    white-space: nowrap;
}
.bg-txt-lets > p { position: relative; z-index: 10; }

.bg-hashtag {
    position: relative;
    z-index: 10;
}
.bg-hashtag::after {
    content: "";
    position: absolute;
    top: -5px;
    left: -5px;
    z-index: -1;
    display: block;
    width: 32.8vw;
    height: 35vw;
    -webkit-mask: url(../../common/img/svg-hashtag.svg);
    mask: url(../../common/img/svg-hashtag.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    vertical-align: middle;
}
.bg-hashtag.icon-red::after { background-color: #B82E29; }
.bg-hashtag.icon-wh::after { background-color: #fff; }
.bg-hashtag > p { position: relative; z-index: 10; }

/*--- .box ---*/
.box-wh, .box-gray, .box-ye {
    margin-bottom: 1.5em;
    padding: 3em;
}
.box-wh { background-color: #fff; /*border: 3px solid #000;*/ }
.box-gray { background-color: #FBFBFB; padding: 1.5em; }
.box-ye { background-color: #FBFCD0; }

/*---- 左側アイコン ---*/
.box-icon-l {
    margin: 0 auto 4em;
    padding: 1.5em 2em;
}
.box-icon-l .box-wrap { display: flex; }
.box-icon-l .icon {
    width: 9.5rem;
    white-space: nowrap;
    margin-right: 2em;
}
.box-icon-l .txt-wrap {
    flex: 1;
    display: flex;
    flex-flow: column;
    justify-content: center;
}
.box-icon-l .txt-wrap .tit {
    font-family: m-plus-1p, 'Noto Sans JP', sans-serif;
    font-size: 1.3em;
    font-weight: 900;
    line-height: 1.3;
    letter-spacing: 0.025em;
    margin-bottom: 1rem;
}
.box-icon-l .txt-wrap .txt { font-size: 15px; }
@media screen and (max-width: 767px) {
    .box-icon-l { padding: 1em 2em 1.5em; }
    .box-icon-l .box-wrap { display: block; }
    .box-icon-l .icon { width: 7rem; margin: 0 auto 1em; }
    .box-icon-l .txt-wrap .tit { font-size: 1.2em; margin-bottom: 0.6rem; }
}

/*--- .btn00 ---*/
/* .btn-wrap { margin: 1em auto 2em; } */
.btn00, .rela-box {
    width: 100%;
    text-align: center;
    position: relative;
    margin: 0 auto 2em;
}
.rela-box { margin-bottom: 0; }
.btn00 a, .btn00 button, .rela-box .rela-btn {
    font-family: m-plus-1p, 'Noto Sans JP', sans-serif;
    font-weight: 800;
    font-size: 1.1em;
    line-height: 1.2;
    position: relative;
    text-decoration: none;
    display: inline-block;
    text-align: center;
    background: transparent;
    border-radius: 0;
    outline: none;
    transition: all 0.2s ease;
}
.btn00 button { outline: none!important; border: none!important; padding: 0!important; }
.btn00 a span, .btn00 button span, .rela-box .rela-btn .rela-wrap {
    position: relative;
    z-index: 2;
    display: block;
    padding: 1em 3em;
    background:#fff;
    border-radius: 0;
    color:#000;
    transition: all 0.3s ease;
}
.btn00 a::before, .btn00 a::after,
.btn00 button::before, .btn00 button::after,
.rela-box .rela-btn::before, .rela-box .rela-btn::after { transition: transform .3s; }
.btn00 a::before, .btn00 button::before, .rela-box .rela-btn::before {
    content: "";
    position: absolute;
    z-index: 0;
    bottom: -6px;
    right: -6px;
    width: calc(100% + 6px);
    height: calc(100% + 6px);
    border-radius: 0;
    background-color: #000;
    clip-path: polygon(calc(100% - 6px) 0%, 100% 6px, 100% 100%, 6px 100%, 0% calc(100% - 6px), 0 0);
    transition: width .3s, height .3s, clip-path .3s;
}
.btn00 a::after, .btn00 button::after, .rela-box .rela-btn::after {
    content: "";
    position: absolute;
    z-index: 5;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 0;
    border: 3px solid #000;
    transition: transform .3s, border-color .3s;
}
.btn00 a span::before, .btn00 button span::before, .rela-box .rela-btn .rela-wrap::before {
    content: "";
    position: absolute;
    z-index: 5;
    top: 7px;
    left: 7px;
    width: calc(100% - 14px);
    height: calc(100% - 14px);
    border-radius: 0;
    border: 3px solid #000;
    transition: transform .3s, border-color .3s;
}
.btn00 a span::after, .btn00 button span::after {
    content: "";
    position: absolute;
    z-index: 5;
    top: 50%;
    right: 1em;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 0 10px 10px;
    border-color: transparent transparent transparent #b82e29;
    transition: transform .3s, border-color .3s;
}
.btn00 a:hover, .btn00 button:hover, .rela-box:hover .rela-btn {
    border-color: #B82E29; 
}
.btn00 a:hover span, .btn00 button:hover span, .rela-box:hover .rela-btn .rela-wrap {
    background-color: #B82E29;
    color: #fff;
}
.btn00 a:hover::after, .btn00 a:hover span,
.btn00 button:hover::after, .btn00 button:hover span,
.rela-box:hover .rela-btn::after,
.rela-box:hover .rela-btn .rela-wrap { transform: translate(6px, 6px); }
.btn00 a:hover::after, .btn00 button:hover::after,
.rela-box:hover .rela-btn::after { border-color: #B82E29; }
.btn00 a:hover::before, .btn00 button:hover::before,
.rela-box:hover .rela-btn::before {
    content: "";
    position: absolute;
    z-index: 0;
    bottom: -6px;
    right: -6px;
    width: 100%;
    height: 100%;
    border-radius: 0;
    clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 0% 100%, 0% 100%, 0 0);
}
.btn00 a:hover span::before, .btn00 button:hover span::before,
.rela-box:hover .rela-btn .rela-wrap::before { border-color: #fff; }
.btn00 a:hover span::after, .btn00 button:hover span::after,
.rela-box:hover .rela-btn .rela-wrap::after { border-color: transparent transparent transparent #fff; }

/*--- .btn-red ---*/
.btn-red a:hover::after, .btn-red:hover .rela-btn::after { border-color: #B82E29; }
.btn-red a:hover span, .btn-red:hover .rela-btn .rela-wrap {
    background-color: #fff;
    color: #B82E29;
}
.btn-red a:hover span::before, .btn-red:hover .rela-btn .rela-wrap::before { border-color: #B82E29; }

/*--- icon-btn アイコンボタン ---*/
.icon-btn {
    color: #fff;
    font-size: 15px;
    font-weight: bold;
    line-height: 1.3;
    letter-spacing: 0.05em;
    margin: 0;
    padding: 2px 0.7em;
    background-color: #B82E29;
    border: 2px solid #B82E29;
    border-radius: 25px;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
}
.icon-btn:hover {
    color: #B82E29;
    background-color: #fff;
}

/* --------------------------------------------
    header
-------------------------------------------- */
.hd01 {
    position: relative;
    z-index: 50;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.hd01::before {
    content: "";
    position: absolute;
    z-index: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 12vw;
    border-radius: 0;
    background-color: #fff;
    transition: transform .3s, border-color .3s;
}
#hd01 .hd-cover {
    display: block;
    width: 23vw;
    position: absolute;
    bottom: 0;
    right: 3vw;
    z-index: 100;
}
#hd01 .hd-txt {
    display: block;
    width: 50vw;
    max-width: 400px;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 50;
    transform: translate(-50%, -50%);
    background-color: rgba(255, 255, 255, 0.8);
}
#hd01 .hd-txt .txt-wrap {
    width: 75%;
    max-width: 360px;
    height: 100%;
    margin: 10px auto 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

/*--- スクロールダウン ---*/
.scroll-box {
    color: #000;
    font-family: bebas-neue, m-plus-1p, 'Noto Sans JP', sans-serif;
    font-size: 16px;
    letter-spacing: 0.1em;
    position: absolute;
    bottom: 40px;
    left: 50%;
    z-index: 50;
    display: inline-block;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    text-decoration: none;
}
.scroll-box .scroll-arrow {
    position: absolute;
    top: 100%;
    left: 50%;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 11px 0 11px;
    border-color: #B82E29 transparent transparent transparent;
    -webkit-animation: sdb 5s infinite;
    animation: sdb 5s infinite;
    box-sizing: border-box;
}
@-webkit-keyframes sdb {
  0% { -webkit-transform: translate(-50%, 0); }
  50% { -webkit-transform: translate(-50%, 10px); }
  100% { -webkit-transform: translate(-50%, 0); }
}
@keyframes sdb {
  0% { transform: translate(-50%, 0); }
  50% { transform: translate(-50%, 10px); }
  100% { transform: translate(-50%, 0); }
}

.main-slider {
    display: block;
    width: 100%;
    /*margin: -25px auto 0;*/
    margin: -2vw auto 3vw;
    margin-right: 0!important;
    position: relative;
    z-index: 10;
}
.main-slider img { width: 100%; height: auto; }

/* --------------------------------------------
    コンテンツ
-------------------------------------------- */
section { position: relative; overflow: hidden; }
.sec-inline, .ft-wrap { padding: 5em 0; padding-inline: calc((100vw - 1000px) / 2); }
#content-main {
    width: calc(100% + 30px);
    margin: 120px -15px 0;
}

/* --- flex-box --- */
.flex-box {
    display: flex;
    justify-content: center;
    align-items: center;
    /*flex-wrap: wrap;*/
}
.flex-wrap {
    display: flex;
    justify-content: flex-end;
    flex-flow: column;
}

/*--- grid-box ---*/
.grid-box {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    grid-gap: 3rem;
}
.grid2 { grid-template-columns: 1fr 1fr; }
.grid3 { grid-template-columns: 1fr 1fr 1fr; }
.grid5 { grid-template-columns: 1fr 1fr 1fr 1fr 1fr; }
.grid-wrap0 { grid-gap: 0!important; }

/*--- dl-list ---*/
.dl-list dl {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
    padding: 0.8em 0;
    border-bottom: 2px solid #000;
}
.dl-list dl:last-of-type { border-bottom: none; }
.dl-list dl dt, .dl-list dl dd {
    font-weight: bold;
}
.dl-list dl dt {
    color: #B82E29;
    margin-left: -0.5em;
}
.dl-list dl dd {
    flex: auto;
    margin-bottom: 0;
}

.set-between, .set-center {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.set-between { justify-content: space-between; }
.set-center { justify-content: center; }
.set-between .btn00, .set-center .btn00 {
    width: auto;
    margin: 0;
}

/* --- row --- */
.row { margin-right: -20px; margin-left: -20px; }
.col-lg-6, .col-md-6 { padding-right: 20px; padding-left: 20px; }

/* --- sec01 --- */
/* .sec01 {
    padding-top: 15vw!important;
    padding-bottom: 12vw!important;
} */
.sec01-wrap {
    position: relative;
    z-index: 50;
}
.sec01-txt {
    font-weight: bold;
    text-align: center;
    margin-bottom: 3rem;
}
.flex-harf {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 2rem;
}
.flex-harf > div { 
    width: 50%;
    margin-bottom: 2rem;
}
/* --- sec02 --- */
/* .sec02 {
    padding-top: 4em;
} */
/* --- sec03 --- */
.sec03 {
    padding-top: 4em;
}
/* --- sec04 --- */
.sec04 {
    padding-top: 4em;
}
.sec04-wrap {
    position: relative;
    z-index: 50;
}
/* --- sec05 --- */
.sec05-wrap {
    position: relative;
    z-index: 50;
    width: 96%;
    margin: 0 auto;
}
.sns-box .eapps-instagram-feed-content {
    height: auto;
    max-height: 400px;
    overflow-y: auto;
    overflow-x: hidden;
}
.sns-box .eapps-instagram-feed-content::-webkit-scrollbar {
   width: 10px;
   height: 10px;
}
.sns-box .eapps-instagram-feed-content::-webkit-scrollbar-track {
   background-color: #fff;
}
.sns-box .eapps-instagram-feed-content::-webkit-scrollbar-thumb {
   background-color: #ccc;
   border-radius: 25px;
   border: 2px solid #fff;
}
.sec05-item a {
    color: #333;
    text-decoration: underline;
}
.sec05-item a:hover {
    opacity: 0.5;
}

/* --- sec06 --- */
.sec06-wrap {
    position: relative;
    z-index: 50;
    width: 96%;
    margin: 0 auto;
}
/* --- sec07 --- */
.sec07-wrap .sec07-box {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 300px;
    cursor: pointer;
}
.sec07-box .sec07-item {
    flex: 1;
    color: #fff;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 350px;
    margin: 0 auto;
    overflow: hidden;
}
.sec07-box .sec07-item .sec07-bg {
    position: absolute;
    width: 100%!important;
    max-width: none!important;
    height: 100%!important;
    margin: auto;
    -webkit-transition: 1s ease!important;
    -o-transition: 1s ease!important;
    transition: 1s ease!important;
}
.sec07-box .sec07-item .sec07-bg img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    display: flex;
    flex-flow: wrap;
    align-items: center;
    width: 100%;
    height: 100%;
    object-fit: cover!important;
    overflow: hidden;
    cursor: pointer;
    -webkit-transition: 1s ease!important;
    -o-transition: 1s ease!important;
    transition: 1s ease!important;
}
.sec07-box .sec07-item:hover .sec07-bg img {
    width: 110%!important;
    height: 110%!important;
}

.sec07-box .sec07-item .rela-btn {
    display: block;
    width: 449px;
    max-width: 86%;
    height: 208px;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 10;
    transform: translate(-50%, -50%);
    margin: auto;
}
.sec07-box .sec07-item .rela-btn .rela-wrap {
    padding: 20px;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    height: 100%;
}

.sec07-box .sec07-item .sec07-tit {
    font-family: vdl-linegrpop-shadow, 'Noto Sans JP', sans-serif;
    display: block;
    font-size: 2.5rem;
    line-height: 1.1;
    letter-spacing: -0.02em;
    white-space: nowrap;
    transition: color .3s;
    margin-bottom: 15px;
}
.x-shrink { transform: scaleX(0.74); }
.sec07-box .sec07-item:hover .sec07-tit { color: #B82E29; }

.sec07-wrap .btn00 { text-align: left;}

/* --- .bnr-box --- */
.bnr-wrap {
    display: block;
    width: 92%;
    max-width: 1095px;
    margin: 0 auto;
    padding: 4rem 0;
}
.bnr-wrap .bnr-box { 
    grid-gap: 1rem;
    text-align: center;
}

/* --------------------------------------------
    footer
-------------------------------------------- */
#ft01 {
    color: #333;
    position: relative;
    z-index: 5;
    background:#fff;
}
.ft-wrap {
    width: 94%;
    margin: 0 auto;
    padding: 3em 0;
    position: relative;
}
.ft-wrap p,
.ft-wrap a {
	position: relative;
	z-index: 1;
	color: #333;
	font-size: 15px;
    font-weight: bold;
	line-height: 1.6;
    letter-spacing: 0.02em;
}
.ft-logo {
    width: 650px;
    max-width: 100%;
    margin-bottom: 30px;
}
.ft-box {
    display: flex;
    justify-content: flex-start;
}
.ft-box .ft-tit { font-weight: bold; margin-bottom: 10px; }

/* .ft-left { white-space: nowrap; } */
.ft-right { margin-left: 5em; }
.ft-list {
    list-style: none;
	display: inline-block;
	vertical-align: top;
	text-align: left;
    margin-bottom: 1.5rem;
    padding: 0;
}
.ft-list:not(:last-of-type) { margin-right: 2em; }
.ft-list > li { margin-bottom: 0.3em; }
.ft-list > li:last-child { margin-bottom: 0; } 
.ft-list > li a {
	padding-left: 0.9em;
	position: relative;
	font-size: 16px;
    letter-spacing: 0.01em;
    padding-left: 10px;
}
.ft-list > li a::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.75em;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4.5px 0 4.5px 5px;
    border-color: transparent transparent transparent #b82e29;
}
.ft-list > li a::after {
    position: absolute;
    bottom: -2px;
    left: 0;
    content: '';
    width: 100%;
    height: 2px;
    background: #333;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .3s;
}
.ft-list > li a:hover::after {
    transform-origin: left top;
    transform: scale(1, 1);
}
.ft-cp {
    color: #fff;
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.05em;
    text-align: center;
    padding: 15px;
    background-color: #000;
}


/* --------------------------------------------
    other page
-------------------------------------------- */
#titbar {
    position: relative;
    z-index: 5;
    background-color: #000;
}
#titbar h1 {
    color: #fff;
    /*font-family: vdl-linegrpop-shadow, 'Noto Sans JP', sans-serif;*/
    font-family: m-plus-1p, 'Noto Sans JP', sans-serif;
    font-size: 40px;
    display: block;
    width: 88%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 70px 15px 80px;
    text-align: center;
    /* text-transform: capitalize; */
}

/*---------- breadcrumb ----------*/
.breadcrumb {
    display: block;
    background-color: transparent;
    margin: 0 auto!important;
    padding: 0!important;
    text-align: right;
}
.breadcrumb ul {
    list-style: none;
    display: block;
    width: 96%;
    max-width: 1000px;
    margin: 0 auto!important;
    padding: 1.5em 0 0!important;
}
.breadcrumb ul li {
    color: #707070;
    position: relative;
    display: inline-block;
    font-size: 15px;
    font-weight: bold;
    letter-spacing: 0.015em;
    margin: 0;
    padding: 0!important;
    /* text-transform: capitalize; */
}
.breadcrumb ul li::before { display: none; }
.breadcrumb ul li:not(:last-child)::after {
    content: "▶";
    font-size: 15px;
    font-weight: 900;
    position: relative;
    padding: 0 5px 0 10px;
    color: #B82E29;
}
.breadcrumb ul li a {
    color: #333;
    border-bottom: 1px solid #333;
}
@media screen and (max-width: 575px) {
    .breadcrumb ul { width: 92%; padding: 30px 0 0!important; }
    .breadcrumb ul li { font-size: 13px; }
    .breadcrumb ul li:not(:last-child)::after { font-size: 13px; padding: 0 0 0 8px; }
}

/*--- section content ---*/
.other-content { position: relative; }
.other-content section { background-color: transparent; }
.other-content section:not(.bg-none) { background-color: #fff; }
.other-content section:nth-of-type(2) { padding-top: 2.5em; }
.other-content .content-wrap p { line-height: 1.8; }
.other-content.en-wrap .sec-inline {
    padding-top: 0 !important;
    padding-bottom: 0;
}
.other-content .row-img {
    display: block;
    height: 100%;
    margin-bottom: 1em;
}
.other-content .row-img img { margin: 0 auto; }
.other-content .row-map {
    line-height: 1;
    border: 1px solid #707070;
}
.other-content .row-map iframe {
    width: 100%;
    height: 365px;
}
.other-content .content-wrap .btn00 { margin-bottom: 1.5em; }

/*--- ul ol ---*/
.other-content ol {
    list-style: none;
    counter-reset: li;
    margin-bottom: 2em;
    padding-left: 1em;
}
.other-content ol li {
    position: relative;
    margin-bottom: 0.7em;
    padding-left: 10px;
    line-height: 1.6;
}
ol > li:before {
    position: absolute;
    color: #000;
    font-weight: bold;
    counter-increment: li;
    content: counter(li) ".";
    left: -1em;
    top: 0;
}
.other-content ol li > ul { margin-top: 10px; margin-bottom: 0; padding-left: 1em; }
.other-content ol.column2 { column-count: 2; padding-left: 0; }
.other-content ol.column2 li { padding-left: calc(1em + 10px); }
.other-content ol.column2 li::before { left: 0; }
.other-content ol li.no-num { padding-left: 0; }
.other-content ol li.no-num::before { display: none; }

.other-content ul { margin-bottom: 2em; }
.other-content ul li { margin-bottom: 0.8em; }

/*--- table ---*/
.js-scrollable {
    width: 100%;
    overflow: scroll;
}
.js-scrollable table {
    width: 100%;
    border: 1px solid #707070!important;
}
.js-scrollable table tr { border-bottom: none!important; }
.js-scrollable table tr th, .js-scrollable table tr td {
    color: #333!important;
    display: table-cell!important;
    width: auto!important;
    border: 1px solid #707070!important;
    white-space: nowrap; 
}
.js-scrollable table tr th { text-align: center; background-color: #F7F7F2; }
.js-scrollable table tr td { line-height: 2!important; }

.other-content table {
    width: 100%;
    margin: 0 auto 15px;
    border-collapse: collapse;
}
.other-content table tr {
    background-color: #FFF;
    border-bottom: 2px solid #000;
}
.other-content table tr:last-child { border-bottom: none; }
.other-content table tr th, .other-content table tr td {
    font-size: 0.95em;
    font-weight: bold;
    line-height: 1.3;
    letter-spacing: 0.02em;
    padding: 15px 30px;
    vertical-align: top;
}
.other-content table tr th {
    color: #B82E29;
}
.other-content table tr th p, .other-content table tr td p {
    line-height: 1.6!important;
    text-align: left;
}
.other-content table tr th p:last-of-type, .other-content table tr td p:last-of-type {
    margin-bottom: 0;
}

.form-table { margin: 1em auto 1.5em!important; border: 1px solid #707070; }
.form-table tr { border-bottom: 1px solid #707070!important; }
.form-table tr th, .form-table tr td { padding: 12px 18px!important; }
.form-table tr th { color: #000!important; background-color: #F7F7F2; }
.form-table .form-cp { font-size: 13px; line-height: 1.3; }
.form-table input, .form-table textarea { width: 100%; padding:5px; }
@media screen and (max-width: 575px) {
    .form-table tr th, .form-table tr td { display: block; }
}

/* --------------------------------------------
    記事
-------------------------------------------- */
.single-content section img { max-width: 100%; height: auto; }
.single-content .aligncenter, .single-content .aligncenter img { margin-left: auto; margin-right: auto; }
.single-content h1, .single-content h2, .single-content h3, .single-content h4 { line-height: 1.1; }
.single-content section .tit-line { padding-bottom: 6px; }

/* --------------------------------------------
    Responsive
-------------------------------------------- */
@media screen and (max-width: 1101px) {
    .sec-inline { padding: 4em 0; padding-inline: calc((100vw - 945px) / 2); }
}
@media screen and (max-width: 991px) {
    html, body { font-size: 17px; }
    h1 { font-size: 2em; }
    h2 { font-size: 1.8em; }
    h3 { font-size: 1.4em; }
    h4 { font-size: 1.3em; }
    h5 { font-size: 1.2em; }
    h6 { font-size: 1.1em; }
    .btn00 a span, .btn00 button span, .rela-box .rela-btn .rela-wrap { padding: 1.3em 3em; }

    #content-main { margin-top: 100px; }
    .sec-inline, .ft-wrap  { padding-inline: calc((100vw - 735px) / 2); }
    .scroll-box { bottom: 30px; }
    .sec07-wrap .sec07-box { display: block; }
    .btn00 a, .btn00 button, .rela-box .rela-btn { width: 100%;}
    .ft-logo { width: 330px; }
    .ft-right { margin-left: 2.5em; }
    .ft-list:not(:last-of-type) { margin-right: 0; margin-bottom: 0; }
    #titbar { margin-top: 67px; }
}
@media screen and (max-width: 767px) {
    html, body { font-size: 16px; }
    html::before, html::after { width: 3px; }
    body::after { height: 3px; }
    .box-wh, .box-gray, .box-ye { padding: 2em; }
    p.text-right { text-align: center!important; }
    .grid-box {
        grid-gap: 15px;
    }
    .grid2 { grid-template-columns: repeat(1, 1fr) !important; }
    .grid3 { grid-template-columns: repeat(1, 1fr) !important; }
    .grid4 { grid-template-columns: repeat(2, 1fr) !important; }
    .grid5 { grid-template-columns: repeat(2, 1fr) !important; }

    #content-main { margin-top: 67px; }
    .hd01::before { height: 6rem; }
    #hd01 .hd-txt { width: 70vw; }
    #hd01 .hd-txt .txt-wrap { width: 90%; max-width: 260px; }
    .main-slider .slick-slide { width: 26.4rem!important; }
    .main-slider .slick-track { margin-left: -13.2rem; }
    .scroll-box { bottom: 40px; }
    .sec-inline, .ft-wrap { padding-inline: calc((100vw - 520px) / 2); }
    .w90 { width: 100%; }
    .flex2 > div { width: 100%; }
    .flex4 > div { width: 50%; }
    .grid-box { grid-gap: 15px; }
    .grid3 { grid-template-columns: repeat(2, 1fr); }
    .grid4 { grid-template-columns: repeat(2, 1fr); }

    .sec01-txt { width: 90%; margin-left: auto; margin-right: auto; }
    .flex-harf {
       display: block;
    }
    .flex-harf > div { 
        width: 90%;
        margin-left: auto; margin-right: auto;
    }

    .sec05-wrap .grid-box {
        width: 80%;
        margin: 0 auto;
    }

    .ft-logo { width: 250px; }
    .ft-box { display: block; }
    .ft-left { margin-bottom: 2em; }
    .ft-right { margin-left: 0; }

    .other-content ol.column2 { column-count: 1; }
    .other-content table tr th, .other-content table tr td { padding: 12px 15px; }
    .js-scrollable table, table.no-responsive { width: 100%; }
    .js-scrollable table tr th, .js-scrollable table tr td,
    table.no-responsive tr th, table.no-responsive tr td { display: table-cell; width: auto!important; }
    .js-scrollable table tr td:last-child, table.no-responsive tr td:last-child { padding-top: 12px!important; }
}
@media screen and (max-width: 575px) {
    /*h1, h2, h3, h4, h5, h6 { letter-spacing: 0.02em; }*/
    h1 { font-size:clamp(25px, 8vw, 2em); }
    h2 { /*font-size:clamp(23px, 7vw, 1.8em);*/ font-size: clamp(20px, 6.6vw, 1.8em); letter-spacing: 0.06em; }
    h3 { font-size:clamp(20px, 6.2vw, 1.4em); }
    h4 { font-size:clamp(18px, 5.8vw, 1.3em); }
    h5 { font-size:clamp(16px, 5.4vw, 1.2em); }
    h6 { font-size:clamp(14px, 5vw, 1.1em); }
    .bg-yamagata::after { top: 2rem; left: 50%; width: 60%; }
    .grid3 { grid-template-columns: 1fr; }
    .box-wh, .box-gray, .box-ye { padding: 1.5em 1.2em; }
    .btn00 a span, .btn00 button span, .rela-box .rela-btn .rela-wrap { padding: 1.3em 2.5em; }
    .sec-inline, .ft-wrap { padding-inline: initial; padding-left: 5%; padding-right: 5%; /*padding-inline: calc((100vw - 300px) / 2);*/ }
    #hd01 .hd-cover { width: 52vw; right: -16vw; max-width: 250px; }
    .main-slider { margin: -10vw auto 5vw; }
    .sec05-wrap, .sec06-wrap { width: 100%; }
    .sec07-box .sec07-item { height: 100vw; }
    .bnr-wrap { width: 96%; max-width: 200px; }
    .bnr-wrap .bnr-box { grid-template-columns: 1fr!important; }
    .ft-wrap { width: 96%; }
    .ft-cp { font-size: 10px; letter-spacing: 0.02em; padding: 15px 10px; }
    #titbar h1 { font-size: 30px; padding: 40px 15px 42px; }

    .order .col-sm-4 p { width: 75%;}
}
@media screen and (max-width: 460px) {
    .sec-inline, .ft-wrap { /*padding-inline: calc((100vw - 315px) / 2);*/ }
}


/* --------------------------------------------
    お知らせリスト
-------------------------------------------- */
.news-box {
    width: 96%;
    margin: 0 auto 4em;
    padding: 1.5em 2.5em;
    overflow: hidden;
    background-color: #fff;
    border-radius: 0;
}
.news-box dl.news-item {
    display: flex;
    margin-bottom: 0;
    padding: 1em 0;
}
.news-box > a:not(:last-of-type) dl { border-bottom: 1px solid #333; }
.news-box dl.news-item::before { display: none; }
.news-box dl.news-item dt {
    font-weight: bold;
    padding-right: 1em;
}
.news-box dl.news-item dd {
    font-weight: bold;
    margin: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.news-box a {
    color: #000;
    padding: 18px 0;
    margin: 0;
    -webkit-transition: 0.5s;
    -o-transition: 0.5s;
    transition: 0.5s;
}
.news-box a:hover, .news-box a:focus {
    color: #333;
    text-decoration: none;
    outline: none;
}
.other-content .news-box { background-color: #F7F7F2; }
@media screen and (max-width: 575px) {
    .news-box { width: 96%; padding: 1em 1.5em; }
    .news-box a { display: block; margin-bottom: 6px; padding: 0; }
    .news-box dl.news-item { display: block; padding: 6px 0; }
    .news-box dl.news-item dd {
        white-space: initial;
        text-overflow: initial;
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }
}

/* --------------------------------------------
    ページネーション
-------------------------------------------- */
.pagenate ul {
    position: relative;
    display: flex;
    justify-content: center;
    padding: 0 30px;
    font-size: 0.9em;
    line-height: 1.2;
    font-family: m-plus-1p, 'Noto Sans JP', sans-serif;
    font-weight: 800;
}
.pagenate ul > * {
    position: relative;
    display: block;
    padding: 3px;
    margin: 5px 10px
}
.pagenate ul a {
    color:#000;
    text-decoration:none;
    border-bottom:2px solid rgba(0,0,0,0)
}
.pagenate ul .current_page {
    border-bottom:2px solid
}
.pagenate ul .previouspostslink,
.pagenate ul .nextpostslink {
    overflow:hidden;
    position:absolute;
    top:50%;
    width:16px;
    height:16px;
    margin:0;
    padding:0;
    margin-top:-10px;
    text-align:left;
    text-indent:-999em;
    background-color:#000;
    border-radius:16px;
    border:0
}
.pagenate ul .previouspostslink::after,
.pagenate ul .nextpostslink::after {
    content:"";
    position:absolute;
    top:50%;
    right:5px;
    margin-top:-2px;
    border-style:solid;
    border-width:2px 0 2px 5px;
    border-color:transparent transparent transparent #fff
}
.pagenate ul .previouspostslink {
    left:0;
    transform:rotate(180deg)
}
.pagenate ul .nextpostslink { right:0 }
@media screen and (min-width: 768px) {
    .pagenate ul a:hover { border-color:#000 }
    .pagenate ul .previouspostslink:hover,
    .pagenate ul .nextpostslink:hover { opacity:.7 }
}
@media screen and (max-width: 767px) {
    .pagenavi { display:block; margin-top:60px }
    .pagenate ul { flex-wrap:wrap; padding:0 40px; font-size:2rem }
    .pagenate ul > * { margin:5px 6px }
    .pagenate ul .previouspostslink,
    .pagenate ul .nextpostslink { width:30px; height:30px; margin-top:-17px }
    .pagenate ul .previouspostslink::after,
    .pagenate ul .nextpostslink::after { right:12px }
}

/* --------------------------------------------
    ステップ
-------------------------------------------- */
.step-box .step-item {
    padding: 1.2em 1.8em;
    background-color: #F7F7F2;
    border-radius: 0;
}
.step-box .step-item .step-wrap {
    display: flex;
}
.step-box .step-item .step-num {
    color: #B82E29;
    margin-right: 2em;
    padding: 0 0 5px;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 85px;
    height: 85px;
    padding: 0;
}
.step-box .step-item .step-num .num-hd {
    display: block;
    font-family: bebas-neue, 'Noto Sans JP', sans-serif;
    font-size: 21px;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.1em;
}
.step-box .step-item .step-num .num-txt {
    display: block;
    font-family: vdl-linegrpop-shadow, 'Noto Sans JP', sans-serif;
    font-size: 62px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.1em;
}
.step-box .step-item .step-txt {
    flex: 1;
    padding: 5px 0;
}
.step-box .step-item .step-txt p { font-weight: 500; margin-bottom: 0!important; }
.arrow-bottom {
    margin: 1.7em auto 1.2em;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 30px 33.5px 0 33.5px;
    border-color: #B82E29 transparent transparent transparent;
}
@media screen and (max-width: 767px) {
    .box-bd .flex-box { display: flex!important; }
}
@media screen and (max-width: 575px) {
    .step-box .step-item .step-wrap { display: block; }
    .step-box .step-item .step-num { margin: 0 auto 1em; }
}

/* --------------------------------------------
    ループ文字
-------------------------------------------- */
.head_marquee {
    overflow: hidden;
    display: flex;
    font-family: bebas-neue, m-plus-1p, 'Noto Sans JP', sans-serif;
    line-height: 1.5;
    padding: 2vw 0 0;
    opacity: 1;
    position: relative;
    z-index: 100;
}
.head_marquee .ff_en {
    font-size: 31px;
    font-weight: normal;
    letter-spacing: 0.1em;
}
.head_marquee .ff_ja {
    font-size: 27px;
    font-weight: 800;
    letter-spacing: 0.05em;
}
#hd01 .head_marquee { font-size: 2.8vw; }
.head_marquee.show {
    transition: opacity 1s;
    opacity: 1;
}
.head_marquee > * {
    display: flex;
    white-space: nowrap;
    /*width: 6000px;*/
    -webkit-animation: 20s linear 0s infinite head_marquee;
    animation: 20s linear 0s infinite head_marquee
}
.head_marquee > * > * {
    position: relative;
    display: flex;
    align-items: center;
}
.head_marquee .ff_en > span { padding: 0 0.2em; }
.head_marquee > * > *::after {
    content: "";
    position: relative;
    display: block;
    width: 70px;
    height: 70px;
    background: no-repeat 50%;
    background-size: 60px;
}
.head_marquee > * > *:nth-child(3n):after { background-image:url(../../common/img/gif-yamagata.gif) }
.head_marquee > * > *:nth-child(3n+1):after { background-image:url(../../common/img/gif-ramen.gif) }
.head_marquee > * > *:nth-child(3n+2):after { background-image:url(../../common/img/gif-naruto.gif) }
@-webkit-keyframes head_marquee {
    from { -webkit-transform:translateX(0) } 
    to { -webkit-transform:translateX(-2500.59px)}
}
@keyframes head_marquee {
    from { transform:translateX(0) }
    to { transform:translateX(-2500.59px) }
}
@media screen and (max-width: 767px) {
    .head_marquee { padding-bottom:20px }
}
@media screen and (max-width: 575px) {
    .head_marquee { padding-top: 4vw; }
}
/* scroll-txt */
.scroll-txt .head_marquee { color: #fff; padding: 4rem 0; }
.scroll-txt .head_marquee .ff_en { font-size: 7.5rem; line-height: 1; }
.scroll-txt .head_marquee > * > *::after { display: none; }
@media screen and (max-width: 767px) {
    .head_marquee { padding-bottom: 0; }
    .head_marquee .ff_ja { font-size: 24px; }
    .head_marquee .ff_en { font-size: 29px; }
    .scroll-txt .head_marquee .ff_en { font-size: clamp(70px, 25vw, 7.5rem); }
    .head_marquee > * > *::after { width: 60px; height: 60px; background-size: 50px; }
}
@media screen and (max-width: 575px) {
    .head_marquee .ff_ja { font-size: 19px; }
    .head_marquee .ff_en { font-size: 24px; }
    .head_marquee > * > *::after { width: 50px; height: 50px; background-size: 40px; }
}

/* --------------------------------------------
    スライダー
-------------------------------------------- */
.slider-wrap { width: 100%; margin: 0 auto 2em; }
.slick-slide img { margin: 0 auto; }
/*--- サムネイルありスライダー ---*/
.single-slider {
    width: 100%;
    height: auto;
}
.single-slider .slide-item,
.single-slider-thumbnail .slide-item {
    position: relative;
	width: 100%;
	padding-top: 66.7%;
    margin: 0 auto;
}
.single-slider .slide-item img,
.single-slider-thumbnail .slide-item img {
    position: absolute;
    width: 100%;
    height: 100% !important;
    top: 0;
    object-fit: cover;
}
.single-slider-thumbnail .slide-item img { padding: 5px; }

/*--- サムネイルありスライダー ---*/
.pickup-slider .slide-item a,
.pickup-slider .slide-item a:hover,
.pickup-slider .slide-item a:focus {
    color: #000;
    text-decoration: none;
    outline: none;
}
.pickup-slider .img {
    position: relative;
	width: 100%;
	padding-top: 66.7%;
    margin: 0 auto;
    overflow: hidden;
}
.pickup-slider .img::before {
    content: "";
    display: block;
    width: calc(100% + 10px);
    height: calc(100% + 10px);
    border: 20px solid #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
}
.pickup-slider .img img {
    position: absolute;
    width: calc(100% - 10px);
    height: calc(100% - 10px)!important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    object-fit: cover;
    /*padding: 10px;*/
    -webkit-transition: width 0.4s, height 0.4s, transform 0.4s;
    -o-transition: width 0.4s, height 0.4s, transform 0.4s;
    transition: width 0.4s, height 0.4s, transform 0.4s;
}
.pickup-slider .txt-wrap {
    padding: 0 10px;
}
.pickup-slider .txt-wrap .tit {
    font-weight: bold;
    margin: 0 0 10px;
    padding: 0 0 4px;
    border-bottom: 2px solid #000;
}
.pickup-slider .txt-wrap p {
    line-height: 1.3;
}
.pickup-slider .slide-item:hover .img img {
    width: 110%;
    height: 110% !important;
}
.bg-gray .pickup-slider .img::before { border-color: #F7F7F2!important; }

@media screen and (max-width: 767px) {
    .pickup-slider { width: 86%; margin: 0 auto; }
}

/* --------------------------------------------
    タグリスト
-------------------------------------------- */
.cat-list {
    display: flex;
    flex-flow: wrap;
}
.cat-list > a {
    color: #000;
    font-size: 22px;
    font-weight: bold;
    line-height: 1.3;
    letter-spacing: 0.02em;
    margin: 0 1.1rem 1.1em 0;
    padding: 7px 40px 10px;
    background-color: #fff;
    border: 4px solid #000;
    border-radius: 25px;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    text-transform: capitalize;
}
.cat-list > a:hover {
    color: #fff;
    background-color: #000;
}
@media screen and (max-width: 991px) {
    .cat-list > a { font-size: 18px; margin: 0 10px 20px 0;  padding: 7px 35px 10px; border: 3px solid #000; }
}
@media screen and (max-width: 767px) {
    .cat-list > a {   font-size: 15px; margin: 0 6px 15px 0; padding: 7px 25px 10px; }
}

/* --------------------------------------------
    ラーメン一覧
-------------------------------------------- */
.img-btn-list {
    display: grid;
    grid-gap: 3px;
}
.list3 { grid-template-columns: 1fr 1fr 1fr; }
.list4 { grid-template-columns: 1fr 1fr 1fr 1fr; }
.img-btn-list > .img-btn-item {
    position: relative;
    color: #fff;
    display: flex;
    flex-flow: wrap;
    align-items: center;
    width: 100%;
    height: 100%;
    overflow: hidden;
    cursor: pointer;
}
.img-btn-list > .img-btn-item::before {
    content: "";
    display: block;
}
.list3 > .img-btn-item::before { padding-top: 66.5%; }
.list4 > .img-btn-item::before { padding-top: 75.5%; }
/* img */
.img-btn-list > .img-btn-item .img-btn-bg img {
    position: absolute;
    width: 100%!important;
    max-width: none!important;
    height: 100%!important;
    object-fit: cover!important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    margin: auto;
    object-fit: cover;
    -webkit-transition: 1s ease!important;
    -o-transition: 1s ease!important;
    transition: 1s ease!important;
}
.img-btn-list > .img-btn-item:hover .img-btn-bg img {
    width: 110%!important;
    height: 110%!important;
}
/* txt */
.img-btn-list > .img-btn-item .img-btn-txt {
    position: absolute;
    width: 100%!important;
    max-width: none!important;
    height: 100%!important;
    object-fit: cover!important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    margin: auto;
    object-fit: cover;
    -webkit-transition: 1s ease!important;
    -o-transition: 1s ease!important;
    transition: 1s ease!important;
}
.img-btn-list > .img-btn-item .img-btn-txt::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    z-index: -2;
    display: block;
    width: 100%;
    height: 100%;
    background-color: transparent;
    opacity: 0.5;
    mix-blend-mode: multiply;
    -webkit-transition: background-color 0.4s!important;
    -o-transition: background-color 0.4s!important;
    transition: background-color 0.4s!important;
}
.img-btn-list > .img-btn-item:hover .img-btn-txt::before { background-color: #000; }
.img-btn-list > .img-btn-item .img-btn-txt::after {
    content: "";
    position: absolute;
    top: 0;
    left: -10px;
    z-index: -1;
    display: block;
    width: 5.65rem;
    height: 5.4rem;
    -webkit-mask: url(../../common/img/svg-hashtag.svg);
    mask: url(../../common/img/svg-hashtag.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background-color: #fff;
    opacity: 0.25;
}
.list3 > .img-btn-item .img-btn-txt::after {
    background-color: #B82E29;
    opacity: 0.35;
}
@media screen and (max-width: 575px) {
    .img-btn-list { grid-template-columns: 1fr 1fr!important; }
    .img-btn-list > .img-btn-item::before { padding-top: 100%!important; }
}
.eapps-instagram-feed-title-container { display: none;}
.coupon-txt {
    text-align: right;
    font-size: 12px;
    color: #707070;
}

/* --------------------------------------------
    店舗検索
-------------------------------------------- */
.search-tit {
    text-align: center;
    font-size: 21px;
    font-weight: 700;
    margin-bottom: 2rem;
}
.grid-search {
    display: grid;
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    align-items: end;
    margin-bottom: 2rem;
}
.grid-search label { cursor: pointer; }
.grid-search.g-s4 {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(2, 1fr);
}
.grid-search.g-s3 {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, 1fr);
}
@media screen and (max-width: 575px) {
    .grid-search.g-s4,.grid-search.g-s3 { grid-template-columns: 1fr 1fr !important; }
}
.btn-search input {
    background: #333;
    color: #fff;
    font-weight: 700;
    border-radius: 8px;
    padding: 10px 20px;
    display: inline-block;
    position: relative;
}

/* --------------------------------------------
    店舗一覧
-------------------------------------------- */
.data-list-box { padding: 0!important; }
.data-box > a {
    color: #333;
    display: block;
}
.data-box .data-img {
    position: relative;
    width: 100%;
    margin: 0 auto 10px;
    overflow: hidden;
}
.data-box .data-img::before {
    content: "";
    display: block;
    padding-top: 80%;
}
.data-box .data-img img {
    position: absolute;
    width: 100%!important;
    max-width: none!important;
    height: 100%!important;
    object-fit: cover!important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    margin: auto;
    object-fit: cover;
    -webkit-transition: 1s ease!important;
    -o-transition: 1s ease!important;
    transition: 1s ease!important;
}
.data-box a:hover .data-img img { width: 110%!important; height: 110%!important; }
/* .cat-list */
.data-box .cat-list > a {
    font-size: 13px;
    letter-spacing: 0.01em;
    margin: 0 5px 10px 0;
    padding: 5px 15px 4px;
    border: 2px solid #000;
    text-transform: capitalize;
}
.data-box .data-txt > a,
.data-box .data-txt > a:hover,
.data-box .data-txt > a:focus {
    color: #333;
    text-decoration: none;
    outline: none;
}
.data-box .data-txt .tit {
    font-size: 1.2em;
    font-weight: bold;
    line-height: 1.1;
}
/* .dl-list */
.data-box .data-dl dl {
    font-size: 14px;
    line-height: 1.4;
    padding: 8px 0;
}
@media screen and (max-width: 991px) {
    .data-list-box { grid-gap: 40px; }
}
@media screen and (max-width: 575px) {
    .data-list-box { grid-template-columns: 1fr; }
}

/* --------------------------------------------
    A-Form
-------------------------------------------- */
.aform-header { display: none!important; }
.aform-content dl {
    margin: 0.125em 0;
    padding: 0.5em 0;
    display: flex;
    border-bottom: 1px dotted #F2F2F2;
}
.aform-content dl:last-child { border-bottom: none; }
.aform-content dl dt {
    font-weight: bold;
    width: 35%;
    max-width: 260px;
    margin-right: 2.5%;
    background: #F2F2F2;
    padding: 10px;
}
.aform-content dl dd {
    margin: 0 0 0.5em;
    padding: 10px 0;
    width: 65%;
}
.aform-content ul,
.aform-name-ul, .aform-radio-ul {
    margin-bottom: 0!important;
    padding-left: 0!important;
}
.aform-name-ul li, .aform-radio-ul li { padding-left: 0!important; }
.aform-name-ul li:last-child, .aform-radio-ul li:last-child { margin-bottom: 0!important; }
.aform-name-ul li::before, .aform-radio-ul li::before { display: none!important; }

.aform-name-ul label { margin-right: 5px; }

.aform-radio-ul li {
    position: relative;
    padding-left: 1.2em!important;
    margin-bottom: 0!important;
}
.aform-content input[type="radio"], .aform-content input[type="checkbox"] { margin-right: 5px; margin-top: 0; }
.aform-content input[type="radio"] {
    position: absolute;
    left: 0;
    top: 0.8em;
}
.aform-content label { margin-top: 5px; }
.aform-input-example { font-size: 14px!important; font-weight: 500!important; }
.aform-upload { margin-bottom: 5px!important; }

.aform-required {
    color: #fff!important;
    font-size: 14px!important;
    font-weight: bold!important;
    line-height: 1!important;
    display: inline-block!important;
    margin-left: 5px!important;
    padding: 0.3em!important;
    background: #C30008!important;
    border-radius: 3px!important;
    vertical-align: bottom!important;
}
.aform-button-area { text-align: center; }
.aform-button-area input {
    color: #000!important;
    font-size: 1rem!important;
    width: auto!important;
    font-size: 1em!important;
    font-weight: bold!important;
    line-height: 1!important;
    letter-spacing: 0.02em!important;
    display: inline-block!important;
    margin: 30px 5px!important;
    padding: 20px 5em!important;
    background: #fff!important;
    border: 3px solid #000!important;
    border-right-width: 6px!important;
    border-bottom-width: 6px!important;
    border-radius: 0!important;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
}
.aform-button-area input:hover {
    color: #FFF!important;
    background: #000!important;
    border-right-width: 3px!important;
    border-bottom-width: 3px!important;
}
@media screen and (max-width: 767px) {
  .aform-content dl { display: block; }
  .aform-content dl dt { width: 100%; max-width: 100%; margin-right: 0; margin-bottom: 15px; padding: 10px 15px; }
  .aform-content dl dd { width: 100%; }
  .aform-content dl dd input, .aform-content dl dd textarea { max-width: 100%; }
  .aform-button-area { padding-top: 30px; }
  .aform-button-area input { width: 100%!important; padding: 20px 1em!important; margin: 0 5px 20px!important; }
  .aform-content .aform-name-ul input { max-width: calc(100% - 2em); }
}