@font-face {
    font-family: 'global_icon';
    src: url('fonts/global_icon.eot?27nabl');
    src: url('fonts/global_icon.eot?27nabl#iefix') format('embedded-opentype'), url('fonts/global_icon.ttf?27nabl') format('truetype'), url('fonts/global_icon.woff?27nabl') format('woff'), url('fonts/global_icon.svg?27nabl#global_icon') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: block;
}

[class^="icon-"],
[class*=" icon-"] {
    font-family: 'global_icon' !important;
    /* speak: never; */
    /* 非推奨: speak-as: never; を使用するか、aria-hidden="true"を推奨 */
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* アイコンクラスは維持 */
.icon-chevron-down:before {
    content: "\e900";
}

.icon-chevron-left:before {
    content: "\e901";
}

.icon-chevron-right:before {
    content: "\e902";
}

.icon-chevron-small-down:before {
    content: "\e903";
}

.icon-chevron-small-left:before {
    content: "\e904";
}

.icon-chevron-small-right:before {
    content: "\e905";
}

.icon-chevron-small-up:before {
    content: "\e906";
}

.icon-chevron-thin-down:before {
    content: "\e907";
}

.icon-chevron-thin-left:before {
    content: "\e908";
}

.icon-chevron-thin-right:before {
    content: "\e909";
}

.icon-chevron-thin-up:before {
    content: "\e90a";
}

.icon-chevron-up:before {
    content: "\e90b";
}

.icon-lock:before {
    content: "\e90c";
}

.icon-minus:before {
    content: "\e90d";
}

.icon-plus:before {
    content: "\e90e";
}

#global-overlay,
#lineup-font-size-sampler {
    top: 0;
    left: 0;
    z-index: -1
}

#wrapper,
body,
html {
    height: 100%
}

#header .header-banner img,
img {
    height: auto;
    width: 100%
}

html {
    overflow-x: hidden;
    min-width: 0;
    width: 100%
}

body.is-gnavopen {
    overflow: hidden
}

img {
    max-width: none;
    vertical-align: top
}

#wrapper {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.5
}

#wrapper #gmenu-inner a {
    font-size: 14px;
    font-size: 1.4rem;
}

#container {
    position: relative;
    padding-bottom: 30px;
}

#contents {
    padding-bottom: 30px
}

#global-overlay,
#gmenu-wrap {
    display: none;
    background-color: #fff;
}

#header {
    position: static;
    background: #fff;
    border-bottom: 1px solid #333;
    width: 100%;
    z-index: 7
}

#header .header-banner {
    line-height: 1;
    font-size: 0
}

#header.simple {
    border-top: 0;
    border-bottom: 5px solid #f4f4f4;
    padding: 0
}

#global-overlay {
    opacity: 0;
    /* filter: alpha(opacity=0); */
    /* IE8以下専用 - 非推奨 */
    /* -moz-opacity: 0; */
    /* 古いFirefox専用 - 非推奨 */
    background: rgba(0, 0, 0, .5);
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    padding: 0 !important;
    margin: 0 !important
}

#header-area {
    position: relative;
    width: 100%;
    min-height: 43px
}

.simple #header-area {
    border-bottom: 3px solid #c83250;
    min-height: 54px
}

#header-area .logo {
    position: absolute;
    left: 0;
    right: 0;
    top: 10px;
    margin: auto;
    width: 70pt;
    z-index: 2;
    z-index: 5
}

.shopMode #header-area .logo {
    top: 15px
}

.simple #header-area .logo {
    top: 9pt
}

.shopMode .simple #header-area .logo {
    top: 4px
}

#header-area .lead {
    display: none
}

.simple #header-area .logo-sd {
    position: absolute;
    top: 9pt;
    right: 10px;
    width: 70px
}

#header-area .utility-members {
    border-left: 1px solid #dedede;
    position: absolute;
    right: 142px;
    bottom: 10px;
    width: 60px;
    height: 2pc;
    text-align: center;
    z-index: 4
}

.shopMode #header-area .utility-members {
    bottom: auto;
    top: 7px
}

#header-area .utility-members a {
    display: inline-block;
    width: 27px;
    height: 2pc;
    vertical-align: middle;
    text-indent: -9999px;
    overflow: hidden;
    position: relative
}

#header-area .utility-members a:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url(/gs_front/image/cmn/ui_sprite.png);
    background-repeat: no-repeat;
    background-position: -377px 0;
    background-size: 600px auto;
    display: inline-block;
    width: 27px;
    height: 2pc;
    vertical-align: middle
}

.login #header-area .utility-members a {
    width: 2pc
}

.login #header-area .utility-members a:before {
    background-position: -406px 0;
    width: 2pc
}

#header-area #nav-toggle {
    position: absolute;
    top: 6px;
    left: 10px;
    width: 30px;
    height: 30px
}

.shopMode #header-area #nav-toggle {
    bottom: auto;
    top: 12px;
}

#header-area #nav-toggle a {
    display: block;
    position: relative;
}

.shopMode #header-area #nav-toggle a:before {
    top: 13pt;
}

#header-area #nav-toggle a span {
    position: absolute;
    bottom: 3px;
    left: 0;
    display: inline-block;
    width: 100%;
    color: #565656;
    font-size: 9pt;
    text-align: center;
    line-height: 1
}

.is-gnavopen #header-area #nav-toggle a:before {
    background: url(/gs_front/image/icon_menu_close.png)no-repeat;
    background-size: 26px auto
}

#header-area .mypage-box {
    display: none
}

#header-area .u-shops {
    position: absolute;
    right: 52px;
    top: 4px;
    width: 36px;
    height: 36px;
    z-index: 3
}

.shopMode #header-area .u-shops {
    bottom: auto;
    top: 12px
}

#header-area .u-shops a {
    display: block;
    position: relative;
    text-decoration: none
}

#header-area .cart-inbox {
    position: absolute;
    right: 10px;
    top: 4px;
    width: 36px;
    height: 36px;
    z-index: 3
}

.shopMode #header-area .cart-inbox {
    bottom: auto;
    top: 12px
}

#header-area .cart-inbox a {
    display: block;
    width: 100%;
    position: relative;
    text-decoration: none
}

