html {
  font-size: 62.5%;
}
body {
  font-size: 1.6rem;
  margin: 0; font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 200;
  font-style: normal; 
  color: #444;
}


/* spacing utilities（mt / mb / pt / pb） */
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: 0.5rem !important; }
.mt-2 { margin-top: 1rem !important; }
.mt-3 { margin-top: 1.5rem !important; }
.mt-4 { margin-top: 2rem !important; }
.mt-5 { margin-top: 3rem !important; }

.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: 0.5rem !important; }
.mb-2 { margin-bottom: 1rem !important; }
.mb-3 { margin-bottom: 1.5rem !important; }
.mb-4 { margin-bottom: 2rem !important; }
.mb-5 { margin-bottom: 3rem !important; }

.pt-0 { padding-top: 0 !important; }
.pt-1 { padding-top: 0.5rem !important; }
.pt-2 { padding-top: 1rem !important; }
.pt-3 { padding-top: 1.5rem !important; }
.pt-4 { padding-top: 2rem !important; }
.pt-5 { padding-top: 3rem !important; }

.pb-0 { padding-bottom: 0 !important; }
.pb-1 { padding-bottom: 0.5rem !important; }
.pb-2 { padding-bottom: 1rem !important; }
.pb-3 { padding-bottom: 1.5rem !important; }
.pb-4 { padding-bottom: 2rem !important; }
.pb-5 { padding-bottom: 3rem !important; }

.sp{display: none;}

h1{
  margin: auto 0;
  padding: auto;
  line-height: 1;
}

.top-bar {
  background: #33423F;
  color: white;
  height: 80px;
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
}

.top-bar-inner {
  max-width: 1200px;
  margin: 0 auto;
  height: 100%;
  display: flex;
  align-items: center;
  padding: 0 1rem;
  gap: 1rem;
}

.top-bar-inner h1 img {
  height: 60px;
  width: auto;
}

header {
      background: url('../images/mv.png') no-repeat center center / cover;
      min-height: 550px;
      display: flex;
      justify-content: center;
      align-items: center;
      text-align: center;
      position: relative;
      margin-top: 80px;
}
header div {
      position: absolute;
      right: 25%;
}
header .mv{
    max-width: 75%;
}
.fixed-btn {
  position: fixed;
  top: 0;
  right: 0;
  background: #ffc107;
  color: #3A5855;
  padding: 1.75rem 0.75rem 1.5rem;
  font-weight: 400;
  z-index: 1000;
  font-size: 1.2rem;
  line-height: 1.25;
  height: 80px;
  text-align: center;;
}
.container{
  width: 800px;
  padding: 80px 0;
  margin: 0 auto;
}

.bg-notice{
  background-color: #E7E8E3;
}
.notice-list {
  margin: 0;
  padding: 0;
}
.notice-item {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid #666;
}
.notice-item dt {
  min-width: 150px;
}
.notice-item dd {
  margin: 0 0 1rem;
}
.notice-list a,.notice-list a:active { text-decoration: underline 1px solid !important; color: #444;}

.bg-products {
  background:linear-gradient(rgba(58, 88, 85, 0.9), rgba(58, 88, 85, 0.9)),
  url('../images/bg-image-olive.png') no-repeat center/cover;
  color: white;
  z-index: 0;
  overflow: hidden;
  position: relative;
}
/* ハイライトテキスト */
.highlight-text {
  text-align: center;
  font-size: 3.0rem;
}

.highlight-circle {
  display: inline-block;
  background: #fdd835;
  color: #333;
  border-radius: 50%;
  margin-right: 0.75rem;
  padding: 1.75rem 0.75rem;
  font-size: 3.0rem;
  font-weight: 600;
}
.highlight-circle small {
  font-size: 75%;
}

/* 商品ボックス */
.product-list {
  margin-bottom: 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
}
.row .column.column-50 {
  flex: 1;
  min-width: calc(50% - 15px);
  box-sizing: border-box;
}
.row .column.product-box {
  background: #FFF8DD;
  color: #333;
  padding: 2rem 1.5rem 1.5rem;
  margin-bottom: 1.5rem;
}
.product-box h3 {
  font-size: 2.6rem;
  margin-bottom: 0.5rem;
  color: #3A5855;
  display: flex;
  align-items: flex-start;
}
.product-box h3 span {
  font-size: 1.2rem;
  margin-left: 0.75rem;
  padding: 0.25rem 1.5rem;
  background: #3A5855;
  color: #FFF;
  position: relative;
  top: 0.6em;
}
.product-box img {
  height: auto;
}
.product-box p {
  font-size: 1.4rem;
  line-height: 1.5;
  margin-bottom: 0.5rem;
}
.product-box p.line2{
  min-height: 4.2rem;
}
.price-list {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
}
.price-list li {
  margin-bottom: 0.25rem;
  text-align: right;
  font-size: 2.2rem;
}
.price-list li span{
  font-size: 70%;
}
/* 注文ボタン（画像入り） */
.button#order {
  color: #3A5855;
  background-color: #ffc107;
  border: none;
  border-radius: 0;
  font-size: 2.25rem;
  font-weight: 500;
  padding: 0.75rem 0;
  margin-left: auto;
  margin-right: auto;
  height: auto;
  width: 60%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  }
.button#order img {
  height: 3rem;
  vertical-align: middle;
}

