@charset "utf-8";

html {
    scroll-behavior: smooth;
}

body {
    width: 1200px;
    margin: 0 auto;
    overflow-x: hidden;
}

header,
div,
img,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
li,
dl,
dt,
dd,
span,
table,
tr,
th,
td,
figure {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
li,
span,
a,
table,
tr,
th,
td,
dl,
dt,
dd,
form,
fieldset,
legend,
figure,
small {
    color: #383838;
    font-family: "游ゴシック", sans-serif;
}

ul,
li,
a {
    list-style: none;
    text-decoration: none;
}

/*メインカラム*/
.primary_wrap {
    margin-bottom: 160px;
}

.primary_inner {
    padding: 0 60px;
}

/*タイトルデザイン*/
.order_title {
    margin: 0 30px 30px;
}

.order_title h2 {
    position: relative;
    padding: 12px 30px;
    background: linear-gradient(135deg, transparent 14px, #ede0d9 14px);
    font-weight: normal;
    font-size: 30px;
    text-align: left;
}
.order_title h2::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    display: block;
    width: 20px;
    height: 20px;
    background: linear-gradient(135deg, transparent 14px, #d7b2a0 14px);
}

.secondary_title {
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    background: #b69f94;
    padding: 15px;
}

.left_border_title {
    color: #ef858c;
    font-weight: bold !important;
    border-left: 10px solid #ef858c;
    margin-bottom: 10px;
    padding-left: 10px;
}

/*ボタンデザイン*/
.primary_btn {
    display: inline-flex;
}

.primary_btn_title_black {
    background: #383838;
}

.primary_btn:hover {
    opacity: 0.6;
}

.primary_btn_title {
    color: #fff;
    display: block;
    width: 340px;
    font-size: 22px;
    font-weight: 400;
    text-align: center;
    padding: 12px 0;
    white-space: nowrap;
}

.primary_btn_arrow_black {
    color: #383838;
    border: 1px solid #383838;
}

.primary_btn_arrow {
    background: #fff;
    min-width: 58px;
    font-size: 22px;
    font-weight: 400;
    text-align: center;
    padding: 12px 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: "meirio", sans-serif;
}

/*リンクデザイン*/
.link_design01 {
    color: #2c3fcb;
    text-decoration: underline;
}

.link_design01:hover {
    text-decoration: none;
}

.link_design02 {
    text-decoration: underline;
}

.link_design02:hover {
    text-decoration: none;
}

.link_design03 {
    color: #276dcc;
    text-decoration: underline;
}

.link_design03:hover {
    text-decoration: none;
}

/*border*/
.border_light_brown {
    border: 5px solid #ede0d9;
    padding: 30px;
}

/* color */
.red {
    color: #ff0000;
}

.red02 {
    color: #f74f4f !important;
}

/* font-size */
.primary_font_size p,
.primary_font_size li,
.primary_font_size span,
.primary_font_size a,
.primary_font_size th,
.primary_font_size td,
.primary_font_size dt,
.primary_font_size dd {
    font-size: 20px;
    line-height: 1.8;
}

.font_s12 {
    font-size: 12px;
}

.font_s14 {
    font-size: 14px;
}

.font_s16 {
    font-size: 16px !important;
}

.font_s20 {
    font-size: 20px !important;
}

/* font-weight */
.bold {
    font-weight: bold !important;
}

.normal {
    font-weight: normal !important;
}

/*text-align*/
.center {
    text-align: center !important;
}

.right {
    text-align: right !important;
}

/* display */
.inline_block {
    display: inline-block !important;
}

/*margin-top*/
.m_t10 {
    margin-top: 10px !important;
}

.m_t15 {
    margin-top: 15px !important;
}

.m_t25 {
    margin-top: 25px !important;
}

.m_t30 {
    margin-top: 30px !important;
}

.m_t50 {
    margin-top: 50px !important;
}

.m_t70 {
    margin-top: 70px !important;
}

/*margin-bottom*/
.m_b10 {
    margin-bottom: 10px !important;
}

.m_b15 {
    margin-bottom: 15px;
}

.m_b30 {
    margin-bottom: 30px !important;
}

.m_b50 {
    margin-bottom: 50px !important;
}

.m_b60 {
    margin-bottom: 60px !important;
}

.m_b80 {
    margin-bottom: 80px !important;
}

/*margin-left*/
.m_l10 {
    margin-left: 10px !important;
}

/* padding */
.p_l10 {
    padding: 0 10px;
}

/*ヘッダー*/
.pc_account_list {
    display: flex;
    justify-content: flex-end;
    padding-top: 30px;
}

.pc_account_item + .pc_account_item {
    margin-left: 20px;
}

.pc_account_item {
    font-size: 14px;
}

.pc_account_item_icon {
    margin-right: 5px;
}

.pc_head_inner {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
    white-space: nowrap;
}

.left_inner {
    display: flex;
    flex-direction: column;
}

.left_inner p {
    font-size: 14px;
    font-weight: bold;
    color: #65bfd6;
    text-align: end;
}

.left_inner li a:hover {
    text-decoration: underline;
}

.logo_inner {
    display: flex;
    align-items: center;
}

.logo_inner img {
    width: 100%;
    height: auto;
    max-width: 329px;
    max-height: 74px;
}

.left_inner ul {
    display: flex;
    justify-content: flex-end;
    margin-top: 15px;
}

.left_inner li a {
    display: flex;
}

.left_inner li a span {
    margin-right: 5px;
}

.left_inner li a span img {
    width: 15px;
    height: 15px;
}

.left_inner li p {
    color: #383838;
    position: relative;
}

.info_inner {
    margin-right: 50px;
    margin-bottom: 7px;
    display: flex;
    justify-content: flex-end;
}

.tel_num {
    width: 100%;
    height: auto;
    max-width: 288px;
    max-height: 44px;
}

.recept_time {
    width: 100%;
    height: auto;
    max-width: 262px;
    max-height: 44px;
    margin-left: 20px;
}

.right_inner {
    display: flex;
    align-items: center;
}

.top_menu p {
    font-size: 18px;
    position: relative;
    top: 2px;
}

.top_menu span {
    font-size: 14px;
    color: #65bfd6;
}

.top_menu {
    display: flex;
}

.top_menu li {
    display: flex;
    flex-direction: column;
    justify-content: end;
    text-align: center;
    padding: 0 50px;
    border-left: 1px dotted #383838;
}

.top_menu a {
    display: block;
    margin: 0 -50px;
    padding: 0 50px;
}

.top_menu li:last-child {
    border-right: 1px dotted #383838;
}

.top_menu a:hover {
    opacity: 0.6;
}

/*トップ*/
.lead_inner {
    padding-top: 115px;
    padding-bottom: 30px;
}

.lead_inner h1 {
    color: #65bfd6;
    font-size: 40px;
    position: relative;
    width: fit-content;
    margin: 0 auto;
}

.lead_inner h1 span {
    position: absolute;
    left: -35px;
    top: -35px;
}

.lead_inner h2 {
    font-size: 30px;
    font-weight: 400;
    text-align: center;
    padding: 28px 0 23px;
}

.lead_inner p {
    font-size: 22px;
    text-align: center;
}

.lead_inner p span {
    color: #ef858c;
}

/*サンプル*/
.slide_wrap {
    overflow-x: hidden;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: 50px;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

@media screen and (max-width: 1199px), print {
    .slide_wrap {
        margin-left: 0;
        margin-right: 0;
    }
}

.slide_items {
    display: flex;
    -webkit-animation: slide 20s infinite linear 1s both;
    animation: slide_items 20s infinite linear 1s both;
}

@-webkit-keyframes slide_items {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-100%);
    }
}

@keyframes slide_items {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-100%);
    }
}

