@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: 20px 6%;
    align-items: center;
  }
  header .logo {
    width: 180px;
    margin: 0;
  }
  header .btn_list {width: 180px;}
  header .btn_list p {width: 45px;}
  header .btn_list .btn_recommend img {width: 21px;}
  header .btn_list .btn_cart img {width: 20px;}
  header .btn_list .btn_setting img {width: 22px;}
  header .btn_list .menu {
    width: 25px;
    height: 16px;
    margin: 0 0 15px 10px;
  }
  header .btn_list p a {width: 50px;}
  header .btn_list p span {margin: 5px 0 0;}
  header .btn_list .btn_setting span {margin: 4px 0 0;}
  header .btn_list .btn_cart span {letter-spacing: -0.1em;}
  
  .header_caution {
    padding: 0 3%;
    height: 36px;
  }
  .header_caution + header {margin: 36px 0 0;}
  
  /* :::::::::: nav :::::::::: */

  nav {padding: 20px 6%;}
  nav .menu_box {padding: 40px 0;}
  nav .menu_box .btn_close {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 - 265px);
    margin: 30px 0 0;
    padding: 0 0 60px;
  }
  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: 1em;}
  .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;}
  .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: 36px;
    font-size: 2em;
  }
  .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;
  }
  .search_form button {
    width: 30px;
    height: 30px;
  }
}


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

