@charset "utf-8";

/* -----------------------------------------------------------
　common
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  body {
    -webkit-text-size-adjust: 100%;
    font-size: 12px;
  }
  .pc_cont {display: none !important;}
  .mt00 {margin-top: 0!important;}
  .mt10 {margin-top: 5px!important;}  
  .mt20 {margin-top: 10px!important;}
  .mt30 {margin-top: 15px!important;}
  .mt40 {margin-top: 20px!important;}
  .mt50 {margin-top: 25px!important;}
  .mt60 {margin-top: 30px!important;}
  .mt70 {margin-top: 35px!important;}
  .mt80 {margin-top: 40px!important;}
  .mt90 {margin-top: 45px!important;}
  .mt100 {margin-top: 50px!important;}

  .mb00 {margin-bottom: 0!important;}
  .mb10 {margin-bottom: 5px!important;}
  .mb20 {margin-bottom: 10px!important;}
  .mb30 {margin-bottom: 15px!important;}
  .mb40 {margin-bottom: 20px!important;}
  .mb50 {margin-bottom: 25px!important;}
  .mb60 {margin-bottom: 30px!important;}
  .mb70 {margin-bottom: 35px!important;}
  .mb80 {margin-bottom: 40px!important;}
  .mb90 {margin-bottom: 45px!important;}
  .mb100 {margin-bottom: 50px!important;}

  .pt00 {padding-top: 0!important;}
  .pt10 {padding-top: 5px!important;}
  .pt20 {padding-top: 10px!important;}
  .pt30 {padding-top: 15px!important;}
  .pt40 {padding-top: 20px!important;}
  .pt50 {padding-top: 25px!important;}
  .pt60 {padding-top: 30px!important;}
  .pt70 {padding-top: 35px!important;}
  .pt80 {padding-top: 40px!important;}
  .pt90 {padding-top: 45px!important;}
  .pt100 {padding-top: 50px!important;}

  .pb00 {padding-bottom: 0!important;}
  .pb10 {padding-bottom: 5px!important;}
  .pb20 {padding-bottom: 10px!important;}
  .pb30 {padding-bottom: 15px!important;}
  .pb40 {padding-bottom: 20px!important;}
  .pb50 {padding-bottom: 25px!important;}
  .pb60 {padding-bottom: 30px!important;}
  .pb70 {padding-bottom: 35px!important;}
  .pb80 {padding-bottom: 40px!important;}
  .pb90 {padding-bottom: 45px!important;}
  .pb100 {padding-bottom: 50px!important;}
}
/* -----------------------------------------------------------
  template
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  /* :::::::::: header :::::::::: */

  header {
    padding: 0 4%;
    height: 70px;
  }
  header::after {height: 4px;}
  header .logo {
    width: 190px;
    margin: 0;
  }
  header .btn_list {
    top: 0;
    bottom: 0;
    right: 4%;
    margin: auto;
  }
  header .btn_list p {margin: 0 0 0 15px;}
  header .btn_list .btn_recommend {width: 22px;}
  header .btn_list .btn_cart {width: 24px;}
  header .btn_list .btn_cart span {
    width: 12px;
    height: 12px;
    line-height: 14px;
    right: -4px;
  }
  header .btn_list .menu {
    width: 30px;
    cursor: pointer;
  }
  
  .header_caution {
    padding: 0 3%;
    height: 36px;
  }
  .header_caution + header {margin: 36px 0 0;}
  
  /* :::::::::: nav :::::::::: */

  nav {padding: 20px 6%;}
  nav .menu_box {
    position: relative;
    z-index: 0;
    padding: 120px 0 90px;
  }
  nav .menu_box .btn_close {
    top: 70px;
    width: 20px;
  }
  nav .menu_box .menu_btn {margin: 0 0 20px;}
  nav .menu_box .menu_btn li {width: 49%;}
  nav .menu_box .menu_product {margin: 0 auto 20px;}
  nav .menu_box .menu_product p.parent::after {right: 5%;}
  nav .menu_box .btn_logout a:hover {opacity: 1;}

  /* :::::::::: main :::::::::: */
  
  main {
    min-height: calc(100vh - 238px);
    padding: 40px 0 50px;
  }
  main article .box {padding: 0 6%;}

  /* :::::::::: footer :::::::::: */

  .pagetop {
    width: 40px;
    height: 40px;
    bottom: 20px;
  }
  footer {padding: 40px 6%;}
  footer .footer_link {margin: 0 auto 20px;}
}

