.site-header .site-branding {
  width: 45%;
}
.site-header .site-title {
  padding-top: 0;
}
.site-title a {
  color: inherit;
  text-decoration: none;
}
@media (max-width: 768px) {
  .site-title a {
    font-size: 20px;
  }
}
#kv {
  background-image: url(img/top/mvimg2.png);
  background-position: left center;
  background-size: contain;
  padding-top: 16%;
  padding-bottom: 16%;
  padding-left: 42%;
}
@media (max-width: 428px) {
  #kv {
    background-position: center center;
    background-size: cover;
    padding: 25vw 0;
  }
  .kv_bg .container {
    padding-right: 0;
    padding-left: 0;
  }
}

.kv_bg {
  background-image: url(img/top/mvbk.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media (min-width: 429px) {
  #kv p.kv-jp {
    font-family: "Shippori Mincho", serif;
    font-weight: 700;
    color: #fff;
    text-shadow: none;
  }
}
.kv-jp span{
  font-size: 38px;
  color: #F3951C;
}
@media (max-width: 428px) {
  #kv {
    background-image: url(img/top/bg_main4.jpg);
  }
  #kv p.kv-jp {
    font-family: "Shippori Mincho", serif;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 0 8px #fff;
  }
  .kv-jp span{
    font-size: 18px;
    color: #F3951C;
  }
}
.site-title {
  font-size: 26px;
  line-height: 2;
}
.kv-img {
  width: 85px;
  margin: 0 auto;
}
.more02 {
  text-align: center;
}
.more02 a {
  padding-left: 0;
  padding-right: 0;
}
@media (min-width: 769px) {
  h3.style3a__2 {
    text-align: center;
  }
  h3.style3a__2:before {
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  }
}
.site-branding{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;


}
.site-branding img{
  width: 40px;
}
.site-title{
  white-space: nowrap;
}
.ml0{
  margin-left: 0;
}
.flex{
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 30px;
}
.flex img{
  width: calc((100% - 30px)/2);
}
@media (max-width: 768px) {
  .site-branding img{
    width: 30px;
  }
  .site-branding{
    padding: 0;
  }
  .flex{
    flex-direction: column;
  }
  .flex img{
    width: 80%;
  }
}
.text-left{
  text-align: left;
}

#kv p.kv-jp{
  line-height: .8;
}
.bottom-line{
  border-bottom: 2px solid #FFF7E6;
  padding-bottom: 20px !important;
}
#kv .kv-text .c-bottom{
  padding-top: 20px;
}