@charset "UTF-8";
/* 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,
q:before,
q:after {
  content: "";
  content: none;
}

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

html {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-style: normal;
}

html {
  background-color: #fffcf1;
  color: #2f2f2f;
  scroll-behavior: smooth;
}

a {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
a:hover {
  text-decoration: none;
}

button {
  cursor: pointer;
  border: none;
}

img {
  max-width: 100%;
  height: auto;
}

.l-footer {
  background-color: #fdd000;
  color: #0086a7;
  padding-block: 5.75rem;
  padding-inline: clamp(5rem, 2.436440678rem + 4.2372881356vw, 6.25rem);
}
@media screen and (max-width: 967px) {
  .l-footer {
    padding-block: 2.625rem 4rem;
    padding-inline: clamp(1.75rem, -0.1896551724rem + 8.275862069vw, 2.5rem);
  }
}
.l-footer__inner {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 967px) {
  .l-footer__inner {
    flex-direction: column;
    row-gap: 58px;
  }
}
.l-footer__logo-wrapper {
  display: flex;
  align-items: start;
  width: clamp(7.5rem, -4.5487288136rem + 19.9152542373vw, 13.375rem);
}
@media screen and (max-width: 967px) {
  .l-footer__logo-wrapper {
    margin-inline: auto;
  }
}
.l-footer__nav {
  margin-block-end: 1.5rem;
}
.l-footer__heading {
  font-size: clamp(2rem, 0.9745762712rem + 1.6949152542vw, 2.5rem);
  font-weight: 600;
  letter-spacing: 0.16em;
}
@media screen and (max-width: 574px) {
  .l-footer__heading {
    font-size: clamp(1.75rem, -0.1896551724rem + 8.275862069vw, 2.5rem);
  }
}
.l-footer__subtitle {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  position: relative;
}
.l-footer__subtitle::before {
  position: absolute;
  content: "｜";
  left: -16px;
  bottom: 0;
}
.l-footer__category-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-block: 0.9375rem 3.25rem;
  margin-inline-start: 0.5625rem;
}
.l-footer__category-item {
  font-size: clamp(1.25rem, 0.7372881356rem + 0.8474576271vw, 1.5rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: clamp(1.75rem, 0.1336206897rem + 6.8965517241vw, 2.375rem);
}
@media screen and (max-width: 967px) {
  .l-footer__category-item {
    font-size: clamp(1.25rem, 0.6034482759rem + 2.7586206897vw, 1.5rem);
  }
}
.l-footer__category-item::before {
  content: "-";
}
.l-footer__right {
  display: flex;
  flex-direction: column;
  justify-content: end;
  align-items: end;
  gap: 2.4375rem;
}
.l-footer__park-link {
  max-width: 428px;
  width: clamp(18.75rem, 2.343220339rem + 27.1186440678vw, 26.75rem);
  margin-inline: auto;
}
@media screen and (max-width: 967px) {
  .l-footer__park-link {
    width: 100%;
  }
}
.l-footer__copyright {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  margin-inline-end: 0.1875rem;
}
@media screen and (max-width: 967px) {
  .l-footer__copyright {
    margin-inline: auto;
  }
}

.l-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
  background-color: #fdd000;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-inline: 36px 23px;
  height: 60px;
  transition: transform 0.3s ease;
}
@media screen and (max-width: 767px) {
  .l-header {
    height: 100px;
  }
}
@media screen and (max-width: 574px) {
  .l-header {
    padding-inline-start: 36px;
  }
}
.l-header__logo-image {
  width: 55px;
  height: auto;
}
.l-header__logo-image--pc {
  width: 278px;
}
.l-header__nav-wrapper {
  background-color: #fff;
  border-radius: 0.625rem;
  width: 423px;
  height: 37px;
}
.l-header__nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-inline: 22px;
  height: 100%;
}
.l-header__category {
  display: flex;
  align-items: center;
}
.l-header__category-list {
  display: flex;
  align-items: center;
  gap: clamp(0.5rem, 0.3571428571rem + 0.2976190476vw, 0.625rem);
  letter-spacing: 0.2em;
  gap: 16px;
  margin-inline-start: 23px;
}
.l-header__category-icon path {
  fill: #fdd000;
}
.l-header__category-icon:hover path {
  fill: #00b1dd;
}
.l-header__heading {
  font-size: 1rem;
  color: #0086a7;
  letter-spacing: 0.16em;
  font-weight: 600;
  line-height: 1;
  transform: translateY(0.12em);
}
.l-header__access {
  display: block;
}
.l-header__hamburger-btn {
  position: fixed;
  top: 22px;
  right: 20px;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 1.625rem;
  z-index: 500;
  border: none;
  padding: 0;
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
}
.l-header__hamburger-line {
  background-color: #fdd000;
  width: 1.5625rem;
  height: 0.1875rem;
  position: relative;
  transition: background-color 0.3s ease;
}
.l-header__hamburger-line::before, .l-header__hamburger-line::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 0.1875rem;
  background-color: #fdd000;
  transition: all 0.3s ease;
  transform-origin: center;
}
.l-header__hamburger-line::before {
  top: -0.5rem;
}
.l-header__hamburger-line::after {
  bottom: -0.5rem;
  width: 1.125rem;
}
.l-header__hamburger-btn[aria-expanded=true] .l-header__hamburger-line {
  background-color: transparent;
}
.l-header__hamburger-btn[aria-expanded=true] .l-header__hamburger-line::before, .l-header__hamburger-btn[aria-expanded=true] .l-header__hamburger-line::after {
  width: 2.375rem;
  height: 0.125rem;
  left: -5px;
}
.l-header__hamburger-btn[aria-expanded=true] .l-header__hamburger-line::before {
  top: 0;
  transform: rotate(155deg);
}
.l-header__hamburger-btn[aria-expanded=true] .l-header__hamburger-line::after {
  bottom: 0;
  transform: rotate(-155deg);
}
.l-header__mobile-menu {
  position: fixed;
  inset: 0;
  width: auto;
  background-color: #fdd000;
  color: #0086a7;
  transform: translateX(100%);
  transition: transform 0.3s ease-in-out;
  z-index: 100;
  padding-block: 2.625rem 4rem;
  padding-inline: clamp(1.75rem, -0.1896551724rem + 8.275862069vw, 2.5rem);
  display: flex;
  flex-direction: column;
  color: #0086a7;
  row-gap: 3.625rem;
  transform: translateX(200vw);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.l-header__mobile-menu.is-open {
  transform: translateX(0);
}
.l-header__mobile-logo-wrapper {
  display: flex;
  margin-inline: auto;
  width: 120px;
  margin-block-end: 3.625rem;
}
.l-header__mobile-nav {
  flex-direction: column;
  margin-block-end: 1.5rem;
}
.l-header__mobile-heading {
  font-size: clamp(2rem, 0.7068965517rem + 5.5172413793vw, 2.5rem);
  font-weight: 600;
  letter-spacing: 0.16em;
}
.l-header__mobile-subtitle {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  position: relative;
}
.l-header__mobile-subtitle::before {
  position: absolute;
  content: "｜";
  bottom: 4px;
  left: -16px;
}
.l-header__mobile-category-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-block: 1rem 3.25rem;
  margin-inline-start: 0.5625rem;
}
.l-header__mobile-category-item {
  font-size: clamp(1.25rem, 0.6034482759rem + 2.7586206897vw, 1.5rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: clamp(1.75rem, 0.1336206897rem + 6.8965517241vw, 2.375rem);
}
.l-header__mobile-category-item::before {
  content: "-";
}
.l-header__mobile-under {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.4375rem;
}
.l-header__mobile-copyright {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.08em;
}
.l-header__menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 18;
}
.l-header__menu-overlay.is-active {
  opacity: 1;
  visibility: visible;
}

body.menu-open {
  overflow: hidden;
}

.c-sec-title {
  position: relative;
}
@media screen and (max-width: 767px) {
  .c-sec-title {
    margin-inline-start: 1.4375rem;
  }
}
.c-sec-title ::after {
  position: absolute;
  content: "";
  width: clamp(2rem, 1.3352601156rem + 1.8497109827vw, 3rem);
  height: calc(100% + 19px);
  background-color: #fdd000;
  top: -12px;
  left: -19px;
  transform: translateX(-100%);
}
@media screen and (max-width: 767px) {
  .c-sec-title ::after {
    left: -8px;
  }
}
.c-sec-title__image {
  width: clamp(23.125rem, 16.5191473988rem + 18.3815028902vw, 33.0625rem);
  margin-block-end: clamp(0.75rem, 0.4176300578rem + 0.9248554913vw, 1.25rem);
}
.c-sec-title__image--access {
  width: clamp(16.375rem, 11.7218208092rem + 12.9479768786vw, 23.375rem);
}
.c-sec-title__subtitle {
  font-size: clamp(1.25rem, 0.7514450867rem + 1.387283237vw, 2rem);
  font-weight: 500;
  margin-inline-start: 0.25rem;
  letter-spacing: 0.16em;
}

.c-container {
  box-sizing: border-box;
  width: 1042px;
  margin-inline: auto;
}
@media screen and (max-width: 1439px) {
  .c-container {
    margin-inline: 12.8%;
    width: unset;
  }
}
@media screen and (max-width: 967px) {
  .c-container {
    margin-inline: clamp(4.625rem, -7.375rem + 25vw, 7.75rem);
  }
}
@media screen and (max-width: 767px) {
  .c-container {
    margin-inline: 12px;
    width: unset;
  }
}
@media screen and (max-width: 767px) {
  .c-container--product-section {
    margin-inline: 74px 12px;
  }
}
.c-container--sunflower {
  position: relative;
}
.c-container--sunflower::before {
  position: absolute;
  content: "";
  background-image: url("../img/commons/fig_sunf.svg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  top: -31px;
  right: -45px;
  width: clamp(19.5rem, 12.06rem + 15.5vw, 21.4375rem);
  height: clamp(19.125rem, 11.685rem + 15.5vw, 21.0625rem);
}
@media screen and (max-width: 574px) {
  .c-container--sunflower::before {
    display: none;
  }
}
.c-container--kurosengoku {
  position: relative;
}
.c-container--kurosengoku::before {
  position: absolute;
  content: "";
  background-image: url("../img/commons/fig_stone.svg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  top: -44px;
  right: -66px;
  width: clamp(17.1875rem, -3.9325rem + 44vw, 22.6875rem);
  height: clamp(17.1875rem, -3.9325rem + 44vw, 22.6875rem);
}
@media screen and (max-width: 574px) {
  .c-container--kurosengoku::before {
    display: none;
  }
}
.c-container--rice {
  position: relative;
}
.c-container--rice::before {
  position: absolute;
  content: "";
  background-image: url("../img/commons/fig_rice.svg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  top: -54px;
  right: -50px;
  width: clamp(13.8125rem, -10.1875rem + 50vw, 20.0625rem);
  height: clamp(18.0625rem, -12.4175rem + 63.5vw, 26rem);
}
@media screen and (max-width: 574px) {
  .c-container--rice::before {
    display: none;
  }
}
.c-container--local-food {
  position: relative;
}
.c-container--local-food::before {
  position: absolute;
  content: "";
  background-image: url("../img/commons/fig_place.svg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  top: -52px;
  right: -91px;
  width: clamp(14.4375rem, -9.7691062176rem + 67.3575129534vw, 22.5625rem);
  height: clamp(15.875rem, -10.1936528497rem + 72.5388601036vw, 24.625rem);
}
@media screen and (max-width: 574px) {
  .c-container--local-food::before {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .c-container--access {
    margin-inline: 30px;
  }
}

.c-product {
  margin-block-end: 5rem;
}
.c-product__title {
  position: relative;
  z-index: 2;
  font-size: clamp(1.5rem, 1.1676300578rem + 0.9248554913vw, 2rem);
  font-weight: 700;
  letter-spacing: 0.16em;
  border-block-end: 2px solid #f7b11e;
  padding-block-end: 1.125rem;
  padding-inline-start: 0.3125rem;
  margin-block-end: 0.5rem;
}
.c-product__title-accent {
  font-size: clamp(2.625rem, 1.6551724138rem + 4.1379310345vw, 3rem);
  color: #00b1dd;
  font-weight: 900;
  letter-spacing: 0.06em;
  padding-inline-end: 0.375rem;
}
.c-product__desc {
  font-size: clamp(1rem, 0.8338150289rem + 0.4624277457vw, 1.25rem);
  line-height: clamp(1.5rem, 1.3338150289rem + 0.4624277457vw, 1.75rem);
  line-height: clamp(2rem, 1.8338150289rem + 0.4624277457vw, 2.25rem);
  letter-spacing: 0.04em;
  font-weight: 500;
  padding-inline-start: 6px;
  margin-block-end: clamp(1.625rem, 0.710982659rem + 2.5433526012vw, 3rem);
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 574px) {
  .c-product__desc {
    padding-inline-start: 10px;
  }
}
.c-product__box {
  position: relative;
  z-index: 2;
  background-color: #fff;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.25);
  padding-block: clamp(1.375rem, -10.145rem + 24vw, 4.375rem) clamp(3rem, -2.76rem + 12vw, 4.5rem);
  padding-inline: clamp(1.25rem, -20.83rem + 46vw, 7rem);
  border-radius: 32px;
  margin-block-end: 7.375rem;
  margin-inline: auto;
  box-sizing: border-box;
  width: calc(100% - 8px);
}
@media screen and (max-width: 767px) {
  .c-product__box {
    padding-block: 1.375rem 3rem;
  }
}
.c-product__pickup {
  box-sizing: border-box;
  padding-inline: clamp(0rem, -7.7142857143rem + 16.0714285714vw, 6.75rem);
  width: 100%;
}
.c-product__pickup-title {
  position: relative;
  z-index: 2;
  width: clamp(11.6875rem, -29.3525rem + 85.5vw, 22.375rem);
  padding-inline-end: clamp(0rem, -0.9971098266rem + 2.774566474vw, 1.5rem);
  margin-block-end: clamp(-4.375rem, 4.3975rem + -14.5vw, -2.5625rem);
  margin-inline: auto;
}
.c-product__pickup-product-title {
  font-size: clamp(1.25rem, 0.7514450867rem + 1.387283237vw, 2rem);
  font-weight: 700;
  margin-block: 1.5rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .c-product__pickup-product-title {
    margin-block: 2.25rem 1rem;
    text-align: left;
  }
}
.c-product__pickup-product-splide {
  padding-block-end: 3.4375rem;
  margin-block-end: 2.1875rem;
}
.c-product__pickup-product-splide .splide__track {
  overflow: hidden !important;
}
.c-product__pickup-product-splide .splide__list {
  will-change: transform;
}
.c-product__pickup-product-desc {
  font-weight: 500;
  font-size: clamp(0.875rem, 0.7088150289rem + 0.4624277457vw, 1.125rem);
  line-height: clamp(1.5rem, 1.0014450867rem + 1.387283237vw, 2.25rem);
  border-block: 2px solid #f7b11e;
  padding-block-start: clamp(0.5625rem, -0.1690521628rem + 2.0356234097vw, 1.0625rem);
  padding-block-end: 1.5rem;
  padding-inline: 0.5625rem 1.1875rem;
}
@media screen and (max-width: 767px) {
  .c-product__pickup-product-desc {
    padding-inline: 0.25rem 0.25rem;
  }
}
.c-product__pickup-product-price {
  font-size: clamp(1rem, 0.8338150289rem + 0.4624277457vw, 1.25rem);
  line-height: clamp(1.5rem, 1.3338150289rem + 0.4624277457vw, 1.75rem);
  font-weight: 700;
  padding-block: 0.8125rem 0.375rem;
  padding-inline-start: clamp(0.125rem, -0.0827312139rem + 0.5780346821vw, 0.4375rem);
}
@media screen and (max-width: 767px) {
  .c-product__pickup-product-price {
    padding-block-start: 0.375rem;
  }
}
.c-product__pickup-product-price:has(+ .c-product__check) {
  margin-block-end: clamp(3.9375rem, 0.8175rem + 6.5vw, 4.75rem);
}
.c-product__pickup-product-price-value {
  padding-inline-start: 1em;
  font-weight: 500;
  font-size: clamp(1rem, 0.6676300578rem + 0.9248554913vw, 1.5rem);
  line-height: clamp(2rem, 1.6676300578rem + 0.9248554913vw, 2.5rem);
}
.c-product__list-title {
  display: block;
  width: calc(100% - 0.875rem);
  color: #fff;
  font-size: clamp(1rem, 0.8338150289rem + 0.4624277457vw, 1.25rem);
  line-height: clamp(1.5rem, 1.3338150289rem + 0.4624277457vw, 1.75rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  padding-block: 0.75rem;
  padding-inline-start: 0.875rem;
}
.c-product__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -moz-column-gap: clamp(1.125rem, -0.7321428571rem + 3.869047619vw, 2.75rem);
       column-gap: clamp(1.125rem, -0.7321428571rem + 3.869047619vw, 2.75rem);
  row-gap: clamp(1.125rem, -1.515rem + 5.5vw, 1.8125rem);
}
@media screen and (max-width: 767px) {
  .c-product__list {
    grid-template-columns: repeat(2, 1fr);
    -moz-column-gap: 18px;
         column-gap: 18px;
    row-gap: 24px;
  }
}
.c-product__list-item {
  display: flex;
  flex-direction: column;
  cursor: pointer;
}
.c-product__list-item-image {
  margin-block-end: 0.8125rem;
  width: 100%;
}
.c-product__list-item-title {
  font-size: clamp(0.875rem, 0.6257225434rem + 0.6936416185vw, 1.25rem);
  font-weight: 700;
  line-height: clamp(1.25rem, 0.8345375723rem + 1.1560693642vw, 1.875rem);
  padding-block-end: clamp(0rem, -0.7478323699rem + 2.0809248555vw, 1.125rem);
}
.c-product__list-item-price {
  font-size: clamp(0.875rem, 0.7919075145rem + 0.2312138728vw, 1rem);
  font-weight: 700;
  line-height: 2.375rem;
  margin-block-start: auto;
}
.c-product__check {
  display: none;
}
.c-product__content {
  visibility: hidden;
  overflow: hidden;
  display: none;
  padding-block-start: clamp(1.4375rem, 0.2326589595rem + 3.3526011561vw, 3.25rem);
  padding-inline: 0.3125rem;
}
.c-product__check:checked ~ .c-product__content {
  visibility: visible;
  height: auto;
  opacity: 1;
  display: block;
}
.c-product__button {
  position: relative;
  background-color: #f7b11e;
  display: flex;
  align-items: center;
}
.c-product__button::after {
  position: absolute;
  content: url("../img/top/angle_down.svg");
  top: 50%;
  right: 26px;
  transform: translateY(-60%);
  width: 1rem;
  height: 0.5rem;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .c-product__button::after {
    left: unset;
    right: 18px;
  }
}
@media screen and (max-width: 574px) {
  .c-product__button::after {
    transform: translateY(-70%) scale(0.8);
  }
}
.c-product__button__check:checked ~ .c-product__button::after {
  transform: scaleY(-1) translateY(2px);
}

.p-fv {
  margin-block-end: clamp(3.625rem, -3.4507772021rem + 19.689119171vw, 6rem);
  position: relative;
}
.p-fv__upper-inner {
  display: flex;
  position: relative;
  margin-block-end: 65px;
}
@media screen and (max-width: 767px) {
  .p-fv__upper-inner {
    margin-block-end: -12px;
  }
}
.p-fv__menu {
  width: 390px;
  height: 925px;
  background-color: #fdd000;
  color: #0086a7;
  padding-block-start: 64px;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  .p-fv__menu {
    height: 0;
  }
}
.p-fv__logo-image {
  margin-block-end: 5.875rem;
  width: 180px;
}
.p-fv__nav {
  padding-inline-end: 37px;
}
.p-fv__heading {
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: 0.16em;
}
.p-fv__category-list {
  display: flex;
  flex-direction: column;
  gap: 2.125rem;
  margin-block-start: 32px;
  margin-block-end: 61px;
}
.p-fv__category-item {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}
.p-fv__category-item::before {
  content: "-";
}
.p-fv__access {
  margin-block-end: 4.375rem;
}
.p-fv__main {
  width: calc(100% - 390px);
  position: relative;
  display: flex;
  justify-content: right;
  align-items: start;
  padding-inline-end: 41px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-fv__main {
    width: 100vw;
    height: clamp(32.125rem, 4.6917938931rem + 117.048346056vw, 60.875rem);
  }
}
@media screen and (max-width: 574px) {
  .p-fv__main {
    padding-inline-end: 19px;
  }
}
.p-fv__main-bg {
  position: absolute;
  top: -23vw;
  right: -16vw;
  width: clamp(43.875rem, -25.8538135593rem + 115.2542372881vw, 77.875rem);
  height: clamp(45.125rem, -22.0402542373rem + 111.0169491525vw, 77.875rem);
  z-index: 30;
}
@media screen and (max-width: 967px) {
  .p-fv__main-bg {
    top: clamp(-17.5rem, -38.14rem + 43vw, -12.125rem);
    right: clamp(-18.75rem, -53.55rem + 72.5vw, -9.6875rem);
  }
}
@media screen and (max-width: 767px) {
  .p-fv__main-bg {
    width: clamp(26.75rem, -2.7108778626rem + 125.6997455471vw, 57.625rem);
    height: clamp(26.75rem, -2.5319656489rem + 124.9363867684vw, 57.4375rem);
    top: 56px;
    right: unset;
    left: 0;
  }
}
.p-fv__main-title {
  padding-block-start: clamp(5.375rem, -5.3919491525rem + 17.7966101695vw, 10.625rem);
  position: relative;
  z-index: 31;
  display: flex;
  flex-direction: row-reverse;
  align-items: start;
  align-self: flex-start;
  height: auto;
  min-height: 0;
  block-size: auto;
  gap: clamp(0.6875rem, 0.0227601156rem + 1.8497109827vw, 1.6875rem);
}
@media screen and (max-width: 767px) {
  .p-fv__main-title {
    padding-block-start: clamp(7.5rem, -7.5323275862rem + 64.1379310345vw, 13.3125rem);
  }
}
.p-fv__main-title-line {
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-size: clamp(2.25rem, 0.7118644068rem + 2.5423728814vw, 3rem);
  color: #fff;
  font-weight: 700;
  background-color: #00b1dd;
  width: clamp(3.5rem, 2.2536127168rem + 3.4682080925vw, 5.375rem);
  letter-spacing: 0.25em;
  display: flex;
  align-items: center;
  padding-block: clamp(0.5rem, 0.2091763006rem + 0.8092485549vw, 0.9375rem);
  padding-inline-start: 1.5rem;
  padding-inline-end: 2rem;
  white-space: nowrap;
  word-break: keep-all;
  line-break: strict;
  block-size: -moz-max-content;
  block-size: max-content;
  flex: 0 0 auto;
}
@media screen and (max-width: 967px) {
  .p-fv__main-title-line {
    font-size: 2.5rem;
  }
}
@media screen and (max-width: 574px) {
  .p-fv__main-title-line {
    font-size: clamp(2rem, 0.7068965517rem + 5.5172413793vw, 2.5rem);
    padding-inline: 1rem;
  }
}
.p-fv__main-title-line--indent {
  margin-inline-start: 3em;
  padding-inline-end: 0;
}
@media screen and (max-width: 574px) {
  .p-fv__main-title-line--indent {
    margin-inline-start: 2.5em;
  }
}
@media screen and (max-width: 767px) {
  .p-fv__main-punct {
    display: inline-block;
    margin-inline-end: -0.4em;
  }
}
.p-fv__intro {
  background-size: contain;
}
@media screen and (max-width: 967px) {
  .p-fv__intro {
    background-position-y: center;
    background-size: 100% auto;
  }
}
@media screen and (max-width: 767px) {
  .p-fv__intro {
    background-size: 100% auto;
  }
}
.p-fv__intro-bg {
  position: relative;
  width: 100%;
}
.p-fv__intro-bg-image {
  position: absolute;
  top: 120px;
  left: 50%;
  transform: translate(-50%, -23%);
  width: 100%;
  height: auto;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-fv__intro-bg-image {
    top: -20px;
  }
}
.p-fv__intro-logo {
  margin-block-end: 17px;
}
.p-fv__intro-desc {
  font-size: clamp(1rem, 0.6676300578rem + 0.9248554913vw, 1.5rem);
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: clamp(2.25rem, 1.0489130435rem + 3.6956521739vw, 4.375rem);
  padding-block-start: clamp(2.5rem, 3.9130434783rem + -4.347826087vw, 0rem);
  padding-inline-start: 10px;
}
@media screen and (max-width: 767px) {
  .p-fv__intro-desc {
    margin-inline-start: clamp(1.25rem, -0.6896551724rem + 8.275862069vw, 2rem);
  }
}
.p-fv__intro-desc-accent {
  font-weight: 700;
  background-color: #00b1dd;
  color: #fff;
  font-size: clamp(1.25rem, 0.7514450867rem + 1.387283237vw, 2rem);
}
.p-fv__intro-desc--note {
  font-size: clamp(0.5rem, 0.1676300578rem + 0.9248554913vw, 1rem);
  padding-block-start: 0;
  padding-block-end: clamp(0rem, -1.7663043478rem + 5.4347826087vw, 3.125rem);
}

.p-products {
  overflow-x: hidden;
}
.p-products__indicator {
  position: fixed;
  top: 104px;
  left: calc(50vw - 521px - 48px - 7px);
  background-color: #fff;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.25);
  border-radius: 24px;
  width: 48px;
  height: 200px;
  display: none;
  flex-direction: column;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: 100;
}
@media screen and (max-width: 1439px) {
  .p-products__indicator {
    left: calc(12.8% - 48px - 10px);
  }
}
@media screen and (max-width: 967px) {
  .p-products__indicator {
    left: clamp(1rem, -11rem + 25vw, 4.125rem);
  }
}
@media screen and (max-width: 767px) {
  .p-products__indicator {
    left: 14px;
  }
}
.p-products__category-list {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.2em;
  gap: 12px;
}
.p-products__category-item.is-active .p-products__category-icon path {
  fill: #00b1dd;
}
.p-products__category-icon path {
  fill: #fdd000;
  transition: fill 0.2s ease;
}
.p-products__category-icon:hover path {
  fill: #00b1dd;
  transition: fill 0.2s ease;
}
.p-products-section--sunflower {
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-products-section--sunflower {
    overflow-y: visible;
  }
}
@media screen and (max-width: 574px) {
  .p-products-section--sunflower::before {
    position: absolute;
    content: "";
    background-image: url("../img/commons/fig_sunf.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    top: -17px;
    right: -86px;
    width: clamp(13.9375rem, 4.724137931rem + 39.3103448276vw, 17.5rem);
    height: clamp(13.75rem, 4.8599137931rem + 37.9310344828vw, 17.1875rem);
  }
}
.p-products-section--kurosengoku {
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-products-section--kurosengoku {
    overflow-y: visible;
  }
}
@media screen and (max-width: 574px) {
  .p-products-section--kurosengoku::before {
    position: absolute;
    content: "";
    background-image: url("../img/commons/fig_stone.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    top: -13px;
    right: -114px;
    width: clamp(13.75rem, 4.8599137931rem + 37.9310344828vw, 17.1875rem);
    height: clamp(13.75rem, 4.8599137931rem + 37.9310344828vw, 17.1875rem);
  }
}
.p-products-section--rice {
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-products-section--rice {
    overflow-y: visible;
  }
}
@media screen and (max-width: 574px) {
  .p-products-section--rice::before {
    position: absolute;
    content: "";
    background-image: url("../img/commons/fig_rice.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    top: -6px;
    right: -56px;
    width: clamp(11rem, 3.7262931034rem + 31.0344827586vw, 13.8125rem);
    height: clamp(14.4375rem, 5.0625rem + 40vw, 18.0625rem);
  }
}
.p-products-section--local-food {
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-products-section--local-food {
    overflow-y: visible;
  }
}
@media screen and (max-width: 574px) {
  .p-products-section--local-food::before {
    position: absolute;
    content: "";
    background-image: url("../img/commons/fig_place.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    top: -9px;
    right: -70px;
    width: clamp(11.5rem, 3.9030172414rem + 32.4137931034vw, 14.4375rem);
    height: clamp(12.6875rem, 4.4439655172rem + 35.1724137931vw, 15.875rem);
  }
}

.p-products-category {
  margin-block-end: 11.875rem;
}
@media screen and (max-width: 767px) {
  .p-products-category {
    margin-block-end: 6.5625rem;
  }
}
.p-products-category__list {
  display: flex;
  -moz-column-gap: clamp(1.5rem, -5.22rem + 14vw, 3.25rem);
       column-gap: clamp(1.5rem, -5.22rem + 14vw, 3.25rem);
  width: 100%;
  margin-block-start: clamp(2.125rem, -4.355rem + 13.5vw, 3.8125rem);
}
@media screen and (max-width: 767px) {
  .p-products-category__list {
    position: relative;
    height: 108vw;
    -moz-column-gap: 5%;
         column-gap: 5%;
  }
}
.p-products-category__link {
  display: flex;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-products-category__link {
    display: block;
  }
}
.p-products-category__link:hover path {
  fill: #00b1dd;
  stroke: #00b1dd;
}
.p-products-category__link:hover .p-products-category__name {
  color: #fff;
}
.p-products-category__item {
  transition: fill 0.2s ease;
}
@media screen and (max-width: 767px) {
  .p-products-category__item {
    position: absolute;
  }
}
.p-products-category__item--1 {
  padding-block-start: 2.3%;
  padding-inline-start: 1.4%;
}
.p-products-category__item--1 .p-products-category__icon {
  width: clamp(10.625rem, 3.3188559322rem + 12.0762711864vw, 14.1875rem);
}
@media screen and (max-width: 767px) {
  .p-products-category__item--1 {
    top: 0;
    left: 3.6%;
  }
  .p-products-category__item--1 .p-products-category__icon {
    width: clamp(10.1875rem, -0.1573275862rem + 44.1379310345vw, 14.1875rem);
  }
}
.p-products-category__item--2 {
  padding-block-start: 0.3%;
  padding-inline-end: 1.1%;
}
.p-products-category__item--2 .p-products-category__icon {
  width: clamp(9.1875rem, 2.7786016949rem + 10.593220339vw, 12.3125rem);
}
@media screen and (max-width: 767px) {
  .p-products-category__item--2 {
    top: 22%;
    right: 3.4%;
  }
  .p-products-category__item--2 .p-products-category__icon {
    width: clamp(8.875rem, -0.0150862069rem + 37.9310344828vw, 12.3125rem);
  }
}
.p-products-category__item--3 {
  padding-block-start: 3.6%;
  padding-inline-end: 0.2%;
}
.p-products-category__item--3 .p-products-category__icon {
  width: clamp(7.875rem, 2.3633474576rem + 9.1101694915vw, 10.5625rem);
}
@media screen and (max-width: 767px) {
  .p-products-category__item--3 {
    top: 48vw;
    left: 5.1%;
  }
  .p-products-category__item--3 .p-products-category__icon {
    width: clamp(7.5625rem, -0.1961206897rem + 33.1034482759vw, 10.5625rem);
  }
}
.p-products-category__item--4 .p-products-category__icon {
  width: clamp(9.125rem, 2.844279661rem + 10.3813559322vw, 12.1875rem);
}
@media screen and (max-width: 767px) {
  .p-products-category__item--4 {
    top: 67vw;
    right: 7.3%;
  }
  .p-products-category__item--4 .p-products-category__icon {
    width: clamp(7.5rem, -4.6228448276rem + 51.724137931vw, 12.1875rem);
  }
}
.p-products-category__name {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #00b1dd;
  font-size: clamp(1.25rem, 0.9642857143rem + 0.5952380952vw, 1.5rem);
  font-weight: 900;
}
@media screen and (max-width: 767px) {
  .p-products-category__name {
    font-size: clamp(1.25rem, 0.6034482759rem + 2.7586206897vw, 1.5rem);
  }
}
.p-products-category__name-caption {
  font-size: 1rem;
  font-weight: 500;
  display: block;
  padding-block-start: 4px;
  white-space: nowrap;
}

.p-access__image {
  margin-block-start: 3.125rem;
  margin-block-end: 2.75rem;
}
.p-access__table {
  font-size: clamp(0.875rem, 0.6257225434rem + 0.6936416185vw, 1.25rem);
  font-weight: 500;
  margin-block-end: 1.5rem;
}
.p-access__table-row {
  height: 53px;
}
@media screen and (max-width: 574px) {
  .p-access__table-row {
    height: 37px;
  }
}
@media screen and (max-width: 519px) {
  .p-access__table-row {
    height: 80px;
  }
}
.p-access__table-row:not(:last-child) .p-access__table-data {
  border-block-end: 2px solid #fdd000;
}
.p-access__table-heading {
  width: clamp(12.5rem, -9.82rem + 46.5vw, 18.3125rem);
  height: 53px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fdd000;
  color: #fff;
  letter-spacing: 0.16em;
}
@media screen and (max-width: 767px) {
  .p-access__table-heading {
    width: 130px;
  }
}
@media screen and (max-width: 574px) {
  .p-access__table-heading {
    height: 37px;
  }
}
@media screen and (max-width: 519px) {
  .p-access__table-heading {
    height: 80px;
  }
}
.p-access__table-heading:not(:last-child) {
  border-block-end: 2px solid #fff;
}
.p-access__table-heading--high {
  height: 80px;
}
@media screen and (max-width: 574px) {
  .p-access__table-heading--high {
    height: 56px;
  }
}
@media screen and (max-width: 519px) {
  .p-access__table-heading--high {
    height: 80px;
  }
}
.p-access__table-data {
  width: 100%;
  padding-inline-start: 47px;
  padding-block: 8px;
  letter-spacing: 0.08em;
  vertical-align: middle;
  line-height: 2rem;
}
@media screen and (max-width: 767px) {
  .p-access__table-data {
    padding-inline-start: 1.3125rem;
    line-height: 1.25rem;
  }
}
.p-access__image-wrapper {
  margin-block: 44px 41px;
}
@media screen and (max-width: 574px) {
  .p-access__image-wrapper {
    margin-block: 36px 16px;
  }
}
.p-access__image {
  aspect-ratio: 1034/440;
}
@media screen and (max-width: 574px) {
  .p-access__image {
    aspect-ratio: 460/307;
  }
}
.p-access__map-wrapper {
  width: 100%;
  aspect-ratio: 1000/330;
  margin-block-end: 6.9375rem;
}
.p-access__map {
  width: 100%;
}

.p-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100dvh;
  z-index: 1000;
  display: none;
  overflow: visible;
}
.p-modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
}
.p-modal__body {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: min(100% - 48px, 810px);
  height: min(100vh - 48px, 870px);
  padding: 0;
  background: none;
  border-radius: 0;
  box-shadow: none;
}
@media screen and (max-width: 967px) {
  .p-modal__body {
    width: min(100% - 48px, 440px);
  }
}
@media screen and (max-width: 574px) {
  .p-modal__body {
    height: min(100vh - 48px, 500px);
    max-width: 440px;
  }
}
.p-modal__btn {
  position: absolute;
  top: -16px;
  right: -28px;
  width: 98px;
  height: 98px;
  border-radius: 49px;
  background: #fff;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.25);
  display: grid;
  place-items: center;
  z-index: 2;
}
@media screen and (max-width: 967px) {
  .p-modal__btn {
    top: -21px;
    right: -21px;
    width: 64px;
    height: 64px;
    border-radius: 32px;
  }
}
.p-modal__closs-icon {
  width: 37.5px;
  height: 37.5px;
}
@media screen and (max-width: 574px) {
  .p-modal__closs-icon {
    width: 24px;
    height: 24px;
  }
}
.p-modal__inner {
  background: #fff;
  border-radius: 32px;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.25);
  padding-block: 95px 76px;
  padding-inline: 93px;
  flex: 1 1 auto;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  min-height: 0;
  min-width: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable both-edges;
}
@media screen and (max-width: 574px) {
  .p-modal__inner {
    padding-block: 43px 19px;
    padding-inline: 36px;
  }
}
.p-modal__image {
  display: block;
  width: 100%;
  height: auto;
}
.p-modal__title {
  font-size: clamp(1.5rem, 0.8352601156rem + 1.8497109827vw, 2.5rem);
  font-weight: 700;
  margin-block: 1rem;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.p-modal__content {
  font-size: clamp(0.875rem, 0.6257225434rem + 0.6936416185vw, 1.25rem);
  line-height: clamp(1.5rem, 0.8352601156rem + 1.8497109827vw, 2.5rem);
  font-weight: 500;
  border-block: 2px solid #f7b11e;
  padding-block: 1.0625rem 0.8125rem;
  padding-inline: 9px 19px;
  overflow-wrap: anywhere;
  word-break: break-word;
}
@media screen and (max-width: 574px) {
  .p-modal__content {
    padding-inline: 4px;
  }
}
.p-modal__price {
  font-size: 1.25rem;
  font-weight: 700;
  padding-block: 0.8125rem 0.375rem;
  padding-inline-start: 7px;
  overflow-wrap: anywhere;
  word-break: break-word;
}
@media screen and (max-width: 574px) {
  .p-modal__price {
    padding-block-start: 0.375rem;
  }
}
.p-modal__price-value {
  font-weight: 500;
  font-size: clamp(1rem, 0.6676300578rem + 0.9248554913vw, 1.5rem);
  line-height: clamp(2rem, 1.6676300578rem + 0.9248554913vw, 2.5rem);
  padding-inline-start: 1em;
}

.u-tac {
  text-align: center;
}

.u-tar {
  text-align: right;
}

.u-taj {
  text-align: justify;
}

.u-font-secondary {
  font-family: "Josefin Sans", sans-serif;
}

.u-font-lato {
  font-family: "Lato", sans-serif;
}

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

@media screen and (max-width: 519px) {
  .u-sp-comp-up {
    display: none;
  }
}

@media screen and (min-width: 460px) {
  .u-460 {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .u-mobile {
    display: none;
  }
}

.u-hover-opacity07:hover {
  opacity: 0.7;
}/*# sourceMappingURL=style.css.map */