.slide_wrap:hover .slide_items {
    -webkit-animation-play-state: paused;
    animation-play-state: paused;
}

.item {
    transition: all 0.2s;
    margin: 10px;
}

.item:hover {
    transform: translateY(-10px);
    box-shadow: 0 3px 10px 0;
    cursor: pointer;
}

.line_up_btn {
    display: flex;
    justify-content: center;
    margin: 35px auto 0;
    width: fit-content;
}

.line_up_btn .btn {
    color: #fff;
    background: #383838;
    display: block;
    width: 100%;
    max-width: 268px;
    font-size: 22px;
    font-weight: 400;
    text-align: center;
    padding: 12px 36px;
    white-space: nowrap;
}

.line_up_btn .btn_white {
    background: #fff;
    border: 1px solid #383838;
    width: 100%;
    width: 58px;
    font-size: 22px;
    font-weight: 400;
    text-align: center;
    padding: 12px 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: "meirio", sans-serif;
}

.line_up_btn:hover {
    opacity: 0.6;
}

.btn_white a:link,
.btn_white a:visited,
.btn_white a:hover,
.btn_white a:active {
    color: #383838;
}

/*おすすめ*/
.appeal_inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.appeal_inner ul {
    padding-top: 120px;
    padding-bottom: 120px;
    margin-top: 96px;
    margin-bottom: 120px;
    background-image: url(../img/bg001.png);
    background-repeat: no-repeat;
    background-size: cover;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: calc(50vw - 50%);
    padding-right: calc(50vw - 50%);
}