#header-area .cart-inbox a span.cart-num {
    position: absolute;
    top: 0;
    left: 5px;
    display: inline-block;
    background-color: #fff;
    width: 20px;
    height: 20px;
    /* ine-height: 20px; */
    /* タイポ: line-heightの誤字 */
    line-height: 20px;
    /* 修正版 */
    border-radius: 50%;
    color: #c83250;
    text-align: center;
    z-index: 2;
    padding-top: 1px;
    font-weight: 700;
    font-size: 15px;
    font-size: 1.5rem;
}

#header-area .cart-inbox a span.cart-txt {
    position: absolute;
    bottom: 3px;
    left: 0;
    display: inline-block;
    width: 100%;
    padding-left: 7px;
    color: #565656;
    font-size: 10px;
    text-align: center;
    line-height: 1
}

#header-area .shop-name-text {
    width: 100%;
    padding: 44px 0 4px;
    text-align: center;
}

#header-area .shop-name-text span {
    display: block;
    width: 100%
}

#header-area .shop-name-text span span {
    display: block;
    color: #356734;
    line-height: 1.2;
    font-size: 9pt;
    font-size: 1.2rem
}

#header.fixed {
    position: fixed !important;
    z-index: 10000;
    width: 100%;
}

#header {
    border-bottom: none;
}

.hidden {
    display: none !important;
}

#search-area {}

.btn.search {
    background: url(/gs_front/image/cmn/ui_sprite.png) no-repeat -106px 2px;
    width: 25px;
    height: 25px;
    float: right;
    background-color: rgb(241, 241, 241);
}

.autocomplete {
    position: relative;
    display: inline-block;
    width: 250px;
}

.autocomplete-items {
    position: absolute;
    border: 1px solid #d4d4d4;
    border-bottom: none;
    border-top: none;
    z-index: 99;
    top: 100%;
    left: 0;
    right: 0;
}

.autocomplete-items span {
    float: right;
    display: inline-block;
    padding: 2px 5px;
}

.autocomplete-items span:hover {
    box-shadow: 2px 2px 5px rgba(0, 0, 0, .2);
    background: #ccc;
    color: #fff;
}

.autocomplete-items div {
    padding: 10px;
    cursor: pointer;
    background-color: #fff;
    border-bottom: 1px solid #d4d4d4;
}

.autocomplete-items div:hover {
    background-color: #e9e9e9;
}

.autocomplete-active {
    background-color: DodgerBlue !important;
    color: #ffffff;
}

#header-area .search-header {
    position: absolute;
    right: 90px;
    top: 4px;
    width: 36px;
    height: 36px;
    z-index: 3
}

.shopMode #header-area .search-header {
    bottom: auto;
    top: 12px
}

#header-area .search-header .search-icon {
    display: block;
    position: relative;
    text-decoration: none
}

#header-area .search-header .search-icon:before {
    display: none !important;
}

.borderTop {
    border-top-color: rgb(85, 85, 85);
    border-top-width: 1px;
    border-top-style: solid;
}

article .anker_area.fixed,
.anchor-nav.fixed,
.anchor-area.fixed,
.is-fixed .anchor-nav,
.nav-fixed,
.is-fixed .sdOkoudengaeshi .m-cr-anchorNav .m-cr-anchorNavInner {
    top: 73px !important;
}

.shopMode article .anker_area.fixed,
.shopMode .anchor-nav.fixed,
.shopMode .anchor-area.fixed,
.shopMode .is-fixed .anchor-nav,
.shopMode .nav-fixed,
.shopMode .is-fixed .sdOkoudengaeshi .m-cr-anchorNav .m-cr-anchorNavInner {
    top: 92px !important;
}

#gmenu-inner .members-box,
#gmenu-inner .users-box {
    line-height: 1.3
}

#gmenu-inner .users-box {
    margin: 30px 10px 0;
}

.login #gmenu-inner .users-box {
    margin: 20px 10px 0;
}

#gmenu-inner .users-login {
    text-align: center;
}

.simple #header-area .shop-name-text {
    padding-top: 40px
}

.simple #header-area .utility-nav {
    letter-spacing: -.4em;
    width: 50%;
    padding-right: 10px;
    position: absolute;
    right: 0;
    bottom: 18px;
    text-align: right
}

.shopMode .simple #header-area .utility-nav {
    right: 90px;
    bottom: auto;
    top: 10px;
    padding-top: 0;
    font-size: 13px;
    font-size: 1.3rem
}

.simple #header-area .utility-nav li {
    display: inline-block;
    letter-spacing: normal
}

.simple #header-area .utility-nav li a {
    display: inline-block;
    position: relative;
    padding-left: 20px
}

.simple #header-area .utility-nav li a:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 5px;
    display: inline-block;
    vertical-align: top;
    width: 4px;
    height: 4px;
    margin-top: -3px;
    border-top: 2px solid #3f3f3f;
    border-right: 2px solid #3f3f3f;
    /* -webkit-transform: rotate(45deg); */
    /* ベンダープレフィックス不要(2015年以降) */
    transform: rotate(45deg)
}

.utility-catalog span>span {
    display: none;
}

#gmenu-wrap {
    width: 100%;
    height: 100%;
    position: fixed;
    z-index: 1000;
    padding: 0 !important;
    margin: 0 !important;
    left: 0
}

#gmenu-inner {
    overflow-y: scroll;
    background: #fff;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    padding: 0 10px 100px;
    /* -moz-transform: translateX(100%); */
    /* 不要(transformで統一) */
    /* -webkit-transform: translateX(100%); */
    /* 不要 */
    /* -o-transform: translateX(100%); */
    /* Opera 12以前専用 - 非推奨 */
    /* -ms-transform: translateX(100%); */
    /* IE9専用 - 非推奨 */
    transform: translateX(100%)
}

.spMode #gmenu-inner {
    padding: 0 10px 80px;
}

#gmenu-inner .members-box .members-name:after,
#gmenu-inner .users-box a span:after {
    top: 50%;
    transform: translateY(-50%);
    right: 10px
}

#gmenu-inner .users-box a.icon-lock span:after {
    font-family: "global_icon";
    content: "\e902";
    font-size: 2rem;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
}

#gmenu-inner .members-box .members-name {
    background: #dcdcdc;
    padding: 18px 24px 1pc 9pt;
    position: relative
}

#gmenu-inner .members-box .members-name:after {
    position: absolute;
    display: inline-block;
    vertical-align: top;
    content: '';
    height: 9pt;
    margin-left: -6px;
    border-right: 2px solid #5f5f5f;
    transform: rotate(45deg)
}

#gmenu-inner .members-box .members-name a {
    display: block
}

