@charset "utf-8";
/* CSS Document */
body {
    text-align: center;
    font-size: 14px;
    color: #333;
    font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
}

header {
    width: 1024px;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 20px;
    margin-bottom: 20px;
}

header .rogo img {
    width: 50%;
}

header dl dt {
    font-size: 2.000em;
    font-weight: bold;
    width: 250px;
}
header dl dt img {
    width: 8%;
}

header dl dd {
    font-size: 0.857em;
}

header .rogo {
    text-align: left;
}

header .telLink {
    text-decoration: none;
    color: #333;
}

.mainimg img {
    width: 100%;
    max-height: 280px;
    object-fit: cover;
}

.mainimg .object-fit-img {
    object-fit: cover;
    object-position: 50% 50%;
    font-family: 'object-fit: cover; object-position: 50% 50%;' /* IE・Edge対応 */;
}

.mainimg dl {
    position: absolute;
    top: 150px;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    color: #FFFFFF;
}

.mainimg dl dt {
    font-size: 1.857em;
    margin-bottom: 20px;
    text-shadow:0 0 12px #111;
}

.mainimg dl dd {
    font-size: 3.286em;
    font-weight: bold;
    text-shadow:0 0 15px #111;
}

.bgGreen {
    background-color: #e5fef4;
    margin-top: -3px;
}

.bgWhite {
    width: 1024px;
    margin-left: auto;
    margin-right: auto;
}

.bgGreen,.bgWhite {
    padding-top: 70px;
    padding-bottom: 70px;
}

.bgGreen h1,.bgGreen h2,.bgWhite h2 {
    font-size: 2.429em;
    font-weight: bold;
    margin-bottom: 30px;
}

.bgGreen hr,.bgWhite hr {
    width: 60px;
    border-bottom: solid #00913a 5px;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 30px;
}

.bgGreen p {
    font-size: 1.143em;
    line-height: 200%;
}

.bgWhite ul {
    display: flex;
}

.bgWhite ul li {
    width: 100%;
    text-align: center;
}

.bgWhite ul li img {
    width: 220px;
    margin-bottom: 15px;
}

.flow li dl {
    margin: auto;
    width: 88%;
    text-align: left;
}

.flow li dl dt {
    font-size: 1.143em;
    font-weight: bold;
    margin-bottom: 10px;
}

.flow li dl dd {
    line-height: 150%;
}

#formBox {
    width: 1024px;
    margin: auto;
    margin-top: 50px;
    text-align: left;
}

#formBox h3 {
    font-size: 1.286em;
    line-height: 150%;
    margin-bottom: 10px;
}
#formBox h3 span {
    -webkit-border-radius:50%;
    -moz-border-radius:50%;
    -ms-border-radius:50%;
    -o-border-radius:50%;
    border-radius:50%;
    font-size: 1.286em;
    line-height: 2em;
    padding-top: 0.3em;
    padding-bottom: 0.2em;
    padding-left: 0.7em;
    padding-right: 0.7em;
    background-color: #00913a;
    color: #fff;
    margin-right: 15px;
}

#formBox .hissu {
    background-color: #ed6942;
    padding: 3px 7px;
    border-radius: 5px;
    color: #fff;
    font-size: 0.826em;
    font-weight: normal;
    margin-left: 15px;
}

.boxChoice,.cushionChoice,.dateChoice,.GuestInfo,.kakunin,.sendBtn {
    margin-bottom: 100px;
}

.boxChoice,.dateChoiceSelect {
    display: flex;
    flex-wrap: wrap;
    width: 1024px;
}

.boxChoice dl {
    width: 24%;
    padding: 5px;
    min-height: 250px;
    margin-bottom: 20px;
}

.boxChoice dl dt img {
    width: 90%;
    border: solid #ccc 1px;
    cursor: pointer;
}

.boxChoice dl dd {
    margin-top: 10px;
}

.boxChoice dl dd input {
    -webkit-appearance: radio;
    -moz-appearance: radio;
    appearance: radio;
    opacity: 0;
    margin-left: -13px;
}

.boxChoice p {
    height: 15px;
    margin-top: 15px;
    border: 1px solid #ccc;
    padding: 15px;
    margin-left: 5px;
}

