@charset "UTF-8";


@font-face {
    font-family: "Optima";
    src: url("../font/Optima/Optima.woff") format("woff");
    font-weight: 400;
    font-style: normal;
}
@font-face {
    font-family: "Optima";
    src: url("../font/Optima/Optima_Italic.woff") format("woff");
    font-weight: 400;
    font-style: italic;
}
@font-face {
    font-family: "Optima";
    src: url("../font/Optima/Optima-Medium.woff") format("woff");
    font-weight: 500;
    font-style: normal;
}
@font-face {
    font-family: "Optima";
    src: url("../font/Optima/Optima_Bold.woff") format("woff");
    font-weight: 700;
    font-style: normal;
}

/* ==========================================================================
   Setting
========================================================================== */
:root {
    --white: #FFF;
    --l-gray: #F8F8F8;
    --l-gray2: #F4F4F4;
    --gray: #A0A0A0;
    --d-gray: #979797;
    --black: #222222;
    --border1: #E3E3E3;
    --border2: #DEDEDE;
    --color0: #DECFB6;
    --color1: #C79F62;
    --color2: #7C684E;
    --color3: #534741;
    --color4: #3F3531;
    --red: #BF272D;
    --l-red: #EAC5C9;
    --blue: #0071B9;
    --font1: 'Optima', sans-serif;
}
/* ==========================================================================
   Loading
========================================================================== */
#screenAnime {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--color1);
  z-index: 9999999;
  text-align:center;
  color:#fff;
}
#screenAnime-cont {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation: screenAnime_cont .8s cubic-bezier(.39, .575, .565, 1) forwards;
}
@keyframes screenAnime_cont{
  0%   { opacity: 0; }
  100% { opacity: .4; }
}
#screenAnime-cont svg {
  display: block;
  width: 5em;
  height: 5em;
}
#screenAnime-cont span {
  display: block;
  margin-top: .5em;
  font-size: .75em;
  font-weight: 700;
  letter-spacing: .24em;
  padding-left: .24em;
}
.screenAnime-bg{
    display: none;
}
body.loaded .screenAnime-bg{
    display: block;
    content: "";
    position:fixed;
    z-index: 999;
    width: 100%;
    height: 100vh;
    top: 0;
    left: 0;
    transform: scaleY(0);
    background-color: var(--color1);
    animation: screenAnime 1s cubic-bezier(.39, .575, .565, 1) forwards;
}
@keyframes screenAnime{
  0% {
    transform-origin:top;
    transform:scaleY(0);
  }
  50% {
    transform-origin:top;
    transform:scaleY(1);
  }
  50.001% {
    transform-origin:bottom;
  }
  100% {
    transform-origin:bottom;
    transform:scaleY(0);
  }
}
body #container {
    opacity: 0;
}
body.loaded #container {
    opacity: 0;
    animation: fadein .8s cubic-bezier(.39, .575, .565, 1) forwards .8s;
}
/***************************************************
 * Generated by SVG Artista
 **************************************************/
svg .svg-elem-0 {
  fill: #FFF;
  opacity: .25;
}
/*
svg .svg-elem-1 {
  stroke-dashoffset: 998.8814086914062px;
  stroke-dasharray: 998.8814086914062px;
  fill: transparent;
  transition: fill .3s cubic-bezier(0.47, 0, 0.745, 0.715) .7s;
}
svg.active .svg-elem-1 {
  fill: #FFF;
}
svg .svg-elem-2 {
  stroke-dashoffset: 116.95411682128906px;
  stroke-dasharray: 116.95411682128906px;
  transition: stroke-dashoffset .4s cubic-bezier(0.47, 0, 0.745, 0.715) .3s;
}
svg .svg-elem-3 {
  stroke-dashoffset: 43.599998474121094px;
  stroke-dasharray: 43.599998474121094px;
  transition: stroke-dashoffset .3s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}
svg.active .svg-elem-2,
svg.active .svg-elem-3 {
  stroke-dashoffset: 0;
}
*/


/* ==========================================================================
   Animation
========================================================================== */
[class*="iv-"] { opacity: 0; }
.delay02 { animation-delay: 0.2s; }
.delay04 { animation-delay: 0.4s; }
.delay06 { animation-delay: 0.6s; }
.delay08 { animation-delay: 0.8s; }
.delay10 { animation-delay: 1.0s; }
@keyframes fadein{
  0%   { opacity: 0; }
  100% { opacity: 1; }
}
@keyframes fadeout{
  0%   { opacity: 1; }
  100% { opacity: 0; }
}
/* ==========================================================================
   Base
========================================================================== */
html {
  font-size: 3.475vw;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}