@media screen and (max-width: 1199px), print {
    .appeal_inner ul {
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }
}

.media_thumb {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
    width: 1200px;
}

.media_thumb._reverse {
    flex-direction: row-reverse;
}

.media_thumb .canvas {
    width: 100%;
    height: auto;
    max-width: 516px;
    margin-right: 60px;
}

.canvas._reverse {
    margin-right: 0;
    margin-left: 60px;
}

.media_body {
    margin-left: 30px;
}

.media_body .media_catch {
    font-size: 40px;
    font-weight: bold;
    color: #65bfd6;
    margin-bottom: 30px;
    position: relative;
}

.media_catch span {
    position: absolute;
    left: -30px;
    top: -40px;
}

.media_body .media_txt {
    font-size: 20px;
}

.appeal_inner li:nth-child(2) {
    margin-top: 67px;
}

/*商品一覧*/
.line_up_inner .title {
    font-size: 40px;
    color: #65bfd6;
    position: relative;
    width: fit-content;
    margin: 0 auto;
}

.line_up_inner .title span {
    position: absolute;
    left: 0;
    top: -40px;
}

.line_up_inner .sub_title {
    font-size: 20px;
    color: #c6c6c6;
    text-align: center;
}

.line_up_inner .info_txt {
    font-size: 20px;
    text-align: center;
    margin-top: 8px;
}

.rect_btn,
.square_btn {
    display: flex;
    justify-content: center;
    margin-top: 35px;
}

.rect_btn .btn,
.square_btn .btn {
    color: #fff;
    display: block;
    width: 340px;
    font-size: 22px;
    font-weight: 400;
    text-align: center;
    padding: 12px 0;
    white-space: nowrap;
}

.rect_btn .btn_white,
.square_btn .btn_white {
    background: #fff;
    min-width: 58px;
    font-size: 22px;
    font-weight: 400;
    text-align: center;
    padding: 12px 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: "meirio", sans-serif;
}

.rect_btn .btn {
    background: #ef858c;
}

.rect_btn .btn_white {
    color: #ef858c;
    border: 1px solid #ef858c;
}

.square_btn .btn {
    background: #8c93c8;
}

.square_btn .btn_white {
    color: #8c93c8;
    border: 1px solid #8c93c8;
}

.rect_btn:hover,
.square_btn:hover {
    opacity: 0.6;
}

.rect_btn .btn_white a:link,
.rect_btn .btn_white a:visited,
.rect_btn .btn_white a:hover,
.rect_btn .btn_white a:active {
    color: #ef858c;
}

.square_btn .btn_white a:link,
.square_btn .btn_white a:visited,
.square_btn .btn_white a:hover,
.square_btn .btn_white a:active {
    color: #8c93c8;
}

.btn_wrapper {
    display: flex;
    margin: 60px 180px 100px;
    justify-content: space-between;
}

/*長方形*/
.rect_inner .title_inner {
    width: 1140px;
    margin: 30px auto 30px;
}

.rect_items {
    border: 1px solid #ef858c;
    width: 380px;
}

.top_inner {
    display: flex;
    align-items: center;
}

.top_inner .square {
    background: #ef858c;
    width: fit-content;
    margin: 20px;
}

.square h2 {
    font-family: "Hiragino Kaku Gothic ProN", sans-serif;
    font-size: 44px;
    color: #fff;
    font-weight: 500;
    padding: 18.5px 15px;
}

.square .ten_over {
    letter-spacing: -3.75px;
    padding: 18.5px 7px;
}

.price_inner h3,
.price_inner h4,
.price_inner h5 {
    font-family: "Hiragino Kaku Gothic ProN", sans-serif;
    font-weight: 600;
}

.price_inner h3 {
    font-size: 20px;
    color: #ef858c;
    line-height: 1.2;
}

