body {
  background-color:#fff;
}
input {
  background-color: #fff;
  border:1px solid #333;
}
.contact_edit_table p {
  color:#000;
  margin-bottom: 8px;
}
section {
  max-width:750px;
  margin:0 auto;
}
header section{
  display: flex;
  padding: 1rem;
  gap: 20px;
  justify-content: flex-start;
}
header section img{
  width:100%;
}
.logo {
  width: 46%;
}
.total-inventory {
  width: 54%;
}
main section.contents div {
  margin:4rem 0;
}
main section.contents img {
  width:100%;
}
footer section{
  text-align:center;
  background-color:#000;
  padding:0.5rem 2rem;
  color: #fff;
}
.contact .inner{
  border: .3rem solid #f00;
  padding: 2rem
}
.contact .contact-title{
  width:75%;
  margin: 0 auto 2rem;
}
.contact .contact-title img {
  width:100%;
}
.flex{
  max-width: 750px;
  margin: 0 auto;
  display: flex;
  padding: 1rem;
  background-color: #ccc;
}
.contact table{
  width:100%;
  margin:0 auto 2rem;
}
.contact th,
.contact td{
  display:block;
}
.contact th{
  text-align:left;
  margin-bottom: 8px;
  color: #000;
}
.contact .wpcf7-text{
  width: 100%;
  height: 3rem;
  border-radius: .5rem;
  padding: 0 1rem;
  color: #000;
}
@media screen and (max-width: 768px) {
  .contact .wpcf7-text{
    height: 2.6rem;
  }
}
@media screen and (max-width: 320px) {
  .contact .wpcf7-text{
    height: 2.4rem;
  }
}
.contact table tr:not(:last-child){
  margin-bottom:1rem;
  display:block;
}
.button-wrapper {
  width: 80%;
  margin: 40px auto 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  .button-wrapper {
    width: 100%;
  }
}
.button-wrapper p {
  display: contents;
  margin: 0;
  padding: 0;
}
.button-wrapper br {
  display: none;
}
.submit-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #dd0101;
  color: #fff;
  border: none;
  border-radius: 16px;
  width: 100%;
  padding: 30px 30px 12px 96px;
  font-size: 52px;
  font-weight: 900;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
  cursor: pointer;
  overflow: visible;
  z-index: 1;
  letter-spacing: 4px;
}
@media screen and (max-width: 768px) {
  .submit-btn {
    border-radius: 10px;
    padding: 12px 0px 12px 38px;
    font-size: 28px;
    line-height: 1.8;
  }
}
@media screen and (max-width: 320px) {
  .submit-btn {
    font-size: 20px;
  }
}
.submit-btn:hover {
  background-color: #c40010;
}
.btn-header-img {
  position: absolute;
  top: -22px;
  left: 60%;
  transform: translateX(-50%);
  width: 72%;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .btn-header-img {
    top: -14px;
  }
}
@media screen and (max-width: 320px) {
  .btn-header-img {
    top: -12px;
  }
}
.btn-content {
  z-index: 1;
  top: 7%;
  left: 4%;
  display: block;
  width: 100px;
  position: absolute;
}
.btn-icon {
  width: 100px;
  height: 100px;
  margin-right: 12px;
  border-radius: 50%;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .btn-icon {
    width: 56px;
    height: 56px;
  }
}
@media screen and (max-width: 320px) {
  .btn-icon {
    width: 42px;
    height: 42px;
  }
}
.flex-contact{
  width: 100%;
  position: fixed;
  bottom: 0;
  transform: translateY(100%);
  transition: transform .4s ease;
  z-index: 9999;
}
.flex-contact div{
  max-width: 750px;
  margin: 0 auto;
  display: flex;
  padding: 1rem;
  background-color: #ccc;
}
.flex-contact.scrolled{
  transform: translateY(0);
}
.flex-contact.at-bottom{
  transform: translateY(100%);
}
@keyframes blinknew {
  0% {
    box-shadow: 0 0 0 1px #f12, 0 0 0 8px rgba(255, 255, 255, 0), 0 0 0 10px rgba(100, 37, 16, 0);
  }
  100% {
    box-shadow: 0 0 0 1px #f12, 0 0 0 1px #fff, 0 0 0 2px #ff5e28;
  }
}
.blink-new-new {
  animation: blinknew 1s infinite;
}
.wpcf7-form input:focus-visible {
  outline: none;
}
/* 送信完了非表示 */
.wpcf7 form .wpcf7-response-output {
  display: none!important;
}
/* 本体の送信ボタンは非表示 */
.hidden-submit {
  display: none;
}
.button-wrapper {
  cursor: pointer;
}
