@media screen and (min-width: 769px), print {
  .contact_cont {
    margin: 41px 0 0;
  }
  .contact_cont .ttl_box {
    text-align: center;
  }
  .contact_cont .ttl_box p {
    font-size: 1.8rem;
    color: #c23b26;
    padding-top: 8px;
  }
  .cont_form {
    max-width: 746px;
    margin: 30px auto 0;
  }
  .cont_form .note {
    text-align: right;
    color: #cc0000;
    font-size: 1.4rem;
  }
  .cont_form .dl_lst {
    padding: 40px 0 91px;
  }
  .cont_form .dl_lst input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: auto;
    padding: 0;
  }
  .cont_form .dl_lst input[type="radio"] + label {
    cursor: pointer;
  }
  .cont_form .dl_lst input[type="radio"] + label:before {
    content: '';
    background: #fff;
    -moz-border-radius: 100%;
         border-radius: 100%;
    border: 1px solid #000;
    display: inline-block;
    width: 21px;
    height: 21px;
    position: relative;
    top: 4px;
    margin-right: 10px;
    vertical-align: top;
    cursor: pointer;
    text-align: center;
    -webkit-transition: all 250ms ease;
    -moz-transition: all 250ms ease;
    transition: all 250ms ease;
  }
  .cont_form .dl_lst input[type="radio"]:checked + label:before {
    background-color: #c23b26;
    -moz-box-shadow: inset 0 0 0 5px #fff;
         box-shadow: inset 0 0 0 5px #fff;
  }
  .cont_form .dl_lst input[type="radio"]:focus + label:before {
    outline: none;
    border-color: #000;
  }
  .cont_form .dl_lst input[type="radio"]:disabled + label:before {
    -moz-box-shadow: inset 0 0 0 4px #fff;
         box-shadow: inset 0 0 0 4px #fff;
    border-color: #bfbfbf;
    background: #bfbfbf;
  }
  .cont_form .dl_lst input[type="radio"] + label:empty:before {
    margin-right: 0;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked), .cont_form .dl_lst input[type="checkbox"]:checked {
    position: absolute;
    left: -9999px;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked) + label, .cont_form .dl_lst input[type="checkbox"]:checked + label {
    position: relative;
    padding-left: 26px;
    cursor: pointer;
    font-size: 1.6rem;
    line-height: 36px;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked) + label:before, .cont_form .dl_lst input[type="checkbox"]:checked + label:before {
    content: '';
    position: absolute;
    left: -7px;
    top: 3px;
    width: 15px;
    height: 15px;
    border: 1px solid #000;
    z-index: 1;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked) + label:after, .cont_form .dl_lst input[type="checkbox"]:checked + label:after {
    content: '';
    position: absolute;
    top: -1px;
    left: -5px;
    line-height: 0.8;
    -webkit-transition: all .2s;
    -moz-transition: all .2s;
    transition: all .2s;
    background: url("../images/check_arr.png") no-repeat;
    width: 15px;
    height: 19px;
    z-index: 2;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked) + label:after {
    opacity: 0;
    -webkit-transform: scale(0);
       -moz-transform: scale(0);
        -ms-transform: scale(0);
            transform: scale(0);
  }
  .cont_form .dl_lst input[type="checkbox"]:checked + label:after {
    opacity: 1;
    -webkit-transform: scale(1);
       -moz-transform: scale(1);
        -ms-transform: scale(1);
            transform: scale(1);
  }
  .cont_form .dl_lst input[type="checkbox"]:disabled:not(:checked) + label:before,
  .cont_form .dl_lst input[type="checkbox"]:disabled:checked + label:before {
    -moz-box-shadow: none;
         box-shadow: none;
    border-color: #bbb;
    background-color: #ddd;
  }
  .cont_form .dl_lst input[type="checkbox"]:disabled:checked + label:after {
    color: #999;
  }
  .cont_form .dl_lst input[type="checkbox"]:disabled + label {
    color: #aaa;
  }
  .cont_form .dl_lst dl {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    padding-bottom: 15px;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .cont_form .dl_lst dl.tt_top {
    -webkit-box-align: start;
       -moz-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .cont_form .dl_lst dl.tt_top.postal dt, .cont_form .dl_lst dl.tt_top.area dt {
    padding-top: 15px;
  }
  .cont_form .dl_lst dl.postal dd {
    font-size: 1.6rem;
    line-height: 26px;
  }
  .cont_form .dl_lst dl.postal dd div input {
    width: 91px;
    margin: 0 16px 0 15px;
    text-align: center;
  }
  .cont_form .dl_lst dl.postal dd textarea {
    margin-top: 20px;
  }
  .cont_form .dl_lst dl dt {
    width: 189px;
    text-align: right;
    font-size: 1.6rem;
    line-height: 36px;
    padding: 1px 32px 0 0;
    letter-spacing: -.25px;
  }
  .cont_form .dl_lst dl dt .require {
    color: #cc0000;
    font-size: 1.4rem;
    padding-left: 8px;
    display: inline-block;
  }
  .cont_form .dl_lst dl dd {
    width: -webkit-calc(100% - 189px);
    width: -moz-calc(100% - 189px);
    width: calc(100% - 189px);
    padding: 3px 0 0 5px;
  }
  .cont_form .dl_lst dl dd label, .cont_form .dl_lst dl dd input, .cont_form .dl_lst dl dd textarea, .cont_form .dl_lst dl dd p {
    font-size: 1.6rem;
    line-height: 26px;
    color: #000;
  }
  .cont_form .dl_lst dl dd input, .cont_form .dl_lst dl dd textarea {
    width: 100%;
    outline: none;
    border: 1px solid #000;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding: 15px 20px 17px;
    -moz-border-radius: 0;
         border-radius: 0;
  }
  .cont_form .dl_lst dl dd textarea {
    resize: none;
    height: 86px;
  }
  .cont_form .dl_lst dl dd input::-webkit-input-placeholder,
  .cont_form .dl_lst dl dd textarea::-webkit-input-placeholder {
    color: #a3a3a3;
  }
  .cont_form .dl_lst dl dd input::-moz-placeholder,
  .cont_form .dl_lst dl dd textarea::-moz-placeholder {
    color: #a3a3a3;
  }
  .cont_form .dl_lst dl dd input:-ms-input-placeholder,
  .cont_form .dl_lst dl dd textarea:-ms-input-placeholder {
    color: #a3a3a3;
  }
  .cont_form .dl_lst dl dd input:-moz-placeholder,
  .cont_form .dl_lst dl dd textarea:-moz-placeholder {
    color: #a3a3a3;
  }
  .cont_form .dl_lst dl dd .group_form {
    margin: 0 0 12px -5px;
  }
  .cont_form .dl_lst dl dd .group_form span {
    display: inline-block;
    padding-top: 2px;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .mess {
    height: 186px;
  }
  .cont_form .dl_lst dl dd.inquiry_conts > p {
    padding: 9px 0 17px;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box figure {
    width: 251px;
    border: 1px solid #000;
    margin: -2px 28px 0 0;
    height: 185px;
    text-align: center;
    position: relative;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box figure img {
    width: auto;
    height: auto;
    max-width: 100%;
    display: inline-block;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    vertical-align: middle;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box figure img.change {
    max-width: 100% !important;
    max-height: 100%;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile {
    margin-bottom: 16px;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile input {
    opacity: 0;
    overflow: hidden;
    position: absolute;
    z-index: -1;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile input + label {
    cursor: pointer;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile input + label {
    font-size: 1.6rem;
    width: 254px;
    line-height: 26px;
    text-align: center;
    color: #000;
    background-color: #fff;
    border: 1px solid #000;
    display: inline-block;
    padding: 11px 0 10px;
    -webkit-transition: all .35s;
    -moz-transition: all .35s;
    transition: all .35s;
    -moz-box-shadow: 3px 1px 7px rgba(0, 0, 0, 0.25);
         box-shadow: 3px 1px 7px rgba(0, 0, 0, 0.25);
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile input:focus + label,
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile input + label:hover {
    background-color: #000;
    color: #fff;
  }
  .cont_form .dl_lst .checkbox {
    text-align: center;
    margin: 34px 0 30px;
  }
  .cont_form .dl_lst .checkbox a {
    border-bottom: 1px solid #959595;
  }
  .cont_form .dl_lst .checkbox a:hover {
    border-bottom-color: #fff;
  }
  .cont_form .dl_lst .links {
    width: 358px;
    line-height: 26px;
    display: block;
    margin: 0 auto;
    padding: 6px;
    outline-color: transparent;
    cursor: pointer;
    outline: none;
  }
  .confirm .dl_lst {
    padding-bottom: 80px;
  }
  .confirm .dl_lst dl {
    padding-bottom: 42px;
  }
  .confirm .dl_lst dl dt {
    width: 215px;
    padding: 1px 66px 0 0;
    letter-spacing: 0;
  }
  .confirm .dl_lst dl dd {
    width: -webkit-calc(100% - 215px);
    width: -moz-calc(100% - 215px);
    width: calc(100% - 215px);
    padding: 0;
    letter-spacing: 1px;
  }
  .confirm .dl_lst dl dd figure {
    width: 251px;
    border: 1px solid #000;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 53px 0 0;
    min-height: 185px;
  }
  .confirm .dl_lst dl dd figure img {
    width: auto;
    height: auto;
    object-fit: contain;
  }
  .confirm .dl_lst dl.tt_top.postal dt {
    padding-top: 0;
  }
  .confirm .dl_lst dl.tt_top.postal dd > p {
    padding-bottom: 11px;
  }
  .confirm .dl_lst .checkbox {
    margin: 11px 0 34px;
  }
  .confirm .dl_lst .checkbox a {
    font-size: 1.6rem;
    line-height: 26px;
    text-decoration: none;
    border: none;
    padding-right: 73px;
  }
  .confirm .dl_lst .checkbox a:hover {
    text-decoration: underline;
  }
  .error .center {
    text-align: center;
  }
  .error .dl_lst dl dt em {
    font-style: normal;
    color: #c23b26;
    font-size: 1.4rem;
    display: block;
    line-height: 26px;
  }
  .error .dl_lst .checkbox {
    margin-bottom: 5px;
  }
  .error .dl_lst .links {
    margin-top: 10px;
  }
  .complete {
    text-align: center;
    margin: 41px auto 80px;
  }
  .complete h3 {
    font-size: 3.2rem;
    line-height: 36px;
    font-weight: 300;
    letter-spacing: 1px;
    padding-left: 10px;
  }
  .complete p {
    font-size: 1.6rem;
    line-height: 24px;
    text-align: center;
    padding: 33px 0 37px;
  }
  .complete .links {
    width: 358px;
  }
}

@media screen and (max-width: 768px) {
  .contact_cont {
    margin: 6.51042vw 0 15.625vw;
  }
  .contact_cont .ttl_box {
    text-align: center;
  }
  .contact_cont .ttl_box h2 img {
    max-width: 27.73438vw;
  }
  .contact_cont .ttl_box p {
    font-size: 3.64583vw;
    color: #c23b26;
    padding-top: 1.30208vw;
  }
  .cont_form {
    margin: 4.16667vw auto 0;
  }
  .cont_form .note {
    text-align: right;
    color: #cc0000;
    font-size: 3.38542vw;
  }
  .cont_form .dl_lst {
    padding: 5.20833vw 0 0;
  }
  .cont_form .dl_lst input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: auto;
    padding: 0;
  }
  .cont_form .dl_lst input[type="radio"] + label {
    cursor: pointer;
  }
  .cont_form .dl_lst input[type="radio"] + label:before {
    content: '';
    background: #fff;
    -moz-border-radius: 50%;
         border-radius: 50%;
    border: 1px solid #000;
    display: inline-block;
    width: 2.86458vw;
    height: 2.86458vw;
    position: relative;
    top: 1.5625vw;
    margin-right: 1.30208vw;
    vertical-align: top;
    cursor: pointer;
    text-align: center;
    -webkit-transition: all 250ms ease;
    -moz-transition: all 250ms ease;
    transition: all 250ms ease;
  }
  .cont_form .dl_lst input[type="radio"]:checked + label:before {
    background-color: #c23b26;
    -moz-box-shadow: inset 0 0 0 0.65104vw #fff;
         box-shadow: inset 0 0 0 0.65104vw #fff;
  }
  .cont_form .dl_lst input[type="radio"]:focus + label:before {
    outline: none;
    border-color: #000;
  }
  .cont_form .dl_lst input[type="radio"]:disabled + label:before {
    -moz-box-shadow: inset 0 0 0 0.65104vw #fff;
         box-shadow: inset 0 0 0 0.65104vw #fff;
    border-color: #bfbfbf;
    background: #bfbfbf;
  }
  .cont_form .dl_lst input[type="radio"] + label:empty:before {
    margin-right: 0;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked), .cont_form .dl_lst input[type="checkbox"]:checked {
    position: absolute;
    left: -9999px;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked) + label, .cont_form .dl_lst input[type="checkbox"]:checked + label {
    position: relative;
    padding-left: 7.29167vw;
    cursor: pointer;
    font-size: 3.64583vw;
    line-height: 4.94792vw;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked) + label:before, .cont_form .dl_lst input[type="checkbox"]:checked + label:before {
    content: '';
    position: absolute;
    left: 1.04167vw;
    top: 0.52083vw;
    width: 4.16667vw;
    height: 4.16667vw;
    border: 1px solid #000;
    z-index: 1;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked) + label:after, .cont_form .dl_lst input[type="checkbox"]:checked + label:after {
    content: '';
    position: absolute;
    top: -0.26042vw;
    left: 1.5625vw;
    line-height: 0.8;
    -webkit-transition: all .2s;
    -moz-transition: all .2s;
    transition: all .2s;
    background: url("../images/check_arr_sp.png") no-repeat;
    -moz-background-size: contain;
         background-size: contain;
    width: 3.90625vw;
    height: 4.94792vw;
    z-index: 2;
  }
  .cont_form .dl_lst input[type="checkbox"]:not(:checked) + label:after {
    opacity: 0;
    -webkit-transform: scale(0);
       -moz-transform: scale(0);
        -ms-transform: scale(0);
            transform: scale(0);
  }
  .cont_form .dl_lst input[type="checkbox"]:checked + label:after {
    opacity: 1;
    -webkit-transform: scale(1);
       -moz-transform: scale(1);
        -ms-transform: scale(1);
            transform: scale(1);
  }
  .cont_form .dl_lst input[type="checkbox"]:disabled:not(:checked) + label:before,
  .cont_form .dl_lst input[type="checkbox"]:disabled:checked + label:before {
    -moz-box-shadow: none;
         box-shadow: none;
    border-color: #bbb;
    background-color: #ddd;
  }
  .cont_form .dl_lst input[type="checkbox"]:disabled:checked + label:after {
    color: #999;
  }
  .cont_form .dl_lst input[type="checkbox"]:disabled + label {
    color: #aaa;
  }
  .cont_form .dl_lst dl {
    padding-bottom: 1.95312vw;
  }
  .cont_form .dl_lst dl.postal dd {
    font-size: 3.64583vw;
    line-height: 6.25vw;
  }
  .cont_form .dl_lst dl.postal dd div input {
    width: 26.04167vw;
    margin: 0 2.60417vw;
    text-align: center;
  }
  .cont_form .dl_lst dl.postal dd textarea {
    margin-top: 2.60417vw;
  }
  .cont_form .dl_lst dl dt {
    font-size: 3.64583vw;
    line-height: 6.25vw;
    padding-bottom: 2.60417vw;
  }
  .cont_form .dl_lst dl dt .require {
    color: #cc0000;
    font-size: 3.38542vw;
    padding-left: 1.04167vw;
    display: inline-block;
  }
  .cont_form .dl_lst dl dd label, .cont_form .dl_lst dl dd input, .cont_form .dl_lst dl dd textarea, .cont_form .dl_lst dl dd p {
    font-size: 3.64583vw;
    line-height: 6.25vw;
    color: #000;
  }
  .cont_form .dl_lst dl dd input, .cont_form .dl_lst dl dd textarea {
    width: 100%;
    outline-color: transparent;
    border: 1px solid #000;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding: 2.08333vw 2.60417vw;
    -moz-border-radius: 0;
         border-radius: 0;
  }
  .cont_form .dl_lst dl dd textarea {
    resize: none;
    height: 17.70833vw;
  }
  .cont_form .dl_lst dl dd input::-webkit-input-placeholder,
  .cont_form .dl_lst dl dd textarea::-webkit-input-placeholder {
    color: #a3a3a3;
  }
  .cont_form .dl_lst dl dd input::-moz-placeholder,
  .cont_form .dl_lst dl dd textarea::-moz-placeholder {
    color: #a3a3a3;
  }
  .cont_form .dl_lst dl dd input:-ms-input-placeholder,
  .cont_form .dl_lst dl dd textarea:-ms-input-placeholder {
    color: #a3a3a3;
  }
  .cont_form .dl_lst dl dd input:-moz-placeholder,
  .cont_form .dl_lst dl dd textarea:-moz-placeholder {
    color: #a3a3a3;
  }
  .cont_form .dl_lst dl dd .group_form {
    margin: 0 0 1.5625vw;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .mess {
    height: 48.4375vw;
  }
  .cont_form .dl_lst dl dd.inquiry_conts > p {
    padding: 1.30208vw 0 1.30208vw 2.60417vw;
    text-indent: -2.60417vw;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box {
    text-align: center;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box figure {
    border: 1px solid #000;
    margin-bottom: 4.16667vw;
    height: 48.17708vw;
    width: 59.89583vw;
    margin: 0 auto;
    text-align: center;
    position: relative;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box figure img {
    width: auto;
    height: auto;
    max-width: 100%;
    display: inline-block;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    vertical-align: middle;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box figure img.change {
    max-width: 100% !important;
    max-height: 100%;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile {
    margin: 2.08333vw 0;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile input {
    width: 0.1px;
    height: 0.1px;
    opacity: 0;
    overflow: hidden;
    position: absolute;
    z-index: -1;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile input + label {
    cursor: pointer;
  }
  .cont_form .dl_lst dl dd.inquiry_conts .thumb_box .inputfile input + label {
    font-size: 3.64583vw;
    max-width: 47.52604vw;
    width: 100%;
    line-height: 26px;
    text-align: center;
    color: #000;
    background-color: #fff;
    border: 1px solid #000;
    display: inline-block;
    padding: 2.08333vw 0;
    -moz-box-shadow: 0.39062vw 0.13021vw 0.91146vw rgba(0, 0, 0, 0.25);
         box-shadow: 0.39062vw 0.13021vw 0.91146vw rgba(0, 0, 0, 0.25);
  }
  .cont_form .dl_lst .checkbox {
    text-align: center;
    margin: 4.42708vw 0 6.51042vw;
  }
  .cont_form .dl_lst .checkbox a {
    border-bottom: 1px solid #959595;
  }
  .cont_form .dl_lst .checkbox a:hover {
    border-bottom-color: #fff;
  }
  .cont_form .links {
    width: 100%;
    max-width: 46.875vw;
    display: block;
    margin: 0 auto;
    padding: 0 0.78125vw;
    outline-color: transparent;
    cursor: pointer;
    color: #000;
  }
  .cont_form .links:hover {
    color: #fff;
  }
  .confirm .dl_lst dl dd {
    padding: 0;
  }
  .confirm .dl_lst dl dd figure {
    border: 1px solid #000;
    height: 48.17708vw;
    width: 59.89583vw;
    margin: 4.16667vw auto 1.30208vw;
    text-align: center;
    position: relative;
  }
  .confirm .dl_lst dl dd figure img {
    width: auto;
    height: auto;
    max-width: 100%;
    display: inline-block;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    vertical-align: middle;
  }
  .confirm .dl_lst dl.tt_top.postal dt {
    padding-top: 0;
  }
  .confirm .dl_lst dl.tt_top.postal dd > p {
    padding-bottom: 1.5625vw;
  }
  .confirm .dl_lst .checkbox {
    margin: 2.08333vw 0 4.6875vw;
  }
  .confirm .dl_lst .checkbox a {
    font-size: 3.64583vw;
    line-height: 6.25vw;
    text-decoration: none;
    border: none;
    padding-right: 9.50521vw;
  }
  .confirm .dl_lst .checkbox a:hover {
    text-decoration: underline;
  }
  .error > .note {
    padding-bottom: 1.5625vw;
  }
  .error .center {
    text-align: center;
  }
  .error .dl_lst dl dt em {
    font-style: normal;
    color: #c23b26;
    font-size: 3.38542vw;
    display: block;
    line-height: 4.94792vw;
  }
  .error .dl_lst .checkbox {
    margin-bottom: 2.34375vw;
  }
  .error .dl_lst .links {
    margin-top: 2.34375vw;
  }
  .complete {
    text-align: center;
    margin: 8.46354vw auto 10.41667vw;
  }
  .complete h3 {
    font-size: 6.25vw;
    line-height: 6.25vw;
    font-weight: 300;
  }
  .complete p {
    font-size: 3.64583vw;
    line-height: 6.25vw;
    text-align: center;
    padding: 7.8125vw 0 9.76562vw;
  }
}