@media (min-width: 375px) {
  html {
    font-size: 81.3%;
  }
}
@media (min-width: 768px) {
  html {
    font-size: 87.5%;
  }
}
@media (min-width: 1200px) {
  html {
    font-size: 100%;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 2;
  color: var(--black);
}
@media (max-width: 991px) {
    body.gNavOpen {
      height: 100%;
      overflow: hidden;
    }
}



#container, #content {
  overflow: hidden;
}
#container {
    margin-top: 5.5em;
}
@media (min-width: 992px) {
    #container {
        margin-top: 0;
    }
}

/* ==========================================================================
   Column layout
========================================================================== */
#main {
    background: #FFF;
    position: relative;
    z-index: 44;
}
@media (min-width: 992px) {
    #pageRow {
        display: flex;
        position: relative;
        z-index: 2;
    }
    #main {
        order: -1;
        flex-basis: 100%;
        width: 100%;
        overflow: hidden;
    }
    #sidebar {
        flex: 0 0 275px;
        max-width: 275px;
        background: var(--l-gray);
    }
}
@media (min-width: 1200px) {
    #sidebar {
        flex: 0 0 300px;
        max-width: 300px;
    }
}
@media (min-width: 1366px) {
    #sidebar {
        flex: 0 0 22vw;
        max-width: 22vw;
    }
}

/* ==========================================================================
   Header
========================================================================== */
#siteHeader {
  background: var(--white);
  width: 100%;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 100;
  transition: opacity .3s;
}
.inner-header {
    width: 100%;
    height: 5.5em;
    padding: 0 5.5em 0 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    z-index: 99;
    transition: background .6s .2s;
}
.siteLogo {
    margin: 0 0 0 20px;
    width: 12.5em;
    font-size: 1rem;
    line-height: 1;
    position: relative;
}
.siteLogo .logo__inner {
    display: block;
    color: inherit;
    position: relative;
}
.siteLogo .logo__inner img {
    display: block;
    vertical-align: bottom;
    width: 100%;
    height: auto;
}

@media (max-width: 991px) {
    body.gNavOpen #siteHeader {
        display: block !important;
    }
    body:not(.gNavOpen) #siteHeader {
        background: rgba(255,255,255,0.75);
    }
}
@media (min-width: 768px) {
    .siteLogo {
        margin: 0 0 0 35px;
    }
}
@media (min-width: 992px) {
    #siteHeader {
        width: 275px;
        display: block !important;
    }
    .inner-header {
        width: 100%;
        height: auto;
        padding: 0;
        background: var(--l-gray);
    }
    .siteLogo {
        display: flex;
        flex-direction: column;
        justify-content: center;
        width: 100%;
        margin: 0;
        padding: .75em 7.5% 0;
        height: 8.5em;
        transition: height .2s;
    }
    .siteLogo .logo__inner {
        max-width: 255px;
        transform-origin: left center;
        transition: transform .2s;
    }
}
@media (min-width: 1200px) {
    #siteHeader {
        width: 300px;
    }
}
@media (min-width: 1366px) {
    #siteHeader {
        width: 22vw;
    }
}


/* ==========================================================================
   Sidebar
========================================================================== */
#sidebar {
    background: var(--l-gray);
    position: relative;
    z-index: 66;
}
.sidebar__inner {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
}
.side-block {
    padding: 3em 7.5%;
    border-top: 1px solid var(--border1);
}
.side__header {
    margin-bottom: 2em;
}
.side__header .en_ttl {
    line-height: 1.25;
}
.side__header .ttl {
    display: block;
    line-height: 1.5;
}

@media (max-width: 991px) {
    #sidebar {
        width: 100%;
        max-width: 29em;
        height: 100vh;
        position: fixed !important;
        top: 0;
        right: 0;
        display: none;
        transform: translateX(105%);
        transition: transform .4s cubic-bezier(0.165, 0.84, 0.44, 1);
    }
    .sidebar__inner {
        height: 100%;
        padding-top: 9.5em;
        padding-bottom: 7em;
        overflow-y: auto;
    }
    #sidebar-overlay {
        width: 100%;
        height: 100%;
        background: rgba(0,0,0,0.5);
        position: fixed;
        top: 0;
        left: 0;
        z-index: 65;
        display: none;
    }
    #sidebar .inner {
        width: 480px;
        max-width: 100%;
        margin: 0 auto;
    }
    /* OPEN */
    #sidebar.on {
        transform: translateX(0);
    }
}
@media(min-width: 992px) {
    #sidebar {
        display: block !important;
    }
    #sidebar-overlay {
        display: none !important;
    }
    #sidebar .side__header .en_ttl {
        font-size: 1.625em;
    }
}
@media (min-width: 1440px) {
    .side-block {
        padding: 3em 7.5%;
    }
}

