@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap');


div#fs_preview_header {
    display: none;
}

.pc_none {
    display: none;
}


/* 全体 */
body {
    //background-color: #f9f7f4;
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-weight: 400;
    letter-spacing: 1px;
}
img {
    max-width: 100%;
    vertical-align: top;
}
[type=hidden], [type=text], [type=search], [type=tel], [type=url], [type=email], [type=password], [type=datetime], [type=date], [type=month], [type=week], [type=time], [type=datetime-local], [type=number], select, textarea, select.fs-c-dropdown__menu {
    border: 1px solid #cccccc;
    border-radius: 3px;
    padding: 12px;
    min-width: 100px;
}

.fs-c-button--primary {
    padding: 0.8em 1.6em;
}
a.btn_ptn01 {
    display: block;
    border: solid 1px;
    color: initial;
    text-decoration: none;
    padding: 10px 80px 10px 20px;
    width: fit-content;
    position: relative;
    transition: all .5s;
}
a.btn_ptn01::after {
    content:url(https://suma2408.itembox.design/item/btn_yaji_navy.png?t=20240719102520);
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) scale(0.1);
    transform-origin: right;
    transition: all .5s;
}
a.btn_ptn01:hover::after {
    right: -20px;
}
.fs-l-sideArea + .fs-l-pageMain,
.fs-l-pageMain + .fs-l-sideArea {
    max-width: 1216px;
}
    .fs-p-logo__image {
        max-width: 200px;
        width: 100%;
    }
.fs-l-main {
    margin: 128px auto 0;
    padding-bottom: 0;
}
.fs-p-heading--lv2_wrap {
    margin-bottom: 4vw;
}
h2.fs-p-heading--lv2 {
    border-bottom: none;
    color: #181e2c;
    font-size: 36px;
    font-family: serif;
    text-align: center;
    letter-spacing: 12px;
    margin: 0 0 10px;
}
.ttl_under_txt {
    font-size: 14px;
    color: #181e2c;
    text-align: center;
    letter-spacing: 4px;
}
h1.fs-c-heading.fs-c-heading--page {
    border-bottom: none;
    color: #181e2c;
    font-size: 24px;
    font-family: serif;
    text-align: center;
    letter-spacing: 12px;
    margin: 0 0 10px;
}
h2.fs-c-registeredUsers__title.fs-c-subSection__title,
.fs-c-subSection__title,
.fs-c-linkedServiceLogin__title {
    padding-bottom: 12px;
    color: #181e2c;
    font-size: 20px;
    font-family: serif;
    text-align: center;
    margin: 0 0 10px;
}
h2.fs-c-documentArticle__heading {
    background: #181e2c;
    padding: 1.4rem;
    letter-spacing: 2px;
    text-align: left;
    font-size: 18px;
}
h3.fs-c-documentColumn__heading {
    border-color: #181e2c;
    color: #181e2c;
}








/* ヘッダー */
.fs-l-header {
padding-top:0;
    position: fixed;
    width: 100%;
    mix-blend-mode: difference;
z-index:3;
top:0;
}
.o_header_contents {

}
.o_header_contents_wrap {
    display: grid;
    grid-template-columns: 200px 1fr;
    align-items: center;
    padding: 0 2vw;
    height: 128px;
}
.o_header_contents_menu {
    display: grid;
    grid-template-columns: 1fr auto auto auto auto auto auto auto auto;
    align-items: center;
    grid-gap: 20px;
    font-size: 11px;
}
.o_header_contents_menu a {
    color: #fff;
    text-decoration: none;
}
.fs-p-drawerButton {
        padding:0;
    }
.grid_vertical_boder {
    background: #fff;
    width: 1px;
    height: 1em;
    margin: -8px 0 0 0;
}
@media screen and (min-width: 1200px) {
    .fs-p-drawer__loginLogout, .fs-p-drawer__welcomeMsg {
        display: block;
    }
    .fs-p-drawerButton {
        display: block;
    }
}
.fs-p-drawer__loginLogout__logout,
.fs-p-drawer__loginLogout__login {
    background: none;
    border: none;
    display: inline-block;
    height: auto;
    color: #fff;
}
a.fs-p-headerNavigation__viewCartButton {
    padding: 0;
    color: #fff;
    font-size: 11px;
    mix-blend-mode: difference;
}