#gmenu-inner .users-box a {
    display: block;
    color: #fff;
    background: #D03658;
    position: relative
}

.login #gmenu-inner .users-box a {
    color: #333;
    background: #fff;
}

#gmenu-inner .users-box a span {
    position: relative;
}

#gmenu-inner .users-box a span:after {
    position: absolute;
    display: inline-block;
    right: -30px;
    transform: rotate(45deg)
}

.login #gmenu-inner .users-box a span:after {
    top: 0;
}

#gmenu-inner .users-box .users-login a {
    padding: 10px 24px 10px 9pt
}

#gmenu-inner .users-box .users-login a:before {
    margin-right: 9px
}

#gmenu-inner .users-box .users-name a {
    padding: 10px 24px 10px 9pt;
    word-break: break-word
}

.login #gmenu-inner .users-box .users-name a {
    text-align: center;
}

#gmenu-inner .users-box .users-point {
    display: block;
    font-size: 9pt;
    margin-top: 3px
}

#gmenu-inner .users-box .users-point span:after {
    display: none;
}

.login span.users-point {
    width: 80%;
    margin: 5px auto 0;
    padding-top: 5px;
    border-top: 1px solid #333;
}

#gmenu-inner .utility-nav {
    width: 100%;
    vertical-align: top;
    border-top: 1px dotted #dedede;
}

#gmenu-inner .utility-nav ul li+li {
    border-top: 1px dotted #EAEAEA;
}

#gmenu-inner .utility-nav ul .service_tpoint span {
    display: inline-block;
    width: 20px;
    margin: 0 3px 0 0;
}

#gmenu-inner .utility-nav ul li a {
    position: relative;
    display: block;
    vertical-align: middle;
    padding: 14px 2em !important;
    line-height: 1.2
}

#gmenu-inner .utility-nav ul li a:after {
    content: "";
    position: absolute;
    right: 15px;
    display: block;
    width: 6pt;
    height: 6pt;
    margin-top: -15px;
    margin-left: -6px;
    border-top: 2px solid #5f5f5f;
    border-right: 2px solid #5f5f5f;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg);
    border-radius: 2px;
}

#gmenu-inner .utility-nav ul li.u-tp {
    padding: 0
}

#gmenu-inner .utility-nav ul li.u-tp img {
    margin-top: -2px
}

#gmenu-inner .utility-nav ul li.u-tp a {
    padding: 15px 9pt 14px
}

#gmenu-inner .utility-nav ul li.u-tp a img {
    max-width: 50%;
    width: auto
}

#gmenu-inner .utility-nav ul li.u-tp a:before {
    display: none
}

#gmenu-inner .utility-nav ul li.u-shop a:before {
    margin-top: -5px
}

#gmenu-inner .utility-nav ul li.u-shop a:after {
    content: "\e902";
}

#gmenu-inner .utility-nav ul li.u-shop>a:after {
    content: "\e90e"
}

#gmenu-inner .utility-nav ul li.u-shop.is-open>a:after {
    content: "\e90d";
}

#gmenu-inner .utility-nav ul li.u-shop.is-open a {
    background: #c2c2c2
}

#gmenu-inner .utility-nav ul li.u-shop.is-open .myshop-box a {
    background: #fff;
    display: block
}

#gmenu-inner .myshop-box {
    display: none;
    width: 100%;
    background: #fff
}

#gmenu-inner .myshop-box .btn-myshop a:after,
#gmenu-inner .myshop-box .myshop-list li a:after {
    font-family: "global_icon";
    content: "\e902";
    font-size: 2rem;
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 20px;
    vertical-align: middle;
    width: 9pt;
}

#gmenu-inner .myshop-box .btn-myshop {
    border-top: 1px solid #bfbfbf
}

#gmenu-inner .myshop-box .btn-myshop a {
    display: block;
    padding: 1pc 9pt 14px 27px;
    position: relative;
    text-decoration: none
}

#gmenu-inner .myshop-box .btn-myshop a:before {
    position: absolute;
    display: inline-block;
    border-top: 2px solid #c83250;
    /* -webkit-transform: rotate(45deg) !important; */
    /* 不要 */
    transform: rotate(45deg) !important
}

#gmenu-inner .myshop-box .myshop-list li {
    display: block;
    border-top: 1px solid #bfbfbf
}

#gmenu-inner .myshop-box .myshop-list li a {
    display: block;
    position: relative;
    padding: 1pc 9pt 14px 27px
}

#gmenu-inner .myshop-box .myshop-list li a:before {
    position: absolute;
    display: inline-block;
    border-top: 2px solid #c83250;
    /* -webkit-transform: rotate(45deg) !important; */
    /* 不要 */
    transform: rotate(45deg) !important
}

#gmenu-inner .utility-nav ul li.u-favorite a:before {
    width: 21px;
    background-position: -228px 0
}

#gmenu-inner .utility-nav ul li.u-shopSearch>a {
    position: relative;
    padding-right: 30px
}

#gmenu-inner .utility-nav ul li.u-shopSearch .detailHead__btn--myshop {
    padding: 10px;
}

#gmenu-inner .utility-nav ul li.u-shopSearch .detailHead__btn--myshop a {
    width: 100%;
    padding: 0
}

#gmenu-inner .utility-nav ul li.u-shopSearch .detailHead__btn--myshop a:after {
    display: none
}

#gmenu-inner .utility-nav ul li.u-guide a:before {
    padding-left: 0;
    margin-right: 0
}

#gmenu-inner .utility-catalog {
    margin: 30px 10px 20px;
    text-align: center;
}

.login #gmenu-inner .utility-catalog {
    margin: 20px 10px 20px;
}

#gmenu-inner .utility-catalog a {
    position: relative;
    font-size: 15px;
    font-size: 1.5rem;
    display: block;
    background: #eaeaea;
    text-decoration: none !important;
    padding: 10px
}

#gmenu-inner .utility-catalog a:before {
    position: absolute;
    top: 12px;
    left: 60px
}

#gmenu-inner .u-shops {
    border-top: 1px solid #bfbfbf;
    width: 100%;
    padding: 10px 15px
}

#gmenu-inner .icon-searchshop {
    position: relative;
    font-size: 15px;
    font-size: 1.5rem;
    display: block;
    background: #f3f3f3;
    border: 1px solid #c2c2c2;
    text-decoration: none !important;
    padding: 8px 10px 6px 8px;
    width: 100%
}