/* ==========================================================================
   Header menu
========================================================================== */
@media (max-width: 991px) {
    #hMenu {
        background: var(--l-gray);
        position: static !important;
    }
    #hMenu .siteLogo {
        display: none;
    }
}

@media(min-width: 992px) {
    #gNav-logo {
        order: -5;
    }
    #hMenu {
        width: 275px;
        border-bottom: 1px solid transparent;
        position: fixed;
        top: 0;
        right: 0;
        z-index: 77;
        transition: opacity .3s, border .3s;
    }
    #hMenu .hMenu__inner {
        display: flex;
        flex-direction: column;
        background: var(--l-gray);
        border-bottom: 1px solid transparent;
    }

    #hMenu .siteLogo  {
        visibility: hidden;
    }
}
@media(min-width: 1200px) {
    #hMenu {
        width: 300px;
    }
}
@media(min-width: 1366px) {
    #hMenu {
        width: 22vw;
    }
}

/* Navigation */
.gNav > nav > ul {
    display: flex;
    flex-wrap: wrap;
}
.gNav > nav > ul > li {
    flex: 0 0 50%;
}
.gNav > nav > ul > li > a {
    padding: 2em 15%;
    font-size: .923em;
    font-feature-settings: "palt";
    letter-spacing: .06em;
    color: var(--gray);
    background-repeat: no-repeat;
    background-position: right 15% center;
    background-size: 1.75rem;
    transition: color .6s cubic-bezier(0.165, 0.84, 0.44, 1);
}
li.shop > a {
    background-image: url(../img/icon/shop.svg);
}
li.floor > a {
    background-image: url(../img/icon/floor.svg);
}
li.event > a {
    background-image: url(../img/icon/event.svg);
}
li.access > a {
    background-image: url(../img/icon/access.svg);
}
li.service > a {
    background-image: url(../img/icon/info.svg);
}
.gNav > nav > ul > li > a > span {
    font-size: 1.167em;
    font-family: var(--font1);
    font-feature-settings: normal;
    letter-spacing: 0;
    color: var(--black);
    transition: color .6s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.gNav > nav > ul > li > a:hover > span {
    color: var(--color1);
}
@media (max-width: 991px) {
    .gNav::before {
        content: 'MENU';
        font-family: var(--font1);
        font-size: 1.5em;
        display: block;
        padding: 0 7.5%;
    }
    .gNav > nav > ul {
        border-bottom: 1px solid var(--border1);
    }
    .gNav > nav > ul > li {
        border-top: 1px solid var(--border1);
    }
    .gNav > nav > ul > li:nth-of-type(odd) {
        border-right: 1px solid var(--border1);
    }
    .gNav > nav > ul > li > a {
        height: 100%;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
}
@media(min-width: 992px) {
    .gNav {
        border-top: 1px solid var(--border1);
        padding: 1.5em 0 1.75em;
        transition: padding .2s;
    }
    .gNav > nav > ul > li > a {
        padding: 1.25em 0 1.25em calc(15% + 2.75em);
        font-size: .625em;
        background-position: 15% center;
        background-size: 1.357rem;
    }
    .gNav > nav > ul > li > a > span {
        font-size: 1.2em;
    }
    .gNav > nav > ul > li.tax-free > a {
        padding-left: 15%;
        padding-bottom: 0;
    }
}
@media(min-width: 1200px) {
    .gNav > nav > ul > li > a {
        background-size: 1.375rem;
    }
    .gNav > nav > ul > li > a > span {
        font-size: 1.3em;
    }
}
@media (min-width: 1440px) {
    .gNav > nav > ul > li > a > span {
        font-size: 1.4em;
    }
}
@media (min-width: 1600px) {
    .gNav > nav > ul > li > a > span {
        font-size: 1.5em;
    }
}
@media (min-width: 1800px) {
    .gNav > nav > ul > li > a > span {
        font-size: 1.6em;
    }
}


/* ==========================================================================
   Nav Btn
========================================================================== */
/* Nav Btn */
.nav-btn {
    background: var(--color1);
    color: var(--white);
    display: flex;
    justify-content: center;
    align-items: center;
    width: 5.5em;
    height: 5.5em;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
}
.nav-btn::after {
    content: 'MENU';
    font-family: var(--font1);
    font-weight: 500;
    font-size: .846em;
    text-align: center;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    z-index: 2;
}
.nav-btn.on::after {
    content: 'CLOSE';
}
.nav-btn i {
    display: block;
    background: currentColor;
    width: 50%;
    height: 1px;
    position: absolute;
    right: 0;
    left: 0;
    margin: -1px auto 0;
    transition: top .2s .2s, transform .2s;
}
.nav-btn i:nth-of-type(1) {
    top: calc(40% - 4px);
}
.nav-btn i:nth-of-type(2) {
    top: calc(40% + 4px);
}
.nav-btn.on i {
    transition: top .2s, transform .2s .2s;
}
.nav-btn.on i:nth-of-type(1) {
    top: 40%;
    transform: rotate(17.5deg);
}
.nav-btn.on i:nth-of-type(2) {
    top: 40%;
    transform: rotate(-17.5deg);
}

@media(min-width: 992px) {
    .nav-btn {
        display: none;
    }
}

/* ==========================================================================
   Select Language
========================================================================== */
.lang-select {
    font-size: .846em;
    margin: 0 1.5em;
    position: relative;
    white-space: nowrap;
}
.lang-select .lang-btn {
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220.5%22%20height%3D%2220.5%22%20viewBox%3D%220%200%2020.5%2020.5%22%3E%3Cpath%20d%3D%22M10.26%2C0c5.66%2C0%2C10.24%2C4.6%2C10.23%2C10.26%2C0%2C5.66-4.6%2C10.24-10.26%2C10.23C4.57%2C20.49%2C0%2C15.89%2C0%2C10.23%2C0%2C4.58%2C4.58%2C0%2C10.23%2C0h.03Zm3.15%2C13.66H7.08c.55%2C3.64%2C1.91%2C5.98%2C3.17%2C5.98s2.63-2.33%2C3.17-5.98m5.58%2C0h-4.72c-.19%2C2.08-.92%2C4.08-2.12%2C5.78%2C3.11-.65%2C5.68-2.82%2C6.84-5.78m-12.79%2C0H1.5c1.16%2C2.96%2C3.73%2C5.13%2C6.84%2C5.78-1.2-1.71-1.94-3.7-2.12-5.78m-.11-5.98H1.21c-.47%2C1.68-.47%2C3.45%2C0%2C5.12H6.11c-.17-1.7-.17-3.42%2C0-5.12m7.42%2C0H6.97c-.18%2C1.7-.18%2C3.42%2C0%2C5.12h6.56c.18-1.7%2C.18-3.42%2C0-5.12m5.76%2C0h-4.9c.17%2C1.7%2C.17%2C3.42%2C0%2C5.12h4.9c.47-1.68%2C.47-3.45%2C0-5.12M8.33%2C1.05C5.23%2C1.7%2C2.65%2C3.87%2C1.49%2C6.83H6.21c.19-2.08%2C.92-4.08%2C2.12-5.78m5.09%2C5.78c-.55-3.64-1.92-5.97-3.17-5.97s-2.62%2C2.33-3.17%2C5.98h6.35Zm-1.26-5.79c1.2%2C1.71%2C1.94%2C3.7%2C2.12%2C5.78h4.72c-1.16-2.96-3.73-5.13-6.84-5.78%22%20fill-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: 0% 50%;
    background-size: 1.125em;
    padding: 0 0 0 1.75em;
    font-family: var(--font1);
    cursor: pointer;
    transition: opacity .6s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.lang-select .lang-btn > span {
    display: inline-block;
    padding-right: 1.125em;
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2211.09%22%20height%3D%226.61%22%20viewBox%3D%220%200%2011.09%206.61%22%3E%3Cpolygon%20points%3D%225.54%206.61%200%201.06%201.06%200%205.54%204.48%2010.02%200%2011.09%201.06%205.54%206.61%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: right 0% top .9em;
    background-size: .5em;
}
.lang-select .lang-btn:hover {
    opacity: .5;
}
.lang-select .lang-list {
    list-style-type: none;
    display: flex;
    flex-direction: column;
    font-size: 1.182em;
    line-height: 1.5;
    min-width: 100%;
    padding: .75em 0;
    border-radius: .25em;
    background: var(--white);
    box-shadow: 0 .125em .5em rgba(0,0,0,0.2);
    position: absolute;
    top: 100%;
    right: 0;
    z-index: 5;
    transform: translateY(-1em);
    transition: transform .6s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: none;
}
.lang-select .lang-list.on {
    transform: translateY(0);
}
.lang-select .lang-list li {
    width: 100%;
}
.lang-select .lang-list li a {
    display: block;
    padding: .25em 1.5em;
    color: var(--d-gray);
}
.lang-select .lang-list li a.active {
    color: var(--black);
    pointer-events: none;
}
.lang-select .lang-list li a:hover {
    color: var(--black);
}


@media (max-width: 991px) {
    .gNav .lang-select {
        display: none;
    }
}
@media (min-width: 992px) {
    #siteHeader .lang-select {
        display: none;
    }
    .lang-select {
        font-size: .75em;
        margin: 0 15%;
    }
}

/* ==========================================================================
   Sidebar contents
========================================================================== */
/* hours */
.hours-list {
    list-style-type: none;
    margin-top: -.45em;
}
.hours-list li {
    display: flex;
    align-items: center;
    background-repeat: no-repeat;
    background-position: left center;
    background-size: 1.75rem;
}
.hours-list li.shopping {
    background-image: url(../img/icon/shop.svg);
}
.hours-list li.gourmet {
    background-image: url(../img/icon/gourmet.svg);
}
.hours-list li span {
    display: inline-block;
    white-space: nowrap;
}
.hours-list li .ttl {
    font-size: .9em;
    padding-left: 2.75em;
}
.hours-list li .open {
    flex-basis: 100%;
}
@media(min-width: 992px) {
    .hours-list li {
        background-size: 1.357rem;
    }
}


#sidebar .hours {
    width: 75%;
    margin-right: auto;
    margin-left: auto;
    padding: 3.5em 0;
    line-height: 1.25;
    border-top: 0;
}
#sidebar .hours .hours-ttl {
    text-align: center;
    font-size: 12px;
    position: relative;
}
#sidebar .hours .hours-ttl::before {
    content: '';
    width: 100%;
    height: 1px;
    background: var(--border1);
    position: absolute;
    top: 50%;
    left: 0;
}
#sidebar .hours .hours-ttl span {
    display: inline-block;
    padding: 0 1em;
    background: var(--l-gray);
    position: relative;
}
#sidebar .hours .hours-list {
    padding: .25em 0 0;
}
#sidebar .hours .hours-list li {
    min-height: 4.5em;
    padding: 1em 0;
    border-bottom: 1px solid var(--border1);
}
#sidebar .hours .hours-list li .open {
    text-align: right;
    position: relative;
}
#sidebar .hours .hours-list li span.note {
    display: block;
    color: var(--color2);
    font-size: .846em;
    line-height: 1.5;
}
#sidebar .hours p {
    font-size: .846em;
}
#sidebar .hours p.close {
    font-size: 1.077em;
    font-feature-settings: "palt";
    text-align: center;
    margin-top: 1.5em;
    padding: .75em;
    background: #FFF;
    border: 1px solid var(--color3);
    border-radius: .25em;
}
#sidebar .hours p.close span.ttl {
    margin-right: 1em;
}
#sidebar .hours p a {
    display: block;
}
#sidebar .hours p a img {
    width: 100%;
}
@media(max-width: 991px) {
    #sidebar .hours .inner {
        width: 480px;
        max-width: 100%;
        margin: 0 auto;
    }
}
@media(min-width: 992px) {
    #sidebar .hours {
        width: 77.5%;
        padding: .5em 0 3em;
    }
    #sidebar .hours .hours-list {
        font-size: .875em;
    }
    #sidebar .hours .hours-list li .ttl {
        font-size: .857em;
    }
    #sidebar .hours .hours-list li span.note {
        font-size: .75em;
    }
    #sidebar .hours p {
        font-size: .625em;
    }
    #sidebar .hours p.close {
        font-size: .75em;
    }
}
@media (min-width: 1200px) {
    .hours-list li {
        background-size: 1.375rem;
    }
    #sidebar .hours .hours-list li span.note {
        font-size: .75em;
    }
}


