/* *********************************
追記 2025/04/09 
			CSS Template

  max-width: 1116px;(padding20)80%

********************************* */
body {
  font-family:"Zen Kaku Gothic New", "メイリオ", sans-serif;
  font-weight: bold;
}
@media screen and (max-width: 1000px) {
  body {
      overflow-x: hidden;
  }
}
.each-clm{
  top: 60px;
  right: 0%;
  left: auto;
}
.clm-link:hover + .each-clm,
.each-clm:hover {
  display: block;
}
main {
  overflow-x: hidden;
  background: #fff;
  /* margin-top: 80px; */
  max-width: 1300px;
  max-width:clamp(1000px,90.28vw,1300px);
  margin: 80px auto 0;
  width: 100%;
}
img {
  width: auto;
  max-width: 100%;
  vertical-align: bottom;
}
.inner{
  padding: 0 20px;
  max-width: 1080px;
  width: 100%;
  margin: auto;
}
/* ヘッダーPC */
nav{
  height: 80px;
}
a.logo {
  display: flex;
      margin-right: auto;
      align-items: center;
}
img.head-logo {
  height: 60px;
  width: auto;
}
.nav-wrap{
  display: flex;
  width: 100%;
  max-width: 1233px;
  margin: 0 auto;
  padding: 0 20px;
}
.nav-main-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 30px;
  gap:clamp(10px,2.34vw,30px);
}
.nav-main-wrap a {
  font-weight: bold;
  font-size: 16px;
  font-size: clamp(13px, 1.11vw, 16px);
  display: flex;
      height: 100%;
      align-items: center;
}
@media screen and (max-width: 1300px) {
  main {
    max-width: 1300px;
    max-width:clamp(90%,90.28vw,1300px);
  }
}
@media screen and (max-width:900px) {
.nav-wrap{
  width: calc(100% - 20px);
}
.nav-main-wrap{
  gap:10px;
}
img.head-logo {
  height: 30px;
  width: auto;
}
.nav-main-wrap a{
  font-size: clamp(11px, 1.33vw, 17px);
}
}
/* ヘッダーSP */
@media screen and (max-width: 770px) {
  main {
    margin-top: 70px;
    max-width: 100%;
  }
  img.head-logo {
    height: 40px;
    width: auto;
  }
  a.logo {
    margin-left: 15px;
}
a.contact-btn {
  background-color: #eb6fa7;
}
}
.inner{
  padding: 0 15px;
}
img.fv-bg {
  width: 100%;
  max-width: unset;
  padding-top: 60px;
}
/* 特徴＆理由 */

section.FV2 {
  padding-bottom: 0;
  text-align: center;
}
section#reason{
  /* background: url("../img2/appeal_79.webp")no-repeat; */
  background-size: 100% auto;
  background-position: center;
  margin-bottom: 20px;
  padding-bottom: 0%;
}
.top-section {
  display: flex;
  align-items: center;
  gap: 30px;
  width: 100%;
  flex-wrap: wrap;
  justify-content: center;
}
.text-box {
  width: auto;
}
.text-box h1{
  font-size: 34px;
  font-size:clamp(20px,2.36vw,34px);
  color: #00A1E9;
  margin:0;
}
.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 40px;
  margin-bottom: 60px;
}
.grid img {
  width: 94%;
  height: auto;
}
.top-section img{
  max-width: 255px;
  height: auto;
}
@media screen and (max-width: 770px) {
  .top-section img {
    max-width: 70%;
    height: auto;
  }
  .text-box h1 {
    font-size: 32px;
    font-size:clamp(20px,7.47vw,32px);
  }
  section.FV2 {
    padding: 0;
  }
  section#reason{
    background: none;
    padding-bottom: 0%;
  }
  .sp-feature-02{
    max-width: 60%;
    margin: 0 auto;
  }
  .top-section {
    gap: 16px;
    margin-top: 70px;
}
  .top-section img {
    max-width: 270px;
    max-width: clamp(100px,72vw,270px);
}

}

/* ボトルの種類が豊富 */
/* 共通一番上の画像 */
.top-section-num {
  text-align: center;
  margin-top: 40px;
  padding-bottom: 20px;
  padding-top: 40px;
  position: relative;
}
.top-section-num img {
  width: 176px;
  max-width: 176px;
  height: auto;
}
.top-section-num::before {
  content: "";
  width: 100%;
  height: 3px;
  display: inline-block;
  background-color: #00a0e9;
  max-width: 924px;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  top: 0;
}
.blue-line{
  background-color: #00afdd;
}
#factory .top-section-num::before{
  display: none;
}
.bottle-item{
  flex-direction: column;
}
.bottle-item-textcontent {
  height: auto;
  width: 100%;
 position: absolute;
  left: 0;
  right: 0;
  margin: auto; 
  /* bottom: -56px; */
  top: 60%;
  padding: 0 15px;
}
.bottle-item .bottle-name,.bottle-item .cap-info,.bottle-item .separator,.bottle-item .description,.bottle-item .case-info{
  position: static;
  transform: translateX(0%);
}
.bottle-item .separator{
  border-left: none;
}
.bottle-item .bottle-name {
  font-size: 23px;
  font-size:clamp(16px,1.8vw,23px);
  color: #00afdd;
  margin-bottom: 10px;
}
.bottle-item .cap-info {
  text-align: left;
  margin: 0 0 5px;
  font-weight: bold;
  font-size: 16px;
  font-size:clamp(13px,1.25vw,16px);
}
.bottle-item .separator {
  margin: 0 0 20px;
}
.bottle-item .case-info{
  margin: 0;
    font-weight: bold;
    font-size: 16px;
    font-size:clamp(13px,1.25vw,16px);
    text-align: left;
}
.bottle-item .description {
  margin: 0;
  line-height: 1.7;
  font-size:clamp(11px,1.09vw,14px);
}

