@charset "UTF-8";
/*

	viewport settings

**************************************************/
/*

	font setting

**************************************************/
/*

	clearfix settings

**************************************************/
/*

	boxsizing settings

**************************************************/
/*

	opacity settings

**************************************************/
/*

	border-radius settings

**************************************************/
/*

	drop shadow settings

**************************************************/
/*

	vertical align setting

**************************************************/
/*

	flexbox layout setting

**************************************************/
/*

	hover transition

**************************************************/
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after {
  content: '';
  content: none;
}

q:before, q:after {
  content: '';
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

input, button, textarea, select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
}

html {
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.875;
  background: #F9FAF5;
  -webkit-font-smoothing: auto;
}

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}

[dir="rtl"] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* Slider */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat;
}

/* Icons */
@font-face {
  font-family: "slick";
  src: url("./fonts/slick.eot");
  src: url("./fonts/slick.eot?#iefix") format("embedded-opentype"), url("./fonts/slick.woff") format("woff"), url("./fonts/slick.ttf") format("truetype"), url("./fonts/slick.svg#slick") format("svg");
  font-weight: normal;
  font-style: normal;
}

/* Arrows */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}

.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  background: transparent;
  color: transparent;
}

.slick-prev:hover:before, .slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
  opacity: 1;
}

.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0.25;
}

.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  color: white;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}

[dir="rtl"] .slick-prev {
  left: auto;
  right: -25px;
}

.slick-prev:before {
  content: "←";
}

[dir="rtl"] .slick-prev:before {
  content: "→";
}

.slick-next {
  right: -25px;
}

[dir="rtl"] .slick-next {
  left: -25px;
  right: auto;
}

.slick-next:before {
  content: "→";
}

[dir="rtl"] .slick-next:before {
  content: "←";
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 20px;
  width: 20px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}

.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}

.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
}

.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: "slick";
  font-size: 6px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
  color: black;
  opacity: 0.75;
}