.price_inner h4 {
    font-size: 22px;
    color: #ef858c;
    line-height: 1.2;
}

.price_inner h5 {
    font-size: 39px;
    color: #383838;
    line-height: 1.2;
}

.price_inner h5 span {
    font-size: 24px;
}

.bottom_inner .bottom_txt {
    font-size: 20px;
    background: #ef858c;
    color: #fff;
    text-align: center;
    font-family: "Hiragino Kaku Gothic ProN", sans-serif;
    font-weight: 500;
    padding: 12px 0;
    position: relative;
}

.bottom_inner .bottom_txt span {
    position: absolute;
    color: #fff;
    right: 20px;
    font-family: "meirio", sans-serif;
}

.bottom_inner:hover {
    opacity: 0.6;
}

.rect_list {
    display: grid;
    gap: 30px;
    grid-template-columns: repeat(3, 1fr);
    position: relative;
}

/*正方形*/
.square_inner_products {
    margin-bottom: 100px;
}

.square_inner .title_inner {
    width: 1140px;
    margin: 100px auto 30px;
}

._sq_list .rect_items {
    border: 1px solid #8c93c8;
}

._sq_list h2,
._sq_list .bottom_txt {
    background: #8c93c8;
}

._sq_list .s_box {
    width: 103px;
    text-align: center;
}

._sq_list h3,
._sq_list h4 {
    color: #8c93c8;
}

/*バナー*/
.bunner_inner {
    width: 1200px;
    /* background: #d7b2a0;
    border: 1px solid #d7b2a0; */
    text-align: center;
    margin-top: 97px;
    /* padding: 32px 0 38px; */
}

.bunner_inner h2,
.bunner_inner h3 {
    font-size: 30px;
    color: #fff;
    letter-spacing: 1.4px;
}

.bunner_inner h2 {
    margin-bottom: 7px;
}

.bunner_inner h3 {
    display: flex;
    justify-content: center;
    align-items: center;
}

.bunner_inner h3 span {
    margin-right: 10px;
    position: relative;
    top: 7px;
}

.bunner_inner h3 span img {
    width: 100%;
    height: auto;
    max-width: 337px;
    max-height: 53px;
}

.bunner_wrapper:hover .bunner_inner {
    opacity: 0.6;
}

/*こだわり*/
.obsession_inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.obsession_inner ul {
    padding-top: 120px;
    padding-bottom: 108px;
    margin-top: 100px;
    background-image: url(../img/bg002.png);
    background-repeat: no-repeat;
    background-size: cover;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: calc(50vw - 50%);
    padding-right: calc(50vw - 50%);
}

@media screen and (max-width: 1199px), print {
    .obsession_inner ul {
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }
}

.obsession_inner ul {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(2, 1fr);
}

.obsession_inner li {
    width: 591px;
    margin-top: 10px;
}

.obsession_inner li:nth-child(3) img {
    margin-bottom: 16px;
}

.obsession_inner .txt_inner {
    padding: 17px 35px 24px 35px;
    position: relative;
}

.obsession_inner .txt_inner span {
    position: absolute;
    left: 0;
}

.obsession_inner h2 {
    font-size: 20px;
    color: #65bfd6;
    font-weight: 400;
    font-style: italic;
}

.obsession_inner h3 {
    font-size: 34px;
    color: #65bfd6;
}

.obsession_inner p {
    font-size: 20px;
}

/*お問い合わせ*/
.contact_inner {
    padding-top: 122px;
    padding-bottom: 126px;
    background-image: url(../img/bg003.png);
    background-repeat: no-repeat;
    background-size: cover;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: calc(50vw - 50%);
    padding-right: calc(50vw - 50%);
}

@media screen and (max-width: 1199px), print {
    .contact_inner {
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }
}

.contact_inner .contact_box {
    text-align: center;
    background: rgba(255, 255, 255, 0.9);
    padding-top: 63px;
    padding-bottom: 60px;
}

.contact_box .txt_inner .title {
    font-size: 40px;
    color: #65bfd6;
    position: relative;
    width: fit-content;
    margin: 0 auto;
}

.contact_box .txt_inner .title span {
    position: absolute;
    left: 0px;
    top: -35px;
}

.contact_box .txt_inner .sub_title {
    font-size: 20px;
    font-weight: 400;
    color: #c6c6c6;
}

