@charset "UTF-8";
/* ==============================
   Foundation
   ============================== */
/**
 * 例：
 * @include sp { ... }
 * @include pc { ... }
 */
html {
  font-size: 16px;
}

/**
 * fluid-type()
 * 375〜1200pxの間で minPX→maxPX に線形スケールし、範囲外はclampで頭打ち
 * @param $min-px  最小フォントサイズ(px)
 * @param $max-px  最大フォントサイズ(px)
 * @param $min-vw  スケール開始幅(px) default:375px
 * @param $max-vw  スケール終了幅(px) default:1200px
 * @param $lh      行間(任意)
 */
/* ============================
   用途別ミックスイン（推奨値）
   ※ 企業サイト向けに控えめなスケール
   ============================ */
/* 変数・mixinをグローバル風に */
/* 使っていれば併用（任意。variablesで@forwardしているなら省略可） */
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  list-style: none;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

/* ==============================
   Foundation
   ============================== */
html,
body {
  height: 100%;
}

body {
  color: #333;
  font-family: "Noto Sans JP", "游ゴシック Medium", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-size: 100%;
  line-height: 1.8;
  font-weight: 400;
}

body.menu-open {
  overflow: hidden;
  touch-action: none;
}

@media (min-width: 768px) {
  body.menu-open {
    overflow: auto; /* 768px以上は固定しない */
    touch-action: auto;
  }
}
h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  line-height: 1.6;
}

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

a {
  color: #333;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
  transition: 0.4s;
}

a:hover g {
  transition: 0.4s;
}