.rotate {
    /* 3D変形させた際の、奥行きを指定 */
    perspective: 300px;
    text-decoration: none;
    display: inline-block;
}

.rotate>span {
    /* 背面の要素（2個目のspanタグ）を非表示にする */
    backface-visibility: hidden;
    /* アニメーション効果を0.5秒間で適用 */
    transition: transform .5s;
    display: block;
    height: 2em;
}

/* ホバー前 */
.rotate>span:first-child {
    /* 10px下に移動し縦中央に表示する */
    transform: translateY(1em) rotateX(0deg);
}

.rotate>span:last-child {
    /* 90度回転させ非表示にする */
    transform: rotateX(-90deg);
}

/* ホバー時 */
.rotate:hover>span:first-child {
    /* X軸周りに90度回転して非表示にする */
    transform: rotateX(90deg);
}

.rotate:hover>span:last-child {
    /* 10px上に移動し表示する */
    transform: translateY(-1em) rotateX(0deg);
}
.fs-p-drawer__loginLogout__logout:hover,
.fs-p-drawer__loginLogout__login:hover {
    background: none;
}
.fs-p-headerNavigation__link:hover {
    background: none;
}
span.fs-p-cartItemNumber {
    position: static;
    background: none;
    font-size: 11px;
    padding: 0;
    line-height: inherit;
}
span.fs-p-cartItemNumber::before {
    content: "（";
}
span.fs-p-cartItemNumber::after {
    content: "）";
}
.hamburger_menu_icon {
    width: 40px;
    height: 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap:8px;
    overflow: hidden;
    position:relative;
}
.hamburger_menu_icon span.hamburger_menu_icon_line_top {
    display: block;
    width: 300%;
    height: 1px;
    transition: all 0.5s ease-in-out;
    background: linear-gradient(90deg, #fff 0%, #fff 33.333%, transparent 33.333%, transparent 66.666%, #fff 66.666%, #fff 100%);
    position: absolute;
    top:calc(50% - 4px);
    left: -200%;
    transform:translateY(-50%);
}
.hamburger_menu_icon span.hamburger_menu_icon_line_bottom {
    display: block;
    width: 300%;
    height: 1px;
    transition: all 0.5s ease-in-out;
    background: linear-gradient(90deg, #fff 0%, #fff 33.333%, transparent 33.333%, transparent 66.666%, #fff 66.666%, #fff 100%);
    position: absolute;
    top:calc(50% + 4px);
    left: -200%;
    transform:translateY(-50%);
}
.hamburger_menu_icon:hover span.hamburger_menu_icon_line_top {
    left: 0;
    width: 300%;
}
.hamburger_menu_icon:hover span.hamburger_menu_icon_line_bottom {
    left: 40%;
    width: 300%;
}











/* サイドナビゲーション */
.fs-p-drawer {
    padding:8px 2vw;
    background: #181e2c;
    color:#fff;
}
aside.fs-p-drawer.fs-l-sideArea {
    position: fixed;
    visibility: hidden;
    width: 100%;
}
.fs-p-ctrlDrawer:checked + .fs-p-drawer {
    transform: none;
    width: 100%;
    opacity: 1;
    visibility: visible;
z-index:4;
}
@media screen and (min-width: 1200px) {
    .fs-l-sideArea {
        max-width: 100%;
        opacity: 0;
    }
}
.fs-p-drawer__buttonContainer {
    align-items: center;
    padding: 0;
    height: 128px;
}
.hamburger_menu_icon_x {
    width: 40px;
    height: 40px;
    position: relative;
}
span.hamburger_menu_icon_line_x_top {
    width: 35px;
    display: block;
    height: 1px;
    background: #fff;
    transform: translate(-50%, -50%) rotate(45deg);
    transform-origin: center;
    position: absolute;
    top: 50%;
    left:50%;
    transition: all 0.5s ease-in-out;
}
span.hamburger_menu_icon_line_x_bottom {
    width: 35px;
    display: block;
    height: 1px;
    background: #fff;
    transform: translate(-50%, -50%) rotate(-45deg) ;
    transform-origin: center;
    position: absolute;
    top: 50%;
    left:50%;
    transition: all 0.5s ease-in-out;
}

.hamburger_menu_icon_x:hover span.hamburger_menu_icon_line_x_top {
    transform: translate(-50%, -50%) rotate(35deg) ;
}
.hamburger_menu_icon_x:hover span.hamburger_menu_icon_line_x_bottom {
    transform: translate(-50%, -50%) rotate(-35deg) ;
}

.fs-p-drawer h2.fs-p-heading--lv2,
.fs-p-drawer .ttl_under_txt,
.fs-p-drawer ul.fs-p-dateList li a,
.fs-p-drawer ul.fs-p-dateList li time:first-child {
    color: #fff;
}
.o_sidemenu_contents {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 92%;
    margin: 0 auto;
}
.o_sidemenu_contents .fs-c-productListCarousel.fs-c-slick {
    margin-top: 1em;
}
.o_sidemenu_contents .fs-c-productListItem {
    background: #fff;
    padding: 16px;
    color: #222;
    border-radius: 6px;
    position:relative;
}
.o_sidemenu_contents button.fs-c-button--addToWishList--icon.fs-c-button--particular {
    position: absolute;
    top: 6px;
    right: 6px;
}











/* インフォメーション */
.o_top_infomation {
    margin-bottom: 12vw;
}
ul.fs-p-dateList li {
    position: relative;
    padding: 0 !important;
    margin: 0 !important;
    border-color: #ddd;
    transition: all 0.5s ease-in-out;
}
ul.fs-p-dateList li:hover a {
    transition: all 0.5s ease-in-out;
    padding-left:20px;
}
ul.fs-p-dateList li a {
    display: grid;
    grid-template-columns: 128px 1fr;
    color: #181e2c;
    line-height:4em;
    text-decoration: none;
    position: relative;
    transition: all 0.5s ease-in-out;
}

ul.fs-p-dateList li time:first-child {
    background: none;
    color: #181e2c;
    align-content: center;
    transition: all 0.5s ease-in-out;
}
a.fs-pt-list__link p {
    grid-column: 2 / 3;
    line-height: 1.6em;
}
.news_tag_new::before {
    content: "NEW";
    border: solid 1px;
    font-size: 12px;
    padding: 4px 12px;
    margin-right: 20px;
}







/* プロダクト */






/* パーツ用CSS インスタグラム*/
.o_top_sns {
    padding: 12vw 0;
}
.o_top_sns_inr img {
    width: 22px;
}
.o_top_column_inr a {
    display: flex;
    gap: 10px;
    align-items: center;
    margin: 0 auto;
    border: solid 2px;
    padding: 20px 80px 20px 20px;
}
.o_top_column_inr img {
    width: 1.6em;
}





/* パーツ用CSS コンタクト */
.o_top_contact {
    background: #181e2c;
    margin: 0 calc(50% - 50vw);
    padding: 12vw 0;
}
.o_top_contact h2.fs-p-heading--lv2 {
    color: #fff;
}
.o_top_contact .fs-p-heading--lv2_wrap .ttl_under_txt {
    color: #fff;
}
.o_top_contact a {
    border: solid 1px #fff;
    color: #fff;
    margin: 0 auto;
}
.o_top_contact a.btn_ptn01::after {
    content: url(https://suma2408.itembox.design/item/btn_yaji.png?t=20240719102520);
}
.o_top_contact p {
    text-align: center;
    color: #fff;
    margin-top: 19px;
}






/* SNSリスト */
.o_top_sns_list {
    background: #eee;
    margin: 0 calc(50% - 50vw);
    padding: 30px 0;
}
.o_top_sns_list_inr {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    max-width: 420px;
    grid-gap: 68px;
    align-items: center;
    margin: 0 auto;
}



/* カートページ */
.fs-c-cartTable__headerCell--quantity,
.fs-c-cartTable__dataCell--quantity {
    width: auto;
}



/* マイページ */
.fs-body-my-top .fs-c-accountService {
flex-basis: 100%;
}
li.fs-c-accountService__page.fs-c-accountService__page--accountCard {
    display: none;
}



/* フッター */
footer.fs-l-footer {
    margin: 0;
    border: none;
    padding: 2vw 2vw 1vw;
    line-height: 1em;
}
.o_footer_contents {
    font-size: 14px;
}
.o_footer_contents ul {
    display: flex;
    gap: 20px;
    padding: 0;
    list-style: none;
    margin: 0 auto 20px;
    width: fit-content;
}
.o_copyright {
    text-align: center;
}
.o_copyright {
    text-align: center;
    border-top: solid 1px #ddd;
    padding: 10px 2vw 0;
}