.icon-searchshop:before {
    display: none !important;
}

#gmenu-inner .btn-logout {
    display: none
}

.login #gmenu-inner .btn-logout {
    display: block;
    width: 100%;
    padding: 30px 15px 10px;
}

.login #gmenu-inner .btn-logout a {
    display: block;
    background: #D03658;
    color: #fff;
    text-align: center;
    text-decoration: none !important;
    padding: 8px 10px 6px
}

#gnav,
#gnav .main,
#gnav-area {
    width: 100%
}

#gnav a:hover {
    text-decoration: none !important
}

#gnav .main li {
    border-top: 1px solid #bfbfbf
}

#gnav .main li a {
    display: block;
    width: 100%;
    color: #000;
    text-shadow: none;
    padding: 1pc 9pt 14px;
    white-space: nowrap
}

#gnav .main li a:after {
    content: "";
    float: right;
    display: inline-block;
    vertical-align: middle;
    width: 9pt;
    height: 9pt;
    margin-left: 6px;
    border-top: 2px solid #5f5f5f;
    border-right: 2px solid #5f5f5f;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg)
}

/* .isIE9クラスは削除推奨(IE9サポート終了済み) */
/* .isIE9 #gnav .main li a:after {
    width: 9pt;
    height: 23px;
    background: url(/gs_front/image/cmn/ui_sprite.png)-449px -57px no-repeat;
    border-top: 0;
    border-right: 0;
    -webkit-transform: none;
    transform: none
} */

#gnav .main li.is-child a:after {
    /* -webkit-transform: rotate(135deg); */
    /* 不要 */
    transform: rotate(135deg)
}

/* .isIE9 #gnav .main li.is-child a:after {
    width: 24px;
    height: 9pt;
    background-position: -25pc -57px;
    -webkit-transform: none;
    transform: none
} */

#gnav .submenu-top,
#gnav .submenu-ttl {
    display: none !important
}

#gnav .main li .submenu-wrap {
    display: none;
    width: 100%
}

#gnav .main li.is-open a {
    background: #c2c2c2;
    color: #000
}

#gnav .main li.is-open a:after {
    /* -webkit-transform: rotate(-45deg); */
    /* 不要 */
    transform: rotate(-45deg);
    margin-top: 6px
}

/* .isIE9 #gnav .main li.is-open a:after {
    width: 24px;
    height: 9pt;
    background-position: -25pc -72px;
    -webkit-transform: none;
    transform: none
} */

#gnav .sub {
    display: block;
    background: #fff
}

#gnav .sub li.isTBb {
    display: block !important
}

#gnav .sub li {
    border: 0;
    border-top: 1px solid #bfbfbf;
    display: block;
    text-align: left
}

#gnav .sub li a {
    background: #fff !important;
    color: #000 !important;
    line-height: 1.2;
    vertical-align: top;
    padding: 1pc 9pt 14px 27px;
    font-size: 1pc;
    font-size: 1.6rem;
    white-space: normal
}

#gnav .sub li a:after {
    display: none
}

#gnav .sub li a:before {
    display: inline-block;
    vertical-align: top;
    content: '';
    width: 5px;
    height: 5px;
    margin-top: 6px;
    margin-left: -18px;
    margin-right: 10px;
    border-top: 2px solid #c83250;
    border-right: 2px solid #c83250;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg)
}

/* .isIE9 #gnav .sub li a:before {
    width: 6px;
    height: 9px;
    margin-right: 8px;
    background: url(/gs_front/image/cmn/ui_sprite.png)-8pc -24px no-repeat;
    border-top: 0;
    border-right: 0;
    -webkit-transform: none;
    transform: none
} */

#search-area {
    padding: 10px 15px;
}

#search-area fieldset {
    background: #f3f3f3;
    display: block;
    position: relative;
    width: 100%;
    height: 36px
}

#search-area .query {
    position: absolute;
    top: 0;
    left: 0;
    border: 0;
    background: 0;
    border-radius: 0;
    font-size: 1pc;
    font-size: 1.6rem;
    padding: 4px 5px 2px 38px;
    width: 100%;
    height: 36px;
    /* -webkit-appearance: none; */
    /* Safari 15.4+では不要 */
    /* -moz-appearance: none; */
    /* Firefox 80+では不要 */
    appearance: none;
    transition: .3s ease 0;
    /* -webkit-transition: ease .3s */
    /* 不要 */
}

#search-area button {
    position: absolute;
    left: 4px;
    top: 3px;
    width: 25px;
    height: 30px;
    text-indent: 200%;
    white-space: nowrap;
    overflow: hidden;
    transition: left .5s ease 0;
    /* -webkit-transition: left .5s ease 0 */
    /* 不要 */
}

#search-area button:before {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 2;
    content: "";
    background: url(/gs_front/image/cmn/ui_sprite.png)-393px 5px no-repeat;
    background-size: 500px auto;
    display: block;
    width: 25px;
    height: 30px
}

.pagetop,
.pagetop a {
    width: 55px;
    height: 40px
}

#search-area.isFocus .query {
    padding: 4px 38px 2px 5px
}

#search-area.isFocus button {
    margin-left: -30px;
    left: 100% !important
}

.pagetop {
    display: none !important;
    position: absolute;
    right: 8px;
    bottom: 10px;
    z-index: 6
}

.pagetop a {
    background: url(/gs_front/image/cmn/pagetop.png)no-repeat;
    background-size: 55px auto;
    text-indent: -9999px;
    overflow: hidden
}

.pagetop.is-fixed {
    position: fixed;
    display: none !important;
}

.pagetop.is-fixed a {
    display: none !important;
    opacity: .7;
    /* filter: alpha(opacity=70); */
    /* IE8以下専用 - 非推奨 */
    /* -moz-opacity: .7 */
    /* 非推奨 */
}

#shop-detail-area {
    border-bottom: 1px solid #d5d5d5;
    box-shadow: 0 5px #f4f4f4;
    width: 100%
}

#shop-detail-area .shop-detail-inner {
    width: 100%;
    padding: 3px 10px 6px
}

#shop-detail-area .shop-data-box:after {
    content: "";
    display: block;
    clear: both
}

#shop-detail-area .shop-data-ico {
    width: 100%
}

