@charset "utf-8";
html {
    font-family: ヒラギノ角ゴ pro w3, hiragino kaku gothic pro, Osaka, ＭＳ Ｐゴシック, ms pgothic, sans-serif;
    color: #333;
    background: #fff;
    height: 100%
}
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, form, input, textarea, p, th, td, section, article {
    margin: 0;
    padding: 0
}
table {
    box-sizing: border-box;
    border-collapse: collapse;
    border-spacing: 0
}
img {
    border: 0;
    vertical-align: top
}
address, em, th {
    font-style: normal;
    font-weight: 400
}
li {
    list-style: none
}
strong {
    font-weight: 700
}
#container img {
    vertical-align: top
}
.mt20 {
    margin-top: 4%
}
.mb20 {
    margin-bottom: 4%
}
#order_info, .customer_info, #order_info_payment_box, #form-order {
    padding: 0 3%
}

#form img {
    vertical-align: top;
    width: 100%;
    display: block
}
@media screen and (min-width:750px) {
    #form{   
        margin: 0 auto;    
        width: 750px;
    }  
}
.ttl01, .form_title {
    background-color: #231f63;
    color: #fff;
    font-weight: 700;
    padding: 8px;
    margin-bottom: 10px;
    font-size: 1.2rem
}
.table_a {
    width: 100%
}
.table_a td {
    vertical-align: middle;
    text-align: center
}
.order_info_table {
    margin-bottom: 5px
}

.table_b, .order_info_table {
    border-left: 1px solid #5d5286;
    border-top: 1px solid #5d5286;
    width: 100%
}
.table_b th, .order_info_table th {
    background: #c5d9fb;
    border-right: 1px solid #5d5286;
    border-bottom: 1px solid #5d5286;
    padding: 12px;
    vertical-align: middle;
    text-align: center;
    color: #333;
    width: 32%;
    font-size: 1rem
}
.table_b td, .order_info_table td {
    border-right: 1px solid #5d5286;
    border-bottom: 1px solid #5d5286;
    padding: 12px;
    vertical-align: middle;
    font-size: 1rem
}
.table_c {
    border-left: 1px solid #5d5286;
    border-top: 1px solid #5d5286;
    width: 100%
}
.table_c th {
    background: #c5d9fb;
    border-right: 1px solid #5d5286;
    border-bottom: 1px solid #5d5286;
    padding: 8px;
    vertical-align: middle;
    text-align: left;
    color: #333;
    width: 30%
}
.table_c td {
    border-right: 1px solid #5d5286;
    border-bottom: 1px solid #5d5286;
    padding: 8px;
    vertical-align: middle
}
.table_d {
    width: 100%
}
.table_d th {
    vertical-align: top;
    width: 38px
}
.table_d td {
    vertical-align: top
}

#form_area {
    margin: 0 auto;
    padding: 0 2%;
    max-width: 750px;
    line-height: 1.2
}
#form_landing{
    margin-top: 0.5rem;
}
select, input {
    padding: 10px 5px;
    font-size: 15px
}
input[type=checkbox], input[type=radio] {
    -webkit-transform: scale(1.5);
    transform: scale(1.5)
}
/*
.form-section01 {
    border: 3px solid #5d5286;
    border-radius: 10px 10px 10px 10px;
    padding: 10px;
    background-color: #c5d9fb;
    margin-bottom: 10px
}
.form-section01 li {
    margin-bottom: 10px
}
*/
.form_notice {
    font-size: 12px;
    color: #666
}
#agreement {
    background: #c5d9fb;
    padding: 10px;
    margin-top: 10px
}
#agreement a {
    color: #2d6fca;
    text-decoration: underline
}
#annotation {
    background: #fff;
    padding: 10px
}
#landing_form {
    background: #fff;
    border-bottom: 1px solid #5d5286
}
#form_checkout_title {
    display: none
}
.form_box {
    border-right: 1px solid #5d5286;
    border-left: 1px solid #5d5286;
    border-bottom: 1px solid #5d5286
}
span.form_required, span.form_notice {
    color: #fff;
    background: red;
    font-weight: 700;
    padding: 3px;
    font-size: 12px;
    margin-left: 10px
}
.form_box_label {
    background: #c5d9fb;
    border-bottom: 1px solid #5d5286;
    border-top: 1px solid #5d5286;
    padding: 8px;
    vertical-align: middle;
    text-align: left;
    color: #333;
    margin-bottom: 0;
    font-size: 1rem
}
.form_input_box {
    padding: 8px;
    font-size: 1rem
}
.form_input_box p {
    font-size: 1rem
}
.form_example {
    padding: 0 8px 8px;
    color: #666;
    font-size: 0.9rem
}
.form_example p {
    color: #c00
}
.form_input_box input[type=text], .form_input_box input[type=email] {
    width: 95%
}
.form_input_box input.zip1, .form_input_box input.zip2 {
    width: 30%
}
.form_input_box input.tel_no, .form_input_box input.input_year {
    width: 20%
}
.form_input_box #OrderBirthdayMonth, .form_input_box #OrderBirthdayDay {
    width: 25%
}
.form_input_box label {
    margin: 0 7px;
    vertical-align: bottom
}
#form-order {
    margin-top: 4%
}
#confirm_button, #form .finish_button img{
    margin: 4% auto;
    text-align: center;
}
#confirm_button img,
#form .finish_button img{   
    width: 90%;    
    width: 90%;
} 