.bottle-grid {
  gap: 75px 50px;
  margin: 0;
  /* margin-top: -130px;
  margin-top: clamp(-170px, -10.16vw, -100px);  */
} 
@media screen and (min-width: 771px) {
  .bottle-grid{
    gap: 0 50px;
    gap:0 clamp(20px,3.91vw,50px);
    margin-top: -100px;
  }
  .bottle-item {
    height: 685px;
    height: clamp(600px,53.52vw,658px);
}
.item01{
  height: 748px;

  /* height: clamp(600px,48.61vw,700px); */
}
.item02{
  height: 748px;

  /* height: clamp(600px,48.61vw,700px); */
}
.item03{
  height: 748px;
  /* height: clamp(600px,48.61vw,700px); */
}

.item04{
  height: 600px;
  padding-top: 120px;
  /* height: clamp(100px,55.7vw,713px); */
}
.item04 .bottle-item-textcontent{
  top: 65%;
}
.item05{
  height: 600px;
  /* height: clamp(100px,44.84vw,574px); */
}
.item05 .bottle-item-textcontent{
  top: 65%;
}
.item06{
  height: 691px;
  padding-top: 0;
}
.item06 .bottle-item-textcontent{
  top: 55%;
}

.item07,.item08{
  height: 920px;
  height: clamp(100px,71.88vw,920px);
  justify-content: flex-start;
  padding-top: 190px;
  padding-top: clamp(100px,14.84vw,190px);
  padding-top: clamp(100px, 16.05vw, 160px);
}
.item07 .bottle-item-textcontent, .item08 .bottle-item-textcontent {
  top: 62%;
}
.item09 {
  height: 795px;
  height: clamp(100px,62.11vw,795px);
  justify-content: flex-start;
}
.item09 .bottle-item-textcontent {
  top: 79%;
}
}
@media screen and (min-width: 1190px) {

}
@media screen and (min-width: 1190px) {
  section.reason02 {
    margin-top: -150px;
}
.item07 .bottle-item-textcontent,.item08 .bottle-item-textcontent{
  top: 48%;
}
.item07, .item08{
  padding-top: 160px;
}
.item09 .bottle-item-textcontent{
  top: 61%;
}
}

@media screen and (max-width: 770px) {
  .bottle-grid01-img-wrap{
    flex-wrap: wrap;
    gap: 20px;
    align-items: flex-end;
  }
  .bottle-grid01-item-image {
    width: calc((100% - 20px) / 2);
}
  .bottle-item-textcontent{
    top: 33%;
  }
  .top-section-num::before{
    height: 2px;
    width: 100%;
  }

  .container02 .text-box02 .description{
    font-size: 17px;
  }
  .container02 .text-box02{
    padding: 0;
  }
  .bottle-item-t
  extcontent {
    padding: 0 8px;
    bottom: 0;
}
  .bottle-item .bottle-name{
    font-size: 18px;
  }
  .bottle-item .cap-info,.bottle-item .case-info {
    font-size: 14px;
}
.bottle-item .separator {
  margin: 0 0 15px;
}
.bottle-item .description {
  font-size: 13px;
}
.bottle-item {
  margin-bottom: 190px;
  margin-bottom: clamp(50px,50.67vw,200px);
  justify-content: flex-start;
}
.bottle-item.item04 {
  padding-top: 30%;
}
.bottle-item.item06 {
  padding-top: 40%;
}
.item05 .bottle-item-textcontent{
  top: 38%;
}
.item06 .bottle-item-textcontent{
  top: 38%;
}
.item09 {
  margin-bottom: 0px;
}
.item09 .bottle-item-textcontent{
  top: 66%;
}

}
@media screen and (max-width: 500px) {

}

/*小ロットから作れる*/
.bottle-grid02{

}
.bottle-grid02-img-wrap {
  margin: 40px 0 50px;
}
.bottle-grid02-item-image{
  margin-bottom: 12px;
}
.bottle-item02 .bottle-name02{
  position: static;
  transform: translateX(0%);
  color: #00afdd;
  font-size: 20px;
  margin-top: 20px;
}
.bottle-item02 {
  height: auto;
      position: relative;
}
@media screen and (min-width: 771px) {
  .bottle-grid02{
    gap: 30px;
    margin-top: 0px;
    grid-template-rows: 350px 350px 400px;
  }
  
  .bottle-item02 {
    position: relative;
    overflow: hidden;
}
.bottle-item02 span{
  width: 100%;
  position: absolute;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  bottom: 20%;
  left: 0;
  right: 0;
  margin: auto;
}
.bottle-item02 img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  /* object-position: top; */
  object-position: 50% 100%;
}
.bottle-item02 .bottle-name02{
  position: absolute;
  display: block;
  bottom: 0%;
  top: auto;
}
}
@media screen and (max-width: 770px) {
  .bottle-grid02 {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows:auto;
    padding: 0px;
    gap: 30px;
    margin-top: clamp(-100px, -12vw, -45px);
    margin-bottom: 30px;
  }
  .bottle-item02{
    display: block;
  }
  .bottle-item02 .bottle-name02{
    font-size: clamp(15px, 4.53vw, 20px);
  }
  .new-banner{
    padding:0;
  }
}