/* SNS */
#sidebar .follow {
    padding: 2em 7.5%;
}
#sidebar .follow .sns-links {
    list-style-type: none;
    display: flex;
    justify-content: center;
    align-items: center;
}
#sidebar .follow .sns-links li {
    padding: 0 .6em;
}
#sidebar .follow .sns-links .ttl h6 {
    line-height: 1;
}
#sidebar .follow .sns-links li a {
    display: block;
    width: 3em;
    height: 3em;
    transform: scale(1);
    transition: transform .6s cubic-bezier(0.165, 0.84, 0.44, 1);
}
#sidebar .follow .sns-links li a:hover {
    transform: scale(1.1);
}
#sidebar .follow .qr-box {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: .625em;
    margin-top: 2.5em;
}
#sidebar .follow .qr-box .qr {
    flex: 0 0 70px;
    max-width: 25%;
}
#sidebar .follow .qr-box .dashed-note {
    background-image: linear-gradient(90deg, transparent 0%, transparent 50%, var(--l-gray) 50%, var(--l-gray) 100%),
                    linear-gradient(180deg, var(--color1) 1px, transparent 1px); /* 点線2の色と太さ */
    background-size: 5px 100%, 100% 2.5em;
    line-height: 2.5em;
    padding-bottom: 1px;
    margin-left: 5%;
    margin-bottom: 1.25em;
    border-top: 1px solid var(--l-gray);
}
#sidebar .follow .qr-box .dashed-note::before {
    content: '';
    display: block;
    width: 100%;
    height: 2px;
    background: var(--l-gray);
    position: relative;
    z-index: 2;
}
@media(max-width: 991px) {
    .sidebar__contents {
        padding-top: 0 !important;
    }
    #sidebar .follow .qr-box {
        display: none;
    }
}
@media(min-width: 992px) {
    #sidebar .follow {
        padding: 2em 7.5%;
    }
    #sidebar .follow .sns-links {
        flex-wrap: wrap;
    }
    #sidebar .follow .sns-links .ttl {
        flex: 0 0 100%;
        text-align: center;
        margin-bottom: .75em;
    }
    #sidebar .follow .sns-links .ttl h6 {
        font-size: .688em;
    }
    #sidebar .follow .sns-links li a {
        width: 2.5em;
        height: 2.5em;
    }
}
@media (min-width: 1440px) {
    #sidebar .follow {
        padding: 1.75em 7.5%;
    }
}


