@charset "UTF-8";
:root {
  --color-primary: #0072DE;
  --color-background: #fff;
  --color-background-sub: #F1F9FF;
  --color-gray: #454545;
  --color-red: #971e17;
  --color-border: #e3e3e3;
  --color-event-xmas: #981F17;
  --color-event-xmas-gold: #968047;
  --color-event-xmas-gold-light: #B2A278;
  --font-size-base: 1rem;
  --font-size-sm: 0.875rem;
  --font-size-lg: 1.25rem;
  --font-size-xl: 1.5rem;
  --font-size-xxl: 3.3rem;
  --font-size-sp-xxl: 2.2rem;
  --font-en: "Norican", cursive;
  /* サイドバー幅と各種トークン */
  --sidebar: clamp(200px, 20vw, 320px);
  /* だいたい300px帯 */
  --gap: clamp(12px, 2vw, 24px);
  /* サイドバーと主領域の間隔 */
  --content-max: 1000px;
  /* 商品一覧の最大幅（調整可） */
  --gutter: clamp(12px, 2vw, 24px);
  /* グリッドのカード間隔など */
}
@media (max-width: 1600px) {
  :root {
    --sidebar: clamp(200px, 18vw, 280px);
    --font-size-base: .9rem;
    --font-size-sm: 0.85rem;
    --font-size-lg: 1rem;
    --font-size-xl: 1.25rem;
    --font-size-xxl: 2.3rem;
    --font-size-sp-xxl: 1.7rem;
  }
}
@media (max-width: 950px) {
  :root {
    --font-size-base: .85rem;
    --font-size-sm: 0.75rem;
    --font-size-lg: 1.25rem;
    --font-size-xl: 1.5rem;
    --font-size-xxl: 1.3rem;
    --font-size-sp-xxl: 2.2rem;
  }
}

* {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

*:focus {
  outline: none;
}

body {
  background-color: var(--color-background);
  color: var(--color-primary);
  padding: 0;
  margin: 0;
  font-feature-settings: "halt";
  font-family: "Noto Serif JP", serif;
  height: 100%;
}

body {
  background-color: var(--color-background-sub);
}

#logoSlider .swiper-wrapper,
#aboutSlide .swiper-wrapper {
  height: inherit;
}

.globalNavWrap {
  top: 0;
}

.c-section {
  margin: 5em auto 0;
  padding: 0 0 2rem;
}
@media (max-width: 767px) {
  .c-section {
    margin: 8rem auto 0;
  }
}
.c-section--christmas {
  background-color: #85161B;
}

.c-head {
  font-family: var(--font-en);
  font-size: var(--font-size-xxl);
  color: var(--color-primary);
}
.c-head--christmas {
  color: var(--color-red);
  background-color: var(--color-background-sub);
  text-align: right;
  font-size: var(--font-size-lg);
}

.c-breadcrumb {
  margin-top: 1rem;
  margin-bottom: 5rem;
}
.c-breadcrumb__list {
  display: flex;
  justify-content: flex-end;
  gap: 1rem;
  list-style: none;
  margin: none;
  padding: none;
}
.c-breadcrumb__item::after {
  content: "\f105";
  font-family: "Font Awesome 7 Free";
  font-weight: bold;
}
.c-breadcrumb__item:last-child::after {
  content: "";
}