section.performance{
  padding: 60px 20px 30px;
  /* max-width: 1080px; */
  max-width: 100%;
  width: 100%;
  margin: auto;
}
.performance-title {
  text-align: center;
  background: url(../img2/appeal_44.webp)no-repeat;
  background-size: 98% auto;
  max-width: 924px;
  padding: 133px 0 0;
  /* padding:clamp(100px,9.24vw,133px) 0 0; */
  background-position: bottom center;
  margin: auto;
}
.performance-title h1{
  color: #e95098;
  font-size: 50px;
  font-size:clamp(40px,3.47vw,50px);
  letter-spacing: 0.09em;
}
h1.fv_title {
  display: block;
  position: absolute;
  top: 70px;
  z-index: 10;
  color: #00afdd;
  font-size: 14px;
  padding: 0 10px;
  left: 6%;
}
table.contact-tbl th {
  background: #fff;
  color: #00afdd;
  padding: 10px 20px;
  border: 2px solid #00afdd;
  width: 30%;
  text-align: left;
  position: relative;
  border-right-color: #00afdd;
}

th.required:after {
  content: "必須";
  position: absolute;
  right: 20px;
  color: #121212;
  background: #fff;
  padding: 0 5px;
}
button.sub-btn {
  display: block;
  width: 400px;
  height: 55px;
  line-height: 55px;
  border: none;
  border-radius: 0px;
  background: #8c95a0;
  color: #fff;
  font-weight: bold;
  font-size: 20px;
  margin: auto;
  position: relative;
  cursor: pointer;
}

.caution {
  max-width: 1100px;
  margin: 10px auto;
  text-align: left;
}

a.inq-btn {
  background: #00a0e9;
  color: #fff;
  border-radius: 40px;
  padding: 8px 30px;
  display: flex;
  height: auto;
  
}
footer {
  position: relative;
  padding: 50px 0 0;
  overflow-x: hidden;
  text-align: center;
}
.footer-logo-wrap{
  width: 98%;
  max-width: 885px;
  margin:0 auto;
  display: block;
}
.foot-data {
  padding: 23px 0 150px;
  text-align: center;
  max-width: 980px;
  max-width: 885px;
  margin: 0 auto;
}
.foot-txt {
  margin: 15px 0;
  padding-left: 15px;
  border-left: 2px solid #4694d1;
  text-align: left;
  display: inline-block; /* 中央に配置するためにインラインブロックにする */
  width: 90%;
}
.banner-box {
  display: flex;
  justify-content: center;
  max-width: 66%;
  margin: 0 auto;
}
table.contact-tbl th {
  /* border: none; */
}
img.hw-logo {
  width: 90%;
  margin: 0;
}
.add-more-btn a {
  background-color:#00afdd;
  color: #fff;
  text-decoration: none;
  padding: 15px 40px 15px 40px;
  border-radius: 30px;
}

@media screen and (max-width: 770px) {
  .sns-flex {
    flex-wrap: wrap;
    justify-content: flex-start;
    width: 80%;
    margin: 0 auto;
  }

  .sns-flex a {
    width: 32.6%;
    margin-bottom: 10px;
    margin-right: 1%;
  }

  .sns-flex a:last-child {
    margin-right: 0;
  }

  .add-more-btn {
    display: inline-block;
    padding-bottom: 40px;
  }
  section.performance{
    padding: 60px 0px 30px;
  }
  .performance-title{
    background: no-repeat;
    padding: 0;
  }
}

@media screen and (max-width: 450px) {
  .sns-flex {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }

  .sns-flex a {
    width: 49%;
    margin-right: 2%;
  }

  .sns-flex a:nth-child(even) {
    margin-right: 0;
  }
}

.container {
  /* max-width: 1040px;
  margin: auto; */
  padding-bottom: 55px;
  position: relative;
}
.container .grid {
  padding: 0 40px;
  text-align: center;
  justify-items: center;
  gap: 30px;
  max-width: 87%;
  margin: 40px auto 40px;
  position: relative;
  z-index: 3;

}
.container .grid img{
  width: 100%;
}
.text-box p {
  font-size: 16px;
  line-height: 1.6;
}
.empty {
  visibility: hidden;
}

.bottom-row {
  grid-column: 2;
  display: flex;
  justify-content: center;
  gap: 30px;
}

.bottom-row img {
  width: 30%;
}
.container02 {
  max-width: 1080px;
  max-width: 924px;
  margin: auto auto 50px;
  padding: 0 20px;
  position: relative;
}

/* テキスト */
.container02 .text-box02 {
  text-align: center;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.text-box02 {
  text-align: center;
}
.text-box02 .title {
  font-size: 60px;
  font-size: clamp(30px, 4.17vw, 60px);
  color: #e95098;
  margin-bottom: 0px;
  font-weight: bold;
}
.container02 .text-box02 .title{
  color: #e95098;
  font-size: 60px;
  font-size: clamp(30px, 4.17vw, 60px);
}
section.reason02 .container02 .text-box02 .title{
  color: #00a0b8;
}
#step03 .text-box02 .title{
  color: #6eb92b;
}
#factory .text-box02 .title{
  color: #929aa2;
}
.text-box02 .description {
  font-size: 24px;
  font-size: clamp(17px,1.66vw,24px);
  line-height: 1.6;
  font-weight: bold;
}
.sub-section {
  margin-bottom: 40px;
  margin-top: 30px;
  font-size: 20px;
}
.sub-section span{
  position: relative;
}
.sub-section img {
  width: 45%;
  max-width: 118px;
  position: absolute;
    top: 0;
    right: -44%;
    bottom: 0;
    margin: auto;
}