#shop-detail-area .shop-data-ico ul {
    display: flex;
    /* display: -webkit-box等のレガシー構文は不要 */
    /* display: -webkit-flex; */
    /* 不要 */
    /* display: -moz-flex; */
    /* 存在しない構文 */
    /* display: -ms-flexbox; */
    /* IE10専用 - 非推奨 */
    flex-wrap: wrap;
    /* -webkit-flex-wrap: wrap; */
    /* 不要 */
    /* -moz-flex-wrap: wrap; */
    /* 存在しない構文 */
    /* -ms-flex-wrap: wrap; */
    /* 不要 */
    width: 102%;
    margin-left: -2%
}

/* Modernizrのno-flexboxクラスは削除推奨(Flexboxは全モダンブラウザでサポート済み) */
/* .no-flexbox #shop-detail-area .shop-data-ico ul {
    display: table;
    word-spacing: -1em
} */

#shop-detail-area .shop-data-ico li {
    background-color: #b2aca6;
    line-height: 22px;
    height: 20px;
    text-align: center;
    color: #fff;
    width: 31.33333%;
    font-size: 11px;
    font-size: 1.1rem;
    margin-left: 2%;
    margin-top: 4px
}

/* .no-flexbox #shop-detail-area .shop-data-ico li {
    display: inline-block;
    vertical-align: middle;
    word-spacing: normal
} */

#shop-detail-area .shop-data-ico li img {
    height: 20px
}

#shop-detail-area .shop-data-address {
    margin-top: 8px
}

#shop-detail-area .shop-data-address,
#shop-detail-area .shop-data-btn,
#shop-detail-area .shop-data-tel {
    line-height: 1.2
}

#shop-detail-area .shop-data-tel {
    float: left;
    margin-top: 8px
}

#shop-detail-area .shop-data-btn strong,
#shop-detail-area .shop-data-tel strong {
    line-height: 1;
    display: inline-block
}

#shop-detail-area .shop-data-btn {
    display: inline-block;
    float: right
}

#shop-detail-area .shop-data-btn a {
    display: inline-block;
    background: #f3f3f3;
    border: 1px solid #c2c2c2;
    /* -webkit-border-radius: 3px; */
    /* 不要 */
    /* -moz-border-radius: 3px; */
    /* 不要 */
    /* -ms-border-radius: 3px; */
    /* 存在しない構文 */
    /* -o-border-radius: 3px; */
    /* Opera 10.5専用 - 非推奨 */
    border-radius: 3px;
    padding: 5px 8px 3px
}

#footer-utility,
#footer-utility ul li {
    border-bottom: 1px solid #c7c7c7
}

#shop-detail-area .shop-data-btn a:after {
    display: inline-block;
    vertical-align: middle;
    content: '';
    width: 5px;
    height: 5px;
    margin-top: -3px;
    border-top: 2px solid #555;
    border-right: 2px solid #555;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg);
    margin-left: 6px
}

#footer-area .nav h3,
#footer-area .nav h3 a {
    font-weight: 700;
    display: block
}

/* .isIE9 #shop-detail-area .shop-data-btn a:after {
    top: 9px;
    width: 6px;
    height: 9px;
    background: url(/gs_front/image/cmn/ui_sprite.png)-137px -35px no-repeat;
    border-top: 0;
    border-right: 0;
    -webkit-transform: none;
    transform: none
} */

#footer-area .nav h3:after,
#footer-area .nav ul li a:before {
    top: 50%;
    vertical-align: top;
    content: ""
}

#shop-detail-area .shop-data-btn a:hover {
    text-decoration: none
}

#footer-area a,
.btn--entry {
    text-decoration: none !important
}

#footer-area {
    background: #efefef;
    border-top: 1px solid #efefea;
    width: 100%
}

#footer-area a:hover {
    color: #000
}

#footer-area .footer-nav {
    width: 100%;
    margin: 0 auto
}

#footer-area .nav h3 {
    border-top: 1px solid #c7c7c7;
    position: relative;
    font-size: 1pc;
    font-size: 1.6rem;
    cursor: pointer;
    padding: 1pc 30px 14px 9pt
}

#footer-area .nav h3:after {
    position: absolute;
    right: 15px;
    left: auto;
    bottom: auto;
    display: inline-block;
    width: 6pt;
    height: 6pt;
    margin-top: -8px;
    margin-left: -6px;
    border-top: 2px solid #5f5f5f;
    border-right: 2px solid #5f5f5f;
    /* -webkit-transform: rotate(135deg); */
    /* 不要 */
    transform: rotate(135deg);
    border-radius: 2px;
}

#footer-area .nav h3.js-no-toggleSwitch:after {
    content: "";
    position: absolute;
    right: 15px;
    display: block;
    width: 6pt;
    height: 6pt;
    margin-top: -6px;
    margin-left: -6px;
    border-top: 2px solid #5f5f5f;
    border-right: 2px solid #5f5f5f;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg);
    border-radius: 2px
}

/* .isIE9 #footer-area .nav h3:after {
    width: 23px;
    height: 9pt;
    margin-left: 0;
    margin-right: -6px;
    margin-top: -6px;
    background: url(/gs_front/image/cmn/ui_sprite.png)-25pc -57px no-repeat;
    border-top: 0;
    border-right: 0;
    -webkit-transform: none;
    transform: none
} */

#footer-area .nav.is-open h3 {
    background: #dcdcdc
}

#footer-area .nav.is-open h3:after {
    margin-top: -4px;
    /* -webkit-transform: rotate(-45deg); */
    /* 不要 */
    transform: rotate(-45deg)
}

/* .isIE9 #footer-area .nav.is-open h3:after {
    background: url(/gs_front/image/cmn/ui_sprite.png)-25pc -72px no-repeat;
    border-top: 0;
    border-right: 0;
    -webkit-transform: none;
    transform: none
} */

#footer-area .nav .js-toggleContents {
    display: none
}

#footer-area .nav ul {
    vertical-align: top;
    font-size: 14px;
    font-size: 1.4rem
}

#footer-area .nav ul li {
    border-top: 1px solid #c7c7c7;
    line-height: 1.3
}

#footer-area .nav ul li a {
    width: 100%;
    display: block;
    position: relative;
    padding: 9pt 9pt 10px 30px
}

#footer-area .nav ul li a:before {
    position: absolute;
    right: 16px;
    display: inline-block;
    width: 8px;
    height: 8px;
    margin-top: -5px;
    border-top: 2px solid #c7c7c7;
    border-right: 2px solid #c7c7c7;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg)
}

