.block1-image {
  width: 135%;
}
.block1-text1 {
  font-size: 48px; 
  margin-top: 120px; 
  color: white; 
  text-shadow: 0 0 7px #e64809;
}
.block1-text2 {
  font-size: 20px; 
  padding-top: 20px;
  margin-bottom: 70px;
  font-weight:bold;
  color: #f57160; 
  text-shadow: 0 0 3px #ffffff;
}
.block1-text2 div {
  padding-top: 6px;
}
.block1-text3 {
  display: inline;
  border-style: solid; 
  padding: 10px 30px; 
  background-color: rgba(255, 255, 255, 0.2); 
  cursor: pointer;
}
.block1-text3:hover {
  background-color: rgb(174, 189, 172);
  border-color: rgb(174, 189, 172);
  color: white;
  transition: 0.2s;
}
.block {
  margin-top: 100px;
}
.block-title {
  font-size: 48px;
  color: #ef6d15;
  margin-bottom: 60px;
  text-align: center;
}
.block-body {
  margin-top: 20px;
}
.block2-subtitle {
  margin-top: 60px;
  font-size: 24px;
}
.block2-content {
  margin-top: 50px;
}
.block2-content div {
  margin-top: 6px;
  font-family: Lato, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, メイリオ;
}
.block-button {
  margin-top: 40px;
}
.block-button span:hover {
  background-color: rgb(174, 189, 172);
  border-color: rgb(174, 189, 172);
  color: white;
  transition: 0.5s;
}
.block-button span {
  padding: 10px 30px;
  border-style: solid;
  border-color: #555555;
  color: #444433;
  display: inline-block;
  cursor: pointer;
}
.block3-text {
  font-size: 20px;
}
.block3-auto {
  text-align: center; 
  position: absolute; 
  top: 20%; 
  left: 0; 
  right: 0;
  font-size: 24px;
}
.block3-auto-title {
  color: #ff4040;
}
.block3-auto-text {
  font-family: Lato, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, メイリオ;
  margin-top: 0.5em;
}
.block3 .btn-add-to-cart {
  margin-top: 1em;
}
.block3-text {
  position: absolute; 
  top: 50%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translate(0%, -50%);
}
.logo-text {
  position: absolute; 
  top: 44%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
  word-wrap: break-word;
  text-align: center;
}
/* TODO: BLOCK 4 */
.block4 {
  margin-top: 40px !important;
}
.block4-half {
  border-radius: 1em; 
  padding: 20px 10px; 
  height: 100%; 
  text-align: center;
}
.block4-half div {
  padding: 0.5em;
}
.block4-left {
  color: rgb(86,103,84); 
  background-color: rgb(208, 243, 194);
}
.block4-right {
  color: rgb(144,96,78); 
  background-color: rgb(255, 207, 189);
}
.block4-title {
  font-size: 32px;
}
.block4-half div:not(.block4-title) {
  font-size: 20px;
}
.block5 .block-body {
  font-size: 20px;
  line-height: 2em;
}
.block5 .block-body div {
  margin-bottom: 2em;
}
.block6 .img-wrapper {
  padding-right: 0;
  padding-left: 0;
}
.block6 .block-body div {
  max-width: 380px;
  margin: 0 auto;
}
.block6 .block-body .block-button {
  margin-top: -70px;
  margin-bottom: 60px;
  z-index: 500;
}
#cartModal td {
  vertical-align: middle !important;
}
.btn-add-to-cart {
  width: 140px !important;
}
@media (max-width: 1199.98px) and (min-width: 992px) {
  .block1-image {
    width: 138%;
  }
  .block1-text1 {
    font-size: 40px;
    margin-top: 80px;
  }
  .block1-text2 {
    font-size: 18px;
  }
  .block1-text3 {
    padding: 8px 20px;
  }
  .block2-subtitle {
    margin-top: 40px;
  }
  .block2-content {
    margin-top: 20px;
  }
  .block-button span {
    padding: 8px 20px;
    font-size: 15px;
  }
  .block3-text {
    font-size: 18px;
  }
  .block3-auto {
    top: 16%; 
  }
}
@media (max-width: 991.98px) {
  .block6 .block-body .block-button {
    margin-top: 20px;
    margin-bottom: unset;
  }
}
@media (max-width: 991.98px) and (min-width: 768px) {
  .block1-image {
    width: 142%;
  }
  .block1-text1 {
    font-size: 28px;
    margin-top: 60px;
  }
  .block1-text2 {
    font-size: 15px;
    margin-bottom: 50px;
  }
  .block1-text3 {
    font-size: 14px;
    padding: 8px 12px;
  }
  .block {
    margin-top: 60px;
  }
  .block-title {
    font-size: 32px;
    margin-bottom: 30px;
  }
  .block-body {
    margin-top: 20px;
  }
  .block2-subtitle {
    margin-top: 20px;
    font-size: 20px;
  }
  .block2-content {
    margin-top: 20px;
  }
  .block2-content div {
    margin-top: 6px;
    font-family: Lato, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, メイリオ;
    font-size: 13.1px;
  }
  .block-button {
    margin-top: 20px;
  }
  .block-button span {
    padding: 5px 10px;
    font-size: 14px;
  }
  .block3-text {
    font-size: 16px;
  }
  .block3-auto {
    top: 10%;
  }
  .block3-auto-title {
    font-size: 20px;
  }
  .block3-auto-text {
    font-size: 18px;
  }
  .block4-title {
    font-size: 24px;
  }
  .block4-half div:not(.block4-title) {
    font-size: 16px;
  }
  .block5 .block-body {
    font-size: 18px;
  }
  .card-title {
    font-size: 14px;
  }
  .card-text {
    font-size: 11px;
    font-family: "hiragino-sans-gb-w3";
  }
}
@media (max-width: 767.98px) {
  .mobile-mw-380 {
    /* padding-top: 16px; */
    max-width: 380px;
    margin: auto;
    display: block;
  }
  .container {
    margin: 0;
    max-width: none;
  }
  .block1-image {
    width: 100%;
  }
  .block1-text1 {
    font-size: 6vw;
    margin-top: 10vw;
  }
  .block1-text2 {
    font-size: 3.6vw;
    padding-top: 3vw;
    margin-bottom: 4vw;
  }
  .block1-text2 div {
    padding-top: 0;
  }
  .block1-text3 {
    font-size: 3vw;
    padding: 1vw 1.5vw;
  }
  .block1-right {
    margin-top: -60vw;
    text-align: center;
  }
  .block {
    margin-top: 60px;
  }
  .block-title {
    font-size: 32px;
    margin-bottom: 10px;
  }
  .block-body {
    margin-top: 0px;
  }
  .block2-subtitle {
    margin-top: calc(6vw - 15px);
    font-size: 20px;
  }
  .block2-text2 {
    padding-top: 3vw;
  }
  .block2-content {
    margin-top: 4vw;
  }
  .block2-content div {
    margin-top: 0px;
    font-family: Lato, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, メイリオ;
    font-size: 13px;
  }
  .block-button {
    margin-top: 4vw;
    margin-bottom: 3vw;
  }
  .block-button span {
    padding: 5px 10px;
    font-size: 14px;
  }
  .block3-text {
    font-size: 18px;
  }
  .block3-auto {
    top: calc(15vw - 75px);
    font-size: 16px;
  }
  .block3 .btn-add-to-cart {
    margin-top: 1vw;
    font-size: 14px;
    width: 120px;
  }
  .block4-title {
    font-size: 24px;
  }
  .block4-half div:not(.block4-title) {
    font-size: 16px;
  }
  .block5 .block-body {
    font-size: 16px;
  }
  .block6 .img-wrapper {
    padding-left: 15px;
    padding-right: 15px;
  }
  .block2-color1 {
    position: static !important;
    border-radius: 20px;
    padding: 30px 15px;
    margin-bottom: 15px;
  }
}
@media (max-width: 767.98px) and (min-width: 576px) {
  .card-title {
    font-size: 18px;
    margin-bottom: 5px;
  }
  .card-text {
    font-size: 14px;
  }
  .block2-color2 {
    padding-top: 10px;
  }
}
@media (max-width: 575.98px) {
  .block2-color2 {
    position: static !important;
    border-radius: 20px;
    padding: 30px 15px;
    /* margin-bottom: 15px; */
  }
  .block3-text {
    margin-bottom: 30px;
    font-size: 18px;
  }
  .block3-auto {
    top: calc(50% - 60px);
    font-size: 20px;
  }
  .block3-auto-text {
    font-size: 0.7em;
  }
  .block3-auto-title {
    font-size: 0.8em;
  }
  .block5 .block-body {
    font-size: 14px;
  }
  .block3 .col-6 {
    padding: 0 5px;
  }
  .block3 .block-body .card-img-overlay {
    padding: 2px !important;
  }
  .block3 .card-title {
    font-size: 0.8em;
    margin-bottom: 0.05rem;
  }
  .block3 .card-text {
    font-size: 0.6em;
  }
  .block3 .btn-bottom-right {
    bottom: 5px;
    left: 0;
    right: 0;
    text-align: center !important;
  }
  .block3 .btn-custom {
    width: 110px;
    font-size: 14px;
    padding: 3px;
  }
  .block3 div.logo-text {
    font-size: 0.6em !important;
  }
}
@media (min-width: 576px) {
  .col-sm-0 {
    display: none;
  }
}
.card-img-overlay {
  padding: 15px 10px;
  text-align: left;
}
.btn-bottom-right {
  position: absolute;
  bottom: 10px;
  right: 10px;
}
.btn-bottom-right .btn-custom {
  width: 130px;
}
.block2-color1 {
  position: absolute;
  background-color: rgb(208, 243, 194);
  top: 0;
  bottom: 0;
  right: 0;
  left: 15px;
  border-radius: 20px;
  padding-top: 20px;
}
.block2-color2 {
  position: absolute;
  background-color: rgb(255, 207, 189);
  top: 0;
  bottom: 0;
  right: 15px;
  left: 0;
  border-radius: 20px;
}