#input_payment_method {
    padding-bottom: 70%;
    background: url(../images/cre_sp_230622.png) 0 bottom no-repeat;
    background-size: contain;
}

#input_payment_method #form-single-payment-method {
    font-size:0.9rem ;
}
#form_payment_method_credit {
	display: none;
}
.form_input_box .input_label{
    max-height: 2rem;
}
#input_name .form_input_box, #input_kana .form_input_box {
  display:flex;
}
.form_input_box input.ureru_efo_family_name, .form_input_box input.ureru_efo_family_kana{
  width: 50%!important;
  margin-left: 0.5em;
  margin-right: 10px;
}
.form_input_box input.ureru_efo_given_name, .form_input_box input.ureru_efo_given_kana{
  width: 50%!important;
  margin-left: 0.5em;
}
/*--メールアドレス確認を非表示--*/
#input_email_confirm { display:none }


@media screen and (min-width:750px) {

    #input_address1, #input_zip, #input_tel_no{
        position:relative;
    }
    #input_prefecture .form_input_box{
        width: 400px;
    }
    #input_zip .form_input_box{
        width: 500px;
    }

    #input_tel_no .form_input_box input{
        width: 100px;
    }


    #confirm_button img,
    #form .finish_button img{       
        width: 65%;
    }  
    #form-order img{
        width: 65%;
        margin: auto;
    }
    #input_payment_method #form-single-payment-method {
      margin-top: 10px;
    }
}
#agreement table {
    width: 100%;
    border: 0;
    margin: 0 5px
}
#agreement table .agreement_check {
    vertical-align: top;
    width: 38px
}
#agreement table .agreement_label {
    vertical-align: middle
}
#CheckBlockTextareaCheckarea {
    width: 95%
}
.error-message {
    margin: 8px;
    color: red;
    font-weight: 700;
    background: #ffd0d0;
    font-size: 12px
}

.customer_info, #order_info_payment_box {
    margin-top: 20px
}
#form_checkout_title {
    display: none
}
#order_info_checkout, #form_upsell {
    background: #fff;
    border-bottom: 1px solid #5d5286
}
#order_info_payment {
    border-bottom: 1px solid #5d5286;
    border-top: 1px solid #5d5286;
    color: #333
}
#np_area {
    border: 1px solid #000;
    margin: 10px 0;
    padding: 10px
}
#np_area p {
    margin: 20px 0 0
}
#OrderFamilyKana, #OrderGivenKana {
    ime-mode: active
}
#OrderZip1, #OrderZip2 {
    ime-mode: disabled
}
#OrderTelNo1, #OrderTelNo2, #OrderTelNo3, #OrderEmail, #OrderEmailConfirm, #OrderBirthdayYear {
    ime-mode: disabled
}
select, #form_payment_method_select {
    width: 100%
}
.site-footer .box-info {
    border-top: 2px solid #ccc;
    margin: 20px 10px 15px;
    text-align: left
}
.site-footer .footer-logo {
    margin-top: 15px
}
.site-footer .footer-logo img {
    width: 15%
}
.site-footer ul {
    margin-top: 10px
}
.site-footer ul li {
    display: block;
    padding: 4px 0
}
.site-footer ul li a:link {
    color: #333
}
.site-footer .copy {
    background: #231f63;
    color: #fff;
    font-size: .8rem;
    padding: 6px 0;
    text-align: center
}
@media screen and (min-width:750px) {
    .site-footer .box-info{
      width: 750px;
      margin: 20px auto 15px;
    }
    .site-footer ul li {
        display: inline-block;
        padding-right:2em;
  }
}
/* -------- */

/* 購入時確認画面メッセージ */
#order_info_confirm_message label {
    cursor: pointer;
    text-decoration: underline;
    color: #0169d8
}

#order_info_confirm_message input {
    display: none
}

#order_info_confirm_message .acc_cont {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: .8s;
    display: block
}

#order_info_confirm_message input:checked~.acc_cont {
    padding-bottom: 10px;
    height: auto;
    opacity: 1
}