@charset "utf-8";

/* -----------------------------------------------------------
　common
----------------------------------------------------------- */

@media screen and (max-width: 767px){ 

  body {
    -webkit-text-size-adjust: 100%;
    font-size:1.2rem;
  }
  .pc_cont {display:none;} 
  .course {background:url("../img/sub/bg_category_sp.png") no-repeat top 500px center / 100%;}
}

/* -----------------------------------------------------------
  template
----------------------------------------------------------- */

@media screen and (max-width: 767px){

  /* :::::::::: header :::::::::: */
  
  header {
    width:100%;
    min-width:100%;
    height:70px;
    min-height:70px;
    padding:5px 20px 0;
  }
  header::before,
  header::after {
    width:150%;
    height:70px;
    bottom:-8px;
  }
  header::before {
    right:auto;
    left:-100px;
    transform-origin:bottom left;
  }
  header::after {
    left:auto;
    right:-100px;
    transform-origin:bottom right;
  }
  header .header_box .logo {width:40px;} 
  header .header_box ul li {
    width:80px;
    margin:0 0 0 15px;
  }
  header .header_box ul li img {vertical-align:middle;}
  
  /* :::::::::: main :::::::::: */
  
  main {
    min-width:100%;
    margin:0 0 50px;
    overflow:hidden;
  }
  .box {
    width:100%;
    padding:0 20px;
  }
  .btn_top {
    max-width:100%;
    margin:50px auto 0;
  }
  .btn_top a {font-size:1.6rem;}
  

  /* :::::::::: footer :::::::::: */
  
  footer {
    min-width:100%;
    padding:20px 0 30px;
  }
  footer .footer_box {
    width:100%;
    padding:20px 20px 0;
  }
  footer .p_top {bottom:50px;}
  footer .pagetop {
    width:40px;
    height:40px;
    right:10px;
  }
  footer .f_logo {margin:0 auto 30px;}
  footer .f_logo li {
    width:120px;
    margin:0 10px;
  }
  footer p {font-size:1.4rem;}
  footer nav {
    padding:60px 0 0;
    background:url("../img/common/bg_nav.png") no-repeat top 20px center / 60px;
  }
  footer nav ul {width:100%;}
  footer nav ul li {
    width:32.5%;
    height:50px;
    margin:0 1.25% 2% 0;
  }
  footer nav ul li:nth-child(4n) {margin:0 1.25% 2% 0;}
  footer nav ul li:nth-child(3n) {margin:0 0 2%;}
  footer nav ul li a {
    padding:8px 0 0;
    border-left:solid 6px;
  }
  footer nav ul li a p:nth-child(1) {font-size:1rem;}
  footer nav ul li a p:nth-child(1) span {font-size:1.3rem;}
  footer nav ul li a p:nth-child(2) {font-size:1.2rem;}
  footer nav ul li a p:nth-child(2) span {
    font-size:1.4rem;
    margin:0 0.2em 0 0;
  }
} 
  
/* -----------------------------------------------------------
 static
----------------------------------------------------------- */