@media screen and (max-width: 800px) {
 
  header.home {justify-content: flex-end;}
  header.home h1 {
    position: absolute;
    top: -15px;
    left: 3%;
    width: 320px;
    transform: rotate(90deg);
    transform-origin: bottom left;
  }
  header.home h1 img {
  }
  header.home .logo {width: 180px;}
  header.home.fixed h1 {width: 320px;}
  header.home.fixed .logo {width: 180px;}
  .home_kv {position: relative;}

  .home_kv img {
    position: absolute;
    width: 120%;
    height: 120%;
    margin: auto;
    bottom: 0;
    left: -100%;
    right: -100%;
  }
  .home_kv p.index_caution {
    padding: 50px 10px 20px;
    bottom: 30px;
  }
  .home_kv p.index_caution::before {top: 15px;}
  .home_status {padding: 30px 10%;}
  .home_status h2 {
    font-size: 24px;
    bottom: 20px;
    right: 5%;
  }
  .home_status > p {font-size: 21px;}
  .home_status > div {
    align-items: flex-start;
    width: calc(100% - 50px);
    margin: 50px 0 0;
  }
  
  .home_status > div figure {
    width: 65px;
    height: 65px;
  }
  .home_status > div figure span {font-size: 1.4rem;}
  .home_status > div p {width: calc(100% - 80px);}
  .home_category {display: block;}
  .home_category > div {
    width: 100%;
    height: 170px;
  }
  .home_category > div:nth-of-type(4) ,
  .home_category > div:nth-of-type(5) {
    width: 100%;
    height: 170px;
  }
  .home_category > div > a ,
  .home_category > div > span  {padding: 20px;}
  
  .home_category > div > a > p ,
  .home_category > div > span > p {padding: 0 40px 0 0;}
  .home_category > div > a > p > span  ,
  .home_category > div > span > p > span {margin: 5px auto 0;}
  .home_category > div > a > p::after ,
  .home_category > div > span > p::after {
    width: 1.675em;
    height: 1.675em;
  }
  .home_category > div > a figure img ,
  .home_category > div > span figure img  {transition: 0s;}
  .home_category > div > a:hover figure img ,
  .home_category > div > span:hover figure img {transform: scale(1);}
  
  .home_category > div .hikidemono_modal > div {
    width: 70vw;
    max-height: 520px;
    padding: 50px 10px;
    border-radius: 5px;
  }
  .home_category > div .hikidemono_modal > div ul {display: block;}
  .home_category > div .hikidemono_modal > div ul li {
    width: 100%;
    margin: 0 0 15px;
    height: auto;
  }
  .home_category > div .hikidemono_modal > div ul li a figure {display: none;}
  .home_category > div .hikidemono_modal > div ul li a figure img {transition: 0s;}
  .home_category > div .hikidemono_modal > div ul li a:hover figure img {transform: scale(1);}
  .home_category > div .hikidemono_modal > div ul li a p {color: var(--common);}
  .home_category > div .hikidemono_modal > div ul li.list_all {height: auto;}
  .home_category > div .hikidemono_modal > div ul li.list_all a {
    color: var(--common);
    font-size: 1.25em;
    border: none;
    transition: 0s;
  }
  .home_category > div .hikidemono_modal > div ul li.list_all a:hover {
    color: var(--common);
    background: none;
  }
  .home_category > div .hikidemono_modal > div .btn_close {
    width: 80px;
    height: 30px;
    line-height: 30px;
  }
  .home_feature {padding: 40px 0;}
  .home_feature h2 {
    position: static;
    font-size: 35px;
    line-height: 1.2;
    transform: rotate(0deg);
    margin: 0 0 20px;
    padding: 0 5%;
  }
  .home_feature .feature_slider {
    width: 150vw;
    transform: translateX(3%);
    padding: 0 0 80px;
  }
  .home_feature .feature_slider .slick-slide {
    margin: 0 4vw 0 0;
    padding: 10px;
  }
  .home_feature .feature_slider .slick-slide figure {margin: 0 0 20px;}
  .home_feature .feature_slider .slick-slide .btn {
    height: 40px;
    line-height: 38px;
  }
  .home_feature .feature_slider .slick-slide .btn a {transition: 0s;}
  .home_feature .feature_slider .slick-slide .btn a:hover {color: var(--color);}
  .home_feature .feature_slider .slick-slide .btn a::after {display: none;}
  .home_feature .feature_slider .slick-arrow {
    width: 40px;
    height: 40px;
    opacity: 1;
    transition: 0s;
    transform: translate(0, 0);
  }
  .home_feature .feature_slider .slick-arrow.slick-prev {
    cursor: auto;
    background: url("../img/common/al_b.svg") no-repeat center / cover;
    left: calc(100vw - 140px);
    top: auto;
    bottom: 20px;
  }
  .home_feature .feature_slider .slick-arrow.slick-next {
    cursor: auto;
    background: url("../img/common/ar_b.svg") no-repeat center / cover;
    left: calc(100vw - 90px);
    top: auto;
    bottom: 20px;
    right: auto;
  }
  .home_feature .feature_category {
    width: 90vw;
    transform: translateX(0);
    margin: 0 auto;
  }
  .home_feature .feature_category li a {transition: 0s;}
  .home_feature .feature_category li a:hover {opacity: 1;}

  .home_recommend {padding: 40px 0;}
  .home_recommend h2 {
    font-size: 35px;
    top: -20px;
    left: 2%;
  }
  .home_recommend .box {
    width: calc(100% - 60px);
    margin: 0 0 0 auto;
  }
  .home_recommend .box ul {min-height: 420px;}
  .home_recommend ul::after {width: 48%;}
  .home_recommend ul li {
    width: 48%;
    margin: 0 0 25px;
  }
  .home_recommend ul li figure {margin: 0 auto 10px;}
  .home_recommend ul li .p_price {margin: 5px 0 0;}
}

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

@media screen and (max-width: 800px) {
  
.product_list .p_title_area {
  top: 60px;
  left: calc(2% + 30px);
  min-width: 500px;
}
  .product_list .p_title_area .p_title {
    font-size: 1.3em;
    margin: 0 20px 0 0;
  }
  .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.search_list .p_title_area {top: 100px;}
  .product_list.search_list .p_title_area .p_title span.child_category {
    height: 390px;
    top: 120px;
    display: block;
  }
  .product_list.search_list .list_search_box {
    justify-content: flex-end;
    flex-wrap: wrap;
  }
  .product_list.search_list .list_search_box .search_form {
    width: 260px;
    margin: 0 0 10px;
    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_box {margin: 0 0 30px;}
  .product_list .p_list .select_sort {
    width: 120px;
    height: 30px;
    line-height: 30px;
  }
  .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%;}
}

