@charset "utf-8";

.form-notice {
   font-size: 1.2rem;
   font-weight: bold;
   text-align: center;
   margin-bottom: 2rem;
}

#mainvis {
   background-image: url("../img/inq/mi.png");
}

#mf1 .mf-inner {
   padding: 80px 0 100px;
}

/* ---- Header ---- */
.es-subtitle {
   text-align: center;
   color: #c7000b;
   font-size: 1.05em;
   font-weight: bold;
   margin: 0 0 15px 0;
   letter-spacing: 0.05em;
}

.es-form-wrap {
   border: 3px solid #c7000b;
   border-radius: 20px;
   margin: 0 0 40px 0;
   overflow: hidden;
}

.es-title {
   background: #c7000b;
   color: #fff;
   font-size: 1.8em;
   font-weight: 900;
   letter-spacing: 0.08em;
   text-align: center;
   padding: 25px 20px;
   margin: 0;
}

.es-form-body {
   padding: 50px 40px 10px;
}

/* ---- Form Layout ---- */
#mf1 dl {
   line-height: 1em;
   display: flex;
   justify-content: space-between;
   margin: 0 0 5px 0;
}

#mf1 dl dt {
   width: 240px;
   min-width: 240px;
   padding: 20px 20px;
   background: #FBF7EF;
   color: #333;
   display: flex;
   justify-content: space-between;
   align-items: center;
   font-weight: bold;
   font-size: 0.95em;
   position: relative;
}

#mf1 dl:last-of-type dt {
   align-items: flex-start;
}

#mf1 dl dt .req {
   line-height: 1em;
   font-weight: bold;
   color: #fff;
   background: #00A3CE;
   border: solid 1px transparent;
   border-radius: 3px;
   padding: 8px 14px;
   font-size: 0.75em;
   white-space: nowrap;
}

#mf1 dl dd {
   display: flex;
   align-items: center;
   flex-wrap: wrap;
   width: 900px;
   padding: 15px 20px;
}

/* ---- Inputs ---- */
#mf1 input[type="text"],
#mf1 input[type="tel"],
#mf1 input[type="email"],
#mf1 textarea {
   width: 100%;
   padding: 15px;
   border: #00A3CE solid 2px;
   font-size: 1em;
   background: #fff;
   box-sizing: border-box;
}

#mf1 input[type="text"]:focus,
#mf1 input[type="tel"]:focus,
#mf1 input[type="email"]:focus,
#mf1 textarea:focus {
   border-color: #0090b5;
   outline: none;
   box-shadow: 0 0 0 2px rgba(0, 163, 206, 0.15);
}

#mf1 input[type="text"]::placeholder,
#mf1 input[type="tel"]::placeholder,
#mf1 input[type="email"]::placeholder,
#mf1 textarea::placeholder {
   color: #bbb;
}

/* ---- Checkbox Group ---- */
.cb-group {
   display: flex;
   flex-wrap: wrap;
   gap: 6px 20px;
}

.cb-label {
   display: flex;
   align-items: center;
   cursor: pointer;
   font-size: 0.95em;
}

.cb-label input[type="checkbox"] {
   width: 18px;
   height: 18px;
   margin: 0 6px 0 0;
   cursor: pointer;
}

/* ---- Postal Code ---- */
#mf1 div.csrean {
   width: 900px;
   display: flex;
   align-items: center;
   padding: 15px 20px;
}

#mf1 div.csrean dd {
   position: relative;
   width: 100px;
   padding: 0;
}

.csrean-sep {
   display: flex;
   align-items: center;
   padding: 0 12px !important;
   width: auto !important;
   font-size: 1.1em;
   color: #333;
}

/* ---- Submit Button ---- */
#mf1 .sbtn {
   margin: 40px 0 40px 0;
   text-align: center;
}

#mf1 .sbtn p.btn-send {
   display: inline-block;
   max-width: 520px;
   width: 100%;
   position: relative;
}

#mf1 .sbtn p.btn-send:after {
   content: "";
   width: 10px;
   height: 10px;
   border: #00A3CE solid;
   border-width: 2px 2px 0 0;
   position: absolute;
   right: 40px;
   top: 50%;
   transform: translate(0, -50%) rotate(45deg);
   pointer-events: none;
}

#mf1 .sbtn p.btn-send button {
   width: 100%;
   border: #00A3CE solid 2px;
   font-weight: bold;
   padding: 20px 50px;
   color: #00A3CE;
   background: #fff;
   font-size: 1em;
   cursor: pointer;
   transition: opacity 0.2s;
   white-space: normal;
   letter-spacing: 0.05em;
}
#mf1 .sbtn p.btn-send button br.sp{
   display: none;
}

#mf1 .sbtn p.btn-send button:hover {
   opacity: 0.7;
}

/* ---- Confirm: Back Button ---- */
#mf1 .sbtn p.btn-back {
   display: inline-block;
   max-width: 250px;
   width: 100%;
   margin: 0 15px;
}