.sub-txt {
  width: 100%;
  font-weight: bold;
}
.sub-txt {
  width: 100%;
}
.sub-txt p {
  font-size: 18px;
  font-size:clamp(14px,1.25vw,18px);
  color: #00afdd;
}

section.reason01 {
  background: #fff;
  margin-top: -40px;
  /* margin-bottom: 150px; */
  margin-bottom:20px;
}

.circle {
  display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 30px;
      height: 30px;
      background-color: transparent;
      border: 1px solid #121212;
      border-radius: 50%;
      color: #121212;
      font-size: 14px;
      font-weight: bold;
      margin: 5px;
      line-height: 1;
}

.black-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background-color: #121212;
  border-radius: 50%;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
}
@-moz-document url-prefix() {
  @media screen and (min-width: 771px){
    .container .grid{
      display: flex;
      flex-wrap: wrap;
      align-items: flex-start;
    }
    .container .grid img{
      width: 30%;
    }
  }
}
@media screen and (min-width: 771px){

  .bacground-bottle{
    position: absolute;
    width: 50px;
    top: 0;
    left: 0;
  }
  .bacground-reason01.bg01 {
    right: 1%;
    left: auto;
    top: 2%;
}
.bacground-reason01.bg02 {
  top: 10%;
  left: 1%;
}
.bacground-reason01.bg03 {
  top: 3%;
  left: 22%;
}
  .bacground-reason01{
    position: absolute;
    width: 50px;
    top: 0;
    left: 0;
  }
  .bacground-bottle img{
    width: 100%;
  }
  .container .bg01{
    top: 9%;
    left: 0;
  }
  .container .bg02{
    left: 35%;
    top: 38%;
  }
  .container .bg03{
    top: 55%;
    left: 10%;
    width: 85px;
  }
  .container .bg04{
    top: auto;
    left: auto;
    right: 0;
    bottom: 31%;
    width: 55px;
  }
  .container .bg05{
    top: auto;
    left: auto;
    right: 18%;
    bottom: 2%;
  }
  .bacground-reason02{
    position: absolute;
    width: 50px;
    top: 0;
    left: 0;
  }
  .bacground-reason02.bg01 {
    right: 1%;
    left: auto;
    top: 6%;
}
.bacground-reason02.bg02 {
  top: 2%;
  /* width: 70px; */
  left: 2%;
}
.bacground-reason02.bg03 {
  top: 15%;
  left: 1%;
}
}
@media screen and (max-width: 770px){
  .bacground-reason02, .bacground-reason01{
    display: none;
  }
  .bacground-bottle{
    display: none;
  }
  .container02{
    padding:0 15px;
  }
  section.reason01{
    margin-bottom: 0px;
  }
  .container02 .text-box02 .title{
    font-size: clamp(15px, 8vw, 40px);
  }
  .container .grid {
    margin-bottom: 0px;
    padding: 0px;
    align-items: center;
    gap: 20px;
    max-width: 100%;
    margin: 40px auto 0px;
  }
  .bottom-row {
    gap: 10px;
  }
  #step03 .step03-title-wrap {
    padding-left: 15px;
    padding-right: 15px;
}
}
@media screen and (max-width: 500px){
  section.reason01{
    /* margin-bottom: 200px;
    margin-bottom: clamp(50px,66.67vw, 400px); */
  }
}

#faq {
  background-color: #fff;
}

.container07 {
  margin: auto;
  background-color: #fff;
  max-width: 1080px;
  max-width: 975px; 
  padding: 0px 20px 0;
  margin-top: 100px;
}

.container07 h2 {
  text-align: center;
  color: #0091db;
  margin-bottom: 40px;
  font-size: 50px;
  font-size:clamp(20px,3.47vw,50px);
}

.faq-item {
  margin-bottom: 20px;
}

.faq-item .question {
  display: flex;
  background-color:#00b8de;
  color: white;
  padding: 20px;
  border-radius: 13px;
  font-weight: bold;
  margin: 0 0 15px;
  align-items: center;
  position: relative;
  font-size: clamp(17px, 1.25vw, 20px);
}
.faq-item .question::before{
  content: "";
  display: inline-block;
  width: 20px;
  background: url(../img2/tsuno_02.webp) no-repeat;
  width: 30px;
  height: 20px;
  background-size: contain;
  position: absolute;
  bottom: -20px;
  left: 30px;
}
.faq-item .answer {
  display: flex;
  background-color: #fff;
  padding: 10px;
  border-radius: 5px;
  font-size: 14px;
}

.faq-item .answer p {
  margin: 0;
}

.answer-icon {
  margin: 0px 20px 0 0;
  color: #00b8de;
  font-weight: bold;
  font-size: 24px;
}

.faq-item .answer p {
  margin: 0;
  font-size: 18px;
  font-size: clamp(15px,1.25vw,18px);
  color: #00b8de;
  font-weight: bold;
  line-height: 1.7;
}

.question-icon {
  margin: 0 20px 0 0;
  font-size: 25px;
}

.contact-container {
  text-align: center;
}

.contact-container h1 {
  font-size: 50px;
  font-size:clamp(20px,3.47vw,50px);
  color: #00afdd;
  margin: 0;
  font-weight: bold;
}

.contact-container p {
  font-size: 24px;
  color: #00afdd;
  font-weight: bold;
  margin-top: 5px;
  margin-bottom: 30px;
}