/* -----------------------------------------------------------
 gift_list
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  .group_settings {margin: 30px auto 50px;}
  .gift_list {
    margin: 0 0 25px;
    padding: 30px 5% 0;
    border-radius: 6px;
  }
  .gift_list dt {padding: 0 0 20px 2em;}
  .gift_list dd {
    display: block;
    padding: 15px 0;
    min-height: 60px;
  } 
  .gift_list dd .p_cat {
    width: 100%;
    margin: 0 0 10px;
  }
  .gift_list dd > div {
    width: 100%;
    align-items: flex-start;
  }
  .gift_list dd > div figure {width: 60px;}
  .gift_list dd > div > div {
    justify-content: flex-end;
    flex-wrap: wrap;
    width: calc(100% - 75px);
  }
  .gift_list dd > div > div .p_title {
    width: 100%;
    line-height: 1.625;
    margin: 0 0 10px;
  }
  .gift_list dd.no_item p,
  .gift_list dd.other_item p {padding: 10px 0;}
  .gift_list dd.no_item .p_cat {text-align: left;}
  .gift_list dd.no_item .p_title {width: 100%;}
  .gift_list dd.no_item figure {display: none;}
  .gift_list dd.no_item > div > div {width: 100%;}
  .gift_list dd.no_item > div > div .p_title {text-align: center;}
  .group_settings .gift_list dt {
    display: block;
    padding: 0 0 20px;
  }
  .group_settings .gift_list dt > div:nth-of-type(1) {
    width: 100%;
    max-width: 100%;
    margin: 0 0 10px;
  }
  .group_settings .gift_list dt > div:nth-of-type(2) {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
  }
  .group_settings .gift_list dt > div:nth-of-type(2) button {
    width: 48%;
    height: 30px;
    line-height: 26px;
    margin: 0;
    border-radius: 4px;
  }
  .group_settings .btn_add {
    width: 100px;
    height: 20px;
    line-height: 20px;
    margin: 10px 0 0 auto;
  }
}

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

@media screen and (max-width: 800px) {
  
  .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 .p_cat {margin: 0 0 30px;}
  .product_detail .box .products_info button.btn_common {margin: 35px 0 45px;}
  .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;}
  .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;
  }

  
  
  
}

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

@media screen and (max-width: 800px) {
  
  .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: 32%;
    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:nth-child(4) ,
  .mypage_box .mypage_list li:nth-child(5) {width: 49%;}
  .mypage_box .mypage_list li a {  
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    padding: 5px 0;
  }
  .mypage_box .mypage_list li:hover,
  .mypage_box .mypage_list li.current {border: solid 1px var(--color);background: #F8F5F2;}
  .mypage_box .mypage_list li:nth-child(4) a,
  .mypage_box .mypage_list li:nth-child(5) a ,
  .mypage_box .mypage_list li:nth-child(6) a {padding: 1em 0;}
  .mypage_box .mypage_list li.list_reset {
    width: 100%;
    padding: 0;
    text-align: left;
    border: none;
  }
  .mypage_box .mypage_list li.list_reset.current {background: none;}
  .mypage_box .mypage_list li.list_reset a {display: inline-block;}
  .mypage_box .mypage_list li.list_reset a::before {content: "> ";}
  .mypage_box .mypage_column {width: 100%;}
  .mypage_box .mypage_column dl {padding: 15px 0;}
  .mypage_box .mypage_column dl.mypage_info:nth-last-of-type(1) {margin: 0;}
  .mypage_box .mypage_column dl.mypage_setting01:nth-of-type(1) {margin: 20px 0 0;}
  .mypage_box .mypage_column dl.mypage_setting01:nth-last-of-type(1) {margin: 0 0 20px;}
  .mypage_box .mypage_column dl.mypage_setting01 dd:nth-of-type(2) {width: 18px;height: 18px;}
  .mypage_box .mypage_column dl.mypage_setting01 dd:nth-of-type(3) {width: 14px;height: 18px;}
  .mypage03 .mypage_box .mypage_column table {
    table-layout: fixed;
    margin: 0 auto 20px;
  }
  .mypage03 .mypage_box .mypage_column table tr {display: block;}
  .mypage03 .mypage_box .mypage_column table th {width: 100px;}
  .mypage03 .mypage_box .mypage_column table td {
    width: calc(100% - 100px);
    padding: 20px 30px;
  }
  .mypage03 .mypage_box .mypage_column table td input {width: 0;}
  .mypage03 .mypage_box .mypage_column table td input.date {
    display: inline-block;
    width: 140px;
    height: 30px;
    margin: 5px 0;
  }
  .mypage03 .mypage_box .mypage_column table td label {
    margin: 0 30px 5px 0;
  }
  .mypage03 .mypage_box .mypage_column table td .select_outer {width: 160px;}
  .mypage03 .mypage_box .mypage_column .btn_common {
    width: 120px;
    padding: 0.5em 1em;
    margin: 0 auto 40px;
  }
  .mypage03 .mypage_box .mypage_column dl {display: block;}
  .mypage03 .mypage_box .mypage_column dl:nth-of-type(1) {padding: 20px 0;}
  .mypage03 .mypage_box .mypage_column dl:nth-of-type(1) dt,
  .mypage03 .mypage_box .mypage_column dl:nth-of-type(1) dd:nth-of-type(1) {display: none;}
  .mypage03 .mypage_box .mypage_column dl:nth-of-type(1) dd:nth-of-type(2) {width: 100%;}
  .mypage03 .mypage_box .mypage_column dl {padding: 10px 0;}
  .mypage03 .mypage_box .mypage_column dl dt ,
  .mypage03 .mypage_box .mypage_column dl dd:nth-of-type(1) {
    display: inline-block;
    width: auto;
    font-size: 1.2em;
  }
  .mypage03 .mypage_box .mypage_column dl dd:nth-of-type(1)::before {content: "／";}
  .mypage03 .mypage_box .mypage_column dl dd:nth-of-type(2) {
    width: 100%;
    padding: 5px 0 0;
  }
  .mypage03 .mypage_box .mypage_column dl dt span {display: inline-block;}
  .mypage03 .pagenation a, .mypage03 .pagenation span {
    font-size: 1.6em;
    margin: 0 5px;
  }
  .mypage03 .pagenation a.btn_next, .mypage03 .pagenation a.btn_prev {
    width: 1.2em;
    height: 1.2em;
  }
  .mypage04 label {margin: 0 0 10px;}
  .mypage04 button.btn_common.btn_narrow {margin: 20px auto 0;}
  .mypage05 .mypage_box .mypage_column .reset_date {margin: 0 0 10px;}
  .mypage05 .mypage_box .mypage_column dl {padding: 30px 5% 0;}
  .mypage05 .mypage_box .mypage_column dl dd {min-height: auto;}
  .mypage05 .mypage_box .gift_list dd > div {width: 100%;}
  .mypage05 .gift_list dd > div > div .p_title {display: block;}
  .mypage05 .mypage_box .gift_list dd .p_cat.nocat {margin: 0;}
  .mypage05 .gift_list dd.no_item > p {padding: 0;}
}

/* -----------------------------------------------------------
 setting
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  .setting00:nth-of-type(1) ,
  .setting00:nth-last-of-type(1) {border-bottom: solid 1px var(--common);}
  .setting00 > a {
    position: relative;
    z-index: 0;
    display: block;
    padding: 20px 0;
  }
  .setting00.setting_head {
    display: block;
    border-top: solid 1px var(--common);
    padding: 15px 0;
  }
  .setting00 dt {position: static;width: 100%;margin: 0 0 10px;padding: 0;}
  .setting00 dt::before {
    width: 1em;
    height: 1em;
    margin: auto;
    top: 0;
    bottom: 0;
    left: auto;
    right: 0.5em;
  }
  .setting00 dd {width: 100%;margin: 0 0 10px;}
  .setting00 dd:nth-last-of-type(1) {width: 160px;margin: 0;padding: 0;}
  .setting00.setting_head dd:nth-of-type(1) {margin: 0;}
  .setting00.setting_head dd:nth-of-type(2),
  .setting00.setting_head dd:nth-of-type(3) {display: none;}
  .setting00 dd:nth-last-of-type(1) .btn_setting {width: 35px;}
  .setting00 dd:nth-last-of-type(1) .btn_setting span {
  padding: 28px 0 0;
  background: url("../img/sub/ico_setted.svg") no-repeat top center / 25px;}
  .setting00 dd:nth-last-of-type(1)::after {
    width: 140px;
    top: 14px;
    left: 0;
    right: 0;
    margin: auto;
  }
  .setting_box {padding: 40px 6% 50px;}
  .setting_box .btn_back {
    width: 120px;
    margin: 0 0 25px;
  }
  .setting01 {
    position: relative;
    z-index: 0;
    padding: 30px 5%;
    margin: 0 0 20px;
    border-radius: 4px;
  }
  .setting01 .setting_ac {display: block;}
  .setting01 .setting_ac p {
    position: static;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
    width: 100%;
    padding: 0;
    margin: 0 0 10px;
  }
  .setting01 .setting_ac > span {
    bottom: 10px;
    right: 10px;
  }
  .setting01 .setting_ac div {text-align: left;}
  .setting01 .setting_ac div > .set_num {margin: 0 0.5em 0 0.75em;}
  .setting01 .setting_ac div > .set_num + span {margin: 3px 0 0 5px;}
  .setting01 .ac_box dl {
    display: block;
    padding: 10px 0;
  } 
  .setting01 .ac_box dl:nth-of-type(1) {margin: 20px 0 0;}
  .setting01 .ac_box dl:nth-last-of-type(1) {padding: 10px 0 0;}
  .setting01 .ac_box dl dt {width: 100%;}
  .setting01 .ac_box dl dd {
    width: 100%;
    align-items: flex-start;
  }
  .setting01 .ac_box dl dd + dt + dd {margin: 5px 0 0;}
  .setting01 .ac_box dl dd figure {width: 60px;}
  .setting01 .ac_box dl dd .p_title {width: calc(100% - 80px);}
  .noshi_setting_pc {display: none;}
  .noshi_setting_sp {display: block;}
  .setting02 {
    flex-wrap: wrap;
    padding: 10px 0;
  }
  .setting02:nth-of-type(1) {border-top: solid 1px var(--line);}
  .setting02 dt {width: 80px;}
  .setting02 dt figure {width: 60px;}
  .setting02 dd:nth-of-type(1) {
    display: block;
    width: calc(100% - 80px);
  }
  .setting02 dd:nth-of-type(2) {
    width: 100%;
    display: block;
    padding: 20px 20px 20px 80px;
    background: rgba(233,226,217,0.3);
    margin: 10px 0 0;
  }
  .setting02 dd p {
    margin: 0;
    padding: 0;
  }
  .setting02 dd p span {display: none;}
  .setting02 dd p span.tips {
    display: block;
    width: 1.5em;
    height: 1.5em;
    right: -2.5em;
  }
  .setting02 dd p span.tips span {display: block;width: 120px;left: -50px;font-size:1em;}
  .setting02 dd p span.tips > span::after {left: 55px;}
  .setting02 dd label {
    width: 110px;
    font-size: 1em;
    margin: 0;
  } 
  .setting02 dd label span {vertical-align: middle;}
  .setting02 dd > .p_title {
    width: 100%;
    -webkit-line-clamp: 1;
    margin: 0 0 10px;
  }
  .setting02 dd > div {width: 190px;}
  .setting02 dd > div label input[type="checkbox"] {width: 0;}
  .setting02 dd > div label input[type="checkbox"] + div {
    width: 50px;
    height: 22px;
  }
  .setting02 dd > div label input[type="checkbox"] + div span {
    width: 18px;
    height: 18px;
    left: 2px;
  }
  .setting02 dd > div label input[type="checkbox"]:checked + div span {left: 30px;}
  .setting02 dd:nth-of-type(2){display: none;}
  .setting02.setted dd:nth-of-type(2) {display: block;}
  .setting02 dd:nth-of-type(2) div {
    position: relative;
    z-index: 0;
    padding: 0 1.75em 0 0;
    margin: 0 0 10px;
  }
  .setting02 dd:nth-of-type(2) div:nth-last-of-type(1) {margin: 0;}
  .setting02 dd:nth-of-type(2) div p {
    position: relative;
    z-index: 0;
    width: 160px;
    height: 30px;
    line-height: 30px;
    background: #FFFFFF;
    border: solid 1px var(--common);
  }
  .setting02 dd:nth-of-type(2) div p::after {
    position: absolute;
    z-index: 0;
    display: block;
    content: "";
    width: 0.5em;
    height: 0.5em;
    border-right: solid 1px var(--common);
    border-bottom: solid 1px var(--common);
    margin: auto;
    top: 0;
    bottom: 0.5em;
    right: 0.5em;
    transform: rotate(45deg);
    pointer-events: none;
  }
  .setting02 dd:nth-of-type(2) div p select {
    width: 100%;
    padding: 0 1em;
    color: var(--common);
  }
  .setting02 dd:nth-of-type(2) div p select option {
    width: 100%;
    color: var(--common);
  }
  .setting04 {align-items: flex-start;}
  .setting04 dt {width: 80px;}
  .setting04 dt figure {width: 60px;}
  .setting04 dd {
    flex-wrap: wrap;
    justify-content: flex-end;
    width: calc(100% - 80px);
  }
  .setting04 dd .p_title {
    width: 100%;
    margin: 0 0 10px;
  }
  .setting03 .tab_box {
    padding: 15px 0;
    margin: 20px 0;
  }
  .setting03 .tab_menu {width: 180px;}
  .setting03 .tab_menu li {
    width: 75px;
    margin: 0 15px 0 0;
  }
  .setting03 .tab_menu li p {font-size: 0.875em;}
  .setting03 .tab_menu li figure {
    width: 75px;
    height: 75px;
  }
  .setting03 .tab_content ul {gap: 1px;}
  .setting03 .tab_content ul > li {width: calc(100% / 3 - 1px);}
  .setting03 .tab_content ul > li label {
    top: 5px;
    right: 5px;
  }
  .setting03 .tab_content ul > li label span {
    width: 20px;
    height: 20px;
    border: solid 1px #FFFFFF;
  }
  .setting03 .btn_prev {
    width: 90px;
    height: 58px;
    line-height: 1.3;
    padding: 8px 0 8px;
    border-radius: 3px;
  }
  .setting03 .btn_prev::before {
    display: block;
    background: url("../img/sub/ico_prev.svg") no-repeat center / cover;
    margin: 0 auto;
  }
  .setting03 .prev_box {
    width: 90%;
    height: 85vh;
    max-height: 650px;
    padding: 5%;
    overflow-y: auto;
  }
  .setting03 .prev_box h2 {margin: 0 0 10px;}
  .setting03 .prev_box dl dd {margin: 0 0 20px;}
  .setting03 .prev_box dl dd figure {width: 20%;}
}

/* -----------------------------------------------------------
 setting
----------------------------------------------------------- */