a:hover img {
  transition: 0.4s;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

figure {
  margin: 0;
}

img[data-fancybox] {
  cursor: pointer;
}

/* ==============================
   Layout
   ============================== */
/* ==============================
   Foundation
   ============================== */
/* ==============================
   Foundation
   ============================== */
/* -----------------------------------------------------------
 *  Container mixins
 * ----------------------------------------------------------- */
/* -----------------------------------------------------------
 *  Container classes
 * ----------------------------------------------------------- */
.c-container, .p-contactmain {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .c-container, .p-contactmain {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .c-container, .p-contactmain {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .c-container, .p-contactmain {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}

.c-container-small, .p-tel, .p-form {
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .c-container-small, .p-tel, .p-form {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .c-container-small, .p-tel, .p-form {
    width: 848px;
    margin-right: auto;
    margin-left: auto;
  }
}

/* -----------------------------------------------------------
 *  etc
 * ----------------------------------------------------------- */
.c-pagetitle {
  text-align: center;
  color: #459058;
  padding: 32px 0;
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .c-pagetitle {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .c-pagetitle {
      font-size: 1.875rem;
    }
  }
}
@media (min-width: 768px) {
  .c-pagetitle {
    padding: 64px 0;
    font-size: clamp(1.75rem, var(--fix, 1) * 1.75rem + (12px) * (100vw - 375px) / 825px, 2.5rem);
    line-height: 1.8;
    font-weight: 700;
  }
  @supports not (font-size: clamp(1rem, 1vw, 2rem)) {
    .c-pagetitle {
      font-size: 1.75rem;
    }
    @media (min-width: 768px) and (min-width: 1200px) {
      .c-pagetitle {
        font-size: 2.5rem;
      }
    }
  }
}
.c-pagetitle__en {
  display: block;
  color: #D3A632;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: clamp(1.125rem, var(--fix, 1) * 1.125rem + (4px) * (100vw - 375px) / 825px, 1.375rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .c-pagetitle__en {
    font-size: 1.125rem;
  }
  @media (min-width: 1200px) {
    .c-pagetitle__en {
      font-size: 1.375rem;
    }
  }
}
@media (min-width: 768px) {
  .c-pagetitle__en {
    font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
    line-height: 1.8;
    font-weight: 700;
  }
  @supports not (font-size: clamp(1rem, 1vw, 2rem)) {
    .c-pagetitle__en {
      font-size: 1.375rem;
    }
    @media (min-width: 768px) and (min-width: 1200px) {
      .c-pagetitle__en {
        font-size: 1.875rem;
      }
    }
  }
}

.c-subtitle {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 32px;
}
@media (min-width: 768px) {
  .c-subtitle {
    flex-wrap: nowrap;
  }
}
.c-subtitle__title {
  font-size: 32px;
  font-family: "Noto Serif JP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", HGS明朝E, メイリオ, Meiryo, serif;
  margin-right: 24px;
}
@media (min-width: 768px) {
  .c-subtitle__title {
    font-size: 38px;
  }
}
.c-subtitle__sub {
  font-size: 18px;
}

.c-pagetop {
  position: fixed;
  right: clamp(12px, 2vw, 20px);
  bottom: clamp(12px, 2vw, 20px);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #459058;
  color: #fff;
  display: grid;
  place-items: center;
  text-decoration: none;
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.2s ease, box-shadow 0.2s ease;
  transform: translateY(8px);
}
.c-pagetop.is-show {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.c-pagetop:hover, .c-pagetop:focus-visible {
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.3);
  transform: translateY(-2px);
  outline: none;
}
.c-pagetop__icon {
  width: 48%;
  height: 48%;
  fill: currentColor;
  display: block;
}
.c-pagetop > * {
  pointer-events: none;
}
@media (prefers-reduced-motion: reduce) {
  .c-pagetop {
    transition: none;
    transform: none;
  }
}

.c-pagination {
  margin-top: 32px;
  display: flex;
  justify-content: center;
  width: 100%;
}
@media (min-width: 768px) {
  .c-pagination {
    margin-top: 40px;
  }
}
@media (min-width: 992px) {
  .c-pagination {
    margin-top: 64px;
  }
}
.c-pagination .page-numbers {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 6px;
  padding: 0;
  margin: 0;
  list-style: none;
}
@media (min-width: 768px) {
  .c-pagination .page-numbers {
    gap: 8px;
  }
}
@media (min-width: 992px) {
  .c-pagination .page-numbers {
    gap: 10px;
  }
}
.c-pagination .page-numbers li {
  display: inline-flex;
}
.c-pagination .page-numbers a,
.c-pagination .page-numbers span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  font-size: 13px;
  border: 1px solid #ddd;
  border-radius: 6px;
  color: #333;
  text-decoration: none;
  background-color: #fff;
  line-height: 1;
  transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}
@media (min-width: 768px) {
  .c-pagination .page-numbers a,
  .c-pagination .page-numbers span {
    min-width: 36px;
    height: 36px;
    font-size: 14px;
    padding: 0 10px;
  }
}
@media (min-width: 992px) {
  .c-pagination .page-numbers a,
  .c-pagination .page-numbers span {
    min-width: 40px;
    height: 40px;
    font-size: 15px;
    padding: 0 12px;
  }
}
.c-pagination .page-numbers a:hover,
.c-pagination .page-numbers a:focus {
  border-color: #459058;
  background-color: #f8f8f8;
}
.c-pagination .page-numbers .current {
  font-weight: 700;
  color: #fff;
  background-color: #459058;
  border-color: #459058;
  pointer-events: none;
}
.c-pagination .page-numbers .dots {
  border: none;
  background: none;
  color: #999;
  cursor: default;
}
.c-pagination .page-numbers .prev,
.c-pagination .page-numbers .next {
  font-weight: 700;
}

/* 404 */
.c-404 {
  text-align: center;
  padding: 80px 0;
}
.c-404__title {
  font-size: 1.4rem;
  font-weight: bold;
}
.c-404__sub-title {
  font-size: 1.2rem;
  font-weight: bold;
}
.c-404__txt {
  margin-top: 16px;
}

.c-contact {
  background-color: #D3A632;
  padding: 64px 0 64px;
  --mask:
    radial-gradient(39px at 50% 55px, #000 99%, #0000 101%) calc(50% - 50px) 0/100px 100%,
    radial-gradient(39px at 50% -30px, #0000 99%, #000 101%) 50% 25px/100px 100% repeat-x;
  -webkit-mask: var(--mask);
  mask: var(--mask);
}
@media (min-width: 768px) {
  .c-contact {
    padding: 120px 0 64px;
    --mask: radial-gradient(78.1px at 50% 110px, #000 99%, #0000 101%) calc(50% - 100px) 0/200px 100%,
      radial-gradient(78.1px at 50% -60px, #0000 99%, #000 101%) 50% 50px/200px 100% repeat-x;
    -webkit-mask: var(--mask);
    mask: var(--mask);
  }
}
@media (min-width: 992px) {
  .c-contact__wrap {
    display: flex;
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 24px;
    padding-left: 24px;
  }
}
@media (min-width: 992px) and (min-width: 768px) {
  .c-contact__wrap {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) and (min-width: 992px) {
  .c-contact__wrap {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) and (min-width: 1200px) {
  .c-contact__wrap {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.c-contact__inner {
  color: #fff;
  position: relative;
  text-align: center;
  border-bottom: dotted 1px #fff;
  padding: 24px 0;
}
@media (min-width: 992px) {
  .c-contact__inner {
    width: 66.6666666667%;
    border-bottom: none;
    padding: 0;
  }
}
@media (min-width: 992px) {
  .c-contact__inner::before {
    content: "";
    position: absolute;
    left: -20px;
    top: 0;
    width: 40px;
    /* 線の幅 */
    height: 100%;
    background: radial-gradient(circle at center, #fff 20%, transparent 21%) repeat-y;
    background-size: 40px 20px;
    background-position: left top;
  }
}
@media (min-width: 992px) {
  .c-contact__inner:last-child::after {
    content: "";
    position: absolute;
    right: -20px;
    top: 0;
    width: 40px;
    height: 100%;
    background: radial-gradient(circle at center, #fff 20%, transparent 21%) repeat-y;
    background-size: 40px 20px;
    background-position: right top;
  }
}
.c-contact__title {
  font-size: 24px;
  margin-bottom: 16px;
}
.c-contact__phone a {
  color: #fff;
  text-decoration: none;
}
.c-contact__num {
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .c-contact__num {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .c-contact__num {
      font-size: 1.875rem;
    }
  }
}
.c-contact__btn {
  margin: 0 auto;
}
.c-contact__icon {
  width: 22px;
  height: auto;
  fill: #D3A632;
  vertical-align: middle;
}
.c-contact__btn:hover .c-contact__icon {
  fill: #fff;
}

.c-postnav {
  display: flex;
  gap: 24px;
  justify-content: center;
  margin-bottom: 120px;
  /* hover時にSVGも白に変わるように */
}
.c-postnav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: bold;
  color: #459058;
  text-decoration: none;
  transition: 0.3s ease;
  padding: 12px 24px;
  border: 2px solid #459058;
  border-radius: 30px;
  background: transparent;
}
.c-postnav a:hover {
  background-color: #459058;
  color: #fff;
}
.c-postnav__prev a::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23459058'><polygon points='348.08 0 419.92 71.82 235.74 256 419.92 440.18 348.08 512 92.08 256 348.08 0'/></svg>") no-repeat center/contain;
  margin-right: 8px;
  transition: transform 0.3s ease;
}
.c-postnav__prev a:hover::before {
  transform: translateX(-4px);
  transform: scaleX(-1);
}
.c-postnav__next a::after {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23459058'><polygon points='163.92 0 92.08 71.82 276.26 256 92.08 440.18 163.92 512 419.92 256 163.92 0'/></svg>") no-repeat center/contain;
  margin-left: 8px;
  transition: transform 0.3s ease;
}
.c-postnav__next a:hover::after {
  transform: translateX(4px);
}
.c-postnav__prev a:hover::before, .c-postnav__next a:hover::after {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23fff'><polygon points='163.92 0 92.08 71.82 276.26 256 92.08 440.18 163.92 512 419.92 256 163.92 0'/></svg>");
}

.l-header {
  width: 100%;
  margin: 0 auto;
  border-bottom: solid 1px #459058;
}
.l-header__wrap {
  border-bottom: solid 1px #459058;
}
.l-header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 80px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .l-header__inner {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .l-header__inner {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .l-header__inner {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.l-header__logo {
  width: 320px;
}
.l-header__menu {
  display: flex;
  gap: 16px;
  margin-left: 24px;
}
@media (min-width: 768px) {
  .l-header__menu {
    gap: 24px;
  }
}
.l-header__menulist {
  display: flex;
  align-items: center;
  justify-content: center;
}
.l-header__icon {
  width: 25px;
}
@media (min-width: 768px) {
  .l-header__icon {
    width: 30px;
  }
}
.l-gnav {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  background-color: #fff;
}
.l-gnav.active {
  opacity: 1;
  z-index: 10;
}
.l-gnav__inner {
  display: flex;
  justify-content: space-between;
  width: 100%;
}
@media (min-width: 768px) {
  .l-gnav__inner {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 24px;
    padding-left: 24px;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  .l-gnav__inner {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 768px) and (min-width: 992px) {
  .l-gnav__inner {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 768px) and (min-width: 1200px) {
  .l-gnav__inner {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.l-gnav__list {
  width: 16.6666666667%;
  border-left: solid 1px #459058;
}
.l-gnav__list:last-child {
  border-right: solid 1px #459058;
}
.l-gnav__link {
  height: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.l-gnav__link:hover {
  background-color: #459058;
  text-decoration: none;
  color: #fff;
}
.l-gnav__link--active {
  background-color: #459058;
  color: #fff;
}
.l-gnav__iconwrap {
  width: 100%;
  display: block;
  text-align: center;
}
.l-gnav__icon {
  display: inline-block;
  width: 24px;
  height: 24px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transition: background-image 0.3s ease;
}
.l-gnav__menu {
  font-size: 10px;
  line-height: 14px;
  height: 30px;
  display: block;
  align-content: center;
  text-align: center;
}
@media (min-width: 768px) {
  .l-gnav__menu {
    font-size: 12px;
  }
  .l-gnav__menu br {
    display: none;
  }
}
@media (min-width: 992px) {
  .l-gnav__menu {
    font-size: 14px;
  }
}

.l-gnav__icon--home {
  background-image: url(../images/common/icon_home.png);
}
.l-gnav__link:hover .l-gnav__icon--home, .l-gnav__link--active .l-gnav__icon--home {
  background-image: url(../images/common/icon_home--white.png);
}

.l-gnav__icon--about {
  background-image: url(../images/common/icon_about.png);
}
.l-gnav__link:hover .l-gnav__icon--about, .l-gnav__link--active .l-gnav__icon--about {
  background-image: url(../images/common/icon_about--white.png);
}

.l-gnav__icon--item {
  background-image: url(../images/common/icon_item.png);
}
.l-gnav__link:hover .l-gnav__icon--item, .l-gnav__link--active .l-gnav__icon--item {
  background-image: url(../images/common/icon_item--white.png);
}

.l-gnav__icon--web {
  background-image: url(../images/common/icon_web.png);
}
.l-gnav__link:hover .l-gnav__icon--web, .l-gnav__link--active .l-gnav__icon--web {
  background-image: url(../images/common/icon_web--white.png);
}

.l-gnav__icon--shop {
  background-image: url(../images/common/icon_shop.png);
}
.l-gnav__link:hover .l-gnav__icon--shop, .l-gnav__link--active .l-gnav__icon--shop {
  background-image: url(../images/common/icon_shop--white.png);
}

.l-gnav__icon--news {
  background-image: url(../images/common/icon_news.png);
}
.l-gnav__link:hover .l-gnav__icon--news, .l-gnav__link--active .l-gnav__icon--news {
  background-image: url(../images/common/icon_news--white.png);
}

/* ==============================
   Foundation
   ============================== */
.l-footer {
  background-color: #FFFDE5;
  text-align: center;
  padding: 40px 0;
}
@media (min-width: 768px) {
  .l-footer {
    padding: 64px 0;
  }
}
.l-footer__linklist {
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .l-footer__linklist {
    margin-bottom: 80px;
    display: flex;
    gap: 24px;
    justify-content: center;
  }
}
.l-footer__logo {
  width: 300px;
  margin: 0 auto 24px;
}
@media (min-width: 768px) {
  .l-footer__logo {
    margin: 0 auto 40px;
  }
}
.l-footer__tel {
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .l-footer__tel {
    margin-bottom: 80px;
  }
}
/* ==============================
   Object
   ============================== */
/* コンテナmixinを上で読み込んでおくと、header/footer等からも使えて便利 */
/* object配下の集約（component, project, utility など） */
/* ==============================
   Foundation
   ============================== */
/* object/_index.scss
   - object配下の component / project / utility をまとめて読み込む
   - ここは「objectフォルダからの相対パス」で記述する
*/
/* （必要なら）foundationの変数・breakpointsを利用 */
/* component */
/* ← c-container / c-container-small の @mixin を使うなら読み込んでおく */
/* ==============================
   Foundation
   ============================== */
.c-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 32px;
  text-align: center;
  color: #fff;
  border-radius: 24px;
  border: 2px solid #459058;
  background: #459058;
  overflow: hidden;
  z-index: 1;
  display: block;
  font-weight: bold;
  max-width: 280px;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
  font-family: "Noto Sans JP", "游ゴシック Medium", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
}
.c-btn::after {
  background: #fff;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.3s ease;
  z-index: -1;
}
.c-btn::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-right: 8px;
  background-repeat: no-repeat;
  vertical-align: middle;
  top: -1px;
  background-size: contain;
  background-position: center;
  transition: transform 0.3s ease;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23fff'><polygon points='163.92 0 92.08 71.82 276.26 256 92.08 440.18 163.92 512 419.92 256 163.92 0'/></svg>");
}
.c-btn:hover::before {
  transform: translateX(4px);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23459058'><polygon points='163.92 0 92.08 71.82 276.26 256 92.08 440.18 163.92 512 419.92 256 163.92 0'/></svg>");
}
.c-btn:hover {
  color: #459058;
  text-decoration: none;
}
.c-btn:hover::after {
  transform: scaleX(1);
}

.c-btn--white {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 32px;
  text-align: center;
  color: #D3A632;
  border-radius: 24px;
  border: 2px solid #fff;
  background: #fff;
  overflow: hidden;
  z-index: 1;
  display: block;
  font-weight: bold;
  max-width: 240px;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
  font-family: "Noto Sans JP", "游ゴシック Medium", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
}
.c-btn--white__icon {
  width: 16px;
  height: 16px;
  transition: transform 0.3s ease;
  vertical-align: middle;
  position: relative;
  top: -2px;
  /* +1〜-2px あたりで調整してみてください */
  margin-left: 8px;
}
.c-btn--white::after {
  background: #D3A632;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.3s ease;
  z-index: -1;
}
.c-btn--white:hover {
  color: #fff;
  text-decoration: none;
}
.c-btn--white:hover::after {
  transform: scaleX(1);
}

/* ==============================
   Foundation
   ============================== */
/* =========================================================
 * Gutenberg Block Editor Style
 * Component: c-entry__content
 * Project: Nakata Komuten Renewal
 * ---------------------------------------------------------
 * WordPressの本文（single/post/page共通）に適用
 * ---------------------------------------------------------
 * 基本思想：
 *  - c-entry__content 以下にすべてスコープ
 *  - サイト全体で統一された記事本文スタイル
 *  - シンプルで読みやすい余白と階層設計
 * ========================================================= */
/* ---------------------------------------
   Design Tokens
--------------------------------------- */
:root {
  --c-text: #222;
  --c-muted: #666;
  --c-border: #e5e5e5;
  --c-accent: #523b31;
  /* 中田工務店ブランドブラウン */
  --ff-sans: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  --ff-mono: ui-monospace, "SFMono-Regular", Consolas, monospace;
  --fs-body: 16px;
  --lh-body: 1.8;
  --w-reading: 80ch;
  --space-1: .25rem;
  --space-2: .5rem;
  --space-3: 1rem;
  --space-4: 1.5rem;
  --space-5: 2rem;
  --space-6: 3rem;
}

/* ---------------------------------------
   Scope
--------------------------------------- */
.c-entry__content {
  color: var(--c-text);
  font-family: var(--ff-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  /*max-width: var(--w-reading);*/
  margin-inline: auto;
}

/* ブロック全体の間隔統一 */
.c-entry__content > * {
  margin-block: var(--space-4);
}

/* メディア要素のリセット */
.c-entry__content img,
.c-entry__content video,
.c-entry__content iframe {
  max-width: 100%;
  height: auto;
}

/* ---------------------------------------
   見出し
--------------------------------------- */
.c-entry__content h1,
.c-entry__content h2,
.c-entry__content h3,
.c-entry__content h4,
.c-entry__content h5,
.c-entry__content h6 {
  line-height: 1.4;
  margin-block: var(--space-5) var(--space-3);
  font-weight: 700;
}

.c-entry__content h1 {
  font-size: clamp(1.75rem, 2vw + 1rem, 2.25rem);
}

.c-entry__content h2 {
  font-size: clamp(1.5rem, 1.6vw + 1rem, 1.875rem);
  border-bottom: 1px solid var(--c-border);
  padding-bottom: 0.4em;
}

.c-entry__content h3 {
  font-size: clamp(1.25rem, 1vw + 0.9rem, 1.5rem);
}

.c-entry__content h4 {
  font-size: 1.125rem;
}

.c-entry__content h5 {
  font-size: 1rem;
}

.c-entry__content h6 {
  font-size: 0.95rem;
  color: var(--c-muted);
}

/* ---------------------------------------
   段落・強調
--------------------------------------- */
.c-entry__content p {
  margin-block: var(--space-3);
}

.c-entry__content strong {
  font-weight: 700;
}

.c-entry__content em {
  font-style: italic;
}

/* ---------------------------------------
   リスト
--------------------------------------- */
.c-entry__content ul,
.c-entry__content ol {
  padding-left: 1.2em;
  margin-block: var(--space-3);
}

.c-entry__content li {
  margin-block: 0.4em;
}

.c-entry__content li > ul,
.c-entry__content li > ol {
  margin-block: 0.4em;
}

/* ---------------------------------------
   引用
--------------------------------------- */
.c-entry__content blockquote {
  margin: var(--space-4) 0;
  padding: var(--space-3) var(--space-4);
  border-left: 4px solid var(--c-accent);
  background: #faf9f7;
  color: #111;
}

.c-entry__content blockquote p:last-child {
  margin-bottom: 0;
}

/* Pullquote */
.c-entry__content .wp-block-pullquote {
  border-top: 2px solid var(--c-border);
  border-bottom: 2px solid var(--c-border);
  padding: var(--space-4) 0;
  text-align: center;
}

/* ---------------------------------------
   画像・図版
--------------------------------------- */
.c-entry__content figure {
  margin: var(--space-4) 0;
}

.c-entry__content figcaption {
  color: var(--c-muted);
  font-size: 0.9rem;
  text-align: center;
  margin-top: 0.5rem;
}

/* ギャラリー */
.c-entry__content .wp-block-gallery {
  gap: var(--space-2);
}

.c-entry__content .wp-block-image img {
  display: block;
}

/* ---------------------------------------
   ボタン
--------------------------------------- */
.c-entry__content .wp-block-button .wp-block-button__link {
  display: inline-block;
  padding: 0.75em 1.25em;
  border-radius: 0.5rem;
  background: var(--c-accent);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  transition: background-color 0.3s;
}

.c-entry__content .wp-block-button .wp-block-button__link:hover {
  background-color: #6a4c40;
}

.c-entry__content .wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent;
  color: var(--c-accent);
  border: 2px solid var(--c-accent);
}

/* ---------------------------------------
   テーブル
--------------------------------------- */
.c-entry__content table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
}

.c-entry__content th,
.c-entry__content td {
  border: 1px solid var(--c-border);
  padding: 0.75em 0.9em;
  vertical-align: top;
}

.c-entry__content th {
  background: #f7f7f7;
  text-align: left;
  white-space: nowrap;
}

/* ---------------------------------------
   区切り線・コード
--------------------------------------- */
.c-entry__content hr {
  border: 0;
  border-top: 1px solid var(--c-border);
  margin-block: var(--space-5);
}

.c-entry__content code {
  font-family: var(--ff-mono);
  font-size: 0.9em;
  background: #f4f6f8;
  padding: 0.15em 0.35em;
  border-radius: 0.25rem;
}

.c-entry__content pre {
  font-family: var(--ff-mono);
  font-size: 0.9rem;
  line-height: 1.6;
  background: #0b1020;
  color: #e8edf7;
  padding: var(--space-4);
  border-radius: 0.5rem;
  overflow: auto;
}

/* ---------------------------------------
   カラム
--------------------------------------- */
.c-entry__content .wp-block-columns {
  gap: var(--space-3);
  margin-block: var(--space-4);
}

@media (max-width: 768px) {
  .c-entry__content .wp-block-columns {
    flex-wrap: wrap !important;
  }
  .c-entry__content .wp-block-column {
    flex-basis: 100% !important;
  }
}
/* ---------------------------------------
   アラインメント
--------------------------------------- */
.c-entry__content .alignwide {
  max-width: min(1100px, 92vw);
  margin-inline: auto;
}

.c-entry__content .alignfull {
  width: 100vw;
  margin-left: 50%;
  transform: translateX(-50%);
}

.c-entry__content .alignleft {
  float: left;
  margin: 0.25rem 1rem 1rem 0;
  max-width: 45%;
}

.c-entry__content .alignright {
  float: right;
  margin: 0.25rem 0 1rem 1rem;
  max-width: 45%;
}

@media (max-width: 768px) {
  .c-entry__content .alignleft,
  .c-entry__content .alignright {
    float: none;
    margin: var(--space-3) 0;
    max-width: 100%;
  }
}
/* ---------------------------------------
   リンク・埋め込み
--------------------------------------- */
.c-entry__content a {
  color: var(--c-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: opacity 0.3s;
}

.c-entry__content a:hover {
  opacity: 0.8;
}

.c-entry__content .wp-block-embed {
  margin-block: var(--space-4);
}

.c-entry__content .wp-block-embed iframe {
  width: 100%;
  aspect-ratio: 16/9;
}

/* ---------------------------------------
   チェックリスト風
--------------------------------------- */
.c-entry__content ul.is-style-checklist li {
  list-style: "✔︎  ";
}

/* ---------------------------------------
   余白調整
--------------------------------------- */
.c-entry__content > *:first-child {
  margin-top: 0;
}

.c-entry__content > *:last-child {
  margin-bottom: 0;
}

/* project */
/* ==============================
   Foundation
   ============================== */
.p-mv {
  background-color: #FFEAEA;
  padding: 40px 0 80px;
  margin-bottom: 64px;
  --mask:
    radial-gradient(39px at 50% calc(100% - 55px), #000 99%, #0000 101%) calc(50% - 50px) 0/100px 100%,
    radial-gradient(39px at 50% calc(100% + 30px), #0000 99%, #000 101%) 50% calc(100% - 25px)/100px 100% repeat-x;
  -webkit-mask: var(--mask);
  mask: var(--mask);
}
@media (min-width: 992px) {
  .p-mv {
    --mask:
      radial-gradient(78.1px at 50% calc(100% - 110px), #000 99%, #0000 101%) calc(50% - 100px) 0/200px 100%,
      radial-gradient(78.1px at 50% calc(100% + 60px), #0000 99%, #000 101%) 50% calc(100% - 50px)/200px 100% repeat-x;
    -webkit-mask: var(--mask);
    mask: var(--mask);
    padding: 72px 0 160px;
    margin-bottom: 120px;
  }
}
.p-mv__wrap {
  margin: 0 auto;
  max-width: 80%;
  position: relative;
}
@media (min-width: 992px) {
  .p-mv__wrap {
    max-width: 1000px;
  }
}
.p-mv__pic {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-mv__pic {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-mv__pic {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-mv__pic {
    border-radius: 40px;
  }
}

.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  background-color: #459058;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: background-color 0.3s ease, transform 0.3s ease;
}
@media (min-width: 992px) {
  .swiper-button-prev,
  .swiper-button-next {
    width: 60px;
    height: 60px;
  }
}
.swiper-button-prev::after,
.swiper-button-next::after {
  color: #fff;
  font-size: 14px;
}
@media (min-width: 992px) {
  .swiper-button-prev::after,
  .swiper-button-next::after {
    font-size: 18px;
  }
}
.swiper-button-prev:hover,
.swiper-button-next:hover {
  background-color: rgb(55.7830985915, 116.4169014085, 71.1436619718);
  transform: translateY(-50%) scale(1.1);
}

.swiper-button-prev {
  left: -15px;
  margin-top: 0px;
  /* ← 画像よりちょっと外 */
}
@media (min-width: 992px) {
  .swiper-button-prev {
    left: -30px;
  }
}

.swiper-button-next {
  right: -15px;
  margin-top: 0px;
}
@media (min-width: 992px) {
  .swiper-button-next {
    right: -30px;
  }
}

.p-indexnews {
  margin-bottom: 64px;
  max-width: 640px;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-indexnews {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-indexnews {
    width: 848px;
    margin-right: auto;
    margin-left: auto;
  }
}
@media (min-width: 992px) {
  .p-indexnews {
    margin-bottom: 120px;
  }
}
.p-indexnews__title {
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  color: #459058;
  font-weight: bold;
  text-align: center;
  margin-bottom: 32px;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-indexnews__title {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-indexnews__title {
      font-size: 1.875rem;
    }
  }
}
.p-indexnews__list {
  margin-bottom: 64px;
}
.p-indexnews__item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.p-indexnews__cat {
  width: 120px;
  background-color: #D3A632;
  text-align: center;
  color: #fff;
  margin-right: 24px;
}
.p-indexnews__date {
  width: 100px;
  margin-right: 16px;
}
.p-indexnews__link {
  width: 100%;
  margin-top: 8px;
}
@media (min-width: 768px) {
  .p-indexnews__link {
    width: calc(100% - 260px);
    margin-top: 0;
  }
}
.p-indexnews__btn {
  margin: 0 auto;
}

.p-indexabout {
  background-color: transparent;
  padding: 180px 0 0;
  margin-bottom: 60px;
  position: relative;
  overflow: visible;
  /* マスクは使うが、適用先は ::before のみ */
  --mask:
    radial-gradient(39px at 50% 55px, #000 99%, #0000 101%) calc(50% - 50px) 0/100px 100%,
    radial-gradient(39px at 50% -30px, #0000 99%, #000 101%) 50% 25px/100px 100% repeat-x;
  /* 中身は前面に（飾り画像も含む） */
}
@media (min-width: 768px) {
  .p-indexabout {
    margin-bottom: 120px;
    --mask:
      radial-gradient(78.1px at 50% 110px, #000 99%, #0000 101%) calc(50% - 100px) 0/200px 100%,
      radial-gradient(78.1px at 50% -60px, #0000 99%, #000 101%) 50% 50px/200px 100% repeat-x;
  }
}
.p-indexabout::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #FFFDE5;
  -webkit-mask: var(--mask);
  mask: var(--mask);
  z-index: 0;
  pointer-events: none;
}
.p-indexabout > * {
  position: relative;
  z-index: 1;
}
.p-indexabout__copy {
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  color: #459058;
  font-weight: bold;
  text-align: center;
  margin-bottom: 48px;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
  line-height: 1.8;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-indexabout__copy {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-indexabout__copy {
      font-size: 1.875rem;
    }
  }
}
.p-indexabout__txt {
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  text-align: center;
  margin-bottom: 60px;
  line-height: 2;
  padding: 0 16px;
  font-size: clamp(1rem, var(--fix, 1) * 1rem + (2px) * (100vw - 375px) / 825px, 1.125rem);
  line-height: 1.8;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-indexabout__txt {
    font-size: 1rem;
  }
  @media (min-width: 1200px) {
    .p-indexabout__txt {
      font-size: 1.125rem;
    }
  }
}
.p-indexabout__txtwrap {
  position: relative;
  display: inline-block;
  margin: 0 auto 60px;
}
.p-indexabout__btn {
  margin: 0 auto 200px;
}
@media (min-width: 768px) {
  .p-indexabout__btn {
    margin: 0 auto 240px;
  }
}
.p-indexabout__pic01, .p-indexabout__pic02, .p-indexabout__pic03, .p-indexabout__pic04 {
  position: absolute;
}
.p-indexabout__pic01 img, .p-indexabout__pic02 img, .p-indexabout__pic03 img, .p-indexabout__pic04 img {
  width: 100px;
  max-width: none;
}
@media (min-width: 768px) {
  .p-indexabout__pic01 img, .p-indexabout__pic02 img, .p-indexabout__pic03 img, .p-indexabout__pic04 img {
    width: 280px;
  }
}
.p-indexabout__pic01 {
  top: -10px;
  left: 10px;
}
@media (min-width: 768px) {
  .p-indexabout__pic01 {
    top: -30px;
    left: 50%;
    margin-left: -500px;
  }
}
.p-indexabout__pic02 {
  top: 50px;
  right: 10px;
}
@media (min-width: 768px) {
  .p-indexabout__pic02 {
    top: 100px;
    left: 50%;
    margin-left: 240px;
  }
}
.p-indexabout__pic03 {
  bottom: 270px;
  left: 10px;
}
@media (min-width: 768px) {
  .p-indexabout__pic03 {
    top: 540px;
    left: 50%;
    margin-left: -540px;
  }
}
.p-indexabout__pic04 {
  bottom: 240px;
  right: 10px;
}
@media (min-width: 768px) {
  .p-indexabout__pic04 {
    top: 660px;
    left: 50%;
    margin-left: 240px;
  }
}
.p-indexabout__family {
  width: 100%;
  overflow: hidden;
}
.p-indexabout__familyimg {
  height: 220px;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media (min-width: 768px) {
  .p-indexabout__familyimg {
    width: 100%;
    height: auto;
  }
}

.p-indexpoint {
  margin-bottom: 80px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-indexpoint {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-indexpoint {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-indexpoint {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
@media (min-width: 768px) {
  .p-indexpoint {
    margin-bottom: 160px;
  }
}
.p-indexpoint__wrap {
  background-color: #FCF2E5;
  padding: 24px 16px;
  margin-bottom: 32px;
}
.p-indexpoint__wrap {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-indexpoint__wrap {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-indexpoint__wrap {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-indexpoint__wrap {
    border-radius: 40px;
  }
}
@media (min-width: 768px) {
  .p-indexpoint__wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
    padding: 48px;
  }
}
@media (min-width: 992px) {
  .p-indexpoint__inner {
    width: calc((100% - 32px) / 2);
  }
}
.p-indexpoint__title {
  color: #459058;
  margin-bottom: 24px;
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-indexpoint__title {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-indexpoint__title {
      font-size: 1.875rem;
    }
  }
}
@media (min-width: 768px) {
  .p-indexpoint__title {
    margin-bottom: 40px;
  }
}
.p-indexpoint__txt {
  margin-bottom: 40px;
}
.p-indexpoint__btn {
  margin: 24px auto;
}
@media (min-width: 768px) {
  .p-indexpoint__btn {
    margin: 0;
  }
}
@media (min-width: 992px) {
  .p-indexpoint__img {
    width: calc((100% - 32px) / 2);
  }
}
.p-indexpoint__photo {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-indexpoint__photo {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-indexpoint__photo {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-indexpoint__photo {
    border-radius: 40px;
  }
}
@media (min-width: 768px) {
  .p-indexpoint__pic {
    width: 100%;
    display: flex;
    gap: 24px;
  }
}
.p-indexpoint__piclist {
  margin-top: 16px;
}
@media (min-width: 768px) {
  .p-indexpoint__piclist {
    margin-top: 0;
    width: calc((100% - 48px) / 3);
  }
}

/* ==============================
   Foundation
   ============================== */
.p-contactmain {
  margin-bottom: 80px;
  padding: 0 32px;
}
@media (min-width: 992px) {
  .p-contactmain {
    padding: 0;
    text-align: center;
  }
}

.p-tel {
  background-color: #FFEAEA;
  margin-bottom: 32px;
  padding: 32px;
  text-align: center;
}
.p-tel__title {
  font-size: 1.6rem;
  color: #459058;
  margin-bottom: 40px;
}
.p-tel__tel {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 16px;
}
.p-tel__fax {
  display: block;
}
@media (min-width: 768px) {
  .p-tel__fax {
    margin-left: 32px;
    display: inline;
  }
}
.p-tel__time {
  display: block;
}
@media (min-width: 768px) {
  .p-tel__time {
    margin-left: 24px;
    display: inline;
  }
}
.p-form {
  background-color: #FFEAEA;
  margin-bottom: 80px;
  padding: 32px;
}
@media (min-width: 992px) {
  .p-form {
    margin-bottom: 160px;
  }
}
.p-form__title {
  font-size: 1.6rem;
  color: #459058;
  text-align: center;
  margin-bottom: 40px;
}
.p-form__txt {
  margin-bottom: 40px;
}
.p-form__list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.p-form__item {
  width: 100%;
  text-align: center;
  margin-bottom: 8px;
  padding-top: 16px;
  color: #459058;
}
@media (min-width: 768px) {
  .p-form__item {
    width: 24%;
    text-align: right;
    padding-right: 16px;
  }
}
.p-form__input {
  width: 100%;
  font-weight: bold;
  padding-bottom: 16px;
  padding-top: 16px;
  text-align: center;
}
@media (min-width: 768px) {
  .p-form__input {
    text-align: left;
    width: 76%;
    padding-left: 32px;
    border-bottom: none;
  }
}
.p-form__privacy {
  margin-bottom: 16px;
}
.p-form__check {
  font-weight: bold;
}
.p-form__confirm {
  text-align: center;
  border-top: solid 1px #ccc;
  padding-top: 24px;
  margin-bottom: 24px;
}
.p-form__btn {
  text-align: center;
  margin: 0 auto;
}
.p-form__btn:hover {
  background-color: #fff;
}
.p-form__must {
  color: #459058;
}
.p-form__mb {
  margin-bottom: 8px;
}
.p-form input[type=text],
.p-form input[type=email],
.p-form input[type=tel],
.p-form textarea {
  width: 100%;
  max-width: 100%;
  height: 2em;
  padding: 2px 2%;
  border-radius: 3px;
  background: #fff;
  border: solid 1px #ccc;
  -webkit-appearance: none;
  font-size: 100%;
  font-family: inherit;
}
@media (min-width: 992px) {
  .p-form input[type=text],
  .p-form input[type=email],
  .p-form input[type=tel],
  .p-form textarea {
    max-width: 90%;
  }
}
.p-form select {
  height: 2em;
  padding: 2px 2%;
  border-radius: 3px;
  background: #fff;
  border: solid 1px #ccc;
  -webkit-appearance: none;
  font-size: 100%;
  font-family: inherit;
}
.p-form textarea {
  height: 200px;
}
.p-form input[type=text]:focus,
.p-form input[type=email]:focus,
.p-form input[type=tel]:focus,
.p-form textarea:focus {
  box-shadow: 0px 0px 5px #ccc;
  border: 1px solid #ccc;
  background: #ffffff;
}
.p-form input[type=radio],
.p-form input[type=checkbox] {
  margin-right: 10px;
  margin-top: 7px;
}
.p-form li:first-child input[type=radio],
.p-form li:first-child input[type=checkbox] {
  margin-top: 0px;
}
.p-form__checkbox {
  display: none;
}
.p-form input::-moz-placeholder, .p-form textarea::-moz-placeholder {
  color: #ccc;
}
.p-form input::placeholder,
.p-form textarea::placeholder {
  color: #ccc;
}
.p-form .uploadbtn {
  padding: 8px;
  display: block;
  background-color: #efefef;
  cursor: pointer;
}
.p-form__inputpost {
  width: 120px !important;
}
.p-form__confirmation {
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
  padding: 16px;
  margin-bottom: 16px;
}
.p-form__submit {
  -webkit-appearance: none;
  padding: 16px 40px;
  border: 1px solid #459058;
  background: #459058;
  color: #ffffff;
  font-weight: bold;
  line-height: 1;
  vertical-align: middle;
}
.p-form__back {
  -webkit-appearance: none;
  padding: 16px 40px;
  border: 1px solid #999;
  background: #999;
  color: #ffffff;
  font-weight: bold;
  line-height: 1;
  vertical-align: middle;
}

/* ==============================
   Foundation
   ============================== */
.p-aboutmain {
  margin-bottom: 60px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-aboutmain {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-aboutmain {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-aboutmain {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.p-aboutmain__img {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-aboutmain__img {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-aboutmain__img {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-aboutmain__img {
    border-radius: 40px;
  }
}

.p-about {
  margin-bottom: 60px;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-about {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-about {
    width: 848px;
    margin-right: auto;
    margin-left: auto;
  }
}
@media (min-width: 768px) {
  .p-about {
    display: flex;
    gap: 24px;
  }
}
@media (min-width: 768px) {
  .p-about__inner {
    width: 60%;
  }
}
.p-about__title {
  color: #459058;
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  margin-bottom: 24px;
  text-align: center;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-about__title {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-about__title {
      font-size: 1.875rem;
    }
  }
}
@media (min-width: 768px) {
  .p-about__title {
    text-align: left;
    margin-bottom: 40px;
  }
}
.p-about__txt {
  margin-bottom: 24px;
}
@media (min-width: 768px) {
  .p-about__txt {
    margin-bottom: 0;
  }
}
.p-about__txt br {
  display: none;
}
@media (min-width: 768px) {
  .p-about__txt br {
    display: block;
  }
}
@media (min-width: 768px) {
  .p-about__list {
    width: calc(40% - 24px);
  }
}
.p-about__img {
  margin-bottom: 24px;
}
.p-about__pic {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-about__pic {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-about__pic {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-about__pic {
    border-radius: 40px;
  }
}

.p-aboutpoint {
  margin-bottom: 80px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-aboutpoint {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-aboutpoint {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-aboutpoint {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
@media (min-width: 768px) {
  .p-aboutpoint {
    margin-bottom: 160px;
  }
}
.p-aboutpoint__wrap {
  background-color: #FCF2E5;
  padding: 24px;
  margin-bottom: 32px;
}
.p-aboutpoint__wrap {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-aboutpoint__wrap {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-aboutpoint__wrap {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-aboutpoint__wrap {
    border-radius: 40px;
  }
}
@media (min-width: 768px) {
  .p-aboutpoint__wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
    padding: 64px;
  }
}
@media (min-width: 992px) {
  .p-aboutpoint__inner {
    width: calc((100% - 32px) / 2);
  }
}
.p-aboutpoint__title {
  color: #459058;
  margin-bottom: 24px;
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-aboutpoint__title {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-aboutpoint__title {
      font-size: 1.875rem;
    }
  }
}
@media (min-width: 768px) {
  .p-aboutpoint__title {
    margin-bottom: 40px;
  }
}
.p-aboutpoint__txt {
  margin-bottom: 40px;
}
.p-aboutpoint__btn {
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .p-aboutpoint__btn {
    margin-bottom: 0;
  }
}
@media (min-width: 992px) {
  .p-aboutpoint__img {
    width: calc((100% - 32px) / 2);
  }
}
.p-aboutpoint__photo {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-aboutpoint__photo {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-aboutpoint__photo {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-aboutpoint__photo {
    border-radius: 40px;
  }
}
@media (min-width: 768px) {
  .p-aboutpoint__pic {
    width: 100%;
    display: flex;
    gap: 24px;
  }
}
.p-aboutpoint__piclist {
  margin-top: 16px;
}
@media (min-width: 768px) {
  .p-aboutpoint__piclist {
    margin-top: 0;
    width: calc((100% - 48px) / 3);
  }
}

/* ==============================
   Foundation
   ============================== */
.p-item {
  margin-bottom: 80px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-item {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-item {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-item {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.p-item__wrap {
  background-color: #FCF2E5;
  padding: 24px;
  margin-bottom: 32px;
}
.p-item__wrap {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-item__wrap {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-item__wrap {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-item__wrap {
    border-radius: 40px;
  }
}
@media (min-width: 768px) {
  .p-item__wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
    padding: 32px;
  }
}
@media (min-width: 992px) {
  .p-item__wrap {
    padding: 64px;
  }
}
.p-item__img {
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .p-item__img {
    width: calc(40% - 32px);
    margin-bottom: 0;
  }
}
.p-item__pic {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-item__pic {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-item__pic {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-item__pic {
    border-radius: 40px;
  }
}
@media (min-width: 768px) {
  .p-item__inner {
    width: 60%;
  }
}
.p-item__title {
  color: #459058;
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-item__title {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-item__title {
      font-size: 1.875rem;
    }
  }
}
.p-item__caption {
  color: #459058;
  margin-bottom: 16px;
  font-size: clamp(1.125rem, var(--fix, 1) * 1.125rem + (2px) * (100vw - 375px) / 825px, 1.25rem);
  line-height: 1.75;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-item__caption {
    font-size: 1.125rem;
  }
  @media (min-width: 1200px) {
    .p-item__caption {
      font-size: 1.25rem;
    }
  }
}
.p-item__etc {
  margin-top: 40px;
  color: #459058;
  text-align: center;
  font-size: clamp(1.125rem, var(--fix, 1) * 1.125rem + (2px) * (100vw - 375px) / 825px, 1.25rem);
  line-height: 1.75;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-item__etc {
    font-size: 1.125rem;
  }
  @media (min-width: 1200px) {
    .p-item__etc {
      font-size: 1.25rem;
    }
  }
}

.p-specialty {
  background-image: url(../images/item/bg_specialty.jpg);
  background-size: cover;
  padding: 40px 0 160px;
  margin-bottom: -120px;
}
@media (min-width: 768px) {
  .p-specialty {
    padding: 40px 40px 160px;
  }
}
.p-specialty__wrap {
  text-align: center;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-specialty__wrap {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-specialty__wrap {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-specialty__wrap {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.p-specialty__inner {
  background: rgba(255, 255, 255, 0.8);
  padding: 24px;
}
.p-specialty__inner {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-specialty__inner {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-specialty__inner {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-specialty__inner {
    border-radius: 40px;
  }
}
@media (min-width: 768px) {
  .p-specialty__inner {
    padding: 56px;
    padding-right: 24px;
    padding-left: 24px;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  .p-specialty__inner {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 768px) and (min-width: 992px) {
  .p-specialty__inner {
    width: 848px;
    margin-right: auto;
    margin-left: auto;
  }
}
.p-specialty__img {
  width: 160px;
  margin: 0 auto 40px;
}
@media (min-width: 768px) {
  .p-specialty__img {
    width: 300px;
  }
}
.p-specialty__title {
  color: #459058;
  margin-bottom: 40px;
  font-size: clamp(1.125rem, var(--fix, 1) * 1.125rem + (4px) * (100vw - 375px) / 825px, 1.375rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-specialty__title {
    font-size: 1.125rem;
  }
  @media (min-width: 1200px) {
    .p-specialty__title {
      font-size: 1.375rem;
    }
  }
}
.p-specialty__txt {
  margin: 0 auto 24px;
  text-align: left;
}
@media (min-width: 768px) {
  .p-specialty__txt {
    max-width: 400px;
  }
}
.p-specialty__list {
  margin-left: 1.4em;
  margin-bottom: 24px;
}
@media (min-width: 768px) {
  .p-specialty__list {
    margin-left: 2em;
  }
}
.p-specialty__detail {
  list-style: decimal;
  max-width: 400px;
  text-align: left;
  margin: 0 auto;
}
.p-specialty__link {
  margin: 0 auto;
}

/* ==============================
   Foundation
   ============================== */
.p-shopwrap {
  background-color: #FFFDE5;
  padding: 0 0 80px;
  margin-bottom: 64px;
  --mask:
    radial-gradient(39px at 50% calc(100% - 55px), #000 99%, #0000 101%) calc(50% - 50px) 0/100px 100%,
    radial-gradient(39px at 50% calc(100% + 30px), #0000 99%, #000 101%) 50% calc(100% - 25px)/100px 100% repeat-x;
  -webkit-mask: var(--mask);
  mask: var(--mask);
}
@media (min-width: 768px) {
  .p-shopwrap {
    --mask:
      radial-gradient(78.1px at 50% calc(100% - 110px), #000 99%, #0000 101%) calc(50% - 100px) 0/200px 100%,
      radial-gradient(78.1px at 50% calc(100% + 60px), #0000 99%, #000 101%) 50% calc(100% - 50px)/200px 100% repeat-x;
    -webkit-mask: var(--mask);
    padding: 0 0 160px;
    margin-bottom: 120px;
  }
}

.p-shopmain {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 40px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-shopmain {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-shopmain {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-shopmain {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.p-shopmain__mainimg {
  width: 100%;
}
.p-shopmain__img {
  width: calc((100% - 32px) / 3);
}
.p-shopmain__pic {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-shopmain__pic {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-shopmain__pic {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-shopmain__pic {
    border-radius: 40px;
  }
}

.p-shopinfo {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-shopinfo {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-shopinfo {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-shopinfo {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.p-shopinfo__inner {
  background-color: #fff;
  padding: 32px 20px;
}
.p-shopinfo__inner {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-shopinfo__inner {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-shopinfo__inner {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-shopinfo__inner {
    border-radius: 40px;
  }
}
@media (min-width: 768px) {
  .p-shopinfo__inner {
    padding: 64px 40px;
  }
}
.p-shopinfo__title {
  color: #459058;
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  text-align: center;
  margin-bottom: 16px;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-shopinfo__title {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-shopinfo__title {
      font-size: 1.875rem;
    }
  }
}
@media (min-width: 768px) {
  .p-shopinfo__title {
    margin-bottom: 40px;
  }
}
.p-shopinfo__txt {
  max-width: 800px;
  margin: 0 auto 40px;
}
.p-shopinfo__addressinner {
  max-width: 800px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .p-shopinfo__addressinner {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
  }
}
@media (min-width: 768px) {
  .p-shopinfo__address {
    width: 40%;
  }
}
.p-shopinfo__item {
  background-color: #FFEAEA;
  text-align: center;
  padding: 8px;
}
.p-shopinfo__detail {
  padding: 8px;
  text-align: center;
}
.p-shopinfo__map {
  width: 100%;
  height: 300px;
}
@media (min-width: 768px) {
  .p-shopinfo__map {
    width: 58%;
    height: auto;
  }
}

.p-company {
  margin-bottom: 64px;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-company {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-company {
    width: 848px;
    margin-right: auto;
    margin-left: auto;
  }
}
@media (min-width: 768px) {
  .p-company {
    margin-bottom: 160px;
  }
}
.p-company__title {
  color: #459058;
  font-family: "Kosugi Maru", "Noto Sans JP", "游ゴシック Medium", sans-serif;
  text-align: center;
  margin-bottom: 40px;
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-company__title {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-company__title {
      font-size: 1.875rem;
    }
  }
}
.p-company__list {
  display: flex;
  flex-wrap: wrap;
}
.p-company__item {
  width: 120px;
  text-align: center;
  padding: 16px;
  background-color: #f5f5f5;
  margin-bottom: 2px;
}
@media (min-width: 768px) {
  .p-company__item {
    width: 200px;
  }
}
.p-company__detail {
  width: calc(100% - 120px);
  background-color: #FFFDE5;
  padding: 16px;
  margin-bottom: 2px;
}
@media (min-width: 768px) {
  .p-company__detail {
    width: calc(100% - 200px);
  }
}

/* ==============================
   Foundation
   ============================== */
.p-newswrap {
  background-color: #FCF2E5;
  padding: 80px 0 80px;
  margin-bottom: -40px;
  --mask:
    radial-gradient(39px at 50% 55px, #000 99%, #0000 101%) calc(50% - 50px) 0/100px 100%,
    radial-gradient(39px at 50% -30px, #0000 99%, #000 101%) 50% 25px/100px 100% repeat-x;
  -webkit-mask: var(--mask);
  mask: var(--mask);
}
@media (min-width: 768px) {
  .p-newswrap {
    --mask: radial-gradient(78.1px at 50% 110px, #000 99%, #0000 101%) calc(50% - 100px) 0/200px 100%,
      radial-gradient(78.1px at 50% -60px, #0000 99%, #000 101%) 50% 50px/200px 100% repeat-x;
    -webkit-mask: var(--mask);
    mask: var(--mask);
    margin-bottom: -80px;
    padding: 160px 0 180px;
  }
}

.p-newscat {
  margin-bottom: 64px;
  border-bottom: solid 8px #459058;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-newscat {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-newscat {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-newscat {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
.p-newscat__list {
  display: flex;
  gap: 4px;
  align-items: stretch;
}
@media (min-width: 768px) {
  .p-newscat__list {
    gap: 16px;
  }
}
.p-newscat__cat {
  width: calc((100% - 12px) / 4);
  display: flex;
}
@media (min-width: 768px) {
  .p-newscat__cat {
    width: calc((100% - 48px) / 4);
  }
}
.p-newscat__link {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  background-color: #D3A632;
  padding: 12px 0;
  color: #fff;
  border-radius: 8px 8px 0 0;
  font-size: 14px;
}
@media (min-width: 768px) {
  .p-newscat__link {
    border-radius: 24px 24px 0 0;
    padding: 24px 0;
    font-size: clamp(1.125rem, var(--fix, 1) * 1.125rem + (2px) * (100vw - 375px) / 825px, 1.25rem);
    line-height: 1.75;
  }
  @supports not (font-size: clamp(1rem, 1vw, 2rem)) {
    .p-newscat__link {
      font-size: 1.125rem;
    }
    @media (min-width: 768px) and (min-width: 1200px) {
      .p-newscat__link {
        font-size: 1.25rem;
      }
    }
  }
}
.p-newscat__link--active, .p-newscat__link:hover {
  background-color: #459058;
  text-decoration: none;
}

.p-newslist {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-newslist {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-newslist {
    width: 960px;
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 1200px) {
  .p-newslist {
    width: 1120px;
    padding-right: 0;
    padding-left: 0;
  }
}
@media (min-width: 768px) {
  .p-newslist {
    gap: 48px;
  }
}
.p-newslist__wrap {
  width: calc((100% - 40px) / 2);
}
@media (min-width: 768px) {
  .p-newslist__wrap {
    width: calc((100% - 96px) / 3);
  }
}
.p-newslist__img {
  margin-bottom: 8px;
  width: 100%;
  aspect-ratio: 4/3;
  /* 好きな比率に */
  overflow: hidden;
}
.p-newslist__pic {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.p-newslist__pic {
  border-radius: 16px;
}
@media (min-width: 768px) {
  .p-newslist__pic {
    border-radius: 24px;
  }
}
@media (min-width: 992px) {
  .p-newslist__pic {
    border-radius: 32px;
  }
}
@media (min-width: 1200px) {
  .p-newslist__pic {
    border-radius: 40px;
  }
}
.p-newslist__title {
  font-size: clamp(1.125rem, var(--fix, 1) * 1.125rem + (4px) * (100vw - 375px) / 825px, 1.375rem);
  line-height: 1.8;
  font-weight: 700;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-newslist__title {
    font-size: 1.125rem;
  }
  @media (min-width: 1200px) {
    .p-newslist__title {
      font-size: 1.375rem;
    }
  }
}
.p-newslist__link:hover {
  text-decoration: none;
}
.p-newslist__info {
  margin-bottom: 8px;
}
.p-newslist__date {
  display: inline-block;
}
.p-newslist__cat {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 4px;
  background-color: #D3A632;
  color: #fff;
  font-size: clamp(0.75rem, var(--fix, 1) * 0.75rem + (2px) * (100vw - 375px) / 825px, 0.875rem);
  line-height: 1.6;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-newslist__cat {
    font-size: 0.75rem;
  }
  @media (min-width: 1200px) {
    .p-newslist__cat {
      font-size: 0.875rem;
    }
  }
}
.p-news {
  margin-bottom: 64px;
  padding-right: 24px;
  padding-left: 24px;
}
@media (min-width: 768px) {
  .p-news {
    padding-right: 32px;
    padding-left: 32px;
  }
}
@media (min-width: 992px) {
  .p-news {
    width: 848px;
    margin-right: auto;
    margin-left: auto;
  }
}
@media (min-width: 768px) {
  .p-news {
    margin-bottom: 160px;
  }
}
.p-news__title {
  font-size: clamp(1.375rem, var(--fix, 1) * 1.375rem + (8px) * (100vw - 375px) / 825px, 1.875rem);
  line-height: 1.8;
  font-weight: 700;
  margin-bottom: 8px;
}
@supports not (font-size: clamp(1rem, 1vw, 2rem)) {
  .p-news__title {
    font-size: 1.375rem;
  }
  @media (min-width: 1200px) {
    .p-news__title {
      font-size: 1.875rem;
    }
  }
}
.p-news__date {
  text-align: right;
  margin-bottom: 16px;
}
.p-news__contents p {
  margin-bottom: 1.6em;
}
.p-news__contents img {
  margin-bottom: 1.6em;
}

/* utility */
/* ==============================
   Foundation
   ============================== *//*# sourceMappingURL=style.css.map */