.contact_box .txt_inner p {
    font-size: 20px;
    margin-top: 63px;
    margin-bottom: 67px;
}

.contact_items {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 90px;
    margin-left: 90px;
    padding: 0 140px;
}

.contact_items .info_inner2 {
    display: flex;
}

.contact_items .info_inner2 .recept_time {
    margin-left: 20px;
}

.mail_btn {
    display: flex;
    justify-content: center;
}

.mail_btn .btn {
    color: #fff;
    background: #383838;
    display: block;
    width: 268px;
    font-size: 22px;
    font-weight: 400;
    text-align: center;
    padding: 12px 36px;
    white-space: nowrap;
}

.mail_btn .btn_white {
    background: #fff;
    border: 1px solid #383838;
    width: 58px;
    font-size: 22px;
    font-weight: 400;
    text-align: center;
    padding: 12px 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.mail_btn:hover {
    opacity: 0.6;
}

/*フッター*/
.foot_top {
    background: #65bfd6;
    background-repeat: no-repeat;
    background-size: cover;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: calc(50vw - 50%);
    padding-right: calc(50vw - 50%);
    padding-top: 67px;
    padding-bottom: 60px;
    display: flex;
    justify-content: space-between;
    align-items: end;
}

@media screen and (max-width: 1199px), print {
    .foot_top {
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }
}

.foot_top ul {
    display: flex;
}

.foot_top ul li {
    margin-right: 26px;
}

.foot_top li a {
    display: flex;
}

.foot_top li a span {
    margin-right: 5px;
}

.foot_top li a span img {
    width: 15px;
    height: 15px;
}

.foot_top p {
    color: #fff;
    font-size: 14px;
    font-weight: bold;
    text-align: end;
}

.foot_top .foot_logo_inner {
    display: flex;
    flex-direction: column;
}

.foot_logo_inner img {
    width: 100%;
    height: auto;
    max-width: 329px;
    max-height: 37px;
}

.foot_top a:hover {
    text-decoration: underline;
    text-decoration-color: #fff;
}

.foot_second {
    margin-top: 70px;
    margin-bottom: 82px;
}

.second_inner .second_left h1 {
    font-size: 16px;
    font-weight: 400;
    border: 1px solid #383838;
    width: fit-content;
    padding: 2px 12px;
}

.pay_inner {
    padding-left: 13px;
}

.pay_inner p {
    margin: 10px 0 15px;
}

.pay_inner img {
    position: relative;
    left: -7px;
}

.second_inner .second_right h1 {
    font-size: 16px;
    font-weight: 400;
    border: 1px solid #383838;
    width: fit-content;
    padding: 2px 20px;
}

.second_inner .second_right h2 {
    font-size: 16px;
    font-weight: 400;
    margin-top: 27px;
    margin-bottom: 10px;
}

.second_inner .second_right p {
    font-size: 14px;
}

.second_inner .second_right {
    margin-left: 75px;
}

.second_inner {
    display: flex;
}

.foot_menu_inner {
    background: #65bfd6;
    background-repeat: no-repeat;
    background-size: cover;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: calc(50vw - 50%);
    padding-right: calc(50vw - 50%);
    padding-top: 67px;
    padding-bottom: 61px;
    display: flex;
    justify-content: space-between;
}

@media screen and (max-width: 1199px), print {
    .foot_menu_inner {
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }
}

.foot_menu p {
    font-size: 14px;
    font-weight: bold;
    color: #fff;
}

.foot_menu {
    display: flex;
}

.foot_menu li {
    padding-right: 48px;
}

.foot_menu a:hover {
    text-decoration: underline;
    text-decoration-color: #fff;
}

.foot_menu_inner .foot_txt {
    font-size: 12px;
    color: #fff;
}

.foot_bottom {
    margin-top: 38px;
    margin-bottom: 40px;
}

.foot_bottom h1 {
    font-size: 12px;
    font-weight: 400;
    text-align: center;
}

/*お問い合わせページ*/
.contac_heading {
    width: 80%;
    background: #f7f7f7;
    margin-inline: auto;
    padding: 30px;
}

.contact_wrap {
    width: 70%;
    margin-inline: auto;
    margin-top: 60px;
    margin-bottom: 100px;
}

.base_table {
    width: 100%;
}

.base_table th {
    padding: 15px;
    text-align: left;
    letter-spacing: 0.06em;
    width: 30%;
}

.base_table td {
    padding: 30px;
}

.base_table .must {
    color: #fff;
    font-size: 12px;
    background: #65bfd6;
    padding: 0 5px;
    float: right;
    position: relative;
    top: 4px;
}

.base_table tr {
    border-bottom: 1px solid #dcdcdc;
}

.base_table td input[type="text"] {
    font-family: inherit;
    height: 45px;
    width: 100%;
    background: #f1f1f1;
    border: none;
    padding: 10px;
    box-sizing: border-box;
}

.base_table td textarea {
    font-family: inherit;
    height: 240px;
    width: 100%;
    background: #f1f1f1;
    border: none;
    padding: 10px;
    box-sizing: border-box;
}

.base_table .contact_contents {
    vertical-align: top;
    padding-top: 40px;
}

.btn_contact {
    text-align: center;
    margin: 30px 0 0 0;
}

input[type="submit"] {
    color: #fff;
    font-size: 14px;
    letter-spacing: 0.05em;
    background: #65bfd6;
    cursor: pointer;
    padding: 7px 27px 6px 27px;
    border: none;
    border-radius: 3px;
    -webkit-appearance: none;
}

input[type="submit"]:hover {
    opacity: 0.7;
    text-decoration: none;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
}

/*データ入稿フォーム*/
.data_form_heading {
    font-weight: bold;
    margin-inline: auto;
    padding: 30px;
}

.data_form_table_under {
    border-bottom: 1px solid #cfcfcf;
    margin-bottom: 40px;
}

.data_form_table th {
    vertical-align: top;
    padding-top: 24px;
    padding-left: 0;
}

.data_form_table td {
    padding-top: 15px;
}

.data_form_title {
    font-size: 20px;
    font-weight: bold;
    border-left: 7px solid #65bfd6;
    margin-bottom: 15px;
    padding-left: 15px;
}

.data_form_caution {
    color: #ed0000;
    font-size: 13px;
    text-indent: -1em;
    display: inline-block;
    padding-left: 1em;
}

.data_form_caution_file_up {
    text-indent: inherit;
    margin-top: 10px;
    margin-left: 8px;
    padding-left: 0;
}

.data_form_caution_radio {
    position: relative;
    top: -5px;
    margin-left: 25px;
}

input[type="file"] {
    font-family: inherit;
}

::file-selector-button,
::-webkit-file-upload-button {
    cursor: pointer;
    margin-right: 1rem;
}

.desired_delivery_item {
    display: inline-block;
    min-width: 115px;
    position: relative;
}

.desired_delivery_item::after {
    content: ":";
    position: absolute;
    right: 5px;
}

.desired_delivery_date select,
.desired_delivery_time select {
    font: inherit;
    width: 130px;
    background: #f7f9f9;
    border: 1px solid #b0bec5;
    border-radius: 3px;
    padding: 5px;
}

.desired_delivery_date select:hover,
.desired_delivery_time select:hover {
    cursor: pointer;
}

/*-------------------------
  会員ログイン
-------------------------*/
.common_wrap {
    margin-top: 100px;
    padding: 15px;
}

.primary_box {
    max-width: 400px;
    margin: 0 auto;
}

.common_title {
    font-size: 26px;
    font-weight: bold;
}

.form_title_members {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 5px;
}

.btn_passview {
    text-align: right;
}

.btn_passview_wrap {
    position: relative;
}

.btn_passview {
    position: absolute;
    top: 13px;
    right: 14px;
}

.btn_passview button {
    appearance: none;
    -webkit-appearance: none;
    font-size: 18px;
    background: none;
    cursor: pointer;
    margin: 0;
    border: none;
}

.btn_passview button:hover {
    color: #65bfd6;
}

.text_forget_pass {
    font-size: 14px;
    margin-top: 5px;
}

.text_member_registration {
    font-size: 14px;
    margin-top: 40px;
}

/*-------------------------
  新規会員登録
-------------------------*/
.heading_box {
    max-width: 700px;
    background: #efefef;
    margin: 0 auto;
    padding: 30px;
}

/*-------------------------
  マイページ
-------------------------*/
.my_account_wrap {
    max-width: 800px;
    margin: 0 auto;
}

.order_history {
    padding: 0 10px;
}

.my_account_order_table {
    width: 100%;
}

.my_account_heading {
    background: #efefef;
    margin-top: 30px;
    margin-bottom: 15px;
    padding: 10px;
}

.text_order_number {
    display: block;
    margin-bottom: 10px;
}

.my_account_order_table_wrap {
    display: block;
    overflow-y: auto;
    max-height: 260px;
}

.my_account_order_table_wrap::-webkit-scrollbar {
    width: 7px;
}

.my_account_order_table_wrap::-webkit-scrollbar-thumb {
    background: #bcbcbc;
    border-radius: 5px;
}

.my_account_order_table_wrap::-webkit-scrollbar-track-piece {
    background: #f1f1f1;
}

.my_account_order_table tbody {
    width: 100%;
}

.my_account_order_table th {
    position: sticky;
    top: 0;
    z-index: 1;
}

.my_account_order_table th {
    text-align: left;
}

.my_account_order_table th,
.my_account_order_table td {
    font-weight: normal;
    border: 1px solid #dfdfdf;
    padding: 5px;
}

.my_account_order_table .my_account_order_table_order_number {
    width: 170px;
}

.my_account_order_table .my_account_order_table_order_date {
    width: 170px;
}

.my_account_order_table .my_account_order_table_money {
    text-align: right;
}

.my_account_order_table .my_account_order_table_points {
    text-align: right;
    width: 190px;
}

/* ログアウトボタン */
button[type="submit"].text_logout {
    background: none;
    border: none;
    border-radius: inherit;
    box-shadow: none;
}

.icon_text_logout {
    margin-right: 5px;
}

/* 退会するボタン */
.withdrawal_wrap {
    text-align: right;
    border-top: 2px solid #ddd;
    margin-top: 30px;
}

button[type="submit"].text_withdrawal {
    color: #ff0000;
    background: none;
    border: none;
    border-radius: inherit;
    box-shadow: none;
    text-decoration: underline;
    margin-top: 15px;
}

button[type="submit"].text_withdrawal:hover {
    text-decoration: none;
}

.icon_text_withdrawal {
    margin-right: 5px;
}

/* 注文履歴詳細 */
.order_details_list {
    display: flex;
    flex-wrap: wrap;
}

.order_details_list dt {
    width: 20%;
}

.order_details_list dd {
    width: 80%;
}

.order_details_list dt,
.order_details_list dd {
    padding: 5px;
}

.my_account_order_table_details th {
    text-align: left;
}

.my_account_order_table_details th,
.my_account_order_table_details td {
    font-weight: normal;
    border: 1px solid #dfdfdf;
    padding: 5px;
}

.my_account_order_table_details_price,
.my_account_order_table_details_total {
    width: 100px;
}

.my_account_order_table_details_amount {
    width: 50px;
}

.total_information_list dt {
    background: #eeeeee;
}

.total_information_list dt,
.total_information_list dd {
    text-align: right;
    padding: 5px;
}

/* データ・入稿について */
.upload_way_dt {
    font-weight: bold;
}

.template_data_wrap {
    display: flex;
}

.template_data_list {
    flex: 1;
}

.template_data_item {
    border-bottom: 1px solid #383838;
    padding: 18px 60px 18px 35px;
}

.template_data_item_f {
    border-right: 1px solid #383838;
}

.template_data_item,
.template_data_item span {
    font-size: 16px !important;
}

.template_data_item_heading {
    font-weight: bold;
    display: grid;
    place-content: center;
}

.template_data_item_contents {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.template_data_item .template_data_item_contents_title {
    font-size: 14px !important;
    line-height: 1.8;
}

.template_data_item_contents_title_large {
    font-weight: bold;
    display: block;
}

.template_data_item_contents_btn {
    color: #fff;
    display: grid;
    place-content: center;
    min-width: 230px;
    box-sizing: border-box;
}

.template_data_item_contents_btn + .template_data_item_contents_btn {
    margin-top: 10px;
}

.template_data_item_contents_btn_ai {
    background: url(../img/data-upload/icon_ai.png) no-repeat 10% 50%, #310201;
    background-size: 24.5px 18.5px;
}

.template_data_item_contents_btn_ps {
    background: url(../img/data-upload/icon_ps.png) no-repeat 10% 50%, #021e35;
    background-size: 24.5px 18.5px;
}

a.template_data_item_contents_btn {
    font-size: 16px;
    padding: 5px 0 5px 10px;
}

.template_data_item_contents_btn:hover {
    opacity: 0.6;
}