/* -----------------------------------------------------------
 parts
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  .p_title_common {margin: 0 0 40px;}
  .p_title_common > span {font-size: 30px;}
  .p_title_common > h1 {font-size: 2em;}
  .w_box {padding: 0 6%;}
  p.btn_common {
    width: 100%;
    margin: 35px auto 0;
  }
  p.btn_common a {transition: 0s;}
  p.btn_common a:hover {opacity: 1;}
  button.btn_common.btn_narrow {width: 120px;}
  .btn_box .btn_common {margin: 0 5px!important;}
  .btn_box .confirm {
    width: 240px;
  }
  .pagenation {margin: 15px 0 0;}
  .pagenation a,
  .pagenation span {
    font-size: 1.6em;
    margin: 0 5px;
  }
  .pagenation a.btn_next {margin: 0 0 0 5px;}
  .pagenation a.btn_prev {margin: 0 5px 0 0;}
  .pagenation a.btn_next,
  .pagenation a.btn_prev {margin: 0 10px;}
  
  /** p_list **/
  
  .p_list ul li {
    width: 48%;
    margin: 0 0 25px;
  }
  .p_list ul li a {transition: 0s;}
  .p_list ul li a:hover {opacity: 1;}
  .p_list ul li figure {margin: 0 0 10px;}
  .p_list ul li .p_name {margin: 0 0 5px;}
  .p_list ul li .p_price {font-size: 1.25em;}
  
  /** error **/

  .error_box > div {
    width: 300px;
    min-height: 170px;
    border-radius: 4px;
    padding: 20px;
  }
  .error_box figure {width: 30px;}
}

/* -----------------------------------------------------------
 form
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  button.delete {
    width: 14px;
    height: 18px;
    margin: 0 10px 0 0;
  }
  button.setting {
    width: 18px;
    height: 18px;
    margin: 0 10px 0 0;
  }
  input[type="text"] {
    height: 32px;
    margin: 0 0 10px;
  }
  input[type="number"] {
    width: 60px;
    height: 32px;
    font-size: 1.6em;
  }
  .select_outer {height: 32px;}
  .select_outer::after {right: 10px;}
  .select_outer select {
    height: 32px;
    padding: 0 10px;
    line-height: 32px;
  }
  .search_form {height: 30px;}
  .search_form input {
    width: calc(100% - 30px);
    height: 30px;
    margin: 0;
  }
  .search_form button {
    width: 30px;
    height: 30px;
  }
  .product_num {
    width: 180px;
    height: 36px;
  }
  .product_num .sub ,
  .product_num .add {
    width: 36px;
    height: 35px;
  }
  .product_num input {
    width: 108px;
    line-height: 34px;
  }
  .error_msg {margin: 0 0 10px;}
  
  
}


/* -----------------------------------------------------------
 home
----------------------------------------------------------- */

@media screen and (max-width: 800px) {

  main.home section {padding: 50px 0;}
  main.home section h2 {margin: 0 auto 30px;}
  main.home section .btn {
    width: 200px;
    height: 30px;
  }
  main.home section .btn a {
    font-size: 1em;
    line-height: 28px;
    transition: 0s;
  }
  main.home section .btn a:hover {opacity: 1;}
  .home_category ul {margin: 0 auto 30px;}
  .home_category ul li {
    width: 48%;
    margin: 0 0 3%;
  }
  .home_category ul li:nth-child(1) {
    width: 100%;
    aspect-ratio: 63 / 25;
  }
  .home_category ul li a img {transition: 0s;}
  .home_category ul li a:hover img {opacity: 1;}
  .home_category ul li a p span {font-size: 1.25em;}
  .home_feature .feature_slider {
    width: 100%;
    margin: 0 auto;
    transform: translateX(0);
    padding: 0 40px;
  }
  .home_feature .feature_slider .slick-slide {padding: 0 1vw;}

  .home_feature .feature_slider .slick-arrow {
    width: 30px;
    height: 30px;
    top: 32%;
  }  
}