.button#mail {
  color: #3A5855;
  background-color: #B0AE00;
  border: none;
  border-radius: 0;
  font-size: 2.25rem;
  font-weight: 500;
  padding: 0.75rem 0;
  margin-left: auto;
  margin-right: auto;
  height: auto;
  width: 60%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  }
.button#mail img {
  height: 3rem;
  vertical-align: middle;
}

.bg-section01 {
  background: url('../images/bg-image01.png') no-repeat center/cover;
  color: white;
  display: flex;
  justify-content:center;
  align-items: center;
  min-height: 530px;
  padding: 2rem;
  padding: 80px 0;
}
.vertical-text {
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-size: 2.2rem;
  line-height: 3.25;
  letter-spacing: 5px;
  padding: 2rem;
  font-weight: 200;
}

.bg-section02 {
  background: url('../images/bg-image02.png') no-repeat center/100% auto;
  min-height: 700px;
}
.bg-section03 {
  background: url('../images/bg-image03.png') no-repeat center/100% auto;
  min-height: 700px;
}
.bg-section04 {
  background: url('../images/bg-image04.png') no-repeat center/100% auto;
  min-height: 700px;
}
.bg-cv{
  background-color: #D9D4C7;
}

.center-title {
  text-align: center;
  font-weight: 500;
  font-size: 3.0rem;
}
.center-title small{
  font-size: 75%;
}
.lh-2{
  line-height: 2;
}

.video-wrap {
  aspect-ratio: 16 / 9;
  width: 560px;
  max-width: 100%;
  margin: 0 auto;
}

.video-wrap iframe {
  width: 100%;
  height: 100%;
  display: block;
  border: none;
}

/* スマホ時に横幅100% */
@media screen and (max-width: 768px) {
  .video-wrap {
    width: 100%;
  }
}


.followBtn {
  text-align: center;
}
.followBtn a img {
  width: 50px;
  height: 50px;
  transition: opacity 0.3s;
}

.followBtn a:hover img {
  opacity: 0.7;
}

footer {
      background: #33423F;
      color: white;
      padding: 80px 0;
      text-align: center;
    }
footer img{
  width: 380px;
}
footer .foot-title{
  font-size: 2.2rem;
}
footer .copyright{
  font-size: 1.4rem;
}

.fade-in {
  opacity: 0;
  transition: opacity 0.8s ease;
}
.fade-in.active {
  opacity: 1;
}

.to-top {
  position: fixed;
  bottom: 3rem;
  right: 3rem;
  width: 50px;
  height: 50px;
  background: #333;
  color: #fff;
  font-size: 24px;
  text-align: center;
  line-height: 50px;
  border-radius: 50%;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
  z-index: 1000;
}

.to-top:hover {
  color: #fff;
  border-color: #fff;
}

.to-top.show {
  opacity: 1;
  pointer-events: auto;
}


@media (max-width: 820px) {
  body {
  font-size: 1.6rem;
  font-weight: 400;
  }
  header {
      background: url('../images/mv.png') no-repeat right -690px center / cover;
}
.fixed-btn{
  padding: 1.75rem 0.5rem 1rem;
}
.fixed-btn img{
  max-width: 90%;
}
  header div {
    left: 5%;
    width: 50%;
}
  .container{
    width: 90%;
    padding: 80px 0;
    margin: 0 auto;
  }
  .notice-item{
    display: block;
  }
  .notice-item dt{
    margin-bottom: 0;
  }

/* ハイライトテキスト */
.highlight-text {
  font-size: 1.9rem;
  text-align: left;
}
.highlight-circle {
  float: left;
  font-size: 2.2rem;
  padding: 1.75rem 1rem;
  margin-right: 0.75rem;
}
.highlight-circle small {
  font-size: 75%;
}
.highlight-text-innner{
  float: left;
  padding-top: 0.75rem;
  margin-bottom: 2.5rem;
  line-height: 1.4;
}
  
  .product-list{
    gap: 2rem;
  }
  .row.no-column{
    flex-direction: row;
    gap: 0.75rem;
  }
  .row .column.column-50.product-box,.row .column.column-75.product-box {
    width: 100%;
    max-width: 100%;
  }
  .row .column.product-box{
    margin-bottom: 0;
  }
  .row .column.column-20-sp{
    max-width: 20%;
  }
  .row .column.column-80-sp{
    max-width: 80%;
    flex: 0 0 80%;
  }
   .row .column.column-33 img{
    width: 94%;
  }
  .product-box p.line2 {
    min-height: auto;
}
  .price-list{
    margin: 0;
  }
  .price-list li{
    font-size: 2.0rem;
    margin: 0;
    line-height: 1.4;
  }
  .bg-products{
    background-position: top left;
  }
  .vertical-text{
    font-size: 1.8rem;
    line-height: 2.25;
  }
  .button#order,.button#mail{
    width: 100%;
    font-size: 1.75rem;
  }
  .button#order img {
    height: 2rem;
    vertical-align: middle;
}
.bg-section02 {
  min-height: 250px;
}
.bg-section03 {
  min-height: 250px;
}
.bg-section04 {
  min-height: 250px;
}
  .highlight-text {
    flex-direction: column;
  }
  .center-title {
  font-size: 2.2rem;
}
footer img{
  width: 70%;
}
.to-top {
  position: fixed;
  bottom: 1rem;
  right: 1rem;
}
.sp{
  display: block;
}
}