/* @group ClearFix */
.clearfix:after {
  content:" ";
  display:block;
  clear:both;
}

html {
/* overflow-yプロパティは、ボックスの範囲内に内容が収まらない場合に、はみ出た要素の上下の表示方法を指定する際に使用 */
overflow-y: scroll;
/* iPhone や Android のブラウザーは、縦向き (Portrate mode) と横向き (Landscape mode) の文字サイズを自動調整する機能 */
-webkit-text-size-adjust: 100%;
font-size: 62.5%;
scroll-behavior: smooth;
}

body {
  margin: 0 auto;
  font-family:"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  font-size: 1.5rem;
  /* line-height: 1.8; */
  background-color: #F4F2EE;
  color: #001722;
  overflow: hidden;
}

h2 {
  font-size: 2.3rem;
  letter-spacing: 0.2rem;
  font-weight: bold;
}

h3 {
  font-size: 2.2rem;
  letter-spacing: 0.15rem;
}

h4 {
  font-size: 1.8rem;
  font-weight: bold;
  color: #0089A7;
}

h4 span {
  margin-right: 0.5rem;
  color: #F7C242;
}

.br-sp {
  display: inline-block;
}

.circle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 5rem;
  height: 5rem;
  background-color: #222127;
  color: #fff;
  border: 1px solid #222127;
  border-radius: 50%;
  cursor: pointer;
}

.icon_arrow::before {
  font-family: 'Font Awesome 5 free';
  font-weight: 900;
  font-size: 2.5rem;
  content: '\f062';
}

#scroll_btn:hover {
  background-color: #FFF489;
}

.circle:hover {
  color: #222127;
}

/* ヘッダ部ここから */

header {
  margin-top: 3rem;
  margin-bottom: 4rem;
}

.sub_header {
  margin-top: 0;
}

.head_area {
  width: 100%;
  background-color: #F7C242;
  padding: 2rem 0;
}

h1 {
  display: flex;
  justify-content: center;
}

.logo_tate {
  width: 48%;
  height: 100%;
  margin-bottom: 1rem;
}

.logo_yoko {
  width: 80%;
}

.top_img {
  width: 80%;
  display: flex;
  margin: auto;
  margin-top: 1rem;
}

.pcback_img {
  display: none;
}

/* ヘッダ部ここまで */

main {
  margin: 0 1.5rem;
  text-align: center;
}

.Btn {
  display: block;
  width: 100%;
  height: 4.6rem;
  padding: 1.5rem 0;
  border-radius: 15rem;
  box-shadow: 0px 6px 20px -10px rgba(0,0,0,0.6);
  background-color: #F7C242;
}

.Btn.black {
  background-color: #001722;
  color: #F4F2EE;
}

.Btn.black.order {
  margin-top: 5rem;
  margin-bottom: 1.5rem;
}

.Btn.gray {
  background-color: #A3A3A3;
  color: #001722;
}

.menu_first {
  margin-bottom: 5rem;
}

.menu_first ul {
  display: flex;
  justify-content: space-between;
  margin-top: 3rem;
}

.menu_first ul li {
  width: 15rem;
}

.menu_eki {
  margin-bottom: 8rem;
  margin-bottom: 5rem;
  font-size: 1.9rem;
  font-weight: bold;
  color: #401C20;
}

.menu_eki p {
  margin-bottom: 2rem;
  text-align: left;
}

.menu_eki ul {
  display: flex;
  justify-content: space-between;
}

.ekiBtn_img {
  width: 9.5rem;
}

.bento {
  margin-bottom: 10rem;
}

.uketori {
  margin-bottom: 2rem;
  text-align: left;
  color: #401C20;
}

.uketori h2 {
  margin-bottom: 1rem;
}

.uketori span {
  font-weight: normal;
}

.uketori p {
  width: 80%;
  margin-left: -2rem;
  border-bottom: solid 1rem #91D2E0;
  border-radius: 10rem;
}

.section_obento {
}

.section_obento img {
  width: 100%;
}

.obento_text {
  background-color: #fff;
  padding: 2rem 1.5rem;
}

.obento_text p {
  margin-top: 1.5rem;
  text-align: justify;
  line-height: normal;
}

.obento_text.B p {
  margin-top: 0;
  
}

.price {
  display: flex;
  justify-content: center;
  align-items: baseline;
  font-size: 2rem;
}

.price span {
  font-size: 1.5rem;
}

.order_push {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 4.6rem;
  margin-top: 1.2rem;
  background-color: #F7C242;
  font-size: 1.8rem;
  cursor: pointer;
}

.order_push span {
	/* background: #fff url("../images/down.png") no-repeat center right 8px/2rem 2rem; */
}

.plusBlack:before {
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f055';
  margin-left: 0.5rem;
}

.plusBlack01:before {
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f056';
  margin-left: 0.5rem;
}

.order_aco {
  padding: 2rem 1.5rem;
  background-color: #fff;
  display: none;
}