/* -----------------------------------------------------------
 page
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  h2.common {margin: 40px 0 0.5em;}
  h2.common.no_border {}
  h3.common {margin: 30px 0 0.5em;}
  
  .product_list::after {height: 520px;}
  .product_list .kv_category {
    width: calc(80% + 5.2vw);
    aspect-ratio: 27 / 20;  
    margin: 0 0 40px 21%;
  }
  .product_list .kv_category > p {font-size: 1em;}
  .product_list .kv_category > p span {font-size: 1.875em;}
  .product_list .p_title_area {
    top: 40px;
    left: calc(2% + 30px);
    min-width: 450px;
  }
  .product_list .p_title_area .p_title {margin: 0 20px 0 0;}
  .product_list .p_title_area .p_title h1 {
    height: 450px;
    font-size: 1em;
    display: block;
  }
  .product_list .p_title_area .p_title span {
    font-size: 1.6em;
    min-width: 350px;
  }
  .product_list .p_title_area .p_title span.child_category {
    top: 100px;
  }
  .product_list .p_title_area .p_title span.child_category::before {left: 0.25em;}
  .product_list .p_title_area .p_title span.child_category {
    height: 390px;
    top: 120px;
  }
  .product_list .list_search_box {display: block;}
  .product_list .list_search_box .search_form {
    width: 100%;
    max-width: 100%;
    margin: 0 0 15px;
    height: 30px;
  }
  
  .product_list .p_title_area .p_cont {font-size: 0.8em;}
  .product_list .p_list {min-height: 500px;}
  .product_list .p_list .select_brand {
    width: 100%;
    margin: 0 0 15px;
  }  
  .product_list .p_list .select_box {
    justify-content: space-between;
    margin: 0 0 30px;
  }
  .product_list .p_list .select_sort {
    width: 48%;
    height: 30px;
    line-height: 30px;
    margin: 0;
  }
  .product_list .p_list .select_sort select {
    height: 30px;
    line-height: 30px;
  }
  .product_list .p_list ul::after ,
  .product_list .p_list ul::before {width: 49%;}
}

/* -----------------------------------------------------------
 product_detail
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  .product_detail {padding: 40px 0 50px;}
  .product_detail .box {display: block;}
  .product_detail .box .products_img ,
  .product_detail .box .products_info {width: 100%;}
  .product_slide {margin: 0 0 10px;}
  .product_detail .box .products_info {padding: 50px 0 0;}
  .product_detail .box .products_info .p_brand {margin: 0 0 10px;}
  .product_detail .box .products_info h1 {
    font-size: 2.4em;
    margin: 0 0 20px;
  }
  .product_detail .box .products_info .recommend {
    width: 20px;
    height: 17px;
    margin: 0 0 10px auto;
  }
  .product_detail .box .products_info .p_catch {
    font-size: 1.8em;
    margin: 0 0 10px;
  }
  .product_detail .box .products_info .p_content {margin: 0 0 15px;}
  .product_detail .box .products_info .btn_show {margin: 0 0 40px;}
  ul.p_tag {margin: 0;}
  ul.p_tag li {
    height: 16px;
    line-height: 14px;
    min-width: 60px;
    font-size: 10px;
  }
  .product_detail .box .products_info .p_cat {margin: 0 0 20px;}
  .product_detail .box .products_info button.btn_common {margin: 20px 0 45px;}
  .product_detail .box .products_info .error_msg {margin: 0 0 30px;}
  .product_detail .box .products_info .product_caution {
    border-radius: 5px;
    padding: 20px;
  }
  .product_detail .box .products_info .product_caution input {
    width: 60px;
    height: 27px;
    line-height: 27px;
  }
  .product_detail .box .products_info .p_info {margin: 0 0 20px;}
  .product_detail .box .products_info .p_info dt {
    padding: 0 0 5px;
    margin: 0 0 10px;
  }
  .product_detail .box .products_info .p_info.ac dt::before ,
  .product_detail .box .products_info .p_info.ac dt::after {bottom: 4px;}
  .product_detail .box .products_info .p_info.ac dt::before {width: 15px;}
  .product_detail .box .products_info .p_info.ac dt::after {
    height: 15px;
    right: 7px;
  }
  .product_detail .box .products_info .p_info dd p span:nth-of-type(1) {width: 100px;}
  .product_detail .box .products_info .p_info dd p span:nth-of-type(2) {width: calc(100% - 120px);}
  .product_detail .box .products_info .select_other {
    padding: 5%;
    margin: 0 auto 40px;
  }
  .product_detail .box .products_info .select_other dl {margin: 20px 0 0;}
  .product_detail .box .products_info .select_other dl dd input[type="text"] {width: calc(100% - 80px);}
  .product_detail .box .products_info .select_other dl dd button {
    width: 60px;
    height: 25px;
    line-height: 23px;
  }
  .product_detail .box .btn_back {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 40px;
    width: 200px;
    height: 40px;
    line-height: 40px;
    margin: auto;
  }
  .product_detail .box .btn_back a {transition: 0s;}
  .product_detail .box .btn_back a:hover {opacity: 1;}
  
  .product_detail .detail_select {
    padding: 60px 0 30px;
    margin: 60px 0 0;
  }
  .product_detail .detail_select .box > div {
    margin: 0 auto 30px;
    border-radius: 5px 0 0 5px;
  }
  .product_detail .detail_select .box > div .slick-list {width: 80%;}
  .product_detail .detail_select .box > div .slick-slide {transition: 0s;}
  .product_detail .detail_select .box > div .slick-slide:hover {opacity: 1;}
  .product_detail .detail_select .box > div .slick-arrow {display: none!important;}
  .product_detail .detail_select .modal_contents .modal figure {
    max-width: 86vw;
    max-height: 86vh;
  }
}

/* -----------------------------------------------------------
 order
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  .cart_error {margin: 0 0 20px;}
  .cart_caution {padding: 20px;}
  .cart_caution input {
    width: 60px;
    height: 30px;
    font-size: 1.5em;
    line-height: 30px;
  }
  .cart_box {
    align-items: flex-start;
    flex-wrap: wrap;
    padding: 20px 0;
  }
  .cart_box > figure {
    width: 90px;
    margin: 0 20px 0 0;
  }
  .cart_box > figure + div {
    width: calc(100% - 110px);
    padding: 0;
    margin: 0 0 15px;
  }
  .cart_box > figure + div .p_num {
    min-width: 80px;
    margin: 0 5px 5px 0;
  }
  .cart_box > .p_price {
    width: calc(100% - 110px);
    padding: 0;
    margin: 0 0 10px 110px;
  }
  .cart_box > .product_num {
    width: 100px;
    height: 30px;
    margin: 0 30px 0 110px;
  }
  .cart_box > .product_num .sub ,
  .cart_box > .product_num .add {
    width: 30px;
    height: 29px;
  }
  .cart_box > .product_num input {
    width: 40px;
    height: 28px;
    line-height: 20px;
  }
  .cart_box > button {margin: 5px 0 0 auto;}
  .confirm .cart_box > figure {width: 45px;}
  .confirm .cart_box > figure + div {width: calc(100% - 70px);}
  .cart_box > div .p_price {min-width: 160px;}
  .cart_box > figure + div + div {
    justify-content: flex-start;
    align-items: flex-start;
    width: calc(100% - 70px);
    margin: 0 0 0 auto;
  }
  .cart_box > div .confirm_num {
    line-height: 1;
    padding: 0 0 0 1em;
  }
  .cart_total {
    width: 300px;
    padding: 20px 0 0;
    margin: 0 0 30px auto;
  }
  .cart_total dl {margin: 0 0 10px;}
  .cart_total dl dt {width: 100px;}
  .cart_total dl dd {width: 200px;}
  .cart_total dl.total {font-size: 1.5em;}
  .confirm .cart_total {width: 100%;}
  .confirm .cart_total dl {
    width: 220px;
    margin: 0 0 10px auto;
  }
  .confirm .cart_total dl.g_total {
    display: block;
    width: 100%;
    font-size: 1.5em;
    text-align: right;
  }
  .confirm .cart_total dl.g_total dt {width: 100%;}
  .confirm .cart_total dl.g_total dd {width: 100%;}
  .cart .btn_show ,
  .confirm .btn_show {
    width: 180px;
    margin: 20px 0 0 auto;
  }
  .cart .btn_show a,
  .confirm .btn_show a {
    padding: 0.15em 1em;
    transition: 0s;
  }
  .cart .btn_show a:hover,
  .confirm .btn_show a:hover {opacity: 1;}
  .btn_box {
    display: block;
    margin: 45px auto 0;
  }
  .btn_box button {
    display: block;
    width: 200px;
    border-radius: 4px;
    margin: 0 auto 10px;
    transition: 0s;
  }
  .btn_box button:hover {opacity: 1;}
  .deliv_flow {margin: 0 auto 40px;}
  .deliv_flow::after {inset: 11px 0 auto;}
  .deliv_flow li {width: 7em;}
  .deliv_flow li::before {
    width: 27px;
    height: 23px;
  }

  .deliv_box {padding: 20px 0;}
  .deliv_box dt {width: 130px;}
  .deliv_box dt span {width: 60px;}
  .deliv_box dd {
    display: block;
    width: calc(100% - 130px);
  }
  .deliv_box dd p:nth-of-type(1) {width: 100%;}
  .deliv_box dd p:nth-of-type(2) {
    width: 100%;
    padding: 0;
  }
  .deliv_box dd div {
    justify-content: flex-start;
    width: 100px;
    margin: 0 0 0 auto;
  }
  .deliv_box dd div button {margin: 0 0 0 2em;}
  button.add {
    width: 160px;
    height: 24px;
    line-height: 22px;
    margin: 20px 0 0 auto;
  }

  .deliv_edit {padding: 20px 0 10px;}
  .deliv_edit dt {
    width: 110px;
    margin: 0 0 10px;
  }
  .deliv_edit dd {width: calc(100% - 110px);}
  .deliv_edit dd > div {padding: 0 0 10px;}
  .deliv_edit dd > div + div {padding: 20px 0 10px;}
  .deliv_edit dd input {height: 30px;}
  .deliv_edit dd input.zip {width: 110px;}
  .deliv_edit dd .select_outer {
    width: 110px;
    height: 30px;
  }
  .deliv_edit dd .select_outer::after {right: 5px;}
  .deliv_edit dd .select_outer select {
    height: 30px;
    line-height: 30px;
  }
  .deliv_edit dd input[type="number"] {
    width: 60px;
    height: 30px;
    font-size: 1em;
    line-height: 30px;
  }
  .deliv_edit dd .zip_link {margin: 0 0 0.5em 0.5em;}
  .deliv_edit dd .btn_zip {
    width: 80px;
    height: 24px;
    line-height: 20px;
  }
  
}
  
@media screen and (max-width: 540px) {

  .deliv_edit dd > div .name_input {width: 220px;}
  .deliv_edit dd > div .name_input input {
    width: 70px;
    margin: 0 0 0 0.5em;
  }
  .deliv_edit dd > div .name_input input:nth-of-type(1) {margin: 0 1em 0 0.5em;}
}

@media screen and (max-width: 800px) {
  
  .deliv_edit dd > div button {
    position: static;
    display: block;
    margin: 10px 0 0 auto;
  }
  .deliv_edit button.add {
    width: 170px;
    margin: 20px 0 10px auto;
  }
  .deliv_setting {margin: 0 0 30px;}
  .deliv_setting .setting01 {
    padding: 20px;
    align-items: flex-start;
  }
  .deliv_setting .setting01 figure {
    width: 70px;
    margin: 0 20px 0 0;
  }
  .deliv_setting .setting01 div:nth-of-type(1) {
    width: calc(100% - 90px);
    padding: 0 ;
  }
  .deliv_setting .setting01 .p_num {
    min-width: 80px;
    margin: 0 5px 5px 0;
  }
  .deliv_setting .setting01 .p_price {
    font-size: 1.25em;
    width: calc(100% - 90px);
    margin: 10px 0 10px auto;
  }
  .deliv_setting .setting01 div:nth-last-of-type(1) {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: calc(100% - 90px);
    margin: 0 0 0 auto;
    padding: 0 ;
  }
  .deliv_setting .setting01 div:nth-last-of-type(1) p {
    display: block;
    padding: 0 1em;
  }
  .deliv_setting .setting01 div:nth-last-of-type(1) p:nth-of-type(1) {
    padding: 0 1em 0 0;
    border-right: solid 1px var(--common);
    border-bottom: none;
  }
  .deliv_setting .setting02 {
    position: relative;
    z-index: 0;
    flex-wrap: wrap;
    width: 100%;
    margin: 0;
    padding: 20px 0;
  }
  .deliv_setting .setting02 p:nth-of-type(1) {width: 100%;}
  .deliv_setting .setting02 .select_outer {
    width: 150px;
    height: 30px;
    margin: 0;
  }
  .deliv_setting .setting02 .select_outer::after {right: 5px;}
  .deliv_setting .setting02 .select_outer select {
    height: 30px;
    line-height: 30px;
  }
  .deliv_setting .setting02 .product_num {
    width: 100px;
    height: 30px;
    margin: 0 5px 0 0;
  }
  .deliv_setting .setting02 .product_num .sub ,
  .deliv_setting .setting02 .product_num .add {
    width: 30px;
    height: 29px;
  }
  .deliv_setting .setting02 .product_num input {
    width: 40px;
    height: 30px;
    line-height: 20px;
    font-size: 1em;
  }
  .deliv_setting .setting02 button {
    position: absolute;
    z-index: 1;
    top: 25px;
    right: 0;
    margin: 0;
  }
  .deliv_setting .setting02 + button.add {margin-top: 15px;}

  .option .option_select {margin: 0 auto 30px;}
  .option .option_select button {
    width: 31%;
    height: auto;
    line-height: 1.2;
    padding: 0.35em;
  }
  .option .bg_box {
    flex-wrap: wrap;
    padding: 30px 30px 10px;
  }
  .option .bg_box.bg_box01 {
    display: block;
    max-width: 100%;
  }
  .option .bg_box.bg_box01 figure {
    width: 45%;
    margin: 0 auto 20px;
  }
  .option .bg_box.bg_box03 {max-width: 100%;}
  .option .bg_box label {
    width: 46%;
    margin: 0 0 20px;
  }
  .option .bg_box.bg_box03 label {
    width: 46%;
    margin: 0 0 20px;
  }
  .option .bg_box.bg_box03 label:nth-last-of-type(1) {width: 100%;}
  .option input.name {
    width: 70px;
    height: 30px;
    line-height: 30px;
    margin: 0 2em 10px 0.5em;
  }
  .option input.name02 {
    width: 90px;
    height: 30px;
    line-height: 30px;
  }
  button.preview {
    width: 120px;
    height: 27px;
    line-height: 25px;
    margin: 15px 0;
}
  .option .bg_box.card_bag {
    align-items: flex-start;
    margin: 20px 0 10px;
  }
  .option .bg_box.card_bag figure {width: 45%;}
  .option .bg_box.card_bag.card_bag03 {max-width: 100%;}
  .option .bg_box.card_bag.card_bag03 > figure {
    width: 45%;
    margin: 0 0 20px;
  }
  .option .bg_box.card_bag.card_bag03 div.sp_cont {
    display: block;
    width: 45%;
    height: 0;
  }
  .option .bg_box.card_bag .modal figure {margin: 0 auto 30px;}
  .setting_box {padding: 20px 0 10px;}
  .setting_box:nth-last-of-type(1) {border-bottom: solid 1px var(--color);} 
  .setting_box dt {width: 110px;}
  .setting_box dd {width: calc(100% - 110px);}
  .setting_box dd .option_product01 {
    justify-content: space-between;
    padding: 0 0 5px;
  }
  .setting_box dd .option_product01 > div {
    width: 31%;
    margin: 0 0 10px;
  }
  .setting_box dd .option_product01 > div figure {margin: 0 0 5px;}
  .setting_box dd .option_product02 {padding: 20px 0 10px;}
  .setting_box dd .option_product02:nth-last-of-type(1) {
    padding: 20px 0 10px;
    border: none;
  }
  .setting_box dd .option_product02 dl {display: block;}
  .setting_box dd .option_product02 dl dt {
    width: 100%;
    padding: 0 0 5px;
  }
  .setting_box dd .option_product02 dl dd {margin: 0;}
  .setting_box dd .option_product02 dl dd input {
    width: 60px;
    height: 27px;
    line-height: 27px;
  }
  .setting_box dd .setting_date {padding: 20px 0 10px;}
  .setting_box dd .setting_date label {
    width: 100px;
    margin: 0;
  }    
  .setting_box dd .date_select input + span {display: block;}
  .confirm .bg_box {padding: 20px;}
  figure.card {
    width: 160px;
    margin: 15px 0;
  }
  .confirm .card_input {
    width: 100%;
    padding: 20px;
  }
  .confirm .card_input dt ,
  .confirm .card_input dd {width: 100%;}
  .confirm .card_input dd input {
    width: 100%;
    height: 30px;
    line-height: 30px;
    margin: 0 0 10px;
  }
  .confirm .card_input dd .select_outer {
    width: 100px;
    height: 30px;
  }
  .confirm .card_input dd .select_outer::after {right: 5px;}
  .confirm .card_input dd .select_outer select {
    height: 30px;
    line-height: 30px;
  }
  .mypage h3.common span ,
  .confirm h3.common span {
    width: 60px;
    height: 15px;
    line-height: 15px;
    font-size: 0.7em;
  }
  .mypage h3.common.ac ,
  .confirm h3.common.ac {margin: 30px 0 20px;}
  .mypage h3.common.ac::before ,
  .confirm h3.common.ac::before {
    width: 4px;
    height: calc(100% - 1.4em);
    left: 0.75em;
  }
  .mypage h3.common.ac .ac_mark,
  .confirm h3.common.ac .ac_mark {
    width: 17px;
    height: 17px;
    inset: 0 10px 0 auto;
  }
  .mypage h3.common.ac + div ,
  .confirm h3.common.ac + div {margin: 0 0 40px;}
  .confirm .option_box {
    display: block;
    padding: 20px 0 20px 70px;
  }
  .confirm .option_box .option_title {width: 100%;}
  .confirm .option_box.noshi .option_title {width: 100%;}
  .confirm .option_box div {
    justify-content: flex-start;
    width: 100%;
  }
  .confirm .option_box > div .p_price {width: 160px;}
  .confirm .option_box div .confirm_num {
    width: calc(100% - 160px);
    padding: 0 0 0 1em;
  }
  .complete .box .btn_common {
    width: 260px;
    margin-top: 40px;
  }
}

/* -----------------------------------------------------------
 mypage
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  
  .mypage_box .pagenation {margin: 20px 0 0;}
  .mypage_box {display: block;}
  .mypage_box .mypage_list {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    width: 100%;
    border: none;
    margin: 0 auto 20px;
  }
  .mypage_box .mypage_list li {
    width: 49%;
    line-height: 1.3;
    text-align: center;
    list-style-type: none;
    margin: 0 0 10px;
    border: solid 1px var(--common);
    border-radius: 8px;
  }
  .mypage_box .mypage_list li a {  
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    padding: 1em 0;
  }
  .mypage_box .mypage_list li:hover,
  .mypage_box .mypage_list li.current {
    border: solid 1px var(--color);
    background: #F8F5F2;}
  .mypage_box .mypage_column {width: 100%;}
  .mypage_box .mypage_column .deliv_box dt {width: 110px;}
  .mypage_box .mypage_column .deliv_box dd {width: calc(100% - 110px);}
  .mypage_box .mypage_column .deliv_box dd > div:nth-of-type(1) {
    display: block;
    width: 100%;
    padding: 0;
  }
  .mypage_box .mypage_column .deliv_box dd > div p:nth-of-type(1) {width: 100%;}
  .mypage_box .mypage_column .deliv_edit dt {width: 110px;}
  .mypage_box .mypage_column .deliv_edit dd > div .name_input {width: 220px;}
}

@media screen and (max-width: 550px) {
  .mypage_box .mypage_column .deliv_edit dd {width: calc(100% - 110px);}
  .mypage_box .mypage_column .deliv_edit dd > div .name_input input:nth-of-type(1) {margin: 0 1em 0 0.5em;}
}

@media screen and (max-width: 800px) {
  .mypage_box .mypage_column .deliv_edit dd > div {padding: 0 0 10px;}
  .mypage_box .mypage_column .deliv_edit dd > div + div {padding: 20px 0 20px 0;}
  .mypage_box .mypage_column .p_list ul li {
    width: 48%;
    font-size: 1em;
  }
  .mypage_box .mypage_column .mypage_order {
    padding: 30px 6%;
    margin: 0 0 30px;
  }
  .mypage_box .mypage_column .order_info {display: block;}
  .mypage_box .mypage_column .order_info h2 {font-size: 1.5em;}
  .mypage_box .mypage_column .order_info p {font-size: 1em;}
  .mypage_box .mypage_column .cart_box > figure {
    width: 45px;
    margin: 0 20px 0 0;
  } 
  .mypage_box .mypage_column .cart_box > figure + div {
    width: calc(100% - 65px);
    padding: 0;
    margin: 0 0 5px;
  }
  .mypage_box .mypage_column .cart_box > figure + div + div {
    width: calc(100% - 65px);
  }
  .mypage_box .mypage_column .option_box {display: block;}
  .mypage_box .mypage_column .option_box .option_title {
    width: 100%;
    padding: 0 0 0 65px;
  }
  .mypage_box .mypage_column .option_box div .p_price {min-width: 160px;}
  .mypage_box .mypage_column .option_box div {
    justify-content: flex-start;
    width: calc(100% - 65px);
    margin: 0 0 0 auto;
  }
  .mypage_box .mypage_column .option_box.noshi .option_title {
    width: 100%;
    padding: 0;
  }
  .mypage_box .mypage_column .option_box div .confirm_num {padding: 0 0 0 1em;}
  
  
  .mypage_box .mypage_column .cart_total {width: 100%;}
  .mypage_box .mypage_column .cart_total dl {
    width: 220px;
    margin: 0 0 5px auto;
  }
  .mypage_box .mypage_column .cart_total dl.g_total {margin: 15px 0 0;}
  .mypage_box .mypage_column .cart_total dl.g_total {display: block;}
  .mypage_box .mypage_column .cart_total dl.g_total dt {
    width: 100%;
    text-align: right;
  }
  .mypage_box .mypage_column .cart_total dl.g_total dd {
    width: 100%;
    padding: 5px 0 0;
  }
  .mypage_box .mypage_column .btn_order {
    display: block;
    width: 140px;
    height: 30px;
    line-height: 30px;
    margin: 20px 0 0 auto;
  }
  .mypage_box .mypage_column .order_detail {
    margin: 0;
  }
  .mypage_box .mypage_column .order_detail .btn_box {
    margin: 0 0 10px;
  }
  .mypage_box .mypage_column .deliv_box dd p:nth-of-type(1) {
    width: 100%;
    padding: 0 ;
  }
  .mypage_box .mypage_column .deliv_box dd p:nth-of-type(2) {width: 100%;}
  .mypage_box .mypage_column .cancel_caution {
    padding: 7%;
    margin: 20px 0 30px;
  }
  .mypage_box .mypage_column .cancel_input {margin: 20px 0;}
  .mypage_box .mypage_column .cancel_input + .btn_common {width: 140px;}
  .mypage_box .mypage_column .receipt > div:nth-of-type(1) {padding: 6%;  }
  .mypage_box .mypage_column .receipt > div input[type="text"] {width: 140px;}
  .mypage_box .mypage_column .receipt > div button {margin: 10px 0 0;}
}


@media (orientation: landscape) and (max-width: 767px){
  .option .modal.noshi_preview figure > div p {font-size: min(5.5vw, 18px);}

}

/* -----------------------------------------------------------
 static
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  .page_static .p_title {margin: 0 0 40px;}
  .page_static .p_title h1 {font-size: 1.67em;}
  .page_static .box h2 {margin: 30px 0 20px;}
  .page_static .box h2 .tips {
    width: 15px;
    height: 15px;
    font-size: 11px;
    margin: 0 0 5px 5px;
  }
  .page_static .box p {margin: 0 0 15px;}
  .page_static .box .btn_sub {
    margin: 15px 10px 15px 0;
    padding: 0.5em 1.5em;
  }
  .page_static .box .btn_sub:hover {opacity: 1;}
  .page_static table th {width: 120px;}
  .page_static .box h2 {margin: 30px 0 20px!important;}
  .page_static .box h3 {margin: 20px 0 15px!important;}
  .page_static .box h4.h2_common {margin: 20px 0 15px!important;}
  .page_static .box h4.h3_common {margin: 20px 0 15px!important;}
  .page_static .box h2,
  .page_static .box .h2_common {margin: 30px 0 20px;}
  .page_static .box h3,
  .page_static .box .h3_common {margin: 20px 0 15px;}
  .page_static .box .ac + div {margin: 0 0 30px;}
  .page_static .box .ac .ac_mark {
    width: 17px;
    height: 17px;
    inset: 0 10px 0 auto;
  }
  .page_static .box .ac + div + .ac {margin-top: 30px!important;}
  
  .page_static .noshi_caution .p_tag {width: 130px;}
  .page_static .noshi_caution p {
    width: calc(100% - 130px);
    margin: 0 0 0 10px;
  }
  
  
  .page_static .box .bg_box {
    flex-wrap: wrap;
    padding: 30px 30px 10px;
  }
  .page_static .box .bg_box.bg_box03 {max-width: 100%;}
  .page_static .box .bg_box.card_bag {
    align-items: flex-start;
    margin: 20px 0 10px;
  }
  .page_static .box .bg_box.card_bag > figure {width: 45%;}
  .page_static .box .bg_box.card_bag.card_bag03 {max-width: 100%;}
  .page_static .box .bg_box.card_bag.card_bag03 > figure ,
  .page_static .bg_box.card_bag.card_bag_use > figure {
    width: 45%;
    margin: 0 0 20px;
  }
  .page_static .box .bg_box.card_bag.card_bag03 div.sp_cont {
    display: block;
    width: 45%;
    height: 0;
  }
  .page_static .box .bg_box.card_bag .modal figure {margin: 0 auto 30px;}
  .page_static .dl_contact {padding: 20px 0 10px;}
  .page_static .dl_contact dt {width: 110px;}
  .page_static .dl_contact dd {width: calc(100% - 110px);}
  .page_static .dl_contact dd .select_outer {
    width: 130px;
    height: 30px;
  }
  .page_static .dl_contact dd .select_outer::after {
    right: 5px;
    bottom: 0.2em;
  }
  .page_static .dl_contact dd .select_outer select {
    height: 30px;
    line-height: 30px;
  }
  .page_static .dl_contact dd input[type="number"] {
    width: 60px;
    height: 30px;
    font-size: 1em;
    line-height: 30px;
  }
  .page_static .dl_contact dd .name_input {width: 230px;}
  .page_static .dl_contact dd .name_input input {
    margin: 0 1em 0 0.5em;
    width: 70px;
    height: 30px;
  }
  .page_static .dl_contact dd .name_input span {
    display: inline-block;
    width: 2em;
    text-align: right;
    line-height: 1;
  }
  .page_static .dl_contact dd input[type="email"] {
    width: 100%;
    height: 30px;
    line-height: 30px;
    margin: 0 0 10px;
  }
.page_static .use_contact {
  padding: 4% 5%;

  
}
/* -----------------------------------------------------------
 org
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  .page_org {padding: 40px 0 0;}
  .page_org .kv_category {
    width:  94%;
    height: auto;
    aspect-ratio: 7 / 4;  
    margin: 0 0 40px auto;
  }
  .page_org .kv_category::after {top: -40px;}
  .product_list .kv_category > h1 {font-size: 1em;}
  .product_list .kv_category > h1 span {font-size: 1.875em;}
  .page_org .select01 {padding: 0 0 40px;}
  .page_org .select01 h2 {font-size: 1.5em;}
  .page_org .select02 {padding: 40px 0;}
  .page_org .select02 section {margin: 0 auto 40px;}
  .page_org .select02 section > figure img {width: 50%;}
  .page_org .select02 ul {display: block;}
  .page_org .select02 ul li {
    width: 100%;
    margin: 0 auto 20px;
  }
  .page_org .select02 ul li figure {width: 100%;}
  .page_org .manner01 {padding: 0 0 40px;}
  .page_org .manner02 {
    padding: 50px 0 20px;
    margin: 0 ;
  }
  .page_org .manner02::after {
    right: 55vw;
    left: auto;
  }
  .page_org .manner02 .box h2 {font-size: 1.6em;}
  .page_org .manner02 .box h2 span {font-size: 0.7em;}
  .page_org .manner02 .box h2 {left: 5%;}
  .page_org .manner02 section {margin: 0 0 30px;}
  .page_org .manner02 section h3 {margin: 0 0 5px;}
  .page_select .select02::after {
    width: 40%;
    right: auto;
  }
  .page_org .manner02 .box {padding-left: calc(5% + 50px);}
  .page_org .manner02 .box h2 {
    font-size: 1.6em;
    left: 5%;
  }
  .page_org .manner02 .box > div {display: block;}
  .page_org .manner02 .box > div dl {
    width: 100%;
    margin: 0 auto 40px;
  }
  .page_org .manner02 .box > div dl dt {font-size: 1.75em;}
  .page_org .manner02 .box > div dl dd p {
    min-height: auto;
    margin: 0 auto 20px;
  }
  .page_org .manner03 {
    padding: 50px 0 ;
    margin: 0 ;
  }
  .page_org .manner03 section {margin: 0 0 30px;}
  .page_org .manner03 .box h2 {font-size: 1.6em;}
  .page_org .manner03 .box h2 span {font-size: 0.7em;}
  .page_org .manner03 .box h2 {right: 5%;}
  .page_org .manner03 .box {padding-right: calc(5% + 80px);}
  
  
}