@media screen and (max-width: 800px) {
  
  .tutorial {padding: 75px 0;}
  .tutorial.tutorial01 {padding: 50px 0;}
  .tutorial.tutorial01 .box .logo {
    width: 250px;
    margin: 0 auto 40px;
  }
  .tutorial.tutorial01 .box figure {margin: 0 auto 60px;}
  .tutorial.tutorial01 .box h2 {
    font-size: 1.5em;
    margin: 0 auto 15px;
  }
  .tutorial .btn_tutorial {
    width: 260px;
    margin: 25px auto;
  }
  .tutorial .btn_tutorial:hover {opacity: 1;}
  .tutorial_radio {
    width: 260px;
    margin: 30px auto 20px;
  }
  .tutorial03 h1 + .center {margin: 0 auto 25px;}
  .tutorial_setting {padding: 15px 10px;}
  .tutorial_setting:nth-of-type(1) {margin: 25px auto 0;}
  .tutorial_setting:nth-last-of-type(1) {margin: 0 auto 10px;}
  .tutorial_setting dt {
    width: 2em;
    padding: 0.5em;
    margin: 0;
  }
  .tutorial_setting dd:nth-of-type(1) {width: calc(100% - 180px);}
  .tutorial_setting dd:nth-of-type(2) {width: 130px;}
  .tutorial_setting dd:nth-of-type(3) {width: 30px;}
  .tutorial_setting dd button.g_setting {
    width: 120px;
    height: 30px;
    line-height: 28px;
    border-radius: 4px;
  }
  .tutorial_setting dd button.g_edit {
    width: 120px;
    height: 30px;
    line-height: 28px;
    border-radius: 4px;
  }
  .tutorial .btn_add {width: 100px;}
  .congratulation {font-size: 2.5em;}
}

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