@media screen and (max-width: 600px) {
  body.new-style {
    padding-top: 17.44186vw;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  body.new-style {
    padding-top: 8.33333vw;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  body.new-style {
    padding-top: 7.32422vw;
  }
}

.s-header {
  background: #fff;
  padding: 1.6rem 3.6rem;
  position: relative;
}

.s-header-inner {
  display: flex;
  align-items: center;
}

.s-header-logo {
  width: 6.6rem;
}

.s-header-logo img {
  width: 100%;
  height: auto;
}

.s-header-menus {
  margin-left: auto;
  display: flex;
  align-items: center;
}

.s-header-search {
  display: none;
  position: absolute;
  width: 40rem;
  background: #255470;
  padding: 1.2rem 1.4rem;
  top: 100%;
  right: 0;
}

.s-header-form {
  display: flex;
  width: 100%;
  background: #fff;
}

.s-header-input {
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  display: block;
  font-size: 1.6rem;
  padding: 0 1.2rem;
  height: 4.8rem;
  box-sizing: border-box;
  width: calc( 100% - 4.8rem);
}

.s-header-submit {
  margin-left: auto;
  cursor: pointer;
  outline: none;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  padding: 0;
}

.s-header-submit img {
  width: 4.8rem;
  height: 4.8rem;
  vertical-align: top;
}

@media screen and (max-width: 600px) {
  .s-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 10000;
    padding: 0 2.7907vw;
    box-sizing: border-box;
  }
  .s-header-inner {
    height: 16.27907vw;
  }
  .s-header-logo {
    flex: 1 1;
    text-align: center;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
  }
  .s-header-logo img {
    width: 11.39535vw;
  }
  .s-header-search {
    position: fixed;
    width: 100%;
    padding: 2.7907vw 3.25581vw;
    top: 17.44186vw;
    left: 0;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-header {
    padding: 0 1.33333vw;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 10000;
  }
  .s-header-inner {
    height: 7.77778vw;
  }
  .s-header-logo {
    flex: 1 1;
    text-align: center;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
  }
  .s-header-logo img {
    width: 5.44444vw;
  }
  .s-header-search {
    position: fixed;
    padding: 1.33333vw 1.55556vw;
    top: 8.33333vw;
    width: 100%;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 10000;
    padding: 0 1.17188vw;
  }
  .s-header-inner {
    height: 7.32422vw;
  }
  .s-header-logo {
    flex: 1 1;
    text-align: center;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
  }
  .s-header-logo img {
    width: 4.78516vw;
  }
  .s-header-search {
    position: fixed;
    padding: 1.17188vw 1.36719vw;
    top: 7.32422vw;
    width: 100%;
  }
}

.s-menus {
  display: flex;
  align-items: center;
  gap: 2.4rem;
}

.s-menus > li {
  position: relative;
  display: block;
  color: #1D1616;
  font-size: 1.4rem;
  text-decoration: none;
  font-weight: 500;
  transition: all, .3s;
  cursor: pointer;
}

.s-menus > li:hover .s-menus-sub {
  opacity: 1;
  visibility: visible;
}

.s-menus > li a {
  display: block;
  color: #1D1616;
  font-size: 1.4rem;
  text-decoration: none;
  font-weight: 500;
  transition: opacity 0.3s ease-in-out;
}

.s-menus > li a:hover {
  opacity: .5;
}

.s-menus-sub {
  visibility: hidden;
  z-index: 10;
  position: absolute;
  top: 100%;
  left: -50%;
  padding: 2.4rem 0 0;
  width: 20rem;
  opacity: 0;
  transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
}

.s-menus-sub li {
  background: #D8F1F6;
  font-size: 1.6rem;
}

.s-menus-sub li a {
  display: block;
  padding: .8rem 1.2rem;
}

.s-menus-sub li a:hover {
  background: #3D92C3;
  color: #fff;
}

.s-menus-sub li + li {
  border-top: 1px dotted #ccc;
}

.s-menus-trigger {
  display: none;
}

@media screen and (max-width: 600px) {
  .s-menus {
    display: none;
  }
  .s-menus-trigger {
    display: block;
    width: 11.16279vw;
    height: 11.16279vw;
  }
  .s-menus-trigger a {
    display: flex;
    flex-direction: column;
    width: 11.16279vw;
    height: 11.16279vw;
    padding: 0 2.7907vw;
    box-sizing: border-box;
    justify-content: center;
    position: relative;
  }
  .s-menus-trigger a span {
    display: block;
    background: #1D1616;
    height: 0.69767vw;
  }
  .s-menus-trigger a span + span {
    margin-top: 1.39535vw;
  }
  .s-menus-trigger a.active span {
    position: relative;
  }
  .s-menus-trigger a.active span:nth-of-type(1) {
    top: 2.32558vw;
    transform: rotate(45deg);
  }
  .s-menus-trigger a.active span:nth-of-type(2) {
    visibility: hidden;
  }
  .s-menus-trigger a.active span:nth-of-type(3) {
    bottom: 1.86047vw;
    transform: rotate(-45deg);
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-menus {
    display: none;
  }
  .s-menus-trigger {
    display: block;
    width: 5.33333vw;
    height: 5.33333vw;
  }
  .s-menus-trigger a {
    display: flex;
    flex-direction: column;
    width: 5.33333vw;
    height: 5.33333vw;
    padding: 0 1.33333vw;
    box-sizing: border-box;
    justify-content: center;
  }
  .s-menus-trigger a span {
    display: block;
    background: #1D1616;
    height: 0.33333vw;
  }
  .s-menus-trigger a span + span {
    margin-top: 0.66667vw;
  }
  .s-menus-trigger a.active span {
    position: relative;
  }
  .s-menus-trigger a.active span:nth-of-type(1) {
    top: 1.11111vw;
    transform: rotate(45deg);
  }
  .s-menus-trigger a.active span:nth-of-type(2) {
    visibility: hidden;
  }
  .s-menus-trigger a.active span:nth-of-type(3) {
    bottom: 0.88889vw;
    transform: rotate(-45deg);
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-menus {
    display: none;
  }
  .s-menus-trigger {
    display: block;
    width: 4.6875vw;
    height: 4.6875vw;
  }
  .s-menus-trigger a {
    display: flex;
    flex-direction: column;
    width: 4.6875vw;
    height: 4.6875vw;
    padding: 0 1.17188vw;
    box-sizing: border-box;
    justify-content: center;
  }
  .s-menus-trigger a span {
    display: block;
    background: #1D1616;
    height: 0.29297vw;
  }
  .s-menus-trigger a span + span {
    margin-top: 0.58594vw;
  }
  .s-menus-trigger a.active span {
    position: relative;
  }
  .s-menus-trigger a.active span:nth-of-type(1) {
    top: 0.97656vw;
    transform: rotate(45deg);
  }
  .s-menus-trigger a.active span:nth-of-type(2) {
    visibility: hidden;
  }
  .s-menus-trigger a.active span:nth-of-type(3) {
    bottom: 0.78125vw;
    transform: rotate(-45deg);
  }
}

.s-icons {
  margin-left: 2.4rem;
  display: flex;
  align-items: center;
  position: relative;
}

.s-icons-item a {
  display: block;
}

.s-icons-item a img {
  vertical-align: bottom;
}

.s-icons.not-pc {
  display: none;
}

@media screen and (max-width: 600px) {
  .s-icons {
    margin-left: 0;
  }
  .s-icons.not-pc {
    display: block;
  }
  .s-icons-item a {
    display: block;
  }
  .s-icons-item a img {
    width: 11.16279vw;
    height: 11.16279vw;
    -o-object-fit: cover;
    object-fit: cover;
    vertical-align: bottom;
  }
  .s-icons-beginner {
    display: none;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-icons.not-pc {
    display: block;
  }
  .s-icons-item a {
    display: block;
  }
  .s-icons-item a img {
    width: 5.33333vw;
    height: 5.33333vw;
    -o-object-fit: cover;
    object-fit: cover;
    vertical-align: bottom;
  }
  .s-icons-beginner {
    display: none;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-icons-item a {
    display: block;
  }
  .s-icons-item a img {
    width: 4.6875vw;
    height: 4.6875vw;
    -o-object-fit: cover;
    object-fit: cover;
    vertical-align: bottom;
  }
  .s-icons-beginner {
    display: none;
  }
}

.s-alert {
  background: #3D92C3;
  padding: .8rem 0;
}

.s-alert-inner {
  display: flex;
  justify-content: center;
}

.s-alert-inner p {
  line-height: 1;
  text-align: center;
}

.s-alert-inner p a {
  color: #FFF;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
  text-decoration: none;
  position: relative;
  padding-left: 2.8rem;
  transition: opacity 0.3s ease-in-out;
}

.s-alert-inner p a:hover {
  opacity: .5;
}

.s-alert-inner p a:before {
  width: 1.6rem;
  height: 1.6rem;
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: .2rem;
  transform: translateY(-50%);
  background: url(../images/new/ico-caution.svg);
  background-size: 1.6rem 1.6rem;
  content: "";
}

@media screen and (max-width: 600px) {
  .s-alert {
    background: #D8F1F6;
    padding: 1.86047vw 2.7907vw;
  }
  .s-alert-inner {
    background: #3D92C3;
    padding: 1.86047vw 2.7907vw;
    border-radius: 0.93023vw;
  }
  .s-alert-inner p a {
    font-size: 3.72093vw;
    padding-left: 8.37209vw;
    display: block;
  }
  .s-alert-inner p a:before {
    position: absolute;
    width: 3.72093vw;
    height: 3.72093vw;
    background-size: 3.72093vw 3.72093vw;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-alert {
    padding: 0.88889vw 1.33333vw;
  }
  .s-alert-inner {
    padding: 0.88889vw 1.33333vw;
    border-radius: 0.44444vw;
  }
  .s-alert-inner p a {
    font-size: 1.77778vw;
    padding-left: 3.11111vw;
  }
  .s-alert-inner p a:before {
    width: 1.77778vw;
    height: 1.77778vw;
    background-size: 1.77778vw 1.77778vw;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-alert {
    padding: 0.78125vw 1.17188vw;
  }
  .s-alert-inner {
    padding: 0.78125vw 1.17188vw;
    border-radius: 0.39062vw;
  }
  .s-alert-inner p a {
    font-size: 1.5625vw;
    padding-left: 2.73438vw;
  }
  .s-alert-inner p a:before {
    width: 1.5625vw;
    height: 1.5625vw;
    background-size: 1.5625vw 1.5625vw;
  }
}

@media screen and (min-width: 1025px) {
  .s-alert-inner p a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-alert-inner p a:hover {
    opacity: .5;
  }
}

.s-slder {
  padding: 2.4rem 0 0;
  position: relative;
  background: #fff;
}

.s-slder-item {
  margin: 0 2rem;
}

.s-slder-item a img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

.s-slder-dots {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
}

.s-slder-dots li {
  width: .8rem;
  height: .8rem;
  border-radius: 50%;
  background: #ccc;
  text-indent: -9999px;
}

.s-slder-dots li.slick-active {
  background: #3D92C3;
}

.s-slder-dots li + li {
  margin-left: .8rem;
}

@media screen and (max-width: 600px) {
  .s-slder {
    padding: 5.5814vw 0 0;
  }
  .s-slder-item {
    margin: 0 0.93023vw;
  }
  .s-slder-dots {
    margin-top: 2.7907vw;
    display: flex;
    justify-content: center;
  }
  .s-slder-dots li {
    width: 1.86047vw;
    height: 1.86047vw;
  }
  .s-slder-dots li + li {
    margin-left: 1.86047vw;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-slder {
    padding: 2.66667vw 0 0;
  }
  .s-slder-item {
    margin: 0 0.44444vw;
  }
  .s-slder-dots {
    margin-top: 1.33333vw;
  }
  .s-slder-dots li {
    width: 0.88889vw;
    height: 0.88889vw;
  }
  .s-slder-dots li + li {
    margin-left: 0.88889vw;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-slder {
    padding: 2.34375vw 0 0;
  }
  .s-slder-item {
    margin: 0 0.39062vw;
  }
  .s-slder-dots {
    margin-top: 1.17188vw;
  }
  .s-slder-dots li {
    width: 0.78125vw;
    height: 0.78125vw;
  }
  .s-slder-dots li + li {
    margin-left: 0.78125vw;
  }
}

@media screen and (min-width: 1025px) {
  .s-slder-item a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-slder-item a:hover {
    opacity: .75;
  }
}

.s-recommend {
  background: #F9FAF5;
  padding: 6rem 0;
}

.s-recommend-inner, .s-search-inner, .s-ranking-inner, .s-recipe-container, .s-recipe-footer, .s-about-head, .s-about-menu, .s-instagram-gallery, .s-banners-inner, .s-guide-inner, .s-contact-container, .s-footer-inner {
  max-width: 120rem;
  margin: 0 auto;
}

.s-recommend-ttle, .s-search-ttle, .s-ranking-ttle, .s-recipe-ttle, .s-about-ttle, .s-instagram-ttle {
  font-family: "Noto Serif JP", serif;
  font-size: 2.4rem;
  font-weight: 600;
  margin-bottom: 1.6rem;
}

.s-recommend-lead {
  margin-bottom: 1.6rem;
  font-size: 1.8rem;
}

.s-recommend-body {
  position: relative;
  padding: 2.4rem 0;
  background: #fff;
  border-radius: .4rem;
}

.s-recommend-lists {
  display: flex;
}

.s-recommend-lists .slick-arrow {
  width: 6rem;
  height: 6rem;
  text-indent: -9999px;
  position: absolute;
  z-index: 1000;
}

.s-recommend-lists .slick-prev {
  top: 50%;
  margin-top: -3rem;
  left: -4rem;
  background: url(../images/new/ico-recommend-arrow-next.svg) no-repeat 0 0;
  background-size: 6rem 6rem;
}

.s-recommend-lists .slick-next {
  top: 50%;
  margin-top: -3rem;
  right: -4rem;
  background: url(../images/new/ico-recommend-arrow-prev.svg) no-repeat 0 0;
  background-size: 6rem 6rem;
}

.s-recommend-controller {
  margin-top: 1.6rem;
}

.s-recommend-dots {
  display: flex;
  justify-content: center;
}

.s-recommend-dots li {
  text-indent: -9999px;
  background: #A0A0A0;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
}

.s-recommend-dots li.slick-active {
  background: #8F995F;
}

.s-recommend-dots li + li {
  margin-left: .8rem;
}

.s-recommend-item {
  margin: 0 1.2rem;
  width: 26rem;
}

.s-recommend-link {
  display: block;
  color: #1D1616;
  text-decoration: none;
  transition: opacity 0.3s ease-in-out;
}

.s-recommend-link:hover {
  text-decoration: none;
  opacity: .75;
}

.s-recommend-figure {
  position: relative;
}

.s-recommend-figure img {
  width: 100%;
  border-radius: .4rem;
  vertical-align: bottom;
}

.s-recommend-badge {
  position: absolute;
  top: 0;
  left: .1rem;
  padding: .4rem;
  background: #C39B3D;
  color: #fff;
  font-size: 1.2rem;
}

.s-recommend-badge span + span {
  margin-left: .8rem;
}

.s-recommend-content {
  margin-top: 1.2rem;
  padding: 0 1.2rem;
}

.s-recommend-name {
  font-weight: 500;
  line-height: 160%;
  font-size: 1.6rem;
  margin-bottom: .8rem;
}

.s-recommend-price {
  text-align: right;
  color: #B71B2C;
  font-size: 14px;
  margin-bottom: 1.8rem;
}

.s-recommend-price span {
  font-size: 18px;
  font-weight: 500;
}

.s-recommend-button {
  background: #B71B2C;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  padding: 1.6rem 0;
  line-height: 1;
  display: block;
  text-align: center;
  border-radius: .4rem;
}

@media screen and (max-width: 600px) {
  .s-recommend {
    background: #F9FAF5;
    padding: 11.16279vw 0 0;
  }
  .s-recommend-head {
    padding: 0 5.5814vw;
  }
  .s-recommend-ttle, .s-search-ttle, .s-ranking-ttle, .s-recipe-ttle, .s-about-ttle, .s-instagram-ttle {
    font-size: 4.65116vw;
    margin-bottom: 1.86047vw;
  }
  .s-recommend-lead {
    font-size: 3.72093vw;
    line-height: 1.5;
    margin-bottom: 1.86047vw;
  }
  .s-recommend-body {
    padding: 5.5814vw 0 5.5814vw 5.5814vw;
    background: #fff;
    border-radius: 0;
  }
  .s-recommend-lists {
    display: flex;
  }
  .s-recommend-item {
    flex: none;
    width: 43.02326vw;
    margin: 0;
  }
  .s-recommend-item + .s-recommend-item {
    margin-left: 2.7907vw;
  }
  .s-recommend-controller {
    margin: 3.72093vw 0 8.37209vw;
    padding-left: 5.5814vw;
  }
  .s-recommend-dots {
    display: flex;
    justify-content: flex-start;
  }
  .s-recommend-dots li {
    text-indent: -9999px;
    background: #A0A0A0;
    width: 2.32558vw;
    height: 2.32558vw;
    border-radius: 50%;
  }
  .s-recommend-dots li.slick-active {
    background: #8F995F;
  }
  .s-recommend-dots li + li {
    margin-left: .8rem;
  }
  .s-recommend-figure img {
    border-radius: 0.93023vw;
  }
  .s-recommend-badge {
    left: 2.32558vw;
    padding: 0.93023vw;
    background: #C39B3D;
    font-size: 3.25581vw;
  }
  .s-recommend-badge span {
    display: block;
  }
  .s-recommend-badge span + span {
    margin-left: 0;
  }
  .s-recommend-content {
    margin-top: 2.7907vw;
    padding: 0;
  }
  .s-recommend-name {
    font-size: 4.18605vw;
    margin-bottom: 0.93023vw;
  }
  .s-recommend-price {
    font-size: 3.72093vw;
    margin-bottom: 4.18605vw;
  }
  .s-recommend-price span {
    font-size: 4.65116vw;
  }
  .s-recommend-button {
    font-size: 3.72093vw;
    padding: 2.7907vw 0;
    border-radius: 0.93023vw;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-recommend {
    background: #F9FAF5;
    padding: 5.33333vw 0 0;
  }
  .s-recommend-head {
    padding: 0 2.66667vw;
  }
  .s-recommend-ttle, .s-search-ttle, .s-ranking-ttle, .s-recipe-ttle, .s-about-ttle, .s-instagram-ttle {
    font-size: 2.22222vw;
    margin-bottom: 0.88889vw;
  }
  .s-recommend-lead {
    font-size: 1.77778vw;
    line-height: 1.5;
    margin-bottom: 0.88889vw;
  }
  .s-recommend-body {
    padding: 2.66667vw 0 2.66667vw 2.66667vw;
    background: #fff;
    border-radius: 0;
    overflow: hidden;
  }
  .s-recommend-lists {
    overflow: scroll;
    display: flex;
    gap: 1.33333vw;
  }
  .s-recommend-item + .s-recommend-item {
    margin-left: 1.33333vw;
  }
  .s-recommend-controller {
    margin: 1.77778vw 0 4vw;
    padding-left: 2.66667vw;
  }
  .s-recommend-dots {
    display: flex;
    justify-content: flex-start;
  }
  .s-recommend-dots li {
    text-indent: -9999px;
    background: #A0A0A0;
    width: 1.11111vw;
    height: 1.11111vw;
    border-radius: 50%;
  }
  .s-recommend-dots li.slick-active {
    background: #8F995F;
  }
  .s-recommend-dots li + li {
    margin-left: .8rem;
  }
  .s-recommend-item {
    flex: none;
    width: 27.22222vw;
  }
  .s-recommend-figure img {
    border-radius: 0.44444vw;
  }
  .s-recommend-badge {
    left: 1.11111vw;
    padding: 0.44444vw;
    background: #C39B3D;
    font-size: 1.55556vw;
  }
  .s-recommend-content {
    margin-top: 1.33333vw;
    padding: 0;
  }
  .s-recommend-name {
    font-size: 2vw;
    margin-bottom: 0.44444vw;
  }
  .s-recommend-price {
    font-size: 1.77778vw;
    margin-bottom: 2vw;
  }
  .s-recommend-price span {
    font-size: 2.22222vw;
  }
  .s-recommend-button {
    font-size: 1.77778vw;
    padding: 1.77778vw 0;
    border-radius: 0.44444vw;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-recommend {
    background: #F9FAF5;
    padding: 4.6875vw 0 0;
  }
  .s-recommend-head {
    padding: 0 2.34375vw;
  }
  .s-recommend-ttle, .s-search-ttle, .s-ranking-ttle, .s-recipe-ttle, .s-about-ttle, .s-instagram-ttle {
    font-size: 1.75781vw;
    margin-bottom: 0.78125vw;
  }
  .s-recommend-lead {
    font-size: 1.5625vw;
    line-height: 1.5;
    margin-bottom: 0.78125vw;
  }
  .s-recommend-body {
    padding: 2.34375vw 0 2.34375vw 2.34375vw;
    background: #fff;
    border-radius: 0;
    overflow: hidden;
  }
  .s-recommend-lists {
    overflow: scroll;
    display: flex;
    gap: 1.17188vw;
  }
  .s-recommend-item {
    flex: none;
    width: 23.92578vw;
  }
  .s-recommend-figure img {
    border-radius: 0.39062vw;
  }
  .s-recommend-badge {
    left: 0.97656vw;
    padding: 0.39062vw;
    background: #C39B3D;
    font-size: 1.17188vw;
  }
  .s-recommend-content {
    margin-top: 1.17188vw;
    padding: 0;
  }
  .s-recommend-name {
    font-size: 1.5625vw;
    margin-bottom: 0.39062vw;
  }
  .s-recommend-price {
    font-size: 1.36719vw;
    margin-bottom: 1.75781vw;
  }
  .s-recommend-price span {
    font-size: 1.75781vw;
  }
  .s-recommend-button {
    font-size: 1.5625vw;
    padding: 1.5625vw 0;
    border-radius: 0.39062vw;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1200px) {
  .s-recommend-head {
    padding-left: 2.4rem;
  }
}

@media screen and (min-width: 1025px) {
  .s-recommend-link {
    transition: opacity 0.3s ease-in-out;
  }
  .s-recommend-link:hover {
    opacity: .75;
  }
}

.s-search {
  padding: 6rem 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.s-search-lists {
  display: flex;
  justify-content: space-between;
}

.s-search-item {
  width: 16%;
}

.s-search-item a {
  display: block;
  color: #1D1616;
  text-decoration: none;
  text-align: center;
}

.s-search-item a img {
  vertical-align: bottom;
  width: 100%;
  height: auto;
}

.s-search-item a p {
  text-align: center;
  margin-top: 1.2rem;
  font-family: "Noto Serif JP", serif;
  font-size: 1.6rem;
  font-weight: 600;
}

@media screen and (max-width: 600px) {
  .s-search {
    background: #D8F1F6;
    padding: 11.16279vw 0 0;
  }
  .s-search-head {
    padding: 0 5.5814vw;
  }
  .s-search-body {
    background: #fff;
    padding: 5.5814vw;
  }
  .s-search-lists {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 5.5814vw;
  }
  .s-search-item {
    flex-basis: 46.5%;
    width: 46.5%;
  }
  .s-search-item:nth-child(even) {
    margin-left: auto;
  }
  .s-search-item a img {
    width: 80%;
  }
  .s-search-item a p {
    margin-top: 2.7907vw;
    font-size: 3.72093vw;
    line-height: 1.2;
  }
  .s-search-item a p span {
    white-space: nowrap;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-search {
    background: #D8F1F6;
    padding: 5.33333vw 0 0;
  }
  .s-search-head {
    padding: 0 2.66667vw;
  }
  .s-search-body {
    background: #fff;
    padding: 2.66667vw;
  }
  .s-search-lists {
    flex-wrap: wrap;
    gap: 1.33333vw;
  }
  .s-search-item {
    flex: 1 1;
  }
  .s-search-item:nth-child(even) {
    margin-left: 0;
  }
  .s-search-item a img {
    width: 80%;
  }
  .s-search-item a p {
    margin-top: 1.33333vw;
    font-size: 1.55556vw;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-search {
    background: #D8F1F6;
    padding: 4.6875vw 0 0;
  }
  .s-search-head {
    padding: 0 2.34375vw;
  }
  .s-search-body {
    background: #fff;
    padding: 2.34375vw;
  }
  .s-search-lists {
    flex-wrap: wrap;
    gap: 1.17188vw;
  }
  .s-search-item {
    flex: 1 1;
  }
  .s-search-item:nth-child(even) {
    margin-left: 0;
  }
  .s-search-item a img {
    width: 80%;
  }
  .s-search-item a p {
    margin-top: 1.17188vw;
    font-size: 1.36719vw;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1200px) {
  .s-search-head {
    padding-left: 2.4rem;
  }
  .s-search-lists {
    padding: 0 2.4rem;
  }
}

@media screen and (min-width: 1025px) {
  .s-search-item a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-search-item a:hover {
    opacity: .75;
  }
}

.s-ranking {
  padding: 6rem;
  box-sizing: border-box;
}

.s-ranking-body {
  display: flex;
  align-items: stretch;
  gap: 2.4rem;
}

.s-ranking-primary {
  width: 50rem;
  background: #fff;
}

.s-ranking-primary-item a {
  color: #1D1616;
  text-decoration: none;
  display: block;
  position: relative;
  transition: opacity 0.3s ease-in-out;
}

.s-ranking-primary-item a:hover {
  opacity: .75;
}

.s-ranking-primary-image {
  position: relative;
}

.s-ranking-primary-image img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
  vertical-align: bottom;
}

.s-ranking-primary-badge {
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 5.3rem;
  height: 5.3rem;
  background: #CCAA00;
}

.s-ranking-primary-badge img {
  width: 2rem;
  height: auto;
  vertical-align: bottom;
}

.s-ranking-primary-badge p {
  font-family: "Hepta Slab", serif;
  font-weight: 600;
  margin-top: .4rem;
  color: #fff;
  font-size: 1.6rem;
  text-align: center;
  line-height: 1;
}

.s-ranking-primary-content {
  height: calc( 100% - 36.5rem);
  padding: 0 2.4rem;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}

.s-ranking-primary-name {
  margin-top: 2.4rem;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: 1.8rem;
}

.s-ranking-primary-excerpt {
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  min-height: 11rem;
}

.s-ranking-primary-excerpt p {
  font-size: 1.8rem;
  line-height: 1.5;
}

.s-ranking-primary-price {
  text-align: right;
}

.s-ranking-primary-price p {
  color: #B71B2C;
  font-size: 1.2rem;
  text-align: right;
}

.s-ranking-primary-price p span {
  font-size: 3.6rem;
  font-weight: 700;
}

.s-ranking-primary-button {
  margin-top: auto;
  margin-bottom: 1.8rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: .4rem;
  background: #B71B2C;
  padding: 0px;
  height: 4.8rem;
  color: #fff;
  font-size: 2.2rem;
  line-height: 1;
  text-align: center;
}

.s-ranking-secondary {
  width: calc( 100% - 50rem);
  display: flex;
  flex-wrap: wrap;
}

.s-ranking-item {
  width: 48.5%;
}

.s-ranking-item:nth-child(even) {
  margin-left: auto;
}

.s-ranking-item a {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  background: #fff;
  padding: 1.2rem;
  color: #1D1616;
  text-decoration: none;
  position: relative;
  transition: opacity 0.3s ease-in-out;
}

.s-ranking-item a:hover {
  opacity: .75;
}

.s-ranking-item + .s-ranking-item + .s-ranking-item {
  margin-top: 1.2rem;
}

.s-ranking-badge {
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 5.3rem;
  height: 5.3rem;
  z-index: 10;
}

.s-ranking-badge img {
  width: 2rem;
  height: auto;
  vertical-align: bottom;
}

.s-ranking-badge p {
  font-family: "Hepta Slab", serif;
  text-align: center;
  font-weight: 600;
  margin-top: .4rem;
  color: #fff;
  font-size: 1.6rem;
  line-height: 1;
}

.s-ranking-2 {
  background: #A9A9A9;
}

.s-ranking-3 {
  background: #B38B67;
}

.s-ranking-label {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  padding: .8rem;
  background: #255470;
}

.s-ranking-label p {
  font-family: "Hepta Slab", serif;
  font-weight: 600;
  margin-top: .4rem;
  color: #fff;
  font-size: 1.6rem;
  line-height: 1;
}

.s-ranking-image {
  position: relative;
}

.s-ranking-image > img {
  width: 100%;
  height: 20rem;
  -o-object-fit: cover;
  object-fit: cover;
  vertical-align: bottom;
}

.s-ranking-content {
  padding: 1.2rem 0 0;
}

.s-ranking-name {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1;
  margin-bottom: .8rem;
}

.s-ranking-price {
  text-align: right;
  color: #B71B2C;
  font-size: 1.2rem;
  margin-bottom: .8rem;
}

.s-ranking-price p {
  line-height: 1;
  text-align: right;
}

.s-ranking-price span {
  font-size: 24px;
  font-weight: 500;
}

.s-ranking-button {
  margin-top: auto;
  border-radius: .4rem;
  background: #B71B2C;
  padding: 0px;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1;
  text-align: center;
  height: 4.8rem;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width: 600px) {
  .s-ranking {
    padding: 11.16279vw 0 0;
  }
  .s-ranking-head {
    padding: 0 5.5814vw;
  }
  .s-ranking-body {
    background: #fff;
    padding: 5.5814vw;
    flex-direction: column;
    gap: 0;
  }
  .s-ranking-primary {
    padding-bottom: 2.7907vw;
    width: 100%;
  }
  .s-ranking-primary-item a {
    display: flex;
  }
  .s-ranking-primary-image {
    position: relative;
    display: flex;
    align-items: stretch;
    width: 38.37209vw;
  }
  .s-ranking-primary-image img {
    width: calc( 100% - 11.62791vw);
    height: auto;
    vertical-align: bottom;
  }
  .s-ranking-primary-badge {
    position: static;
    width: 11.62791vw;
    height: 100%;
    padding: 0;
    box-sizing: border-box;
  }
  .s-ranking-primary-badge img {
    width: 2.7907vw;
  }
  .s-ranking-primary-badge p {
    font-size: 3.25581vw;
  }
  .s-ranking-primary-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    padding-left: 2.7907vw;
    width: calc( 100% - 38.37209vw);
  }
  .s-ranking-primary-name {
    font-size: 4.18605vw;
    margin-top: 0;
    margin-bottom: 1.86047vw;
  }
  .s-ranking-primary-excerpt {
    display: none;
  }
  .s-ranking-primary-price p {
    font-size: 3.72093vw;
  }
  .s-ranking-primary-price p span {
    font-size: 4.65116vw;
  }
  .s-ranking-primary-button {
    margin-left: auto;
    display: inline-block;
    border-radius: 0.93023vw;
    padding: 1.86047vw 3.72093vw;
    font-size: 3.72093vw;
    height: auto;
    margin-bottom: 0;
  }
  .s-ranking-secondary {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
  }
  .s-ranking-item {
    width: 100%;
    padding-top: 2.7907vw;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
  }
  .s-ranking-item:nth-child(even) {
    margin-left: 0;
  }
  .s-ranking-item a {
    height: auto;
    padding: 0;
    display: flex;
    align-items: stretch;
    flex-direction: row;
  }
  .s-ranking-image {
    position: relative;
    display: flex;
    align-items: stretch;
    width: 38.37209vw;
  }
  .s-ranking-image img {
    width: calc( 100% - 11.62791vw);
    height: auto;
    vertical-align: bottom;
  }
  .s-ranking-item + .s-ranking-item {
    margin-top: 2.7907vw;
  }
  .s-ranking-badge, .s-ranking-label {
    display: flex;
    flex-direction: column;
    position: static;
    width: 11.62791vw;
    height: 100%;
    padding: 0;
    box-sizing: border-box;
  }
  .s-ranking-badge img, .s-ranking-label img {
    width: 2.7907vw;
  }
  .s-ranking-badge p, .s-ranking-label p {
    font-size: 3.25581vw;
  }
  .s-ranking-label {
    align-items: center;
    justify-content: center;
  }
  .s-ranking-label p {
    text-align: center;
  }
  .s-ranking-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    padding-left: 2.7907vw;
    width: calc( 100% - 38.37209vw);
  }
  .s-ranking-name {
    font-size: 4.18605vw;
    margin-top: 0;
    margin-bottom: 1.86047vw;
    line-height: 1.2;
  }
  .s-ranking-price p {
    font-size: 3.72093vw;
  }
  .s-ranking-price p span {
    font-size: 4.65116vw;
    font-weight: 700;
  }
  .s-ranking-button {
    margin-left: auto;
    display: inline-block;
    border-radius: 0.93023vw;
    padding: 1.86047vw 3.72093vw;
    font-size: 3.72093vw;
    height: auto;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-ranking {
    padding: 5.33333vw 0 0;
  }
  .s-ranking-head {
    padding: 0 2.66667vw;
  }
  .s-ranking-body {
    background: #fff;
    padding: 2.66667vw;
    flex-direction: column;
    gap: 0;
  }
  .s-ranking-primary {
    padding-bottom: 1.33333vw;
    width: 100%;
  }
  .s-ranking-primary-item a {
    display: flex;
  }
  .s-ranking-primary-image {
    position: relative;
    display: flex;
    align-items: stretch;
    width: 18.33333vw;
  }
  .s-ranking-primary-image img {
    width: calc( 100% - 3.11111vw);
    height: auto;
    vertical-align: bottom;
  }
  .s-ranking-primary-badge {
    position: static;
    width: 4vw;
    height: 100%;
    padding: 0 0.88889vw;
    box-sizing: border-box;
  }
  .s-ranking-primary-badge img {
    width: 1.33333vw;
  }
  .s-ranking-primary-badge p {
    font-size: 1.33333vw;
  }
  .s-ranking-primary-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    padding-left: 1.33333vw;
    width: calc( 100% - 18.33333vw);
  }
  .s-ranking-primary-name {
    font-size: 1.77778vw;
    margin-bottom: 0.88889vw;
  }
  .s-ranking-primary-excerpt {
    display: none;
  }
  .s-ranking-primary-price p {
    font-size: 1.33333vw;
  }
  .s-ranking-primary-price p span {
    font-size: 1.77778vw;
  }
  .s-ranking-primary-button {
    margin-left: auto;
    display: inline-block;
    border-radius: 0.44444vw;
    padding: 0.88889vw 1.77778vw;
    font-size: 1.55556vw;
    height: auto;
  }
  .s-ranking-secondary {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
  }
  .s-ranking-item {
    width: 100%;
    padding-top: 1.33333vw;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
  }
  .s-ranking-item:nth-child(even) {
    margin-left: 0;
  }
  .s-ranking-item a {
    height: auto;
    padding: 0;
    display: flex;
    align-items: stretch;
    flex-direction: row;
  }
  .s-ranking-image {
    position: relative;
    display: flex;
    align-items: stretch;
    width: 18.33333vw;
  }
  .s-ranking-image img {
    width: calc( 100% - 3.11111vw);
    height: auto;
    vertical-align: bottom;
  }
  .s-ranking-item + .s-ranking-item {
    margin-top: 1.33333vw;
  }
  .s-ranking-badge, .s-ranking-label {
    display: flex;
    flex-direction: column;
    position: static;
    width: 4vw;
    height: 100%;
    padding: 0 0.88889vw;
    box-sizing: border-box;
  }
  .s-ranking-badge img, .s-ranking-label img {
    width: 1.33333vw;
  }
  .s-ranking-badge p, .s-ranking-label p {
    font-size: 1.33333vw;
  }
  .s-ranking-label {
    align-items: center;
    justify-content: center;
  }
  .s-ranking-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    padding-left: 1.33333vw;
    width: calc( 100% - 18.33333vw);
  }
  .s-ranking-name {
    font-size: 1.77778vw;
    margin-bottom: 0.88889vw;
  }
  .s-ranking-price p {
    font-size: 1.33333vw;
  }
  .s-ranking-price p span {
    font-size: 1.77778vw;
  }
  .s-ranking-button {
    margin-left: auto;
    display: inline-block;
    border-radius: 0.44444vw;
    padding: 0.88889vw 1.77778vw;
    font-size: 1.55556vw;
    margin-top: 0;
    height: auto;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-ranking {
    padding: 4.6875vw 0 0;
  }
  .s-ranking-head {
    padding: 0 2.34375vw;
  }
  .s-ranking-body {
    background: #fff;
    padding: 2.34375vw;
    flex-direction: column;
    gap: 0;
  }
  .s-ranking-primary {
    padding-bottom: 1.17188vw;
    width: 100%;
  }
  .s-ranking-primary-item a {
    display: flex;
  }
  .s-ranking-primary-image {
    position: relative;
    display: flex;
    align-items: stretch;
    width: 31.73828vw;
  }
  .s-ranking-primary-image img {
    width: calc( 100% - 2.73438vw);
    height: auto;
    vertical-align: bottom;
  }
  .s-ranking-primary-badge {
    position: static;
    width: 3.51562vw;
    height: 100%;
    padding: 0 0.78125vw;
    box-sizing: border-box;
  }
  .s-ranking-primary-badge img {
    width: 1.17188vw;
  }
  .s-ranking-primary-badge p {
    font-size: 1.17188vw;
  }
  .s-ranking-primary-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    padding-left: 1.17188vw;
    width: calc( 100% - 16.11328vw);
  }
  .s-ranking-primary-name {
    font-size: 1.5625vw;
    margin-bottom: 0.78125vw;
    margin-top: 0;
  }
  .s-ranking-primary-excerpt {
    display: none;
  }
  .s-ranking-primary-price p {
    font-size: 1.17188vw;
  }
  .s-ranking-primary-price p span {
    font-size: 1.5625vw;
  }
  .s-ranking-primary-button {
    margin-left: auto;
    display: inline-block;
    border-radius: 0.39062vw;
    padding: 0.78125vw 1.5625vw;
    font-size: 1.36719vw;
    height: auto;
  }
  .s-ranking-secondary {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
  }
  .s-ranking-item {
    width: 100%;
    padding-top: 1.17188vw;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
  }
  .s-ranking-item:nth-child(even) {
    margin-left: 0;
  }
  .s-ranking-item a {
    height: auto;
    padding: 0;
    display: flex;
    align-items: stretch;
    flex-direction: row;
  }
  .s-ranking-image {
    position: relative;
    display: flex;
    align-items: stretch;
    width: 31.73828vw;
  }
  .s-ranking-image img {
    width: calc( 100% - 2.73438vw);
    height: auto;
    vertical-align: bottom;
  }
  .s-ranking-item + .s-ranking-item {
    margin-top: 1.17188vw;
  }
  .s-ranking-badge, .s-ranking-label {
    display: flex;
    flex-direction: column;
    position: static;
    width: 3.51562vw;
    height: 100%;
    padding: 0 0.78125vw;
    box-sizing: border-box;
  }
  .s-ranking-badge img, .s-ranking-label img {
    width: 1.17188vw;
  }
  .s-ranking-badge p, .s-ranking-label p {
    font-size: 1.17188vw;
  }
  .s-ranking-label {
    align-items: center;
    justify-content: center;
  }
  .s-ranking-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    margin-left: auto;
    padding-left: 1.17188vw;
    width: calc( 100% - 16.11328vw);
  }
  .s-ranking-name {
    font-size: 1.5625vw;
    margin-bottom: 0.78125vw;
  }
  .s-ranking-price p {
    font-size: 1.17188vw;
  }
  .s-ranking-price p span {
    font-size: 1.5625vw;
  }
  .s-ranking-button {
    margin-left: auto;
    display: inline-block;
    border-radius: 0.39062vw;
    padding: 0.78125vw 1.5625vw;
    font-size: 1.36719vw;
    margin-top: 0;
    height: auto;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1280px) {
  .s-ranking-body {
    display: flex;
    align-items: stretch;
    gap: 1.2rem;
  }
  .s-ranking-secondary {
    width: calc( 100% - 50rem);
    display: flex;
    flex-wrap: wrap;
  }
  .s-ranking-item {
    width: 48.5%;
  }
  .s-ranking-item a {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    background: #fff;
    padding: 1.2rem;
    color: #1D1616;
    text-decoration: none;
    position: relative;
  }
}

@media screen and (min-width: 1025px) {
  .s-ranking-primary-item a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-ranking-primary-item a:hover {
    opacity: .75;
  }
  .s-ranking-item a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-ranking-item a:hover {
    opacity: .75;
  }
}

.s-recipe {
  padding: 6rem 0;
  background: linear-gradient(90deg, #3D92C3 0%, #B7E5FF 100%);
  position: relative;
  overflow: hidden;
}

.s-recipe-container {
  position: relative;
}

.s-recipe-ttle {
  color: #fff;
  letter-spacing: 1.2px;
}

.s-recipe-body {
  position: relative;
}

.s-recipe-body .slick-arrow {
  width: 6rem;
  height: 6rem;
  text-indent: 9999px;
  position: absolute;
  z-index: 1000;
}

.s-recipe-body .slick-prev {
  top: 50%;
  margin-top: -3rem;
  left: -3rem;
  background: url(../images/new/ico-arrow-next.svg) no-repeat 0 0;
  background-size: 6rem 6rem;
}

.s-recipe-body .slick-next {
  top: 50%;
  margin-top: -3rem;
  right: -3rem;
  background: url(../images/new/ico-arrow-prev.svg) no-repeat 0 0;
  background-size: 6rem 6rem;
}

.s-recipe-sldr {
  box-sizing: border-box;
  width: calc(100% + (50vw - 50%));
  margin-bottom: 2.4rem;
  z-index: 100;
  background: #fff;
  border-radius: .4rem;
  padding: 4.8rem;
  padding-right: 0;
  box-sizing: border-box;
}

.s-recipe-sldr.slick-slider {
  position: static;
}

.s-recipe-item {
  width: 26rem;
  box-sizing: border-box;
}

.s-recipe-item a {
  text-decoration: none;
  color: #1D1616;
}

.s-recipe-item a p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.6;
}

.s-recipe-item + .s-recipe-item {
  margin-left: 2.51323vw;
}

.s-recipe-img {
  margin-bottom: 1.8rem;
}

.s-recipe-img img {
  width: 100%;
  height: 18rem;
  -o-object-fit: cover;
  object-fit: cover;
  vertical-align: bottom;
}

.s-recipe-name {
  margin-bottom: 1.8rem;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.5;
}

.s-recipe-dots {
  display: flex;
}

.s-recipe-dots li {
  width: 2rem;
  height: 2rem;
  background: #255470;
  border-radius: 50%;
  text-indent: -9999px;
}

.s-recipe-dots li.slick-active {
  background: #fff;
}

.s-recipe-dots li + li {
  margin-left: .8rem;
}

.s-recipe-footer {
  margin-top: 2.4rem;
  display: flex;
}

.s-recipe-footer a {
  display: inline-block;
  margin-left: auto;
}

.s-recipe-link {
  display: block;
  font-weight: 600;
  padding-right: 2rem;
  color: #255470;
  position: relative;
}

.s-recipe-link:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  width: 7px;
  height: 7px;
  margin-top: -4px;
  border-top: solid 2px #7f7f7f;
  border-right: solid 2px #7f7f7f;
  transform: rotate(45deg);
  content: "";
}

@media screen and (max-width: 600px) {
  .s-recipe {
    padding: 11.16279vw 0 5.5814vw 5.5814vw;
  }
  .s-recipe-head {
    padding: 0 5.5814vw;
  }
  .s-recipe-sldr {
    width: 100%;
    margin-bottom: 2.4rem;
    border-radius: 0.93023vw 0 0 0.93023vw;
    padding: 5.5814vw 0 5.5814vw 5.5814vw;
  }
  .s-recipe-item {
    width: 55.81395vw;
    box-sizing: border-box;
  }
  .s-recipe-item a {
    text-decoration: none;
    color: #1D1616;
  }
  .s-recipe-item a p {
    font-size: 3.48837vw;
    font-weight: 400;
  }
  .s-recipe-item + .s-recipe-item {
    margin-left: 5.5814vw;
  }
  .s-recipe-img {
    margin-bottom: 2.7907vw;
  }
  .s-recipe-img img {
    height: 30.23256vw;
  }
  .s-recipe-name {
    margin-bottom: 2.7907vw;
    font-size: 3.72093vw;
  }
  .s-recipe-footer {
    margin-top: 2.7907vw;
  }
  .s-recipe-footer a {
    margin-left: 0;
  }
  .s-recipe-link {
    border: 1px solid #255470;
    background: #C8EBFF;
    color: #255470;
    border-radius: 0.93023vw;
    padding: 2.7907vw 5.5814vw 2.7907vw 2.7907vw;
    font-size: 2.7907vw;
    text-decoration: none;
  }
  .s-recipe-link:after {
    position: absolute;
    top: 50%;
    right: 2.32558vw;
    width: 1.62791vw;
    height: 1.62791vw;
    margin-top: -0.93023vw;
    border-top: solid 0.46512vw #255470;
    border-right: solid 0.46512vw #255470;
    content: "";
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-recipe {
    padding: 5.33333vw 0 2.66667vw 2.66667vw;
  }
  .s-recipe-head {
    padding: 0 2.66667vw;
  }
  .s-recipe-sldr {
    width: 100%;
    margin-bottom: 2.4rem;
    border-radius: 0.44444vw 0 0 0.44444vw;
    padding: 2.66667vw 0 2.66667vw 2.66667vw;
  }
  .s-recipe-item {
    width: 35.55556vw;
    box-sizing: border-box;
  }
  .s-recipe-item a {
    text-decoration: none;
    color: #1D1616;
  }
  .s-recipe-item a p {
    font-size: 1.77778vw;
    font-weight: 400;
  }
  .s-recipe-item + .s-recipe-item {
    margin-left: 2.66667vw;
  }
  .s-recipe-img {
    margin-bottom: 1.33333vw;
  }
  .s-recipe-img img {
    height: 20vw;
  }
  .s-recipe-name {
    margin-bottom: 1.33333vw;
    font-size: 2vw;
  }
  .s-recipe-footer {
    margin-top: 1.33333vw;
  }
  .s-recipe-footer a {
    margin-left: 0;
  }
  .s-recipe-link {
    border: 1px solid #255470;
    background: #C8EBFF;
    color: #255470;
    border-radius: 0.44444vw;
    padding: 1.33333vw 2.66667vw 1.33333vw 1.33333vw;
    font-size: 1.33333vw;
    text-decoration: none;
  }
  .s-recipe-link:after {
    position: absolute;
    top: 50%;
    right: 1.11111vw;
    width: 0.77778vw;
    height: 0.77778vw;
    margin-top: -0.44444vw;
    border-top: solid 0.22222vw #255470;
    border-right: solid 0.22222vw #255470;
    content: "";
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-recipe {
    padding: 4.6875vw 0 2.34375vw 2.34375vw;
  }
  .s-recipe-head {
    padding: 0 2.34375vw;
  }
  .s-recipe-sldr {
    width: 100%;
    margin-bottom: 2.4rem;
    border-radius: 0.39062vw 0 0 0.39062vw;
    padding: 2.34375vw 0 2.34375vw 2.34375vw;
  }
  .s-recipe-item {
    width: 22.46094vw;
    box-sizing: border-box;
  }
  .s-recipe-item a {
    text-decoration: none;
    color: #1D1616;
  }
  .s-recipe-item a p {
    font-size: 1.17188vw;
    font-weight: 400;
  }
  .s-recipe-item + .s-recipe-item {
    margin-left: 0.58594vw;
  }
  .s-recipe-img {
    margin-bottom: 1.17188vw;
  }
  .s-recipe-img img {
    height: 17.57812vw;
  }
  .s-recipe-name {
    margin-bottom: 1.17188vw;
    font-size: 1.36719vw;
  }
  .s-recipe-footer {
    margin-top: 1.17188vw;
  }
  .s-recipe-footer a {
    margin-left: 0;
  }
  .s-recipe-link {
    border: 1px solid #255470;
    background: #C8EBFF;
    color: #255470;
    border-radius: 0.39062vw;
    padding: 1.17188vw 2.34375vw 1.17188vw 1.17188vw;
    font-size: 1.17188vw;
    text-decoration: none;
  }
  .s-recipe-link:after {
    position: absolute;
    top: 50%;
    right: 0.97656vw;
    width: 0.68359vw;
    height: 0.68359vw;
    margin-top: -0.39062vw;
    border-top: solid 0.19531vw #255470;
    border-right: solid 0.19531vw #255470;
    content: "";
  }
}

@media screen and (min-width: 1025px) and (max-width: 1280px) {
  .s-recipe {
    padding-left: 4.8rem;
  }
  .s-recipe-body {
    position: relative;
  }
  .s-recipe-body .slick-arrow {
    width: 4.8rem;
    height: 4.8rem;
    text-indent: 9999px;
    position: absolute;
    z-index: 1000;
  }
  .s-recipe-body .slick-prev {
    top: 50%;
    margin-top: -3rem;
    left: -3rem;
    background: url(../images/new/ico-arrow-next.svg) no-repeat 0 0;
    background-size: 4.8rem 4.8rem;
  }
  .s-recipe-body .slick-next {
    top: 50%;
    margin-top: -3rem;
    right: 3rem;
    background: url(../images/new/ico-arrow-prev.svg) no-repeat 0 0;
    background-size: 4.8rem 4.8rem;
  }
}

@media screen and (min-width: 1025px) {
  .s-recipe-item a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-recipe-item a:hover {
    opacity: .75;
  }
  .s-recipe-footer a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-recipe-footer a:hover {
    opacity: .75;
  }
}

.s-about {
  padding: 6rem 0 0;
}

.s-about-body {
  background: #fff;
}

.s-about-menu {
  display: flex;
  gap: 2.4rem;
  padding: 4.8rem 0;
}

.s-about-item {
  flex: 1 1;
}

.s-about-item a {
  display: block;
  border-radius: .4rem;
  overflow: hidden;
  background: #000;
  position: relative;
  color: #fff;
}

.s-about-img img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
  opacity: .4;
}

.s-about-text {
  position: absolute;
  text-align: center;
  width: 100%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  color: #FFF;
  font-family: "Noto Serif JP";
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: .4rem;
}

@media screen and (max-width: 600px) {
  .s-about {
    padding: 11.16279vw 0 0;
  }
  .s-about-head {
    padding: 0 5.5814vw;
  }
  .s-about-body {
    padding: 5.5814vw;
  }
  .s-about-menu {
    display: flex;
    gap: 2.7907vw 0;
    padding: 0;
    flex-wrap: wrap;
  }
  .s-about-item {
    flex: none;
    width: 48.5%;
  }
  .s-about-item:nth-child(even) {
    margin-left: auto;
  }
  .s-about-item a {
    border-radius: 0.93023vw;
  }
  .s-about-img img {
    height: 27.90698vw;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .s-about-text {
    font-size: 4.18605vw;
    letter-spacing: 1;
    line-height: 1.2;
  }
  .s-about-text span {
    display: block;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-about {
    padding: 5.33333vw 0 0;
  }
  .s-about-head {
    padding: 0 2.66667vw;
  }
  .s-about-body {
    padding: 2.66667vw;
  }
  .s-about-menu {
    display: flex;
    gap: 1.33333vw 0;
    padding: 0;
    flex-wrap: wrap;
  }
  .s-about-item {
    flex: none;
    width: 48.5%;
  }
  .s-about-item:nth-child(even) {
    margin-left: auto;
  }
  .s-about-item a {
    border-radius: 0.44444vw;
  }
  .s-about-img img {
    height: 13.33333vw;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .s-about-text {
    font-size: 2vw;
    letter-spacing: 1;
    line-height: 1.2;
  }
  .s-about-text span {
    display: block;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-about {
    padding: 4.6875vw 0 0;
  }
  .s-about-head {
    padding: 0 2.34375vw;
  }
  .s-about-body {
    padding: 2.34375vw;
  }
  .s-about-menu {
    display: flex;
    gap: 1.17188vw 0;
    padding: 0;
    flex-wrap: wrap;
  }
  .s-about-item {
    flex: none;
    width: 48.5%;
  }
  .s-about-item:nth-child(even) {
    margin-left: auto;
  }
  .s-about-item a {
    border-radius: 0.39062vw;
  }
  .s-about-img img {
    height: 11.71875vw;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .s-about-text {
    font-size: 1.75781vw;
    letter-spacing: 1;
    line-height: 1.2;
  }
  .s-about-text span {
    display: block;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1280px) {
  .s-about-head {
    padding: 0 2.4rem;
  }
  .s-about-body {
    padding: 0 2.4rem;
    background: #fff;
  }
}

@media screen and (min-width: 1025px) {
  .s-about-item a img {
    transition: opacity 0.3s ease-in-out;
  }
  .s-about-item a:hover img {
    opacity: .6;
  }
}

.s-instagram {
  padding: 12rem 0 0;
}

.s-instagram-ttle {
  text-align: center;
}

.s-instagram-body {
  padding: 2.4rem 0;
  background: #fff;
}

.s-instagram-gallery {
  display: flex;
  gap: 2.4rem;
}

.s-instagram-item {
  flex: 1 1;
}

.s-instagram-item img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

@media screen and (max-width: 600px) {
  .s-instagram {
    padding: 11.16279vw 0 0;
  }
  .s-instagram-body {
    padding: 5.5814vw;
  }
  .s-instagram-gallery {
    display: flex;
    flex-wrap: wrap;
    gap: 2.7907vw;
  }
  .s-instagram-item {
    flex: none;
    width: 26.74419vw;
  }
  .s-instagram-item img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-instagram {
    padding: 5.33333vw 0 0;
  }
  .s-instagram-body {
    padding: 2.66667vw;
  }
  .s-instagram-gallery {
    display: flex;
    flex-wrap: wrap;
    gap: 1.33333vw;
  }
  .s-instagram-item {
    flex: 1 1;
  }
  .s-instagram-item img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-instagram {
    padding: 4.6875vw 0 0;
  }
  .s-instagram-body {
    padding: 2.34375vw;
  }
  .s-instagram-gallery {
    display: flex;
    flex-wrap: wrap;
    gap: 1.17188vw;
  }
  .s-instagram-item {
    flex: 1 1;
  }
  .s-instagram-item img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1280px) {
  .s-instagram-body {
    padding: 2.4rem;
    background: #fff;
  }
}

.s-banners {
  padding: 6rem 0;
}

.s-banners-flex {
  display: flex;
  gap: 2.4rem;
  margin-bottom: 2.4rem;
}

.s-banners-item {
  flex: 1 1;
}

.s-banners-item a {
  display: block;
}

.s-banners-item a img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

@media screen and (max-width: 600px) {
  .s-banners {
    padding: 11.16279vw 5.5814vw 5.5814vw;
  }
  .s-banners-flex {
    display: flex;
    flex-direction: column;
    gap: 2.7907vw;
    margin-bottom: 2.4rem;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-banners {
    padding: 5.33333vw 2.66667vw 2.66667vw;
  }
  .s-banners-flex {
    display: flex;
    flex-direction: column;
    gap: 1.33333vw;
    margin-bottom: 2.4rem;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-banners {
    padding: 4.6875vw 2.34375vw 2.34375vw;
  }
  .s-banners-flex {
    display: flex;
    gap: 1.17188vw;
    margin-bottom: 2.4rem;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1280px) {
  .s-banners {
    padding: 6rem 2.4rem;
  }
}

@media screen and (min-width: 1025px) {
  .s-banners-item a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-banners-item a:hover {
    opacity: .75;
  }
}

.s-sns-flex {
  display: flex;
  gap: 2.4rem;
  justify-content: center;
}

.s-sns-item {
  width: 6rem;
}

.s-sns-item a img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

@media screen and (max-width: 600px) {
  .s-sns-flex {
    gap: 5.5814vw;
  }
  .s-sns-item {
    width: 10.46512vw;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-sns-flex {
    gap: 2.66667vw;
  }
  .s-sns-item {
    width: 5vw;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-sns-flex {
    gap: 2.34375vw;
  }
  .s-sns-item {
    width: 4.39453vw;
  }
}

@media screen and (min-width: 1025px) {
  .s-sns-item a {
    transition: opacity 0.3s ease-in-out;
  }
  .s-sns-item a:hover {
    opacity: .75;
  }
}

.s-guide {
  padding: 6rem 0;
}

.s-guide-lists {
  display: flex;
  align-items: stretch;
  gap: 2.4rem;
}

.s-guide-lists li {
  flex: 1 1;
}

.s-guide-lists li a {
  height: 28rem;
  text-decoration: none;
  color: #1D1616;
  line-height: 1.2;
  display: flex;
  background: #fff;
  border-radius: .4rem;
  flex-direction: column;
  padding: 2.4rem 2.4rem 0;
  box-sizing: border-box;
  border: .4rem solid transparent;
}

.s-guide-img {
  text-align: center;
  margin-bottom: 1.2rem;
}

.s-guide-img img {
  width: 12rem;
}

.s-guide-name {
  font-size: 1.8rem;
  font-weight: 500;
  margin-bottom: .8rem;
}

.s-guide-text {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
}

@media screen and (max-width: 600px) {
  .s-guide {
    padding: 5.5814vw;
  }
  .s-guide-lists {
    flex-direction: column;
    gap: 2.7907vw 0;
  }
  .s-guide-lists li {
    flex: none;
    background: #fff;
    border-radius: .4rem;
  }
  .s-guide-lists li a {
    height: auto;
    padding: 2.7907vw 5.5814vw;
  }
  .s-guide-img {
    text-align: center;
    margin-bottom: 2.7907vw;
  }
  .s-guide-img img {
    width: 13.95349vw;
  }
  .s-guide-name {
    font-size: 4.18605vw;
    margin-bottom: 1.86047vw;
  }
  .s-guide-text {
    font-size: 3.72093vw;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-guide {
    padding: 2.66667vw;
  }
  .s-guide-lists {
    flex-wrap: wrap;
    gap: 1.33333vw 0;
  }
  .s-guide-lists li {
    flex: none;
    width: 48.5%;
    background: #fff;
    border-radius: .4rem;
  }
  .s-guide-lists li:nth-child(even) {
    margin-left: auto;
  }
  .s-guide-lists li a {
    height: auto;
    padding: 1.33333vw 2.66667vw;
  }
  .s-guide-img {
    text-align: center;
    margin-bottom: 1.33333vw;
  }
  .s-guide-img img {
    width: 6.66667vw;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-guide {
    padding: 2.34375vw;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1280px) {
  .s-guide {
    padding: 6rem 2.4rem;
  }
}

@media screen and (min-width: 1025px) {
  .s-guide-lists li a {
    transition: border .3s ease-in-out;
  }
  .s-guide-lists li a:hover {
    border: .4rem solid #3D92C3;
  }
}

.s-contact {
  position: relative;
  overflow: hidden;
  z-index: 10;
}

.s-contact-inner {
  width: calc(100% + (50vw - 50%));
  background: #C8EBFF;
  padding: 4.8rem 8.4rem;
  box-sizing: border-box;
  border-radius: 4rem 0px 0px 4rem;
  box-sizing: border-box;
}

.s-contact-label {
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 2.4rem;
}

.s-contact-tel {
  display: flex;
  gap: 3.6rem;
}

.s-contact-item {
  margin-right: 3.2rem;
  margin-bottom: 1.2rem;
}

.s-contact-text {
  font-size: 1.6rem;
  font-weight: 500;
  margin-bottom: .4rem;
}

.s-contact-number {
  font-family: "Montserrat", sans-serif;
  font-size: 6rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: .4rem;
  position: relative;
  padding-left: 7.8rem;
}

.s-contact-number:before {
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 7rem;
  height: 4rem;
  background: url(../images/new/ico-dial.svg) no-repeat 0 0;
  background-size: 7rem 4rem;
  content: "";
}

.s-contact-number a {
  color: #1D1616;
  text-decoration: none;
  pointer-events: none;
  cursor: text;
}

.s-contact-note {
  font-size: 1.2rem;
  font-weight: 400;
}

@media screen and (max-width: 600px) {
  .s-contact {
    padding: 5.5814vw 0 0 5.5814vw;
  }
  .s-contact-inner {
    width: 100%;
    padding: 5.5814vw;
    border-radius: 9.30233vw 0px 0px 9.30233vw;
  }
  .s-contact-label {
    font-size: 4.18605vw;
    font-weight: 500;
    margin-bottom: 2.32558vw;
  }
  .s-contact-tel {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
  .s-contact-item {
    margin-right: 0;
    margin-bottom: 4.65116vw;
  }
  .s-contact-text {
    font-size: 3.72093vw;
    font-weight: 500;
    margin-bottom: 0.93023vw;
  }
  .s-contact-number {
    font-size: 8.37209vw;
    margin-bottom: 0.93023vw;
    padding-left: 9.76744vw;
  }
  .s-contact-number:before {
    width: 8.13953vw;
    height: 4.65116vw;
    background-size: 8.13953vw 4.65116vw;
  }
  .s-contact-number a {
    pointer-events: auto;
    cursor: pointer;
  }
  .s-contact-note {
    font-size: 3.48837vw;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-contact {
    padding: 2.66667vw 0 0 2.66667vw;
  }
  .s-contact-inner {
    width: 100%;
    padding: 2.66667vw;
    border-radius: 2.22222vw 0px 0px 2.22222vw;
  }
  .s-contact-label {
    font-size: 1.77778vw;
    font-weight: 500;
    margin-bottom: 1.11111vw;
  }
  .s-contact-tel {
    display: flex;
    flex-direction: row;
    gap: 0;
  }
  .s-contact-item {
    margin-right: 3.55556vw;
    margin-bottom: 2.22222vw;
  }
  .s-contact-text {
    font-size: 1.55556vw;
    font-weight: 500;
    margin-bottom: 0.44444vw;
  }
  .s-contact-number {
    font-size: 5.33333vw;
    margin-bottom: 0.44444vw;
    padding-left: 5.33333vw;
  }
  .s-contact-number:before {
    width: 4.44444vw;
    height: 2.77778vw;
    background-size: 4.44444vw auto;
  }
  .s-contact-number a {
    pointer-events: auto;
    cursor: pointer;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-contact {
    padding: 2.34375vw 0 0 2.34375vw;
  }
  .s-contact-inner {
    width: 100%;
    padding: 2.34375vw;
    border-radius: 1.95312vw 0px 0px 1.95312vw;
  }
  .s-contact-label {
    font-size: 1.5625vw;
    font-weight: 500;
    margin-bottom: 0.97656vw;
  }
  .s-contact-tel {
    display: flex;
    flex-direction: row;
    gap: 2.34375vw;
  }
  .s-contact-item {
    margin-right: 3.125vw;
    margin-bottom: 1.95312vw;
  }
  .s-contact-text {
    font-size: 1.36719vw;
    font-weight: 500;
    margin-bottom: 0.39062vw;
  }
  .s-contact-number {
    font-size: 4.6875vw;
    margin-bottom: 0.39062vw;
    padding-left: 4.6875vw;
  }
  .s-contact-number:before {
    width: 3.90625vw;
    height: 2.44141vw;
    background-size: 3.90625vw auto;
  }
  .s-contact-number a {
    pointer-events: auto;
    cursor: pointer;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1280px) {
  .s-contact {
    padding-left: 2.4rem;
  }
  .s-contact-number {
    font-family: "Montserrat", sans-serif;
    font-size: 4.8rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: .4rem;
    position: relative;
    padding-left: 7.8rem;
  }
  .s-contact-number:before {
    display: block;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 7rem;
    height: 4rem;
    background: url(../images/new/ico-dial.svg) no-repeat 0 0;
    background-size: 7rem 4rem;
    content: "";
  }
}

.s-footer {
  background: linear-gradient(0deg, rgba(38, 85, 113, 0.4) 0%, #265571 100%), url(../images/new/bg-footer.png) no-repeat left bottom;
  padding: 13rem 0 0;
  position: relative;
  margin-top: -8rem;
  z-index: 8;
}

.s-footer-logo {
  width: 6.1rem;
  margin: 0 auto 2.4rem;
}

.s-footer-logo img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

.s-footer-menu {
  display: flex;
  padding-bottom: 6.4rem;
}

.s-footer-menu-item {
  flex: 1 1;
}

.s-footer-menu-trigger {
  color: #FFF;
  font-size: 1.8rem;
  font-weight: 400;
  display: block;
  margin-bottom: 2.4rem;
  pointer-events: none;
}

.s-footer-menu-sub li a {
  color: #FFF;
  font-size: 1.6rem;
  font-weight: 400;
  text-decoration: none;
}

.s-footer-menu-sub li + li {
  margin-top: .4rem;
}

.s-footer-copy {
  background: #1D1616;
  text-align: center;
  padding: 2.4rem 0;
  color: #fff;
  font-size: 1rem;
  line-height: 1;
}

@media screen and (max-width: 600px) {
  .s-footer {
    padding: 23.25581vw 0 0 0;
    margin-top: -18.60465vw;
  }
  .s-footer-logo {
    width: 14.18605vw;
    margin: 0 auto 2.7907vw;
  }
  .s-footer-menu {
    flex-direction: column;
    padding: 0 5.5814vw 11.16279vw;
  }
  .s-footer-menu-item {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
  }
  .s-footer-menu-item:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }
  .s-footer-menu-trigger {
    font-size: 3.72093vw;
    margin-bottom: 0;
    padding: 2.7907vw 0;
    position: relative;
    cursor: pointer;
    pointer-events: all;
  }
  .s-footer-menu-trigger:after {
    display: block;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3.72093vw;
    height: 3.72093vw;
    background: url(../images/new/ico-plus.svg);
    background-size: 3.72093vw 3.72093vw;
    content: "";
  }
  .s-footer-menu-sub {
    display: none;
    padding: 2.7907vw 1.86047vw;
    background: #1F445A;
  }
  .s-footer-menu-sub li a {
    font-size: 3.72093vw;
  }
  .s-footer-menu-sub li + li {
    margin-top: 0.93023vw;
  }
  .s-footer-copy {
    padding: 2.7907vw 0;
    font-size: 2.32558vw;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-footer {
    padding: 11.11111vw 0 0 0;
    margin-top: -8.88889vw;
  }
  .s-footer-logo {
    width: 6.77778vw;
    margin: 0 auto 1.33333vw;
  }
  .s-footer-menu {
    flex-direction: column;
    padding: 0 2.66667vw 5.33333vw;
  }
  .s-footer-menu-item {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
  }
  .s-footer-menu-item:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }
  .s-footer-menu-trigger {
    font-size: 1.77778vw;
    margin-bottom: 0;
    padding: 1.33333vw 0;
    position: relative;
    cursor: pointer;
    pointer-events: all;
  }
  .s-footer-menu-trigger:after {
    display: block;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1.77778vw;
    height: 1.77778vw;
    background: url(../images/new/ico-plus.svg);
    background-size: 1.77778vw 1.77778vw;
    content: "";
  }
  .s-footer-menu-sub {
    display: none;
    padding: 1.33333vw 0.88889vw;
    background: #1F445A;
  }
  .s-footer-menu-sub li a {
    font-size: 1.77778vw;
  }
  .s-footer-menu-sub li + li {
    margin-top: 0.44444vw;
  }
  .s-footer-copy {
    padding: 1.33333vw 0;
    font-size: 1.11111vw;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-footer {
    padding: 9.76562vw 0 0;
    margin-top: -7.8125vw;
  }
  .s-footer-logo {
    width: 5.95703vw;
    margin: 0 auto 1.17188vw;
  }
  .s-footer-menu {
    padding: 0 2.34375vw 4.6875vw;
  }
  .s-footer-menu-trigger {
    font-size: 1.5625vw;
    margin-bottom: 0;
    padding: 1.17188vw 0;
  }
  .s-footer-menu-sub li a {
    font-size: 1.5625vw;
  }
  .s-footer-menu-sub li + li {
    margin-top: 0.39062vw;
  }
  .s-footer-copy {
    padding: 1.17188vw 0;
    font-size: 0.97656vw;
  }
}

.s-pane {
  position: fixed;
  left: -100%;
  /* 初期位置: 画面外（左） */
  width: 300px;
  /* パネルの幅 */
  height: 100vh;
  background: #333;
  color: white;
  transition: left 0.3s ease-in-out;
  /* アニメーションの設定 */
  z-index: 1000;
  overflow: auto;
}

.s-pane.active {
  left: 0;
}

@media screen and (max-width: 600px) {
  .s-pane {
    width: 100%;
    background: #fff;
    top: 17.44186vw;
  }
  .s-pane-container {
    background: #255470;
    padding: 2.7907vw 5.5814vw;
  }
  .s-pane-form {
    display: flex;
    width: 100%;
    background: #fff;
  }
  .s-pane-input {
    padding: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    font-size: 3.72093vw;
    padding: 0 2.7907vw;
    height: 11.16279vw;
    box-sizing: border-box;
    width: calc( 100% - 11.16279vw);
  }
  .s-pane-submit {
    margin-left: auto;
    cursor: pointer;
    outline: none;
    background: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    padding: 0;
  }
  .s-pane-submit img {
    width: 11.16279vw;
    height: 11.16279vw;
    -o-object-fit: cover;
    object-fit: cover;
    vertical-align: top;
  }
  .s-pane-list > li a {
    text-decoration: none;
    color: #000;
    display: block;
    font-size: 3.72093vw;
    padding: 2.7907vw 5.5814vw;
    position: relative;
  }
  .s-pane-list > li a:not(.s-pane-trigger):after {
    display: block;
    position: absolute;
    top: 50%;
    right: 5.5814vw;
    width: 1.62791vw;
    height: 1.62791vw;
    margin-top: -0.93023vw;
    border-top: solid 0.46512vw #3D92C3;
    border-right: solid 0.46512vw #3D92C3;
    transform: rotate(45deg);
    content: "";
  }
  .s-pane-list > li a.s-pane-trigger:after {
    display: block;
    position: absolute;
    top: 50%;
    right: 4.65116vw;
    width: 3.72093vw;
    height: 3.72093vw;
    margin-top: -1.86047vw;
    background: url(../images/new/ico-pane-plus.svg);
    background-size: 3.72093vw 3.72093vw;
    content: "";
  }
  .s-pane-list > li + li {
    border-top: 1px solid #ccc;
  }
  .s-pane-pannel {
    display: none;
    background: rgba(61, 146, 195, 0.2);
  }
  .s-pane-pannel > li a {
    text-decoration: none;
    color: #000;
    display: block;
    font-size: 3.72093vw;
    padding: 2.7907vw 5.5814vw;
    position: relative;
  }
  .s-pane-pannel > li + li {
    border-top: 1px dotted #ccc;
  }
}

@media screen and (min-width: 601px) and (max-width: 900px) {
  .s-pane {
    width: 100%;
    background: #fff;
    top: 8.33333vw;
  }
  .s-pane-container {
    background: #255470;
    padding: 1.33333vw 2.66667vw;
  }
  .s-pane-form {
    display: flex;
    width: 100%;
    background: #fff;
  }
  .s-pane-input {
    padding: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    font-size: 1.77778vw;
    padding: 0 1.33333vw;
    height: 5.33333vw;
    box-sizing: border-box;
    width: calc( 100% - 5.33333vw);
  }
  .s-pane-submit {
    margin-left: auto;
    cursor: pointer;
    outline: none;
    background: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    padding: 0;
  }
  .s-pane-submit img {
    width: 5.33333vw;
    height: 5.33333vw;
    -o-object-fit: cover;
    object-fit: cover;
    vertical-align: top;
  }
  .s-pane-list > li a {
    text-decoration: none;
    color: #000;
    display: block;
    font-size: 1.77778vw;
    padding: 1.33333vw 2.66667vw;
    position: relative;
  }
  .s-pane-list > li a:not(.s-pane-trigger):after {
    display: block;
    position: absolute;
    top: 50%;
    right: 2.66667vw;
    width: 0.77778vw;
    height: 0.77778vw;
    margin-top: -0.44444vw;
    border-top: solid 0.22222vw #3D92C3;
    border-right: solid 0.22222vw #3D92C3;
    transform: rotate(45deg);
    content: "";
  }
  .s-pane-list > li a.s-pane-trigger:after {
    display: block;
    position: absolute;
    top: 50%;
    right: 2.22222vw;
    width: 1.77778vw;
    height: 1.77778vw;
    margin-top: -0.88889vw;
    background: url(../images/new/ico-pane-plus.svg);
    background-size: 1.77778vw 1.77778vw;
    content: "";
  }
  .s-pane-list > li + li {
    border-top: 1px solid #ccc;
  }
  .s-pane-pannel {
    display: none;
    background: rgba(61, 146, 195, 0.2);
  }
  .s-pane-pannel > li a {
    text-decoration: none;
    color: #000;
    display: block;
    font-size: 1.77778vw;
    padding: 1.33333vw 2.66667vw;
    position: relative;
  }
  .s-pane-pannel > li + li {
    border-top: 1px dotted #ccc;
  }
}

@media screen and (min-width: 901px) and (max-width: 1024px) {
  .s-pane {
    width: 100%;
    background: #fff;
    top: 7.32422vw;
  }
  .s-pane-container {
    background: #255470;
    padding: 1.17188vw 2.34375vw;
  }
  .s-pane-form {
    display: flex;
    width: 100%;
    background: #fff;
  }
  .s-pane-input {
    padding: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    font-size: 1.5625vw;
    padding: 0 1.17188vw;
    height: 4.6875vw;
    box-sizing: border-box;
    width: calc( 100% - 4.6875vw);
  }
  .s-pane-submit {
    margin-left: auto;
    cursor: pointer;
    outline: none;
    background: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    padding: 0;
  }
  .s-pane-submit img {
    width: 4.6875vw;
    height: 4.6875vw;
    -o-object-fit: cover;
    object-fit: cover;
    vertical-align: top;
  }
  .s-pane-list > li a {
    text-decoration: none;
    color: #000;
    display: block;
    font-size: 1.5625vw;
    padding: 1.17188vw 2.34375vw;
    position: relative;
  }
  .s-pane-list > li a:not(.s-pane-trigger):after {
    display: block;
    position: absolute;
    top: 50%;
    right: 2.34375vw;
    width: 0.68359vw;
    height: 0.68359vw;
    margin-top: -0.39062vw;
    border-top: solid 0.19531vw #3D92C3;
    border-right: solid 0.19531vw #3D92C3;
    transform: rotate(45deg);
    content: "";
  }
  .s-pane-list > li a.s-pane-trigger:after {
    display: block;
    position: absolute;
    top: 50%;
    right: 1.95312vw;
    width: 1.5625vw;
    height: 1.5625vw;
    margin-top: -0.78125vw;
    background: url(../images/new/ico-pane-plus.svg);
    background-size: 1.5625vw 1.5625vw;
    content: "";
  }
  .s-pane-list > li + li {
    border-top: 1px solid #ccc;
  }
  .s-pane-pannel {
    display: none;
    background: rgba(61, 146, 195, 0.2);
  }
  .s-pane-pannel > li a {
    text-decoration: none;
    color: #000;
    display: block;
    font-size: 1.5625vw;
    padding: 1.17188vw 2.34375vw;
    position: relative;
  }
  .s-pane-pannel > li + li {
    border-top: 1px dotted #ccc;
  }
}
