@font-face {
  font-family: 'Oswald Regular';
  src: url('/font/Oswald-Regular.ttf') format('truetype');
  font-style: normal;
}

@font-face {
  font-family: 'Oswald Bold';
  src: url('/font/Oswald-Bold.ttf') format('truetype');
  font-style: normal;
}

@-webkit-keyframes open {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes open {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.Main-btn {
  display: block;
  margin: 0 auto;
  background-color: #d30000;
  color: #fff;
  letter-spacing: 0.08em;
  line-height: 1;
  text-align: center;
  text-decoration: none;
}

.Main-btn._blank span {
  display: block;
  background: url('/img/icon_blank.png') 100% 50% no-repeat;
}

.Main-btn._search {
  position: relative;
}

.Main-btn._search span {
  display: block;
  background: url('/img/icon_search.svg') 0 50% no-repeat;
}

.Main-btn._search:after {
  position: absolute;
  top: 50%;
  content: '';
  display: block;
  background: url('/img/icon_search.svg') 0 50% no-repeat;
  transform: translateY(-50%);

  -webkit-transform: translateY(-50%);
}

.Main-btn._w {
  background-color: #fff;
  color: #d30000;
  font-weight: bold;
}

.Main-btn._w._blank span {
  background-image: url('/img/icon_link_blank.png');
}

.Main-btn._cancel {
  background-color: #aaa;
}

.Main-btn input[type=submit], .Main-btn input[type=button] {
  cursor: pointer;
  display: block;
  width: 100%;
  margin: 0 auto;
  background-color: #d30000;
  color: #fff;
  letter-spacing: 0.08em;
  line-height: 1;
  text-align: center;
  text-decoration: none;
}

@media screen and (max-width: 767px) {
  .Main-btn {
    border-radius: 3.2vw;
  }

  .Main-btn._s {
    padding: 2.13333vw 0;
    font-size: 2.4vw;
  }

  .Main-btn._m {
    padding: 2vw 0;
    font-size: 3.2vw;
  }

  .Main-btn._m input[type=submit], .Main-btn._m input[type=button] {
    font-size: 3.2vw;
  }

  .Main-btn._l {
    padding: 1.33333vw 0;
    font-size: 3.46667vw;
  }

  .Main-btn._search span {
    min-height: 3.33333vw;
    margin: 0 3.86667vw;
    background-size: 3.33333vw 3.33333vw;
    line-height: 3.33333vw;
  }

  .Main-btn._search:after {
    left: 3.86667vw;
    height: 3.33333vw;
    width: 3.33333vw;
    background-size: 3.33333vw 3.33333vw;
  }

  .Main-btn._blank span {
    margin: 0 3.86667vw;
    background-size: 1.86667vw 1.86667vw;
  }
}

@media print, screen and (min-width: 768px) {
  .Main-btn {
    opacity: 1;
    border-radius: 24px;
    transition: opacity 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
  }

  .Main-btn:hover {
    opacity: 0.7;
  }

  .Main-btn._s {
    padding: 11px 0;
    font-size: 12px;
  }

  .Main-btn._m {
    padding: 15px 0;
    font-size: 14px;
  }

  .Main-btn._m input[type=submit], .Main-btn._m input[type=button] {
    font-size: 14px;
  }

  .Main-btn._l {
    padding: 12px 0;
    font-size: 26px;
  }

  .Main-btn._search {
    padding: 12px 0 !important;
  }

  .Main-btn._search span {
    min-height: 20px;
    margin: 0 29px;
    background-size: 20px 20px;
    line-height: 20px;
  }

  .Main-btn._search:after {
    left: 29px;
    height: 20px;
    width: 20px;
    background-size: 20px 20px;
  }

  .Main-btn._blank span {
    margin: 0 29px;
    background-size: 14px 14px;
  }
}

@media screen and (max-width: 767px) {
  .Main-btnbox {
    padding: 0 5.33333vw 9.33333vw;
  }
}

@media print, screen and (min-width: 768px) {
  .Main-btn {
    width: 330px;
  }

  .Main-btnbox {
    padding-bottom: 70px;
  }

  .Main + .Pagetop + footer {
    background-color: #fff !important;
  }
}

.Make-tit {
  position: relative;
  border-bottom: 1px solid #ededed;
  font-weight: bold;
  text-align: center;
}

.Make-tit:after {
  position: absolute;
  left: 50%;
  content: '';
  display: block;
  background: url('/img/gurume/make_bg_tit_after.png') 0 0 no-repeat;
}

.Make-icon {
  position: relative;
  display: inline-block;
}

.Make-icon:after {
  position: absolute;
  left: 0;
  top: 50%;
  content: '';
  display: block;
}

.Make-icon.food:after {
  background: url('/img/gurume/make_ico_food.png') 0 0 no-repeat;
}

.Make-icon.cocktail:after {
  background: url('/img/gurume/make_ico_cocktail.png') 0 0 no-repeat;
}

.Make-contents {
  border-bottom: 1px solid #ededed;
}

.Make-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;

  -ms-flex-wrap: wrap;
}

.Make-item dl dt {
  border: 1px solid #ededed;
  font-family: 'Oswald Regular';
  font-weight: bold;
  text-align: center;
}

.Make-item dl dd {
  border-bottom: 1px solid #ededed;
  border-left: 1px solid #ededed;
  border-right: 1px solid #ededed;
}

@media screen and (max-width: 767px) {
  .Make {
    margin: 0 0 9.33333vw;
  }

  .Make-tit {
    position: relative;
    padding: 8vw 0 6vw;
    font-size: 4vw;
  }

  .Make-tit:after {
    bottom: -8px;
    height: 8px;
    width: 23px;
    margin-left: -12px;
    background-size: 23px 8px;
  }

  .Make-tit.is_open:before {
    position: absolute;
    right: 10.66667vw;
    top: 50%;
    content: '';
    display: block;
    height: 8px;
    width: 12px;
    margin-top: -4px;
    background: url('/img/arr_top.png') 0 0 no-repeat;
    background-size: 12px 8px;
  }

  .Make-tit.is_close:before {
    position: absolute;
    right: 10.66667vw;
    top: 50%;
    content: '';
    display: block;
    height: 8px;
    width: 12px;
    margin-top: -4px;
    background: url('/img/arr_bottom.png') 0 0 no-repeat;
    background-size: 12px 8px;
  }

  .Make-icon.food {
    padding-left: 7.46667vw;
  }

  .Make-icon.food:after {
    height: 18px;
    width: 19px;
    margin-top: -10px;
    background-size: 19px 18px;
  }

  .Make-icon.cocktail {
    padding-left: 5.73333vw;
  }

  .Make-icon.cocktail:after {
    height: 25px;
    width: 12px;
    margin-top: -15px;
    background-size: 12px 25px;
  }

  .Make-list {
    padding: 6.66667vw 4vw;
  }

  .Make-item {
    width: 50%;
    margin: 0 0 4vw;
    padding: 0 2vw;
  }

  .Make-item dl dt {
    padding: 0.66667vw 0;
    font-size: 3.73333vw;
  }

  .Make-item dl dd {
    padding: 4vw;
    font-size: 2.93333vw;
    line-height: 1.45;
  }
}

@media print, screen and (min-width: 768px) {
  .Make {
    width: 1240px;
    margin: 0 auto 70px;
  }

  .Make-tit {
    padding: 54px 0 44px;
    border-left: 1px solid #ededed;
    border-right: 1px solid #ededed;
    font-size: 24px;
  }

  .Make-tit:after {
    bottom: -16px;
    height: 16px;
    width: 46px;
    margin-left: -23px;
  }

  .Make-icon.food {
    padding-left: 52px;
  }

  .Make-icon.food:after {
    height: 37px;
    width: 39px;
    margin-top: -19px;
  }

  .Make-icon.cocktail {
    padding-left: 42px;
  }

  .Make-icon.cocktail:after {
    height: 49px;
    width: 24px;
    margin-top: -30px;
  }

  .Make-contents {
    display: block !important;
    padding: 19px 39px;
    border-left: 1px solid #ededed;
    border-right: 1px solid #ededed;
  }

  .Make-list {
    margin-left: -39px;
  }

  .Make-item {
    margin-bottom: 20px;
    margin-left: 39px;
    margin-top: 20px;
  }

  .Make-item dl {
    width: 360px;
  }

  .Make-item dl dt {
    padding: 5px 0;
    font-size: 20px;
  }

  .Make-item dl dd {
    padding: 30px;
    font-size: 14px;
    line-height: 1.71;
  }
}

.Recipe {
  background-color: #fbfbf9;
  border: 1px solid #ededed;
}

.Recipe-pic {
  border: 1px solid #ededed;
}

.Recipe-subtit {
  color: #d30000;
  font-weight: bold;
}

.Recipe-tit {
  border-bottom: 1px solid #ededed;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .Recipe {
    padding: 5.2vw;
  }

  .Recipe-pic {
    margin: 0 0 6.66667vw;
  }

  .Recipe-subtit {
    margin: 0 0 0.66667vw;
    font-size: 2.66667vw;
    line-height: 1.3;
  }

  .Recipe-subtit br {
    display: none;
  }

  .Recipe-tit {
    padding-bottom: 1.73333vw;
    font-size: 4vw;
  }

  .Recipe-txt {
    margin: 2vw 0 0;
    font-size: 2.93333vw;
  }
}