/* Pickup posts */
#sidebar .pickup .card .ttl {
    font-size: .923em;
}
@media (min-width: 768px) {
    #sidebar .pickup .card .ttl {
        font-size: .929em;
    }
}
@media (min-width: 1200px) {
    #sidebar .pickup .card .ttl {
        font-size: .938em;
    }
}
@media (min-width: 1366px) {
    #sidebar .pickup .cards li {
        max-width: 260px;
        margin-right: auto;
        margin-left: auto;
    }
}
@media (min-width: 1800px) {
    #sidebar .pickup .cards li {
        flex: 0 0 50%;
        max-width: 50%;
        margin-right: 0;
        margin-left: 0;
    }
}


/* Tag list */
@media (min-width: 992px) {
  #sidebar .tag-list {
    margin: 0 -.3em;
  }
  #sidebar .tag-list > a {
    font-size: .733em;
    margin: .4em .3em;
    padding: .75em 1em;
  }
}
@media (min-width: 1200px) {
  #sidebar .tag-list > a {
    font-size: .75em;
  }
}



/* ==========================================================================
   PC Sidebar fixed menu (is fixed)
========================================================================== */
@media(min-width: 992px) {
    body.navFixed #hMenu {
        border-bottom-color: var(--border1);
    }
    body.navStop #siteHeader {
        visibility: hidden;
    }
    body.navStop #hMenu  {
        position: absolute;
        top: auto;
        bottom: 0;
        border-bottom-color: transparent;
    }
    body.navStop #hMenu .siteLogo {
        visibility: visible;
    }
}