/* .isIE9 #footer-area .nav ul li a:before {
    width: 8px;
    height: 1pc;
    margin-left: 0;
    margin-right: -6px;
    margin-top: -8px;
    background: url(/gs_front/image/cmn/ui_sprite.png)-487px -57px no-repeat;
    border-top: 0;
    border-right: 0;
    -webkit-transform: none;
    transform: none
} */

#footer-area .box-info {
    padding-top: 10px
}

.simple #footer-area .box-info {
    float: right;
    width: 30%
}

#footer-area .box-info .sns-info {
    float: left;
    width: 50%;
    padding-left: 8px
}

#footer-area .box-info .sns-info ul {
    margin-top: 30px;
    letter-spacing: -.4em
}

#footer-area .box-info .sns-info ul li {
    display: inline-block;
    letter-spacing: normal;
    vertical-align: bottom;
    margin-right: 10px
}

#footer-area .box-info .sns-info ul li a {
    display: block;
    text-indent: -9999px;
    overflow: hidden;
    width: 28px;
    height: 28px
}

#footer-area .box-info .sns-info ul li a:before {
    content: "";
    display: block;
    width: 28px;
    height: 28px;
    margin: 0;
    background-image: url(/gs_front/image/cmn/ui_sprite.png);
    background-repeat: no-repeat;
    background-size: 25pc auto
}

#footer-area .box-info .sns-info ul li:first-child a:before {
    display: block;
    background-position: -200px -45px
}

#footer-area .box-info .sns-info ul li:nth-child(2) a:before {
    background-position: -232px -45px
}

#footer-area .box-info .sns-info ul li:nth-child(3) a:before {
    background-position: -261px -45px
}

#footer-area .footer-btm {
    float: right;
    width: 18%;
    padding-right: 8px
}

#footer-area .footer-btm p img {
    width: 45px
}

#footer-area .footer-btm p+p {
    margin-top: 0
}

#footer-area .footer-btm p+p a {
    display: block
}

#footer-area .footer-btm p+p a+a {
    margin-top: 6px
}

.simple #footer-area .footer-btm {
    padding-bottom: 10px;
    width: 100%
}

.simple #footer-area .footer-btm p {
    text-align: right
}

#footer-utility ul {
    display: table;
    width: 100%;
    word-spacing: -1em;
    margin-bottom: -1px;
    border-top: 1px solid #c7c7c7
}

#footer-utility ul li {
    width: 50%;
    display: inline-block;
    vertical-align: top;
    word-spacing: normal;
    font-size: 14px;
    font-size: 1.4rem
}

#footer-utility ul li:nth-child(odd) {
    border-right: 1px solid #c7c7c7
}

#footer-utility ul li a {
    display: block;
    position: relative;
    padding: 8px 6px 6px 20px
}

#footer-utility ul li a:before {
    content: "";
    position: absolute;
    top: 1.3em;
    right: 10px;
    display: inline-block;
    vertical-align: top;
    width: 4px;
    height: 4px;
    margin-top: -3px;
    border-top: 2px solid #3f3f3f;
    border-right: 2px solid #3f3f3f;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg)
}

/* .isIE9 #footer-utility ul li a:before {
    width: 6px;
    height: 10px;
    margin-top: -5px;
    background: url(/gs_front/image/cmn/ui_sprite.png)-255px -28px no-repeat;
    background-size: 25pc auto;
    border-top: 0;
    border-right: 0;
    -webkit-transform: none;
    transform: none
} */

#footer .copyright {
    width: 100%;
    background: #555;
    padding: 6px 10px
}

#footer .copyright small {
    display: block;
    font-size: 11px;
    font-size: 1.1rem;
    color: #fff;
    max-width: 100pc;
    margin: 0 auto;
    text-align: center
}

#footer .attention {
    display: none
}

#footer.simple .utility-nav {
    width: 50%;
    float: left;
    padding-top: 15px;
    display: table;
    word-spacing: -1em
}

#footer.simple .utility-nav li {
    width: 100%;
    display: inline-block;
    vertical-align: top;
    word-spacing: normal;
    font-size: 14px;
    font-size: 1.4rem
}

#footer.simple .utility-nav li:nth-child(even) {
    border-left: 1px solid #c7c7c7
}

#footer.simple .utility-nav li a {
    display: inline-block;
    position: relative;
    padding: 8px 6px 6px 20px
}

#footer.simple .utility-nav li a:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 5px;
    display: inline-block;
    vertical-align: top;
    width: 4px;
    height: 4px;
    margin-top: -3px;
    border-top: 2px solid #3f3f3f;
    border-right: 2px solid #3f3f3f;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg)
}

/* .isIE9 #footer.simple .utility-nav li a:before {
    width: 6px;
    height: 10px;
    margin-top: -5px;
    background: url(/gs_front/image/cmn/ui_sprite.png)-255px -28px no-repeat;
    background-size: 25pc auto;
    border-top: 0;
    border-right: 0;
    -webkit-transform: none;
    transform: none
} */

.btm-sitetop {
    display: none
}

.view-pc a,
.view-pc a:before {
    display: inline-block
}

.view-pc {
    background: #e7e7e7;
    border-top: 1px solid #c7c7c7;
    padding: 6px 8px 4px
}

.view-pc a:before {
    content: "";
    background: url(/gs_front/image/cmn/ui_sprite.png)-293px -45px no-repeat;
    background-size: 25pc auto;
    width: 18px;
    height: 1pc;
    vertical-align: middle;
    margin-right: 6px
}

.shop-information {
    border: 1px solid #bfbfbf;
    margin: 20px 3%;
    padding: 18px 10px 10px
}

.shop-information .title-box {
    margin-top: 0 !important;
    height: 0
}

.shop-information .title-box .title {
    display: block;
    margin: 0 auto
}

.shop-information .title-box .title img {
    max-width: 100%;
    border-left: 10px solid #fff;
    border-right: 10px solid #fff;
    width: auto;
    margin-top: -39px;
    background: #fff
}

.shop-information .title-box:after {
    display: none !important
}

.shop-information+.wrap {
    margin-top: 15px
}

.icon-cart:before,
.icon-catalog:before,
.icon-catalog span::before,
.icon-catalog_red:before,
.icon-favorite:before,
.icon-guide:before,
.icon-lock:before,
.icon-lock_wht:before,
.icon-mail:before,
.icon-mypage:before,
.icon-myshop:before,
.icon-search:before,
.icon-searchshop:before,
.icon-searchshop_wht:before,
.icon-sns:before,
.icon-unlock:before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    margin-top: -4px;
    margin-right: 6px
}