.container-step {
}
@media screen and (max-width: 770px){
  .contact-container h1{
    font-size: clamp(15px, 8vw, 40px);
  }
  .container07 h2{
    font-size: clamp(15px, 8vw, 40px);
    margin-bottom: 35px;
  }
  .faq-item {
    margin-bottom: 20px;
    padding: 0px;
}
.faq-item .question {
  align-items: flex-start;
}
.question-icon {
  margin: 0 15px 0 0;
  font-size: 20px;
}
.faq-item .question {
  align-items: flex-start;
  padding: 10px;
}
.question-text {
  font-size: 14px;
  line-height: 1.7;
}
.faq-item .answer {
  padding: 15px 0;
}
.answer-icon {
  font-size: 20px;
  margin: 0px 15px 0 0;
}
.faq-item .answer p {
  margin: 0;
  font-size: 16px;
}
.faq-item .question::before{
  width: 20px;
  left: 24px;
}
.container07{
  margin-top: 50px;
}

}


/* タイトル */
.container-step h1 {
  text-align: center;
  color: #0091db;
  font-size: 50px;
  font-size:clamp(20px,3.47vw,50px);
  margin-bottom: 40px;
}

.container-step h2 {
  text-align: left;
  color: #e75f94;
  margin: 70px 0 45px;
  margin:clamp(40px,4.86vw,70px) 0 45px;
  font-size: 30px;
  font-size: clamp(15px,2.08vw,30px);
}

#step {
  max-width: 1080px;
  max-width: 975px;
  padding: 0 20px;
  margin: 0 auto;
  text-align: center;
  margin-top: 100px;
}

/* ステップのセクション */
.step-section {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  /* justify-content: space-between; */
  margin-bottom: 40px;
  gap: 25px;
  position: relative;
}

.step-section .step-left {
  width: 30%;
  max-width: 100%;
  height: auto;
  text-align: left;
}

/* 左の画像 */
.step-section .step-left img {
  width: 100%;
  max-width: 100%;
  height: auto;
}

/* 中央のテキスト */
.step-section .step-text {
  width: 50%;
  max-width: 45%;
  text-align: left;
}


/* 右の画像 */
.step-section .step-right img {
  object-fit: contain;
  width: 100%;
  max-width: 100%;
  height: 70px;
}
.step-section .step-right {
  width: 20%;
  max-width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  bottom: 0;
  top: 0;
  margin: auto;
}
.step-section.step01 .step-right img{
  height: 100px;
  height: clamp(50px,7.03vw,90px);
}
.step-number {
  background-color: #ff4e92;
  color: white;
  font-size: 24px;
  font-weight: bold;
  padding: 10px 15px;
  border-radius: 50%;
  margin-bottom: 15px;
}

.step-title {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 10px;
}

.step-description {
  font-size: 16px;
  font-size:clamp(14px,1.11vw,16px);
  color: #555;
}

/* サブタイトル */
.sub-title {
  font-size: 16px;
  color: #00afdd;
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}

.attention {
  font-size: 12px;
}

.container-info {
  margin: 40px auto 0;
  position: relative;
  z-index: 3;
}

#factory {
  max-width: 100%;
  /* background: url(../img2/appeal_81.webp) repeat-y; */
  background-size: 100% auto;
  background-position: top center;
}
#factory .top-section-num{
  position: relative;
  max-width: 924px;
    margin: 40px auto 0;
    padding: 40px 20px 0;
}
.factory-topic-wrap {
  max-width: 1080px;
  max-width: 924px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
}
#factory .text-box02{
  position: relative;
  max-width: 924px;
  margin: 0 auto;
  padding: 0 20px;
}
/* 工場情報セクション */
.factory-info {
  display: flex;
  flex-direction: row;
  margin-top: 0;
  margin-bottom: 40px;
}

.factory-info img {
  max-width: 55%;
  height: 100%;
  aspect-ratio: 3143 / 2017;
  margin-right: 35px;
}

.bottle-info img{
  height: auto;
  aspect-ratio: auto;
}
.factory-info .text {
  flex: 1;
  text-align: justify;
}

.factory-info .text h2 {
  color: #2cb58f;
  margin-bottom: 20px;
  font-size: 40px;
  font-size:clamp(20px,2.78vw,40px);
}
.no2 .factory-info .text h2{
  color:#468bc9;
}
.factory-info .text p{
  line-height: 1.7;
  font-size:clamp(14px,1.11vw,16px);
}
.bottle-info {
  margin-top: 18px;
}
/* 対応ボトル情報 */
.bottle-info img {

  max-width: 100%;
}

.bottle-info p {
  font-size: 16px;
  color: #00afdd;
}

/* 成分情報のタイトル */
.ingredients-title {
  font-size: 20px;
  color: #121212;
  font-weight: bold;
  margin-bottom: 20px;
  text-align: center;
}

/* 成分情報画像 */
.ingredients-image {
  text-align: center;
  margin-bottom: 85px;
}

.ingredients-image img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

.text-info {
  /* display: flex; */
}
.manufacturing-con h2 {
  font-weight: bold;
  text-align: center;
  font-size: 40px;
  font-size: clamp(20px, 2.78vw, 40px);
  color: #778388;
}

.manufacturing-con p {
  font-weight: bold;
  text-align: center;
  margin: 0 40px;
  font-size: 20px;
  font-size: clamp(16px,1.39vw,20px);
    line-height: 2;
}

.manufacturing-con .survey {
  width: 60%;
  max-width: 512px;
  margin: 30px auto 0;
}
#factory .top-section-num h1 {
  font-size: 60px;
  font-size: clamp(30px, 4.17vw, 60px);
  font-weight: bold;
  text-align: center;
  color: #778388;
}
.factory-top-text {
  margin: 39px auto 20px;
  text-align: center;
  max-width: 924px;
  padding: 0 20px;
}
.factory-top-text p {
  font-size: 16px;
  font-size:clamp(13px,1.11vw,16px);
  line-height: 1.7;
}
#pattern {
  max-width: 1080px;
  padding: 0 20px;
  margin: 0 auto;
}
.pattern-con {
  max-width: 100%;
  margin: auto;
  padding-bottom: 20px;
  background-color: #fff;
}