#mf1 .sbtn p.btn-back input {
   width: 100%;
   border: #999 solid 2px;
   border-radius: 50px;
   font-weight: bold;
   padding: 18px 40px;
   color: #666;
   background: #fff;
   font-size: 1em;
   cursor: pointer;
   transition: opacity 0.2s;
}

#mf1 .sbtn p.btn-back input:hover {
   opacity: 0.7;
}

/* ---- Confirm Page ---- */
#conf dl {
   border-bottom: #313131 dashed 1px;
}

#conf dd {
   line-height: 1.8em;
}

/* ---- Thanks Page ---- */
#done h2 {
   text-align: center;
   font-size: 2.25em;
   font-weight: 900;
   margin: 0 0 30px 0;
   line-height: 1.5em;
}

#done .ctext {
   display: table;
   margin: 0 auto 50px auto;
}

#done dl {
   margin: 50px 0 0 0;
   border: none;
}

#done dl dd {
   width: 500px;
   padding: 0;
   display: block;
   line-height: 1.8em;
}

#done dl dt:nth-of-type(1) {
   margin-right: 40px;
}

#done .red {
   color: #f03748;
}

#done .btn a {
   display: table;
   margin: 0 auto;
   padding: 20px 40px;
   background: #f03748;
   color: #fff;
   font-weight: bold;
   text-decoration: none;
}

/* ---- Error ---- */
p.err {
   color: #c7000b;
   font-weight: bold;
   margin: 0 0 8px 0;
   font-size: 0.9em;
   width: 100%;
}

/* ---- Privacy Policy ---- */
#pp {
   border: #ccc solid 1px;
   height: 15em;
   overflow: auto;
   margin: 0 0 50px;
}

#pp .cbox-inner {
   padding: 20px;
}

#pp h2 {
   text-align: center;
   font-size: 1.2em;
   font-weight: 900;
   margin: 0 0 1em 0;
}

#pp p {
   margin: 0 0 1em 0;
   word-break: break-all;
   line-height: 1.8em;
}

#pp .cbox-inner h2,
#pp p {
   margin-bottom: 20px;
}

#pp .cbox-inner h2 {
   text-align: left;
   font-size: 1.3em;
   color: #0AADD6;
   font-weight: bold;
   padding-left: 30px;
   border-left: 3px solid #0AADD6;
}


/* ========================================
   SP (max-width: 800px)
   ======================================== */
@media screen and (max-width: 800px) {
   #mf1 .mf-inner {
      padding: 13vw 5vw;
   }

   .es-subtitle {
      font-size: 0.85em;
      margin: 0 0 3vw 0;
   }

   .es-title {
      font-size: 1.3em;
      padding: 4vw 3vw;
   }

   .es-form-body {
      padding: 5vw 4vw 2vw;
   }

   #mf1 dl {
      display: block;
   }

   #mf1 dl:last-of-type {
      font-size: 1em;
   }

   #mf1 dl dt {
      width: auto;
      padding: 3vw 2vw;
      margin: 0 0 3vw 0;
   }

   #mf1 dl dd {
      padding: 0;
      width: auto;
   }

   #mf1 input[type="text"],
   #mf1 input[type="tel"],
   #mf1 input[type="email"],
   #mf1 textarea {
      padding: 2vw;
      line-height: 1.8em;
   }

   .cb-group {
      gap: 6px 16px;
   }

   #mf1 .sbtn {
      margin: 5vw 0 10vw 0;
   }

   #mf1 .sbtn p.btn-send {
      max-width: none;
      width: 100%;
      margin: 0 auto;
   }

   #mf1 .sbtn p.btn-send:after {
      right: 3vw;
   }

   #mf1 .sbtn p.btn-send button {
      font-size: 0.93em;
      padding: 3vw 10vw 3vw 5vw;
   }
   #mf1 .sbtn p.btn-send button br.sp{
      display: block;
   }

   #mf1 .sbtn p.btn-back {
      max-width: 70vw;
      margin: 0 auto 3vw auto;
      display: block;
   }

   #mf1 .sbtn p.btn-back input {
      padding: 3vw 5vw;
   }

   #form dl {
      margin: 0 0 10vw 0;
   }

   #mf1 div.csrean {
      width: auto;
      padding: 0;
   }

   #mf1 div.csrean dd {
      width: 80px;
   }

   #conf dl {
      border: none;
      padding: 3vw 0;
   }

   #done h2 {
      font-size: 1.4em;
      margin: 0 0 4vw 0;
   }

   #done .ctext {
      width: auto;
      margin: 0 auto 4vw auto;
   }

   #done dl {
      margin: 4vw 0 0 0;
   }

   #done .btn a {
      padding: 4vw 5vw;
   }

   ::-webkit-scrollbar {
      width: 1vw;
   }

   ::-webkit-scrollbar-thumb {
      background: #999;
   }

   #pp .cbox-inner {
      padding: 3vw;
   }

   #pp h2 {
      font-size: 1em;
   }

   #done dl dt:nth-of-type(1) {
      margin-right: 0;
   }
}

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