.radioInput + label{
  padding-left: 20px;
  position:relative;
  margin-right: 20px;
  cursor: pointer;
  font-weight: bold;
  font-size: 1.143em;
}
.radioInput + label::before{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  border: 1px solid #999;
  border-radius: 50%;
  margin-top: 1px;
}
.radioInput:checked + label{
  color: #00913a;
}
.radioInput:checked + label::after{
  content: "";
  display: block;
  position: absolute;
  top: 3px;
  left: 3px;
  width: 11px;
  height: 11px;
  background: #00913a;
  border-radius: 50%;
  margin-top: 1px;
}

.boxChoice dl dd span {
    display: block;
    margin-top: 10px;
    line-height: 120%;
}

.cushionChoice dl,.dateChoice,.GuestInfo {
    margin-top: 25px;
}

.cushionChoice dl dt {
    margin-bottom: 15px;
}

.cushionChoice dl dd {
    line-height: 150%;
}

.dateChoice input,.dateChoice select,.cushionChoice dl dt input,.GuestInfo input,.GuestInfo select,.GuestInfo textarea,.kakunin input {
    margin-right: 15px;
    display: inline;
    vertical-align: middle;
    padding: 10px;
    border: 1px solid #CCC;
    border-radius: 3px;
}

.dateChoice .selectWrap {
    position: relative;
    display: inline-block;
}

.dateChoice .selectWrap select {
  padding-right: 25px;
}

.dateChoice .selectWrap::after {
    content: '';
    width: 6px;
    height: 6px;
    border: 0px;
    border-bottom: solid 2px #b4b3b3;
    border-right: solid 2px #b4b3b3;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    right: 25px;
    margin-top: -6px;
}

.dateChoiceSelect dl {
    margin-right: 15px;
}

.dateChoiceSelect dl dt,.GuestInfo dt {
    font-size: 1.143em;
    margin-bottom: 5px;
    font-weight: bold;
    line-height: 150%;
}

.dateChoice ul {
    margin-top: 15px;
}

.dateChoice li {
    line-height: 150%;
}

.GuestInfo input,.GuestInfo select {
    width: 30%;
}

.GuestInfo dd {
    margin-bottom: 30px;
}

.GuestInfo dd span {
    display: block;
    margin-top: 7px;
    line-height: 150%;
}

.GuestInfo dd .adr01 input,.GuestInfo dd .adr01 select {
    width: 15%;
}

.GuestInfo dd .selectWrap {
    display: contents;
}

.GuestInfo dd li {
    margin-bottom: 10px;
}

.GuestInfo dd textarea {
    width: 70%;
    height: 100px;
}

.kakunin p {
    margin-bottom: 15px;
}

.kakunin li {
    margin-bottom: 15px;
}

.cushionChoice dl dt input,.kakunin li input {
    padding: 3px 10px;
    -webkit-appearance: checkbox;
    -moz-appearance: checkbox;
    appearance: checkbox;
    opacity: 0;
    margin-left: -25px;
}

.checkbox-input{
  display: none;
}
.checkbox-parts{
  padding-left: 20px;
  position:relative;
  margin-right: 20px;
}
.checkbox-parts::before{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  border: 1px solid #999;
  border-radius: 4px;
}
.checkbox-input:checked + .checkbox-parts{
  color: #00913a;
}
.checkbox-input:checked + .checkbox-parts::after{
  content: "";
  display: block;
  position: absolute;
  top: -5px;
  left: 5px;
  width: 7px;
  height: 14px;
  transform: rotate(40deg);
  border-bottom: 3px solid #00913a;
  border-right: 3px solid #00913a;
}

.sendBtn {
    text-align: center;
}

.sendBtn input.btn-mailform {
    padding: 15px 40px;
    font-size: 1.2em;
    background-color: #f9a400;
    color: #fff;
    border-style: none;
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
}

.reCap {    
    display: flex;
    width: fit-content;
    margin: 20px auto;
    position: relative;
    background-color: #f2f1f6;
    border-radius: 5px;
    padding: 20px 20px 20px 65px;
}

#formBox .reCap .hissu {
    height: fit-content;
    position: absolute;
    padding: 8px 7px;
    font-size: 1.000em;
    margin-left: 0 !important;
    top: 43px;
    left: 15px;    
}

footer {
    text-align: center;
    padding: 12px;
    background-color: #e5fef4;
}

input:required + .help-text::before {
    content: '*Required';
}

/* --------------------------------------------------------------SP 1023 */

