@charset "UTF-8";

/* ==========================================================================
   Foundation
   ========================================================================== */

/* Variable
   ----------------------------------------------------------------- */

/* Media Query Break Point */

/* ============================================ */

/* Text Size */

/* ============================================ */

/* Mixin
   ----------------------------------------------------------------- */

/* Default
   ----------------------------------------------------------------- */

/* ==========================================================================
   Layout
   ========================================================================== */

.l-header--pc {
  display: block;
}

@media screen and (max-width: 767px) {
  .l-header--pc {
    display: none;
  }
}

.l-header--mobile {
  display: none;
}

@media screen and (max-width: 767px) {
  .l-header--mobile {
    display: block;
  }
}

/* ==========================================================================
   Object
   ========================================================================== */

/* Component
   ----------------------------------------------------------------- */

/* Project
   ----------------------------------------------------------------- */

.p-common-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 80px;
  background: #11100f;
}

.p-common-header * {
  -webkit-box-sizing: initial;
          box-sizing: initial;
}

.p-common-header *::before {
  -webkit-box-sizing: initial;
          box-sizing: initial;
}

.p-common-header *::after {
  -webkit-box-sizing: initial;
          box-sizing: initial;
}

.p-common-header *:focus-visible {
  outline: none;
}

.p-common-header *:focus {
  outline: none;
}

.p-common-header a {
  color: inherit;
  text-decoration: none;
}

/*
 * SP用ヘッダー このSCSSファイルはPC用なのでSP専用クラスは非表示にする。
*/

.p-common-header.sp {
  display: none;
}

/*
 * PC用ヘッダー
*/

.p-common-header.pc {
  width: 100%px;
}

.p-common-header.pc .p-common-header__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

/*
 * PC用ヘッダーの左ブロック。弁当手配.comロゴのあるブロック。
*/

.p-common-header.pc .p-common-header__left-block {
  width: 15%;
}

/*
 * PC用ヘッダーの弁当手配.comロゴ画像をラップしている。
*/

.p-common-header__logo {
  margin-top: 26px;
  margin-left: 10px;
}

/*
 * PC用ヘッダーの右ブロック。上下段をラップしているブロック。
*/

.p-common-header.pc .p-common-header__right-block {
  width: 80%;
  margin-left: 10px;
}

/*
 * PC用ヘッダーの新規会員登録〜お問い合わせまでの段
*/

.p-common-header.pc .p-common-header__right-block .p-common-header__first_row {
  padding-left: 88px;
  margin-top: 7px;
}

.p-common-header__header-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
  padding: 0 20px;
}

/**
 * 新規会員登録〜お問い合わせまでのリンクボタン群のul
*/

.p-common-header__right-block .p-common-header__header-menu ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  float: right;
  margin-bottom: 0;
  list-style: none;
}

/**
 * １段目のメニューアイテム。
*/

.p-common-header__first_row .p-common-header__item_list li {
  margin-right: 35px;
}

.p-common-header__first_row .p-common-header__item_list li span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 14px;
  color: #fff;
  white-space: nowrap;
}

.p-common-header__first_row .p-common-header__item_list li span > img {
  margin-right: 5.7px;
}

.p-common-header__first_row .p-common-header__item_list li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.p-common-header__first_row .p-common-header__item_list li.item-mypage {
  margin-left: 145px;
}

/**
 * ２段目のリクエスト商品・お気に入り・カートボタン。
*/

.p-common-header__second_row .bottom-menu li:not(:last-child) {
  margin-right: 8px;
}

/*
 * PC用ヘッダーのお弁当/ケータリングボタン・検索ボックス〜カートボタンまでの段
*/

.p-common-header.pc .p-common-header__right-block .p-common-header__second_row {
  margin-top: 12px;
}

/*
 * PC用ヘッダーの検索ボックス
*/

.p-common-header__search-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

/*
 * PC用ヘッダーの検索ボックスの入力欄部分
*/

.p-common-header__search-box input {
  width: 285px;
  padding: 0;
  padding-left: 15px;
  border: none;
  border-radius: 0;
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
}

/*
 * PC用ヘッダーの検索ボックスの検索アイコン画像部分
*/