.order_Btn {
  margin-bottom: 3.3rem;
}

.order_text {
  margin-bottom: 1.4rem;
}

.order_aco ul {
  text-align: left;
}

.order_aco ul li {
  margin-bottom: 1.4rem;
}

.order_aco ul li span {
  color: #F7C242;
}

.order_aco ul li a {
  font-weight: bold;
  color: #0089A7;
}

.text_block {
  margin-top: 15rem;
}

.text_section {
  background-color: #fff;
  padding: 4rem 1.7rem 1rem;
}

.text_section ul {
  margin-top: 4rem;
  margin-bottom: 4rem;
  text-align: left;
  line-height: normal;
}

.text_section ul li {
  margin-bottom: 3rem;
}

.text_section ul li > .text_bold {
  margin-bottom: 1rem;
}

.toiawase_span {
  margin-right: 2rem;
}

/* 注文ページここから */

.order_block {
  margin-top: 5rem;
}

.order_block h2 {
  font-size: 2.0rem;
  margin-bottom: 2rem;
}

.form_area {
  background-color: #fff;
  padding: 3rem 1.5rem 1.8rem 1.5rem;
  margin-top: 2rem;
}

.form_area p {
  text-align: left;
  margin-bottom: 1rem;
}

.form_area.obento {
  margin-top: 0;
}

.order_select, .order_freetext {
  width: 100%;
  height: 4rem;
  padding: 0.4em 0.8em;
  background-color: #fff;
  border: 1px solid #0017225d;
  border-radius: 5px;
  text-align: left;
  cursor: pointer;
  margin-bottom: 2.5rem;
}

.order_select {
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	background: #fff url("../images/down.png") no-repeat center right 8px/2rem 2rem;
}

.order_radio {
  display: grid;
  text-align: left;
  line-height: normal;
}

.order_radio label {
  width: 100%;
  height: 4rem;
  display: flex;
  align-items: center;
  justify-content: left;
  padding: 0.4em 0.8em;
  background-color: #fff;
  border: 1px solid #0017225d;
  border-radius: 5px;
  cursor: pointer;
  margin-bottom: 2rem;
}

.order_radio span {
  margin-left: 1rem;
}

.order_radio ul {
  margin-bottom: 1rem;
}

.tag_hissu {
  font-size: 1.3rem;
  color: #CB0E0E;
  border: 0.1rem solid;
  border-radius: 0.6rem;
  padding: 0.3rem;
  margin-left: 0.5rem;
}

.modoru {
  margin-top: 5rem;
}

/* 確認ページここから */

.sumi_koumoku {
  background-color: #F4F2EE;
  padding: 2rem 0.8rem;
}

/* メール送信ページここから */

.text_sendmail {
  line-height: normal;
  margin-bottom: 2rem;
}

.text_sendmail p {
  margin-bottom: 1rem;
}

/* 共通部ここから */

.text_blue {
  color: #0089A7;
}

.text_red {
  margin-left: 0rem !important;
  color: #CB0E0E;
}

.text_blue.under {
  border-bottom: solid 1px #0089A7;
}

.text_bold {
  font-size: 1.8rem;
  font-weight: bold;
}

.link_border {
  border-bottom: 1px solid #001722;
}

.space {
  margin-top: 10rem;
}

/* フッタ部ここから */

footer {
  width: 100%;
  text-align: center;
  background-color: #F7C242;
  margin-top: 15rem;
  padding: 2rem 0;
}

.nav {
  margin-bottom: 5rem;
}

.nav li {
  margin-top: 3rem;
}

.copyright {
  margin-top: 2.5rem;
}

/* 画面サイズが340px以下のとき */
@media screen and (max-width: 340px){

}

/* 画面サイズが369px以下のとき */
@media screen and (max-width: 369px){

  .br-miniSP {
    display: inline-block;
  }
}

/* タブレット以上 */
@media print, screen and (min-width: 744px) {

  body {
    background-color: #c3e1e7;
    position: relative;
    width: 100vw;
    height: 100vh;
  }

  .wrapper {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    background-color: #F4F2EE;
    width: 40rem;
    height: 72rem;
    margin: auto;
    overflow: auto;
    border: 2rem solid #001722;
    border-radius: 2rem;
  }

  .br-miniSP {
    display: none;
  }

  .pcback_img {
    display: block;
  }

  .pcback_img.senro {
    width: 100vw;
    margin-top: calc(100vh/2);
  }

  .pcback_img.text {
    width: 16rem;
    position: absolute;
    top: calc(50% - 26rem);
    left: calc(50% - -21.5rem);
  }

  /* .br-sp {
    display: none;
  } */

}

/* ノートPC以上 */
@media print, screen and (min-width: 1080px) {

}

/* デスクトップPC想定 */
@media print, screen and (min-width: 1255px) {
  .br-sp {
    display: none;
  }
}