.icon-cart:before {
    width: 29px;
    height: 26px;
    background: url(/gs_front/image/icon_cart.png)center no-repeat;
    background-size: 29px auto
}

.icon-catalog_red:before {
    width: 20px;
    height: 18px;
    background: url(/gs_front/image/icon_catalog_red.png)center no-repeat;
    background-size: 20px auto
}

.icon-catalog span {
    position: relative;
}

.icon-catalog span::before {
    width: 20px;
    height: 18px;
    background: url(/gs_front/image/icon_catalog.png)center no-repeat;
    background-size: 20px auto
}

.icon-favorite:before {
    width: 22px;
    height: 19px;
    background: url(/gs_front/image/icon_favorite.png)center no-repeat;
    background-size: 22px auto
}

.icon-lock_wht:before {
    width: 19px;
    height: 19px;
    background: url(/gs_front/image/icon_lock_wht.png)center no-repeat;
    background-size: 19px auto
}

.icon-mail:before {
    width: 18px;
    height: 9pt;
    background: url(/gs_front/image/icon_mail.png)center no-repeat;
    background-size: 18px auto
}

.icon-mypage:before {
    width: 18px;
    height: 19px;
    background: url(/gs_front/image/icon_mypage.png)center no-repeat;
    background-size: 18px auto
}

.icon-myshop:before {
    width: 23px;
    height: 20px;
    background: url(/gs_front/image/icon_myshop.png)center no-repeat;
    background-size: 23px auto
}

.icon-search:before {
    width: 19px;
    height: 19px;
    background: url(/gs_front/image/icon_search.png)center no-repeat;
    background-size: 19px auto
}

.icon-searchshop_wht:before {
    width: 22px;
    height: 19px;
    background: url(/gs_front/image/icon_searchshop_wht.png)center no-repeat;
    background-size: 22px auto
}

.icon-sns:before {
    width: 18px;
    height: 18px;
    background: url(/gs_front/image/icon_sns.png)center no-repeat;
    background-size: 18px auto
}

.icon-unlock:before {
    width: 19px;
    height: 20px;
    background: url(/gs_front/image/icon_unlock.png)center no-repeat;
    background-size: 19px auto
}

.label-gold,
.label-red,
.label-silver {
    display: inline-block;
    min-width: 80px;
    height: 18px;
    margin-bottom: 4px;
    color: #fff;
    font-size: 9pt;
    font-size: 1.2rem;
    text-align: center
}

.label-red {
    background-color: #930002
}

.label-gold {
    background-color: #333
}

.label-silver {
    background-color: #978f87
}

.btn--entry {
    border-radius: 6px;
    box-sizing: border-box;
    display: block;
    font-size: 87.5%;
    font-weight: 700 !important;
    line-height: 1.21;
    padding: 11px 10px;
    text-align: center;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    width: 100%;
    background-color: #D03658;
    box-shadow: 0 0 5px rgba(0, 0, 0, .05);
    color: #fff !important;
    /* -webkit-transition: background-color .2s linear !important; */
    /* 不要 */
    transition: background-color .2s linear !important
}

.btn--entry:hover,
.btn--entry:visited {
    text-decoration: none;
    color: #fff !important
}

#header-area .myshop-inbox {
    right: 113px
}

.shopMode #header-area .myshop-inbox {
    bottom: auto;
    top: 0
}

#header-area .myshop-inbox a {
    display: block;
    width: 57px;
    height: 60px;
    position: relative;
    text-decoration: none
}

#header-area .myshop-inbox a:before {
    position: absolute;
    left: 8px;
    top: 7px;
    content: "";
    background: url(/gs_front/image/icon_myshop.png)center no-repeat;
    background-size: 46px auto;
    display: block;
    width: 46px;
    height: 40px;
    z-index: 1
}

#header-area .myshop-inbox a span.myshop-txt {
    position: absolute;
    bottom: 3px;
    left: 0;
    display: inline-block;
    width: 100%;
    padding-left: 0;
    color: #565656;
    font-size: 10px;
    text-align: center;
    line-height: 1
}

#header-area .myshop-inbox,
#header-area .t-point-inbox {
    position: absolute;
    top: 0;
    width: 46px;
    height: 60px;
    z-index: 3
}

#header-area .t-point-inbox {
    right: 90pt
}

.shopMode #header-area .t-point-inbox {
    bottom: auto;
    top: 0
}

#header-area .t-point-inbox a {
    display: block;
    width: 46px;
    height: 60px;
    position: relative;
    text-decoration: none
}

#header-area .t-point-inbox a:before {
    position: absolute;
    left: 6px;
    top: 3px;
    content: "";
    background: url(/gs_front/iphone/image/logo_tpoint.png)0 10px no-repeat;
    background-size: 2pc auto;
    display: block;
    width: 35px;
    height: 60px;
    z-index: 1
}

#header-area .t-point-inbox a span.t-point-txt {
    position: absolute;
    bottom: 3px;
    left: 0;
    display: inline-block;
    width: 100%;
    padding-left: 4px;
    color: #565656;
    font-size: 10px;
    text-align: center;
    line-height: 1
}

#gmenu-wrap h2 {
    position: relative;
    width: 100%;
    margin: 0;
    padding: 10px 1em;
    color: #333;
    font-size: 1.6rem;
    font-weight: 700;
    text-align: left;
    background-color: #EAEAEA;
    cursor: pointer;
}

#gmenu-wrap h2.js-toggleSwitch::after {
    display: block;
    position: absolute;
    content: "\e90e";
    font-family: "global_icon";
    font-size: 2rem;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}

#gmenu-inner h2 {
    border-top: 1px dotted #333;
}

#gmenu-inner h2:first-child {
    border-top: none;
}

#gmenu-wrap .is-open h2.js-toggleSwitch::after {
    content: "\e90d";
}

.s_07 .accordion_one {
    max-width: 64pc;
    margin: 0 auto
}

.s_07 .accordion_inner .accordion_one .accordion_header {
    background-color: #fff
}

.s_07 .accordion_inner .accordion_one .accordion_inner .accordion_header {
    background-color: #fff
}

.s_07 .accordion_one .accordion_header {
    background-color: #F7F7F7;
    color: #333;
    font-size: 14px;
    font-weight: 500;
    padding: 14px 2em;
    text-align: left;
    position: relative;
    z-index: 1;
    cursor: pointer;
    transition-duration: .2s
}