@media only screen and (max-width: 1023px) {
    header {
        width: 100%;
        flex-wrap: nowrap;
    }
    
    header .rogo {
        text-align: left;
        margin-left: 10px;
    }
    
    header .rogo img {
        width: 90%;
    }
    
    header dl {
        text-align: right;
        margin-right: 10px;
    }
    
    header dl dt {
        font-size: 1.714em;
    }
    
    header dl dd {
        font-size: 0.786em;
    }
    
    header dl dt img {
        width: 8%;
    }
    
    .mainimg img {
        min-height: 130px;
    }
    
    .mainimg dl {
        top: 110px;
    }
    
    .mainimg dl dt {
        font-size: 1.286em;
        margin-bottom: 10px;
    }
    
    .mainimg dl dd {
        font-size: 2.000em;
    }
    
    .bgGreen, .bgWhite {
        padding-top: 40px;
        padding-bottom: 40px;
    }
    
    .bgWhite {
        width: 95%;
        margin: auto;
    }
    
    .bgGreen h1, .bgGreen h2, .bgWhite h2 {
        font-size: 1.571em;
        margin-bottom: 15px;
    }
    
    .bgGreen hr, .bgWhite hr {
        width: 50px;
        margin-bottom: 20px;
    }
    
    .bgGreen p {
        width: 90%;
        font-size: 1.000em;
        line-height: 170%;
        margin: auto;
    }
    
    .bgWhite ul {
        flex-wrap: wrap;
    }
    
    .bgWhite ul li {
        width: 50%;
        margin-bottom: 15px;
    }
    
    .bgWhite ul li img {
        width: 155px;
    }
        
    .flow li dl {
        width: 95%;
    }
    
    .flow li dl dt {
        font-size: 1.143em;
        margin-bottom: 7px;
    }
    
    .flow li dl {
        font-size: 0.857em;
    }
    
    #formBox {
        width: 95%;
        margin-left: auto;
        margin-right: auto;
    }
    
    #formBox h3 {
     font-size: 1.071em;   
    }
    
    #formBox h3 span {
        font-size: 0.857em;
        padding-top: 0.4em;
        padding-bottom: 0.4em;
        margin-right: 7px;
    }
    
    #formBox .hissu {
        margin-left: 10px;
    }
    
    .boxChoice, .dateChoiceSelect {
        width: 100%;
    }
    
    .boxChoice dl {
        width: 47%;
        min-height: auto;
    }
    
    .boxChoice dl dt img {
        width: 100%;
    }
    
    .boxChoice dl dd span {
        font-size: 0.857em;
    }
    
    .boxChoice .radioInput + label {
        font-size: 0.857em;
        margin-right: 0px;
    }
    
    .cushionChoice .radioInput + label {
        font-size: 1.000em;
    }
    
    .dateChoiceSelect dl {
        margin-right: 0px;
    }
    
    .dateChoice input,.dateChoice select {
        padding: 7px;
    }
    
    .dateChoice input {
        width: 20%;
        margin-right: 7px;
    }
    
    .dateChoice select {
        width: 100%;
        margin-right: 0px;
    }
    
    .dateChoice .selectWrap {
        width: 48%;
    }
    
    .dateChoice .selectWrap::after {
        right: 15px;
    }
    
    .dateChoiceSelect dl dt {
        font-size: 1.000em;
        margin-bottom: 0px;
    }
    
    .dateChoiceSelect dl dd {
        margin-bottom: 7px;
    }
    
    .dateChoice li {
        margin-bottom: 5px;
    }
    
    .dateChoice ul {
        margin-top: 7px;
    }
    
    .GuestInfo dt {
        font-size: 1.000em;
    }
    
    .GuestInfo input, .GuestInfo select {
        width: 90%;
    }
    
    .GuestInfo dd .adr01 input {
        width: 22%;
        margin-right: 10px;
    }
    
    .GuestInfo dd .adr01 select {
        width: 40%;
        margin-right: 0px;
    }
    
    .GuestInfo dd textarea {
        width: 90%;
    }
    
    .kakunin p,.kakunin li {
        line-height: 150%;
    }
    
    .kakunin li input {
        margin-right: 7px;
    }
    .reCap {
    display: block;
    position: static;
    padding: 10px;
    text-align: center;
    }
    .reCap .hissu {
    position: static !important;
    display: inline-block;
    width: fit-content;
    margin: 0px auto 7px auto;
    height: unset !important;
    }
}

@media screen and (min-width: 751px){
  .telLink {
    pointer-events: none;
  }
}

/* recaptchaのロゴを消す */
.grecaptcha-badge { visibility: hidden; }