.p-common-header__search-box img {
  background: #ffa700;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
}

.header-btn span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 130px;
  height: 16px;
  padding: 7px 0;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: -1.5px;
  background: #fee58e;
  border-radius: 15px;
}

.header-btn span img {
  width: 24px;
  height: 24px;
  margin-right: 2px;
}

.menu_sp {
  display: none;
}

.menu_sp .box {
  position: absolute;
  top: 0;
  z-index: 2;
  width: 100vh;
  height: 100vh;
  background: #11100f73;
}

.menu_sp .flex {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 304px;
  height: 100%;
  background: #fff;
}

.menu_sp .flex > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
}

.menu_sp .flex > ul {
  padding: 12px 21px;
}

.menu_sp .flex > ul li {
  list-style: none;
}

.menu_sp .flex > ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 16px 15px;
  border-bottom: 1px dashed #b7b6b6;
}

.menu_sp .flex > ul li a span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 16px;
}

.menu_sp .flex > ul li a span img {
  width: 24px;
  height: 24px;
  margin-right: 10px;
}

/*========== guide ========== */

.guide-title-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 24px;
}

.guide-title-header .span-container span {
  width: 314px;
  height: 2px;
  background: #11100f1a;
  display: inline-block;
}

.guide-title-header > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.guide-title-header > div > span {
  font-size: 26px;
  font-weight: bold;
}

.guide-title-header img {
  -ms-flex-item-align: center;
      align-self: center;
  margin-right: 13px;
}

.guide {
  padding: 24px 0px;
  background: #fee58e42;
}

.guide .slick-prev {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: -53px;
  height: auto;
  width: auto;
}

.guide .slick-prev:before {
  content: url("/images/arrow-left.svg");
}

.guide .slick-next {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -53px;
  height: auto;
  width: auto;
}

.guide .slick-next:before {
  content: url("/images/arrow-right.svg");
}

.guide .left img {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: -53px;
}

.guide .right img {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -53px;
}

.guide-header {
  height: 145px;
  background-image: url("/images/knowledge.jpg");
  display: block;
  background-size: contain;
}

.guide-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 24px;
  position: relative;
  height: 146px;
}

.guide-item {
  margin-right: 20px;
}

.guide-item img {
  width: 313px;
  height: 146px;
}

/*========== guide ========== */

/*========== pickup-area ========== */

.pickup-area {
  padding: 44px 0px;
}

.span-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-item-align: center;
      align-self: center;
}

.span-container > span:not(:first-child) {
  margin-top: 10px;
}

.pickup-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.pickup-header .span-container span {
  width: 309px;
  height: 2px;
  background: #11100f1a;
  display: inline-block;
}

.pickup-header > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.pickup-header > div > span {
  font-size: 26px;
  font-weight: bold;
}

.pickup-header img {
  -ms-flex-item-align: center;
      align-self: center;
  margin-right: 13px;
}

.pickup-subheader {
  text-align: center;
  margin-top: 8px;
  margin-bottom: 15px;
}

.pickup-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.pickup-item {
  width: 322px;
  background: #fee58e42;
}

.pickup-item-header {
  background: #11100F;
  height: 66px;
  padding: 7px 12px;
}

.pickup-item-header > span {
  font-size: 20px;
  font-weight: bold;
  color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: inherit;
  text-align: center;
}

.pickup-item-body {
  padding: 10px 20px;
}

.pickup-item-body > a span:nth-of-type(1) {
  font-size: 14px;
  margin-bottom: 18px;
  display: inline-block;
  min-height: 37px;
}

.pickup-item-body > a span:nth-of-type(2) {
  font-size: 18px;
  font-weight: bold;
  display: inline-block;
  margin-top: 10px;
  margin-bottom: 8px;
}

.price {
  font-size: 12px;
  font-weight: bold;
  margin-bottom: 16px;
}

.price > span {
  font-size: 14px;
  color: #DC000C;
}

.pickup-item-footer {
  padding: 0px 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.footer-item {
  -ms-flex-preferred-size: 40%;
      flex-basis: 40%;
}

.footer-item span {
  font-weight: bold;
  font-size: 14px;
}

/*========== pickup-area ========== */

/* Utility
   ----------------------------------------------------------------- */