.c-event__img {
  width: 100%;
  height: auto;
}
.c-event-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.c-event-box {
  background-color: #fff;
  margin: 1rem 2rem;
}
.c-event-box--christmas {
  color: var(--color-event-xmas);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem 0;
  flex-direction: column;
  font-weight: bold;
  font-size: 1.2rem;
  text-align: center;
}
@media (max-width: 767px) {
  .c-event-box--christmas {
    font-size: var(--font-size-base);
    margin: 1rem;
    padding: 0.5rem 0;
  }
}
.c-event-cta {
  margin: 2rem 4rem;
}
@media (max-width: 767px) {
  .c-event-cta {
    margin: 1rem 1rem;
  }
}
.c-event-cta__ttl {
  color: var(--color-background);
  font-size: var(--font-size-xl);
  text-align: center;
  margin-bottom: 2rem;
}
@media (max-width: 767px) {
  .c-event-cta__ttl {
    font-size: var(--font-size-base);
    text-align: left;
    margin: 1rem 0;
  }
}
.c-event-cta__list {
  list-style: none;
  padding: 0;
  align-items: stretch;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
@media (max-width: 767px) {
  .c-event-cta__list {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}
.c-event-cta__link {
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  padding: 1rem;
}
@media (max-width: 767px) {
  .c-event-cta__link {
    padding: 0.5rem 0;
  }
}
.c-event-cta__link:hover {
  opacity: 0.8;
  transition: opacity 0.3s;
}
.c-event-cta__link--tel {
  border: 6px solid var(--color-event-xmas-gold);
  color: var(--color-event-xmas-gold);
  font-size: var(--font-size-xl);
  font-weight: bold;
}
@media (max-width: 767px) {
  .c-event-cta__link--tel {
    font-size: var(--font-size-base);
  }
}
.c-event-cta__link--shop {
  border-radius: 5rem;
  background-color: var(--color-event-xmas-gold);
  background: linear-gradient(to right, var(--color-event-xmas-gold-light), var(--color-event-xmas-gold));
  color: var(--color-background);
  font-size: 1.3rem;
}
@media (max-width: 767px) {
  .c-event-cta__link--shop {
    font-size: var(--font-size-base);
    padding: 1rem 0;
  }
}
.c-event-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--color-background);
  gap: 1rem;
  align-items: center;
  margin: 1rem 0;
}
.c-event-card__img {
  border-radius: 1rem;
  width: 100%;
}
.c-event-card__ttl {
  font-size: 1.1rem;
  text-align: center;
}
.c-event-card__ttl br {
  display: none;
}
@media (max-width: 768px) {
  .c-event-card__ttl {
    font-size: 0.8rem;
  }
  .c-event-card__ttl br {
    display: block;
  }
}
.c-event-card__price {
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0;
  text-align: center;
}
@media (max-width: 768px) {
  .c-event-card__price {
    font-size: 1rem;
  }
}
.c-event-card__txt {
  font-size: 0.8rem;
  text-align: justify;
  margin: 0;
  font-weight: normal;
}
@media (max-width: 768px) {
  .c-event-card__txt {
    font-size: 0.6rem;
    margin: 1rem 0;
  }
}
.c-event-card__btn {
  border-radius: 3rem;
  background-color: var(--color-event-xmas-gold);
  background: linear-gradient(to right, var(--color-event-xmas-gold-light), var(--color-event-xmas-gold));
  color: var(--color-background);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  width: 80%;
}
.c-event-card__btn:hover {
  opacity: 0.8;
  transition: opacity 0.3s;
}
@media (max-width: 768px) {
  .c-event-card__btn {
    font-size: 0.8rem;
    width: 100%;
    padding: 0.5rem;
  }
}
@media (max-width: 768px) {
  .c-event-card {
    gap: 0.3rem;
  }
}
.c-event-note {
  border: 1px solid var(--color-background);
  padding: 1rem 2rem;
  color: var(--color-background);
  width: 90%;
  margin-inline: auto;
  margin-block: 2rem;
  font-size: 0.9rem;
}
@media (max-width: 768px) {
  .c-event-note {
    font-size: 0.8rem;
  }
}

.c-topBanner {
  display: block;
  z-index: 100;
  position: absolute;
  bottom: 130px;
  right: 20px;
}
@media (max-width: 768px) {
  .c-topBanner {
    bottom: 100px;
    right: 10px;
    text-align: right;
  }
}
.c-topBanner:hover {
  opacity: 0.8;
  transition: opacity 0.3s;
}
.c-topBanner img {
  border-radius: 10px;
}
@media (max-width: 768px) {
  .c-topBanner img {
    width: calc(100% - 10px);
  }
}