.s_07 .accordion_inner .accordion_one .accordion_header {
    padding: 14px 2em;
}

.s_07 .accordion_inner .accordion_one .accordion_header.tg_genre {
    font-weight: 400;
    border-top: 1px dotted #c1c1c1;
}

.s_07 .tg_list .accordion_header {
    padding: 14px 3em !important;
}

.s_07 .accordion_inner .accordion_one .accordion_header .accordion_inner .accordion_header {
    padding: 14px 10%;
}

.s_07 .accordion_one .accordion_header:hover {
    opacity: .8
}

.s_07 .accordion_one .accordion_header .i_link:after {
    content: "";
    position: absolute;
    right: -10px;
    display: block;
    width: 6pt;
    height: 6pt;
    margin-top: -15px;
    margin-left: -6px;
    border-top: 2px solid #5f5f5f;
    border-right: 2px solid #5f5f5f;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg);
    border-radius: 2px
}

.s_07 .accordion_one .accordion_header .i_box:after {
    content: "";
    position: absolute;
    right: 15px;
    display: block;
    width: 6pt;
    height: 6pt;
    margin-top: -15px;
    margin-left: -6px;
    border-top: 2px solid #5f5f5f;
    border-right: 2px solid #5f5f5f;
    /* -webkit-transform: rotate(45deg); */
    /* 不要 */
    transform: rotate(45deg);
    border-radius: 2px
}

.s_07 .accordion_one .accordion_header .i_box:after {
    /* -webkit-transform: rotate(135deg); */
    /* 不要 */
    transform: rotate(135deg)
}

.s_07 .accordion_one .accordion_header.open .i_box:before {
    content: none
}

.s_07 .accordion_one .accordion_header.open .i_box:after {
    margin-top: -14px;
    /* -webkit-transform: rotate(-45deg); */
    /* 不要 */
    transform: rotate(-45deg);
}

.s_07 .accordion_one .accordion_inner {
    display: none;
    padding: 0;
    box-sizing: border-box
}

.s_07 .accordion_one .accordion_header a {
    text-decoration: none;
    display: block
}

#footer-area .sns_box {
    border-top: 1px solid #c7c7c7
}

#footer-area .sns_box ul {
    display: flex;
    justify-content: space-around
}

#footer-area .sns_box ul li {
    width: 7%;
    text-align: center;
    padding: 1.25rem 0
}

#footer-area .sns_box ul li a {
    padding-left: 0;
    transition: all .3s
}

#footer-area .sns_box ul li a:hover {
    opacity: .6
}

#footer-area .sns_box ul li a::before {
    display: none
}

::placeholder {
    color: #999999;
}

input:focus::-webkit-input-placeholder {
    color: transparent;
}

input:focus::-moz-placeholder {
    color: transparent;
}

input:focus::-ms-input-placeholder {
    color: transparent;
}

input:focus::placeholder {
    color: transparent;
}

.infomation_all {
    text-align: center;
    background-color: rgb(167, 140, 87);
    padding: 3px;
}

.infomation_all a {
    display: block;
}

.infomation_all span {
    color: #ffffff;
    font-weight: bold;
    font-size: 1.2rem;
    line-height: 2;
}

.icon {
    height: 2rem;
}

.item-list .box .icon {
    margin-top: 5px;
}

.icon span {
    color: #fff;
    padding: .2rem 1rem;
}

.icon.free_coupon span {
    background-color: #930002;
}

.icon.delivery_in span {
    background-color: #A78C58;
}

.fixed~#container {
    padding-top: 93px;
}

.dynamic_top .pic {
    margin: 0 auto 20px;
}

.dynamic_top .pic.border {
    border: 5px solid #f7f7f7;
}

.dynamic_top h1 {
    margin: 0 auto 20px;
    text-align: center;
    font-size: 2.4rem;
    font-weight: bold;
}

.dynamic_top h1 span {
    font-weight: bold;
    font-size: 1.2rem;
    display: block;
}

.dynamic_top h1 a {
    font-weight: bold;
    font-size: 2.4rem;
}

.dynamic_top h1 a span {
    display: block;
    font-weight: bold;
    font-size: 1.2rem;
}

.dynamic_top_title {
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 20px;
    text-align: left;
    padding: 0 0 0 .6rem;
    border-left: 5px solid;
}

.dynamic_top_title_bottom {
    margin-bottom: -25px;
    font-size: 2rem;
    font-weight: bold;
    text-align: left;
    padding: 0 0 0 .6rem;
    border-left: 3px solid;
}

.dynamic_top .lead {
    text-align: left;
    margin: 0 auto 60px;
}

.dynamic_top .brand_item li {
    margin-bottom: 80px;
}

.dynamic_top .brand_item li:nth-of-type(1) {
    margin-bottom: 60px;
}

.dynamic_top .brand_item .item .pic_area {
    margin-bottom: 20px;
}

.dynamic_top .brand_item .item .txt_area .tltle {
    font-size: 1.8rem;
    font-weight: bold;
    margin-bottom: 20px;
    text-align: left;
}

.dynamic_top .brand_item .item .txt_area .txt {
    text-align: left;
}

.page-back {
    display: block;
    opacity: 1;
    position: fixed;
    left: 5px;
    bottom: 10px;
    width: 55px;
    z-index: 1000002;
}

.page-back a {
    display: block;
    background: url(/gs_front/iphone/image/previous_button.png)no-repeat;
    background-size: 55px 55px;
    height: 55px;
    text-indent: -9999px;
    overflow: hidden;
    border-radius: 50%;
}

.display-none {
    display: none;
}

/* CSSに追加 */
.accordion_inner {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.accordion_inner.active {
    max-height: 1000px;
    /* コンテンツの最大高さより大きい値 */
}

/* matchHeightの代わりになるCSS */
.mh-parent {
    /* もし親要素にクラスがない場合、親要素を特定する必要があります */
    display: flex;
    flex-wrap: wrap;
}

.mh {
    height: auto !important;
    /* JSでついた高さをリセット */
    display: flex;
    /* 中身のレイアウト用 */
    flex-direction: column;
    /* 中身を縦並びに */
}

/* 補足: もし .mh がカードそのものではなく、カード内の「タイトル部分」だけ高さを揃えたい場合 */
/* 例: カード全体をFlexにして、タイトル部分を flex-grow させる手法などが一般的です */