@media screen and (max-width: 800px) {
  
  .page_login {padding: 60px 0;}
  .page_login .box h1 {font-size: 2em;}
  .page_login .box .btn_common {
    width: 300px;
    margin: 30px auto;
  }
  .login_p dl {width: 210px;}
  .login_p dl dt {width: 60px;}
  .login_p dl dd {width: 150px;}
  .login_p dl dd input {height: 25px;}
  .login_p .box .btn_common {
    margin: 30px auto 0;
    width: 150px;
  }
  .page_static .p_title {margin: 0 0 40px;}
  .page_static .p_title h1 {font-size: 1.67em;}
  .page_static .box h2 {margin: 30px 0 0.5em;}
  .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: 80px;}

}

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

@media screen and (max-width: 800px) {
  
  .page_about figure.t_fade {margin: 0 auto 60px;}
  .page_about h2.t_fade {
    font-size: 1.5em;
    margin: 0 auto 15px;
  }
  .page_about h2.t_fade + .t_fade {margin: 0 auto 40px;}
  .page_about h2.t_fade + .t_fade p {margin: 0 auto 20px;}
  .page_about .mid_img {height: 140px;}
  .page_about .mid_img + .box {margin: 0 auto 40px;}
  .page_about .mid_img + .box p {margin: 0 auto 20px;}
  .page_about .about_sect {
    padding: 50px 0 30px;
    margin: 0 0 20px;
  }
  .page_about .about_sect:nth-of-type(1)::after {right: 55vw;}
  .page_about .about_sect:nth-of-type(2)::after {left: 55vw;}
  .page_about .about_sect:nth-of-type(1) .box {padding-left: calc(5% + 80px);}
  .page_about .about_sect:nth-of-type(2) .box {padding-right: calc(5% + 80px);}
  .page_about .about_sect h2 {font-size: 1.6em;}
  .page_about .about_sect h2 span {font-size: 0.7em;}
  .page_about .about_sect:nth-of-type(1) h2 {left: 5%;}
  .page_about .about_sect:nth-of-type(2) h2 {right: 5%;}
  .page_about .about_sect .catch {font-size: 1.75em;}
  .page_about .about_sect section {margin: 0 0 30px;}
  .page_about .about_sect section h3 {margin: 0 0 5px;}
  
  .page_select .kv {height: 225px;}
  .page_select .kv h1 {font-size: 2em;}
  .page_select .select01 {padding: 40px 0;}
  .page_select .select01 h2 {font-size: 1.5em;}
  .page_select .select01 h2 span {font-size: 0.8em;}
  .page_ss .select01 figure {
    width: 180px;
    margin: 30px auto;
  }
  .page_select .select02 {padding: 40px 0;}
  .page_select .select02::after {
    width: 40%;
    right: auto;
  }
  .page_select .select02 .box {padding-left: calc(5% + 50px);}
  .page_select .select02 .box h2 {
    font-size: 1.6em;
    left: 5%;
  }
  .page_select .select02 .box > div {display: block;}
  .page_select .select02 .box > div dl {
    width: 100%;
    margin: 0 auto 40px;
  }
  .page_select .select02 .box > div dl dt {font-size: 1.75em;}
  .page_ss .select02 .box > div dl dd p {
    min-height: auto;
    margin: 0 auto 20px;
  }
  .page_ss .select02 .box > div dl dd img {
    display: block;
    width: 60%;
    margin: 0 auto;
  }
  .page_sc .select02 .box > figure {
    width: 90vw;
    transform: translateX(-50px);
  }
  .page_select .select03 {padding: 40px 0 0;}
  .page_select .select03 section {margin: 0 auto 40px;}
  .page_select .select03 ul {display: block;}
  .page_select .select03 ul li {
    width: 100%;
    margin: 0 auto 20px;
  }
  .page_select .select03 ul li figure {width: 100%;}
  .page_ss .select03 .btn_common {width: 250px;}
}