@media screen and (max-width: 767px) {
     
  /** home **/

  .kv_home {background:url("../img/home/kv_sp.jpg") no-repeat center / cover;}
  .kv .box p {
    width:300px;
    max-width:calc(100% - 40px);
    left:20px;
  }
  .home_intro .box {padding:200px 20px 150px;}
  .home_intro .box::after {
    width:261px;
    height:364px;
    background:url("../img/home/bg_intro_sp.png") no-repeat center / cover;
    margin:auto;
    bottom:30px;
    right:-30px;
  }
  .home_intro h2 {
    width:300px;
    max-width:calc(100% - 40px);
    bottom:140px;
  }
  .home_intro h2.static {top:40px;}
  .home_intro p {
    font-size:1.6rem;
    line-height:1.75;
  }
  .home_course::after {
    width:200vw;
    height:1100px;
  }
  .home_course h2 {
    width:320px;
    max-width:100%;
    margin:0 auto 20px;
  }
  .home_course h2 + p {
    font-size:1.6rem;
    padding:0 0 60px;
    background:url("../img/home/course_ar.png") no-repeat center bottom 20px / 60px;
  }
  .home_course ul {
    width:100%;
    margin:0 auto 80px;
  }
  .home_course ul li {
    display:block;
    width:85%;
    height:50px;
    font-size:1.2rem;
    margin:0 auto 20px;
  }
  .home_course ul li:nth-child(4n) {margin:0 auto 20px;}
  .home_course ul li a {padding:5px 0 0;}
  .home_course ul li a p span:nth-of-type(1) {font-size:1.3rem;}
  .home_course ul li a p span:nth-of-type(2) {font-size:2.4rem;}
  .about_slider {
    height:200px;
    margin:0 0 60px;
  }
  .about_slider .slick-track {width:7350px!important;}
  .about_slider li {
    width:2943px!important;
    height:200px;
  }
  .home_about h2 {
    width:270px;
    margin:0 auto 80px;
  }
  .home_about h3 span {font-size:1.8rem;}
  .home_about h3 + p {
    font-size:1.5rem;
    margin:0 auto 40px;
  }
  .home_about ol li {
    display:block;
    width:100%;
    font-size:1.2rem;
    margin:0 0 15px;
    overflow:hidden;
  }
  .home_about ol li div {
    width:150px;
    height:150px;
    border-radius:50%;
    margin:0 20px 0 0;
    float:left;
  }
  .home_about ol li div span {
    font-size:1.8rem;
    top:10px;
  }
  .home_about ol li div p {font-size:1.5rem;}
  .home_about ol li > p {
    position:absolute;
    width:calc(100% - 170px);
    font-size:1.5rem;
    top:50%;
    right:0;
    transform:translateY(-50%);
  }
  .about_pickup li {
    width:100%;
    margin:0 auto;
  }
  .about_pickup li figure {width:100%;}
  .about_pickup li div {
    width:100%;
    padding:30px 20px 40px;
  }
  .about_pickup li:nth-child(1) div {padding:30px 20px 40px;}
  .about_pickup li::before {content:none;}
  .about_pickup li:nth-child(odd) figure ,
  .about_pickup li:nth-child(odd) div {float:none;}
  .about_pickup li:nth-child(even) figure ,
  .about_pickup li:nth-child(even) div {float:none;}

  .about_pickup li div .pickup_title {
    font-size:2rem;
    margin:0 0 20px;
  }
  .about_pickup li div .pickup_title span {margin:0 0 10px;}
  .about_pickup li div .pickup_btn {
    max-width:100%;
    margin:0 auto;
  }
  .about_pickup li div .pickup_btn a ,
  .about_pickup li div .pickup_btn span {font-size:1.6rem;}
  .home_about .modal_box {min-width:100%;}
  .home_about .modal_box .modal_course {padding:15px 0 0;left:10px;}
  .home_about .modal_box .modal_course span {width:60px;}
  .home_about .modal_box .modal_course::before {
    width:100vw;
    height:50px;
    left:-20px;
  }
  .home_about .modal_box .modal_kv {
    width:100%;
    height:70vw;
    background:url("../img/home/modal_kv_sp.jpg") no-repeat center bottom / cover;
  }
  .home_about .modal_box .modal_cont {
    width:100%;
    padding:120px 20px 60px;
  }
  .home_about .modal_box .modal_cont h3 {
    width:280px;
    height:140px;
    padding:40px 0 0;
    border-radius:140px 140px 0 0;
    top:-80px;
  }
  .home_about .modal_box .modal_cont h3 img {width:200px;}
  .home_about .modal_box .modal_cont h3 + p {font-size:1.4rem;}
  .home_about .modal_box .modal_cont .p_list {margin:0 auto 30px;}
  .home_about .modal_box .modal_cont .p_list li {
    width:23%;
    margin:0 2% 0 0;
    font-size:1.4rem;
  }
  .home_about .modal_box .modal_cont .p_list li:nth-child(4) {margin:0;}
  .home_about .modal_box .modal_cont .p_list li:nth-child(1) ,
  .home_about .modal_box .modal_cont .p_list li:nth-child(4) {transform:translateY(-40px);}
  .home_about .modal_box .modal_cont .pickup_caution {font-size:1.3rem;}
  .home_about .modal_box .modal_cont .pickup_caution span {
    height:auto;
    line-height:1.3;
    padding:0.3em 0.5em;
    margin:0 0 20px;
  }
  .home_about .modal_box .modal_cont .p_logo {padding:50px 0;}
  .home_about .modal_box .modal_cont .p_logo li {
    width:100px;
    margin:0 5px;
  }
  .home_about .modal_box .modal_cont .close {
    width:40px;
    height:40px;
    top:10px;
    bottom:auto;
    right:10px;
  }

  /** category **/

  .kv_course {
    height:220px;
    margin:0 0 40px;
  }
  .kv_course .box h1 {
    top:40%;
    left:20px;
  }
  .kv_course .box h1 span:nth-of-type(1) {font-size:2.4rem;}
  .kv_course .box h1 span:nth-of-type(2) {font-size:4.8rem;}
  .kv_course .box img {
    height:220px;
    right:-100px;
  }
  .category_box h2 span {font-size:1.8rem;}
  .tab_menu {margin:0 auto 20px;}
  .tab_menu li {
    width:24.25%;
    height:40px;
    line-height:40px;
    font-size:1rem;
    margin:0 1% 2% 0;
  }
  .tab_menu li:nth-child(5n) {margin:0 1% 2% 0;}
  .tab_menu li:nth-child(4n) {margin:0 0 2%;}
  .tab_content > li {
    width:49%;
    margin:0 2% 4% 0;
  }
  .tab_content > li:nth-child(3n) {margin:0 2% 4% 0;}
  .tab_content > li:nth-child(even) {margin:0 0 4%;}
  .tab_content > li:nth-child(odd) {clear:both;}
  .tab_content > li .modal_list::before {content:none;}
  .tab_content > li .modal_list > p {
    position:static;
    width:100%;
    transform:translateY(0);
    padding:0;
    color:#000000;
    font-size:1.3rem;
    line-height:1.5;
    text-align:left;
    opacity:1;
  }
  .tab_content > li .modal_list > img {margin:0 0 3px;}
  .tab_content li .modal_box {
    min-width:100%;
    max-width:100%;
    max-height:100%; 
  }
  .tab_content li .modal_box .modal_course {left:10px;}
  .tab_content li .modal_box .modal_course span:nth-of-type(1) {font-size:1.2rem;}
  .tab_content li .modal_box .modal_course span:nth-of-type(2) {font-size:2.3rem;}
  .tab_content li .modal_box .modal_course::before {
    width:100vw;
    height:50px;
    left:-20px;
  }
  .tab_content li .modal_box .modal_cont {padding:60px 20px;}
  .tab_content li .modal_box .modal_cont > img {width:100%;}
  .tab_content li .modal_box .modal_cont > p {
    width:100%;
    font-size:1.2rem;
  }
  .tab_content li .modal_box .modal_cont .p_num {width:100%;}
  .tab_content li .modal_box .modal_cont .p_num li {
    height:24px;
    line-height:26px;
    font-size:1.5rem;
  }
  .tab_content li .modal_box .modal_cont .p_title {font-size:1.8rem;}
  .tab_content li .modal_box .modal_cont .p_content {font-size:1.5rem;}
  .tab_content li .modal_box .modal_cont .p_detail {font-size:1.3rem;}
  .tab_content li .modal_box .modal_cont .p_logo {padding:30px 0 50px;}
  .tab_content li .modal_box .modal_cont .p_logo li {
    width:100px;
    margin:0 5px;
  }
  .tab_content li .modal_box .modal_cont .close {
    width:40px;
    height:40px;
    top:10px;
    bottom:auto;
    right:10px;
  }
  .tab_content li .modal_bg {display:none;}

  /** pickup **/

  .pickup .kv_pickup {padding:100px 0 50px;}
  .pickup .kv_pickup .box > span {
    font-size:1.5rem;
    margin:0 auto 20px;
  }
  .pickup .kv_pickup .box h1 {
    width:280px;
    height:110px;
    padding:20px 0 0;
    margin:0 auto 20px;
  }
  .pickup .kv_pickup .box h1::before,
  .pickup .kv_pickup .box h1::after {width:15px;}
  .pickup .kv_pickup .box h1 img {width:210px;}
  .pickup .kv_pickup .box ul {margin:0 auto 30px;}
  .pickup .kv_pickup .box ul li {
    width:120px;
    margin:0 10px;
   }
  .pickup .kv_pickup .box p {width:295px;}
  .pickup section .pickup_h2 {
    width:100%;
    height:47vw;
  }
  .pickup section .pickup_h2::after {
    width:100%;
    height:100%;
    right:0;
  }
  .pickup section .pickup_h2 .btn_ac {
    width:40px;
    height:40px;
    right:10px;
    bottom:10px;
  }
  .pickup section .pickup_h2 h2 {
    position:absolute;
    width:260px;
    height:110px;
    font-size:2.4rem;
    line-height:2;
    z-index:1;
    margin:auto;
    top:50%;
    left:0;
    right:0;
    transform:translateY(-50%);
  }
  .pickup section .pickup_h2 h2 span {font-size:1.8rem;}
  .pickup section:nth-of-type(1) .pickup_h2 h2 span ,
  .pickup section:nth-of-type(4) .pickup_h2 h2 span {line-height: 1.3;}
  
  
  .pickup section .pickup_h2 h2::before,
  .pickup section .pickup_h2 h2::after {width:15px;}
  .pickup section .ac_box {
    min-width:100%;
    max-width:100%;
    margin:0;
    padding:0 0 50px;
    border-radius:0;
  }
  .pickup section .ac_box .pickup_box {
    width:100%;
    margin:0;
    padding:50vw 0 0 0;
  }
  .pickup section .ac_box .pickup_box figure {
    width:50vw;
    height:50vw;
    margin:auto;
    top:30px;
    left:0;
    right:0;
  }
  .pickup section .ac_box .pickup_box dl {
    width:100%;
    padding:50px 20px 30px;
    border-radius:0;
  }
  .pickup section .ac_box .pickup_box dl dt {
    font-size:1.2rem;
    text-align:center;
  }
  .pickup section .ac_box .pickup_box dl dt > span {font-size:2rem;}
  .pickup section .ac_box .pickup_box dl dt > span span {font-size:1.4rem;}
  .pickup section .ac_box .pickup_box dl dd {font-size:1.4rem;}
  .pickup section section {
		display:flex;
		flex-direction:column;
    margin:0;
    padding:0;
  }
  .pickup section section div {
    width:100%;
    padding:20px 20px 50px;
    float:none;
    order:1;
  }
  .pickup section h3 {font-size:2rem;}
  .pickup section h3::after {width:100%;}
  .pickup section section div p {font-size:1.3rem;}
  .pickup section section figure {
    width:100%;
    float:none;
  }
  .pickup section section figure figcaption {
    font-size:1.2rem;
    padding:5px 20px 0 0;
  }
  .pickup section .center {
    font-size:1.4rem;
    margin:0 auto 20px;
  }
  .pickup section ol {margin:0 auto 50px;}
  .pickup section ol li {
    width:160px;
    margin:0 10px;
  }
  .pickup section .btn_course {
    width:300px;
    height:85px;
    padding:20px 0 0;
    border-radius:5px;
  }
  .pickup section .btn_course p {
    font-size:1.4rem;
    padding:0 40px 0 0;
    background:url("../img/pickup/course_ar.png") no-repeat right 10px center / 20px;
  }
  .pickup section .btn_course img {
    width:100px;
    transform:translateY(-40px);
  }
}

/* 2025/03 美味リクエスト便更新 */
@media screen and (max-width: 767px) {
  .home_course::after{
    height: 1040px;
    bottom: -30px;
  }
  .home .about_pickup{margin: 100px 0 0;}
}