.pattern-con.text-box02 .title {
  color: #f08200;
  margin-bottom: 10px;
}

.pattern-con .description {
  text-align: center;
  font-size: 24px;
  color: #fff;
  background-color: #f08200;
  padding: 6px 15px;
  display: inline-block;
  border-radius: 8px;
  line-height: 1.7;
}
.pattern-img-001 {
  width: 68%;
  max-width: 705px;
  margin: 20px auto 40px;
}
.pattern-img-002 {
  max-width: 924px;
  padding: 0 20px;
  margin: 0 auto 40px;
}
.pattern-img-003 {
  max-width: 924px;
  padding: 0 20px;
  margin: 0 auto;
}
#step03 .text-box02 {
  text-align: center;
  margin: 0 auto;
}
.step03-title-wrap{
  position: relative;
}
#step03 .text-box02 .title {

}

#step03 .text-box02 .description {
  font-size: 24px;
  font-size: clamp(17px, 1.66vw, 24px);
  line-height: 1.6;
  font-weight: bold;
}

.step03-con {
  max-width: 1080px;
  max-width: 924px;
  padding: 0 20px;
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  margin-top: 60px;
  position: relative;
}

/* 左側の画像とテキスト */

section#step03 {
  /* background: url(../img2/appeal_80.webp) no-repeat; */
  background-size: 100% auto;
  background-position: top;

}
.step03-con-wrap {
  position: relative;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 20px;
}
.step03-con{
  gap: 20px;
}
.left-column {
  width: 40%;
  padding-right: 20px;
  text-align: left;
}

.left-column h1 {
  color: #0099a0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  font-weight: bold;
  font-weight: bold;
}
.left-column .type {
  font-size: 50px;
  font-weight: bold;
}
.left-column .label {
  margin-left:0;
}
.left-column .text {
  padding: 20px 0;
  color: #121212;
  text-align: left;
  font-size: 15px;
  font-size: clamp(13px,1.04vw,15px);
  line-height: 2;
}
.left-con-low {
  margin: 15px auto 0;
  max-width: auto;
  max-width: 83%;
}
.left-column img{
  width: 100%;
}
/* 右側のテキストと吹き出し */
.right-column {
  padding-left: 0px;
  width: calc(100% - 40% - 20px);
}


.right-column h2 {
  /* color: #00afdd; */
  margin-bottom: 20px;
  text-align: center;
}

.right-column .speech-bubble {
  background-color: #00b8de;
  color: white;
  padding: 15px;
  border-radius: 10px;
  margin: 0 0 45px;
  position: relative;
  display: inline-block;
  font-size: 16px;
  font-size: clamp(13px, 1.11vw, 16px);
  line-height: 1.7;
}
.right-column .speech-bubble::after {
 content:"";
 position: absolute;
 display: inline-block;
 background: url(../img2/tsuno_01.webp)no-repeat;
 width: 30px;
 height: 20px;
 background-size: contain;
 bottom: -20px;
 right: 50px;
}

/* 青枠のテキストボックス */
.blue-box {
  border: 2px solid #00afdd;
  padding: 20px;
  margin-top: 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-radius: 40px;
  gap:40px;
  background-color: #FFF;
}

.blue-box .blue-text {
  color: #00afdd;
  font-weight: bold;
  padding-right: 0px;
  line-height: 2;
  font-size: 14px;
}

.blue-box img {
  width: 150px;
  height: auto;
  margin-left: 0px;
}

.seen {
  text-align: center;
  max-width: 924px;
  padding: 0 20px;
  margin: 60px auto 0;
  /* max-width: 1080px;
  padding: 0 20px; */
}

.foot-data .separator {
  border-left: 2px solid #00afdd;
  height: 20px;
  margin: 10px auto;
}

.banner-block {
  text-align: center;
}

.contact-tel {
  max-width:100%;
  margin: auto;
  padding: 35px 0px;
}

/* アイコンとテキスト */
.contact-info {
  display: flex;
  align-items: center;
  justify-content: center;
  /* background-color: #e1f6ff; */
  padding: 17px 0;
  /* border-radius: 8px; */
  margin-top: 30px;
  margin-bottom: 30px;
  border-top: 2px solid #00afdd;
  border-bottom: 2px solid #00afdd;
}

