/*************************
共通 250818 AIによる修正ずみ
*************************/
/* 基本スタイルと共通設定 */
html {
  font-size: 0.85em !important;
}

body {
  max-width: 100%;
  min-width: 280px;
  height: auto;
  font-size: 1em;
  position: relative;
  font-family: 'Quicksand', sans-serif;
  line-height: 1.6em;
}

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

a {
  display: block;
  cursor: pointer;
  text-decoration: none;
}

.sp-only,
.sp-br {
  display: block !important;
}

.pc-only {
  display: none !important;
}

.pc-br {
  display: inline-block;
}

.block {
  display: block;
  clear: both;
}

.i-style,
.i-style-home {
  font-size: 3em;
  display: block;
  margin-bottom: 5px;
}

.wrap10 {
  width: 100%;
}

/* 見出しスタイル */
h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
  margin-top: 0;
  margin-bottom: 1.5rem;
  font-weight: 500;
  line-height: 1.8;
  color: #363d47;
}

h1,
.h1 {
  font-size: calc(1.275rem + .3vw);
}

h2,
.h2 {
  font-size: calc(1.4rem + .18vw);
}

h3,
.h3 {
  font-size: calc(1.255rem + .06vw);
}

h4,
.h4 {
  font-size: 1.2rem;
}

h5,
.h5 {
  font-size: 1.15rem;
}

h6,
.h6 {
  font-size: 1.05rem;
}

/* 1200px以上での見出しのフォントサイズ調整 */
@media (min-width: 1200px) {

  h1,
  .h1 {
    font-size: 1.5rem;
  }

  h2,
  .h2 {
    font-size: 1.4rem;
  }

  h3,
  .h3 {
    font-size: 1.3rem;
  }
}

p {
  margin-top: 0;
  margin-bottom: 1rem;
}

h2 {
  padding: 10px 0;
  line-height: 1.6em;
}

h2.h2-left {
  text-align: center;
  position: relative;
  background-size: cover;
  background-position: right;
}

h2.h2-center {
  text-align: center;
}

h2.h2-center span {
  text-shadow: 2px 2px 1px #fff,
    -2px 2px 1px #fff,
    2px -2px 1px #fff,
    -2px -2px 1px #fff;
}

h2.h2-center img,
h2.h2-center span {
  display: block;
  margin: 0 auto;
}

h2.h2-center span:last-child {
  font-size: 0.65em;
}

h2.about-tit {
  background-image: url(../images/about-tit-bg_sp.jpg);
  background-repeat: no-repeat;
  background-color: #f6f6f6;
}

h2.seasonal-tit {
  background-image: url(../images/seasonal-tit-bg.png);
}

h2 span>span {
  text-shadow: 2px 2px 1px #fff,
    -2px 2px 1px #fff,
    2px -2px 1px #fff,
    -2px -2px 1px #fff;
}

h2 span>span:nth-of-type(1),
.product-tit>span:nth-of-type(1),
h2.h2-center span:nth-of-type(1) {
  font-family: 'Tenor Sans', sans-serif;
  font-size: 1.4em;
  display: block;
  margin: 0;
  letter-spacing: 0.04em;
}

h2 span>span:last-child {
  font-size: 0.65em;
  display: block;
}

h2 img {
  width: 35px;
  height: auto;
  vertical-align: bottom;
}

/* ヘッダー */
#main {
  padding: 0;
  margin: 0;
  overflow: hidden;
}

#header01 {
  background-color: rgba(255, 255, 255, 1);
  display: flex;
  width: 100%;
  height: 150px;
  align-items: center;
}

#header02 {
  background-color: rgba(255, 255, 255, 0.8);
  color: #000;
  width: 100%;
  height: 550px;
  display: none;
}

.sp-gnavi-open {
  display: block;
  width: 26px;
  height: 26px;
}

input[type="checkbox"].on-off {
  display: none;
}

#sub-gnavi {
  background-color: rgba(255, 255, 255, 0.8);
  transition: all 0.5s;
  margin: 0 0 10px;
  padding: 0;
  z-index: 1;
}

#sub-gnavi li {
  list-style: none;
  /* デフォルトのリストスタイルを削除 */
}

#sub-gnavi li a {
  width: 47%;
  padding: 0 0 11px;
  float: left;
  color: #5d5d5d;
  background: #fff;
  text-align: center;
  font-size: 0.85em;
  line-height: 1.3em;
  border: 1px solid #bbb;
  border-radius: 10px;
}

#sub-gnavi li:nth-child(odd) a {
  margin: 10px 1% 0 2%;
}

#sub-gnavi li:nth-child(even) a {
  margin: 10px 2% 0 1%;
}

#sub-gnavi li a img {
  width: 30%;
  margin: 0 auto;
}

#sub-gnavi li:nth-child(2) a,
#sub-gnavi li:nth-child(4) a {
  float: right;
}

input[type="checkbox"].on-off+ul {
  height: 0;
  overflow: hidden;
}

input[type="checkbox"].on-off:checked+ul {
  height: 100vh;
  display: block;
  margin: 15px 0 10px !important;
}

#sp-gnavi-open {
  display: block;
  width: 42px;
  height: 42px;
  position: fixed;
  top: 2px;
  right: 10px;
  z-index: 3;
}

#sp-gnavi-open span {
  display: block;
  background: #000;
  width: 24px;
  height: 2px;
  position: absolute;
  left: 9px;
  transition: all 0.4s;
}

#sp-gnavi-open span:first-child {
  top: 12px;
}

#sp-gnavi-open span:nth-child(2) {
  margin-top: -1px;
  top: 50%;
}

#sp-gnavi-open span:last-child {
  bottom: 12px;
}

.image-container {

  /* 16:9のアスペクト比を維持するための設定 */

  position: relative;
  width: 100%;
  padding-top: 56.25%;
  /* 9 / 16 * 100% = 56.25% */
  overflow: hidden;
}



.image-cropped {
  /* 親要素の.image-container内に画像を配置 */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  /* ここで高さを100%に設定することが重要です */
  height: 100%;
  object-fit: cover;
  /* コンテナに合わせて画像をトリミング */

  /* object-position: horizontal vertical; の形式で、ここでは縦位置のみ制御 */
  object-position: 50% var(--crop-position-y, 50%);
  /* デフォルトは中央 (50%) */

}

/* For responsive iframe */
.video-container {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 Aspect Ratio (9 / 16 = 0.5625) */
  overflow: hidden;
  border-radius: 0rem; /* rounded-3xl */
}

.video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}