/* ==========================================================================
   SP Fixed menu
========================================================================== */
#fixedNav {
    background: #FFF;
    box-shadow: 0 0 .5em rgba(0,0,0,0.1);
    width: 100vw;
    position: fixed;
    right: 0;
    bottom: 0;
    z-index: 55;
}
#fixedNav .container {
    padding: 0;
}
#fixedNav ul {
    list-style-type: none;
    display: flex;
}
#fixedNav * + ul {
    border-top: 1px solid var(--border1);
}
#fixedNav ul li {
    flex-basis: 100%;
}
#fixedNav ul li:not(:first-child) {
    border-left: 1px solid var(--border1);
}
#fixedNav ul li a {
    height: 5.5rem;
    padding: 1.5em 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    font-size: .769em;
    font-feature-settings: "palt";
    background-repeat: no-repeat;
    background-position: center 1.25em;
    background-size: 2em;
}
@media (max-width: 575px) {
    #fixedNav .container{
      width: 100%;
    }
}
@media (min-width: 576px) {
    #fixedNav ul {
        border-right: 1px solid var(--border1);
        border-left: 1px solid var(--border1);
    }
}
@media (min-width: 992px) {
    #fixedNav {
      display: none;
    }
}


/* ==========================================================================
   Fixed inquiry button
========================================================================== */
#fixedInquiry {
    position: fixed;
    right: 0;
    z-index: 55;
    bottom: 0;
    transition: opacity .3s cubic-bezier(0.165, 0.84, 0.44, 1);
}
#fixedInquiry a {
    display: block;
    min-width: 25vw;
    font-size: .923em;
    line-height: 1.4;
    letter-spacing: .06em;
    border-radius: .5em 0 0 0;
    padding: 1.25em 4.25em 1.25em 1.75em;
    background: var(--color1);
    color: #FFF;
    position: relative;
    transition: padding .3s cubic-bezier(0.165, 0.84, 0.44, 1);
}
#fixedInquiry a::before {
    content: '';
    display: block;
    width: 0.4em;
    height: 0.4em;
    border-top: 1px solid currentColor;
    border-right: 1px solid currentColor;
    position: absolute;
    top: 50%;
    right: 1.8em;
    transform: rotate(45deg) translateY(-50%);
}
@media (min-width: 768px) {
    #fixedInquiry a {
        font-size: .857em;
    }
}
@media (min-width: 992px) {
    #fixedInquiry {
        right: 275px;
        bottom: 1.5rem;
    }
    #fixedInquiry.is-hidden {
        opacity: 0;
    }
    #fixedInquiry a {
        min-width: inherit;
        writing-mode: vertical-rl;
        text-orientation: upright;
        border-radius: .5em 0 0 .5em;
        padding: 1.75em 1em 4em 1em;
    }
    #fixedInquiry a:hover {
        padding: 2em 1em 3.5em .75em;
    }
    #fixedInquiry a::before {
        top: auto;
        right: auto;
        left: 50%;
        bottom: 1.8em;
        transform: rotate(45deg) translateX(-50%);
    }
}
@media (min-width: 1200px) {
    #fixedInquiry {
        right: 300px;
    }
    #fixedInquiry a {
        font-size: .75em;
    }
}
@media (min-width: 1366px) {
    #fixedInquiry {
        right: 22vw;
    }
}