@media print, screen and (min-width: 768px) {
  .Recipe {
    max-width: 1240px;
    margin: 60px auto 0;
    padding: 39px;
  }

  .Recipe-pic {
    width: 525px;
    margin-right: 40px;
  }

  .Recipe-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }

  .Recipe-contents {
    flex: 1;

    -webkit-box-flex: 1;
    -ms-flex: 1;
  }

  .Recipe-subtit {
    margin: 0 0 3px;
    font-size: 13px;
    line-height: 1.77;
  }

  .Recipe-tit {
    padding-bottom: 13px;
    font-size: 20px;
  }

  .Recipe-txt {
    margin: 14px 0 0;
    font-size: 14px;
    line-height: 1.71;
  }
}

.Material {
  border: 1px solid #ededed;
}

.Material-tit {
  font-weight: bold;
}

.Material-item {
  border-bottom: 1px solid #e6e6e6;
}

.Material-item dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.Material-item dd {
  flex: 1;

  -webkit-box-flex: 1;
  -ms-flex: 1;
}

@media screen and (max-width: 767px) {
  .Material {
    margin-top: 6.66667vw;
    padding: 5.2vw;
  }

  .Material-tit {
    position: relative;
    font-size: 3.2vw;
  }

  .Material-tit.is_open:before {
    position: absolute;
    right: 0;
    top: 50%;
    content: '';
    display: block;
    height: 8px;
    width: 12px;
    margin-top: -4px;
    background: url('/img/arr_top.png') 0 0 no-repeat;
    background-size: 12px 8px;
  }

  .Material-tit.is_close:after {
    position: absolute;
    right: 0;
    top: 50%;
    content: '';
    display: block;
    height: 8px;
    width: 12px;
    margin-top: -4px;
    background: url('/img/arr_bottom.png') 0 0 no-repeat;
    background-size: 12px 8px;
  }

  .Material-subtit {
    margin: 0 0 1.33333vw;
    font-size: 2.93333vw;
  }

  .Material-list {
    margin: 2vw 0 0;
    font-size: 2.93333vw;
  }

  .Material-list.col4 .Material-item dl dt {
    width: 34.66667vw;
  }

  .Material-item dl {
    padding: 2.66667vw 0;
  }

  .Material-item dl dt {
    width: 29.33333vw;
  }
}

@media print, screen and (min-width: 768px) {
  .Material {
    margin-top: 30px;
    padding: 39px;
  }

  .Material-tit {
    margin: 0 0 5px;
    font-size: 18px;
  }

  .Material-subtit {
    margin: 0 0 5px;
    font-size: 14px;
  }

  .Material-contents {
    display: block !important;
  }

  .Material-list {
    font-size: 14px;
  }

  .Material-list.col4 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-left: -20px;
    flex-wrap: wrap;

    -ms-flex-wrap: wrap;
  }

  .Material-list.col4 .Material-item {
    margin-left: 20px;
  }

  .Material-list.col4 .Material-item dl {
    width: 255px;
  }

  .Material-list.col4 .Material-item dl dt {
    width: 165px;
  }

  .Material-item dl {
    padding: 15px 0;
  }

  .Material-item dl dt {
    width: 148px;
  }
}