.contact-info .icon {
  /* background-color: #00b5e2; */
  /* color: #ffebe6; */
  /* padding: 20px; */
  /* border-radius: 50%; */
  margin-right: 35px;
  width: 15%;
  height: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.contact-info .text {
  flex: 1;
  text-align: left;
  display: flex;
  gap: 30px;
  align-items: center;
}

.contact-info .text p {
  font-size: 25px;
  font-size: clamp(16px, 1.74vw, 25px);
  font-weight: bold;
  color: #00afdd;
  margin: 0;
}

.contact-info .text .phone-number {
  font-size: 24px;
  /* color: #ff6f00; */
  font-weight: bold;
  margin-top: 10px;
  /* line-height: 0.5em; */
}

.contact-info .text .company-name {
  font-size: 16px;
  margin-top: 15px;
  color: #121212;
  display: inline-block;
}

.tel {
  color: #00afdd;
  font-size: 50px;
  font-size:clamp(20px,3.47vw,50px);
  font-weight: bold;
}
.manufacturing-con-wrap {
  display: flex;
  gap: 50px;
  margin: 50px 0;
}
.manufacturing-con-wrap img {
  width: calc((100% - 100px) / 3);
}
.factory-topic-relative{
  position: relative;
}
.manufacturing-con {
  max-width: 924px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 771px){
  .factory-no1 .factory-info img{
    margin-top: 12px;
  }
  .bacground-step03,.bacground-step03-con{
    position: absolute;
    top:0;
    left: 0;
    width: 50px;
  }
  .bacground-step03 img,.bacground-step03-con img{
    width: 100%;
  }
  .bacground-step03.bg01 {
    width: 75px;
    top: 14%;
    left: 7%;
  }
  .bacground-step03.bg02 {
    width: 50px;
    top: auto;
    left: auto;
    right: 3%;
    bottom: 3%;
  }
  .bacground-step03-con.bg01 {
    width: 55px;
    bottom: 0;
    top: auto;
    left: 6%;
}
.bacground-step03-con.bg02 {
  width: 40px;
  bottom: 13%;
  top: auto;
  left: 1%;
}
.bacground-step03-con.bg03 {
  width: 39px;
  bottom: 22%;
  top: auto;
  left: 41%;
}
.bacground-factory {
  position: absolute;
  top:0;
  left: 0;
  width: 50px;
}
.bacground-factory.bg01 img {
  width: 100%;
}
.bacground-factory.bg01{
  top: -10%;
  left: auto;
  right: 1%;
}
.bacground-factory.bg02{
  left: 1%;
  top: -33%;
  width: 45px;
}
.bacground-factory.bg03{
  left: auto;
  right: 1%;
  bottom: -37%;
  top: auto;
}
.bacground-factory-topic{
  position: absolute;
  top:0;
  left: 0;
  width: 50px;
}
.bacground-factory-topic.bg02{
  top: 85%;
  left: 9%;
}
.bacground-factory-topic.bg03 {
  bottom: -14%;
  right: 21%;
  left: auto;
  top: auto;
}
.bacground-factory-topic.bg01 {
  right: -6%;
  left: auto;
  top: 50%;
}
.bacground-factory-topic.bg04 {
  bottom: 0;
  top: auto;
  right: -6%;
  left: auto;
}
.bacground-factory-topic.bg05 {
  left: 5%;
  top: -3%;
}
.bacground-factory-topic.bg06 {
  width: 80px;
  bottom: 0;
  top: auto;
  left: 8%;
}
.bacground-factory-topic.bg07 {
  bottom: 8%;
  top: auto;
  right: 10%;
  left: auto;
}
}

@media screen and (max-width: 770px){
  .bacground-factory,.bacground-factory-topic {
    display: none;
}
  .bacground-step03,.bacground-step03-con{
    display: none;
  }
  section#step03{
    background: none;
  }
  .step03-con {
    flex-direction: column;
    padding: 0;
}
#step03 .text-box02 .description{
  font-size: 17px;
}
  .left-column{
    width: 100%;
    padding: 0px;
    text-align: center;
  }
  .left-column img {
    max-width: 80%;
}
.left-con-low {
  max-width: 100%;
}
  .right-column {
    width: 100%;
    /* padding: 0 20px; */
}
.right-column .speech-bubble {
  font-size: 15px;
  border-radius: 8px;
}
.blue-box {
  border-radius: 20px;
  flex-direction: row-reverse;
  gap: 20px;
  align-items: flex-start;
}
.blue-box img {
  width: 25%;
}
.blue-box .blue-text{
  font-size: 14px;
  padding-right: 0;
}
.seen {
  padding: 0 10px;
}
#pattern{
  padding: 0 15px; 
}
.pattern-img-002, .pattern-img-003 {
  padding:0;
  margin: 0 0 20px;
}
.pattern-img-001{
  max-width: 95%;
  width: 100%;
}
  .grid {
    grid-template-columns: 1fr 1fr; /* 2列グリッドに変更 */
  }
  .bottom-row {
    display: contents; /* ラッパーを消去して子画像を直にグリッド配置 */
  }
  .bottom-row img {
    width: 100%; /* スマホでは各画像をセル幅いっぱいに表示 */
  }
  .bottom-row img:last-child {
    grid-column: 1 / -1;
    justify-self: center; /* 中央寄せ */
    width: 48%;
  }
  .top-section-num img {
    width: 35%;
    max-width: 113px;
    height: auto;
  }
  .text-box02 .title {
    font-size: 30px;
    font-size: clamp(15px,8vw,40px);
    color: #eb6fa7;
    margin-bottom: 0px;
  }
 
  .sub-txt {
    width:100%;
    font-weight: bold;
  }
  .bottle-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
    /* margin-top: clamp(-350px, -26.67vw, -100px); */
    margin-bottom: 100px;
    padding: 0px;
  }
  .text-box02 .description {
    font-size: 16px;
  }
  .sub-txt p {
    font-size: 14px;
  }
  .sub-section img {
    width: 37%;
    max-width: 62px;
    right: -26%;
}

  .bottle-item02 {
    margin-bottom: 0px;
  }
  .contact-info {
    padding: 25px 0;
  }
  .contact-info .icon {
    width: 30%;
    height: auto;
  }
  .contact-info .text {
    display: block;
  }
  .contact-info .text p {
    font-size: 18px;
  }
  .tel {
    font-size: 23px;
  }
  .contact-info .text .phone-number {
    /* line-height: 0.5em; */
    margin-top: 20px;
  }
  .contact-info .text .company-name {
    font-size: 8px;
  }
  .banner-block {
    text-align: center;
  }
  .pattern-con .description{
    padding: 7px 7px;
    font-size: 13px;
  }
  #factory{
    background: none;
  }