/* ==========================================================================
   Breadcrumb
========================================================================== */
.breadcrumb {
    color: var(--color2);
    overflow: hidden;
    padding: 1.75em 0;
}
.breadcrumb ol {
    display: flex;
    list-style: none;
    font-size: .813rem;
    line-height: 1.25;
    white-space: nowrap;
    font-feature-settings: "palt";
}
.breadcrumb ol li {
    display: flex;
    align-items: center;
}
.breadcrumb ol li:not(:last-child) {
    opacity: .4;
}
.breadcrumb ol li:not(:first-child)::before {
    content: '/';
    display: inline-block;
    margin: 0 .35em;
}
.breadcrumb ol li > a,
.breadcrumb ol li > span {
    display: block;
}
.breadcrumb ol li:last-child {
    overflow: hidden;
}
.breadcrumb ol li:last-child > a,
.breadcrumb ol li:last-child > span {
    overflow: hidden;
    text-overflow: ellipsis;
}
@media (min-width: 992px) {
    .breadcrumb {
        padding-top: 3.25em;
    }
}

/* ==========================================================================
   Page header
========================================================================== */
#page-header {
    width: 100%;
    padding: 0 0 1.75em;
    border-bottom: 1px solid var(--border1);
    position: relative;
}
#page-header .en_ttl {
    display: block;
    line-height: 1;
}
#page-header .ttl {
    display: block;
    line-height: 1.5;
}

@media (min-width: 992px) {
    #page-header {
        padding: 2.5em 0 2.75em;
    }
    #page-header .ttl {
        margin-top: .75em;
    }
}

/* ==========================================================================
   Page toc
========================================================================== */
#page-toc {
    background: var(--l-gray2);
    padding: .25em 0;
    margin: 0 -.5em;
}
#page-toc ul.toc {
    flex-wrap: nowrap;
}
#page-toc ul.toc li {
    flex-basis: 100% !important;
    padding: 0 .5em;
    margin: 0;
}
#page-toc ul.toc li::before {
    content: '';
    display: block;
    width: 1px;
    background: var(--border1);
    position: absolute;
    top: .5em;
    bottom: .5em;
    left: 0;
    transform: translateX(-50%);
}
#page-toc ul.toc li:first-child::before,
#page-toc ul.toc li::after {
    display: none !important;
  }
#page-toc ul.toc li a {
    flex-wrap: wrap;
    justify-content: center;
    height: 5em;
    padding: 1em 0;
    border-bottom: 0;
}
#page-toc ul.toc li a::before {
    display: none;
}

@media (max-width: 575px) {
    #page-toc {
        margin: 0 -20px;
    }
}

/* ==========================================================================
   Main contents
========================================================================== */
#main-contents {
    margin-bottom: 6em;
}
#page-header + #main-contents,
#page-toc + #main-contents {
    margin-top: 2em;
}
@media (min-width: 992px) {
    #main-contents {
        margin-bottom: 7em;
    }
    #page-header + #main-contents {
        margin-top: 3em;
    }
}
@media (min-width: 1200px) {
    #main-contents {
        margin-bottom: 8em;
    }
    #page-header + #main-contents,
    #page-toc + #main-contents {
        margin-top: 4em;
    }
}

/* ==========================================================================
   Main footer
========================================================================== */
#main-footer {
    width: 100%;
    position: absolute;
    left: 0;
    bottom: 0;
}


.search-shop_category {
    background: var(--l-gray2);
    padding: 1.5em 0;
    line-height: 1;
}
.search-shop_category .ttl {
    margin: .5em 0 1.5em;
}
.search-shop_category .cat-list {
  display: flex;
  flex-wrap: wrap;
  margin: 1em -.4em .2em;
}
.search-shop_category .cat-list > a {
  display: inline-block;
  border-radius: 2em;
  min-width: 8.75em;
  padding: .75em 1.75em;
  margin: .4em;
  border: 1px solid var(--color3);
  font-size: .923em;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}