.c-split {
  --grid: repeat(auto-fit, minmax(200px, 1fr));
  --gap: clamp(2rem, 3.2vw, 3.4rem);
  display: grid;
  grid-template-columns: var(--grid);
  gap: var(--gap);
  list-style: none;
  margin: 0;
  padding: 0;
}
.c-split--event {
  gap: 2rem;
  padding: 0 3rem;
}
@media (max-width: 768px) {
  .c-split--event {
    padding: 0 1rem;
    gap: 1rem;
  }
}
.c-split--2col {
  --grid: repeat(2, 1fr);
}
.c-split--3col {
  --grid: repeat(3, 1fr);
}
.c-split--4col {
  --grid: repeat(4, 1fr);
}
@media (max-width: 950px) {
  .c-split {
    --grid: repeat(auto-fit, minmax(40%, 1fr));
    --grid: repeat(3, 1fr);
  }
  .c-split--4col {
    --grid: repeat(4, 1fr);
  }
}
@media (max-width: 768px) {
  .c-split {
    --grid: repeat(2, 1fr);
  }
}

.l-wrap {
  display: grid;
  grid-template-columns: var(--sidebar) var(--gap) 1fr minmax(0, var(--content-max)) 1fr var(--sidebar);
  grid-template-rows: 1fr auto;
  min-height: 100vh;
}
@media (max-width: 1887px) {
  .l-wrap {
    grid-template-columns: var(--sidebar) var(--gap) 1fr minmax(0, var(--content-max)) 1fr var(--gap);
  }
}
@media (max-width: 950px) {
  .l-wrap {
    --gap: 1.5rem;
    grid-template-columns: 1fr var(--gap) minmax(0, var(--content-max)) 1fr;
    grid-template-columns: var(--gap) 1fr var(--gap);
  }
}

.l-header {
  position: fixed;
  top: 0;
  overflow: auto;
  grid-column: 1;
  grid-row: 1/3;
  padding: var(--gutter);
}
@media (max-width: 950px) {
  .l-header {
    padding-top: 5rem;
    position: fixed;
    left: calc(-1 * var(--sidebar));
    left: -100vw;
    transition: left 0.3s ease, visibility 0.3s ease, opacity 0.3s ease, background-color 0.3s ease;
    height: 100vh;
    width: 100vw;
    visibility: hidden;
    opacity: 0;
    z-index: 99;
  }
  .l-header.is-active {
    background-color: var(--color-background);
    left: 0;
    visibility: visible;
    opacity: 1;
    width: 100vw;
    transition: left 0.3s ease, visibility 0.3s ease, opacity 0.3s ease, background-color 0.3s ease;
  }
}

.l-main {
  grid-column: 4;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--gutter);
}
@media (max-width: 1887px) {
  .l-main {
    grid-column: 3/5;
    max-width: var(--content-max);
  }
}
@media (max-width: 950px) {
  .l-main {
    grid-column: 2/-2;
  }
}

.l-footer {
  grid-column: 1/12;
  text-align: center;
  margin-top: 14rem;
  margin-bottom: 5rem;
  padding-top: 5.4rem;
  border-top: 1px solid var(--color-border);
}
@media (max-width: 950px) {
  .l-footer {
    margin-top: 4rem;
    margin-bottom: 2rem;
    padding-top: 2.4rem;
  }
}

.l-hero {
  grid-column: 3/7;
}
@media (max-width: 950px) {
  .l-hero {
    grid-column: 1/-1;
  }
}

.u-grid {
  display: grid;
  gap: 0;
  grid-template-columns: repeat(16, 1fr);
  align-items: center;
  --gutter: clamp(32px, 4vw, 48px);
  --max: 1280px;
  display: grid;
  grid-template-columns: 1fr repeat(16, minmax(0, calc((var(--max) - 2 * var(--gutter)) / 16))) 1fr;
  column-gap: var(--gutter);
}
.u-grid--edge {
  margin-inline: calc(var(--gutter) * -1);
}

.u-text--small {
  font-size: 60%;
}

.u-pc {
  opacity: 1;
  visibility: visible;
}
@media (max-width: 950px) {
  .u-pc {
    opacity: 0;
    visibility: hidden;
  }
}

.u-sp {
  opacity: 0;
  visibility: hidden;
}
@media (max-width: 950px) {
  .u-sp {
    opacity: 1;
    visibility: visible;
  }
}