.factory-top-text {
  padding: 0 20px;
  text-align: left;
}
.factory-top-text p{
  font-size: 16px;

}
.factory-topic-wrap {
  padding: 0 20px;
}
.container-info {
  margin-top: 20px;
}
.sp-factory-image {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
.factory-info{
  margin-bottom: 20px;
}
.factory-info .text h2 {
  font-size: 25px;
  margin-bottom: 15px;
}
.ingredients-title{
  font-size: 16px;
}

.factory-topic-wrap.no2 .ingredients-image{
  margin-bottom: 50px;
}
.manufacturing-con h2 {
  font-size: 18px;
}
.manufacturing-con-wrap {
  gap: 20px;
  margin: 50px 0 25px;
}
.manufacturing-con-wrap img {
  width: calc((100% - 40px) / 3);
}
.manufacturing-con p {
  margin: 0;
  font-size: 15px;
}
.manufacturing-con .survey {
  width: 100%;
  margin-top: 20px;
}
.container-step h1{
  font-size: clamp(15px, 8vw, 40px);
  margin-bottom: 20px;
}
.container-step h2 {
  font-size: 20px;
  text-align: center;
  margin-top: 20px;
}
.container-step {
  padding: 0px;
}
.step-section .step-right {
  display: none;
}
.step-section {
  flex-direction: column;
  gap: 15px;
  align-items: flex-start;
  margin-bottom: 25px;
}
.step-section .step-left {
  width: 65%;
}
.step-section .step-text {
  width: 100%;
  max-width: 100%;
  padding-left: 30px;
}
.step-description {
  font-size: 15px;
}

.flow-image img{
  object-fit: contain;
  width: 100%;
  max-width: 100%;
}
.flow-image {
    position: absolute;
    top: 0;
    width: 30%;
    height: 45px;
    right: 0;
    margin: auto;
}
.step01 .flow-image {
  width: 23%;
}
.step02 .flow-image {
  width: 20%;
}
.step03 .flow-image img{
  margin-top: 10px;
}
.step04 .flow-image img{
  margin-top: 10px;
}
.step06 .flow-image {
  width: 20%;
}
.contact-info .icon{
  margin-right: 15px;
}

}

.tel-float {
  position: fixed;
  width: 20%;
  max-width: 180px;
  max-width: clamp(80px,12.5vw,180px);
  bottom: 20px;
  right: 10px;
  z-index: 5;
}

.pdf-zone img {
  width: 100%;
}

@media screen and (max-width: 770px) {
  .tel-float {
    width: 25%;
  }
  .contact-tel{
    padding: 35px 0px 0px;
  }
}


section.contact {
  max-width: 1080px;
  max-width: 865px;
  margin: 60px auto 0;
  padding: 80px 0;
  padding: 0 20px;
}
table.contact-tbl {
  max-width: 100%;
  width: 100%;
}
.checkbox-parts {
  font-size: 20px;
  font-weight: bold;
}
.checkbox-parts::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 20px;
  height: 20px;
  border: 1px solid #999;
  border-radius: 1px;
}
a.policy {
  margin-left: 15px;

}
.checkbox-input:checked + .checkbox-parts::after {
  content: "";
  display: block;
  position: absolute;
  top: 2px;
  left: 5px;
  width: 10px;
  height: 15px;
  transform: rotate(40deg);
  border-bottom: 3px solid #dd2763;
  border-right: 3px solid #dd2763;
}
@media screen and (max-width: 770px){
  table.contact-tbl tr th {
    width: 50%;
    padding: 5px 10px;
    font-size: 14px;
}
table.contact-tbl td {
  padding: 5px 10px;
}
table.contact-tbl tr:last-child th{
  padding:10px;
}
table.contact-tbl tr:last-child td{
  padding:10px;
}
input[type="text"], input[type="tel"], input[type="email"] {
  padding: 0;
  font-size: 14px;
}
textarea{
  padding: 0;
  font-size: 14px;
}
section.contact {
  padding: 50px 20px 0;
}
button.sub-btn {
  width: 100%;
}
.checkbox-parts {
  font-size: 16px;
}
}

.foot-txt h4 {
  margin-bottom: 6px;

}
.banner-box-title{
  font-size: 14px;
  text-align: center;
}
a.kumamoto-castle-water img {
  margin: 40px auto;
  display: block;
}
@media screen and (max-width: 770px){
  a.kumamoto-castle-water img{
    margin: 20px auto;
    width: calc(100% - 60px);
  }
  .banner-box .foot-txt {
    width: calc((100% - 20px) / 2);
}
  .banner-box {
    max-width: calc(100% - 60px);
    gap: 20px;
    margin: 0 auto;
}
  a.banner{
    width: 100%;
  }
  .banner-box .foot-txt {
    margin: 0;
    padding: 0;
}
.banner-box-title{
  font-size: 10px;
  font-size: 9px;
  transform: scale(0.8);

}
}
small{
  color:#121212;
}
.banner-box .foot-txt {
  border: none;
}
.overlay{
  z-index: 8;
}
/* /_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_
デバイス表示非表示
/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/
@media screen and (min-width: 981px) {
  .sp-none {
    display: none !important;
  }
}
@media screen and (max-width: 980px) {
  .pc-none {
    display: none !important;
  }
}
@media screen and (min-width: 771px) {
    .sp {
      display: none !important;
    }
    a[href*="tel:"] {
      pointer-events: none;
      cursor: default;
      text-decoration: none;
    }
  }
  @media screen and (max-width: 770px) {
    .pc {
      display: none !important;
    }
  }