.search-shop_category .cat-list > a:hover {
  background: var(--color3);
  color: #FFF;
}
@media (min-width: 768px) {
  .search-shop_category .container {
    display: flex;
  }
  .search-shop_category .ttl {
    white-space: nowrap;
    margin: 1.1em 2em 0 0;
  }
  .search-shop_category .cat-list {
      margin: 0 -.4em;
    }
}
@media (min-width: 992px) {
    .search-shop_category {
        font-size: .867em;
    }
    .search-shop_category .cat-list > a {
        font-size: 1em;
    }
}
@media (min-width: 1200px) {
    .search-shop_category {
        font-size: .75em;
    }
    .search-shop_category .cat-list > a {
        min-width: 7em;
        padding: .75em 1em;
    }
}

/* ==========================================================================
   Footer banner
========================================================================== */
#footer-banner {
    background: var(--color1);
    color: #FFF;
    position: relative;
}
#footer-banner ul.row {
    margin: .5em -10px;
}
#footer-banner ul.row > [class*="col"] {
    padding: 10px;
}
#footer-banner ul.row li a {
    display: block;
    position: relative;
}
#footer-banner ul.row li a img {
    display: block;
    position: relative;
}
#footer-banner ul.row li a::before {
    content: '';
    display: block;
    position: absolute;
    top: -3px;
    right: -3px;
    bottom: -3px;
    left: -3px;
    border-radius: 1px;
    background: transparent;
    transition: background .6s cubic-bezier(0.165, 0.84, 0.44, 1);
}
#footer-banner ul.row li a:hover::before {
    background: rgba(0,0,0,0.1);
}

@media (min-width: 992px) {
    #footer-banner {
        z-index: 88;
    }
}

/* ==========================================================================
   Footer
========================================================================== */
#siteFooter {
    background: var(--color3);
    color: var(--white);
    padding: 3em 0 6em;
    clear: both;
    overflow: hidden;
    position: relative;
}
.inner-footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    position: relative;
}
#page-top {
    flex: 0 0 6.5em;
    font-size: .846em;
    letter-spacing: .16em;
    text-align: center;
}
#page-top a {
    display: block;
}
#page-top img {
    width: 6.5em;
}
#page-top a:hover img {
    transform: translateY(-.25em);
}
#page-top span {
    display: block;
    padding: .25em 0 0 .24em;
}
#siteFooter .fNav {
    flex-basis: 100%;
}
#siteFooter ul {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -1em;
    list-style-type: none;
}
#siteFooter ul li a {
    display: inline-block;
    padding: .25em 1em;
}
#siteFooter ul.main-nav li {
    flex: 0 0 100%;
}
#siteFooter ul.main-nav li a span {
    display: block;
    position: relative;
}
#siteFooter ul.main-nav li a span::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: currentColor;
  opacity: .5;
  bottom: 0;
  left: 0;
  transform-origin: right;
  transform: scaleX(0);
  transition: transform .3s ease-in-out;
}
#siteFooter ul.main-nav li a span:hover::before {
  transform-origin: left;
  transform: scaleX(1);
}

#siteFooter ul.sub-nav {
    margin-top: 2em;
}
#siteFooter ul.sub-nav li {
    padding: .5em 0 0 1em;
}
#siteFooter ul.sub-nav li a {
    background: rgba(255,255,255,0.1);
    border-radius: 2em;
}
#siteFooter ul.sub-nav li a:hover {
    background: rgba(255,255,255,0.2);
}
#siteFooter .copyright {
    font-size: .75em;
    letter-spacing: .08em;
    padding: 1.5rem 0;
    margin: 0;
}


@media (min-width: 576px) {
    #siteFooter ul.main-nav li {
        flex: 0 0 45%;
    }
}
@media (min-width: 768px) {
    #page-top {
        position: absolute;
        top: 50%;
        right: 0;
        transform: translateY(-50%);
    }
    #siteFooter .fNav {
        flex-basis: 85%;
    }
    #siteFooter ul.main-nav li {
        flex: 0 0 33%;
    }
}

@media (min-width: 992px) {
    #siteFooter {
        padding: 4em 0 1.5em;
    }
    #siteFooter > .container {
        position: relative;
    }
    .inner-footer {
        position: static;
    }
    #page-top {
        font-size: .875em;
        top: calc(50% - 1.125em);
        right: 10px;
    }
    #siteFooter ul {
        max-width: 50em;
        font-size: .938em;
    }
    #siteFooter ul.main-nav li {
        flex: 0 0 auto;
    }
}

