@charset "utf-8";

form#mail_form{
    max-width : 1280px;
    width : 100%;
    margin : 30px auto;
    padding : 0 0;
    background : #ffffff;
}
form#mail_form div{
    margin : 20px 0;
}

form#mail_form dl{
    width : 90%;
    margin : 0 auto;
    overflow : hidden;
}

form#mail_form dl dt{
    clear : both;
    width : 20%;
    float : left;
    border-top : 1px solid #cccccc;
    padding : 15px 0;
    text-align : right;
    overflow : hidden;
}

form#mail_form dl dd{
    width : 75%;
    float : right;
    text-align: left;
    border-top : 1px solid #cccccc;
    padding : 15px 0 15px 5%;
}

form#mail_form dl dt:first-child,
form#mail_form dl dt:first-child+dd{
    border : none;
}

form#mail_form dl dt span{
    display : block;
    font-size : 85%;
    color : #3377ff;
}

form#mail_form .warning {
	margin : 5px 0 0 0;
	font-size: 0.8em;
}

form#mail_form .strong {
    font-weight: bolder;
    font-size : 1.2em;
    color: red;
}

/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

form#mail_form dl dt span.required {
    display : inline-block;
    color : red;
    padding-left: 5px;
}

form#mail_form dl dd span.error_blank,
form#mail_form dl dd span.error_format,
form#mail_form dl dd span.error_match{
    display : block;
    color : #ff0000;
    margin-top : 3px;
}


span.loading{
    width : 50px;
    height : 50px;
    border-radius : 50%;
    border-top : 5px solid rgba( 255, 255, 255, 0.2 );
    border-right : 5px solid rgba( 255, 255, 255, 0.2 );
    border-bottom : 5px solid rgba( 255, 255, 255, 0.2 );
    border-left : 5px solid #ffffff;
    -webkit-transform : translateZ( 0 );
    -ms-transform : translateZ( 0 );
    transform : translateZ( 0 );
    -webkit-animation : load-circle 1.0s linear infinite;
    animation : load-circle 1.0s linear infinite;
    position : absolute;
    top : 50%;
    left : 50%;
    margin-top : -25px;
    margin-left : -25px;
}

@-webkit-keyframes load-circle{
    0%{
        -webkit-transform : rotate( 0deg );
        transform : rotate( 0deg );
    }
    100%{
        -webkit-transform : rotate( 360deg );
        transform : rotate( 360deg );
    }
}

@keyframes load-circle{
    0%{
        -webkit-transform : rotate( 0deg );
        transform : rotate( 0deg );
    }
    100%{
        -webkit-transform : rotate( 360deg );
        transform : rotate( 360deg );
    }
}


/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */


form#mail_form input[type="text"],
form#mail_form input[type="email"],
form#mail_form input[type="tel"]{
    max-width : 90%;
    height : 2em;
    padding : 2px 2%;
    border : 1px solid #cccccc;
    border-radius : 3px;
    background : #fafafa;
    -webkit-appearance : none;
    font-size : 100%;
    font-family : inherit;
    margin-top : 5px;
}

form#mail_form input[type="text"]:focus,
form#mail_form input[type="email"]:focus,
form#mail_form input[type="tel"]:focus,
form#mail_form textarea:focus{
    box-shadow : 0px 0px 5px #55ccff;
    border : 1px solid #55ccff;
    background : #ffffff;
}

form#mail_form ul li input[type="radio"],
form#mail_form ul li input[type="checkbox"]{
    margin-right : 10px;
    margin-top : 7px;
}

form#mail_form ul li:first-child input[type="radio"],
form#mail_form ul li:first-child input[type="checkbox"]{
    margin-top : 0px;
}

form#mail_form select{
    font-size : 100%;
    margin-top : 5px;
}

form#mail_form textarea{
    display : block;
    width : 90%;
    max-width : 90%;
    height : 200px;
    padding : 2px 2%;
    resize : vertical;
    border : 1px solid #cccccc;
    border-radius : 3px;
    background : #fafafa;
    -webkit-appearance : none;
    font-size : 100%;
    font-family : inherit;
}


form#mail_form ul{
    list-style-type : none;
}

form#mail_form ul li label:hover{
    cursor : pointer;
}


form#mail_form input#company{
    width : 60%;
}

form#mail_form input#name_1,
form#mail_form input#name_2,
form#mail_form input#read_1,
form#mail_form input#read_2,
form#mail_form input#postal,
form#mail_form input#phone,
form#mail_form input#schedule,
form#mail_form input#schedule2{
    width : 30%;
}

form#mail_form input#mail_address,
form#mail_form input#mail_address_confirm{
    width : 80%;
}

form#mail_form input#postal+a{
    display : inline-block;
    padding : 9px 15px;
    vertical-align : middle;
    line-height : 1;
    background : #5bc0de;
    border : 1px solid #46b8da;
    border-radius : 3px;
    color : #ffffff;
    font-family : inherit;
    text-decoration : none;
    position : relative;
    top : -1px;
}

form#mail_form input#postal+a:hover{
    cursor : pointer;
    background : #31b0d5;
    border : 1px solid #269abc;
}

form#mail_form input#address{
    width : 90%;
}

form#mail_form div#form_submit{
    width : 90%;
    margin : 0 auto;
    padding : 15px 0;
    text-align: center;
}
form#mail_form div#form_submit #form_submit_confirm{
    max-width : 400px;
    width: 90%;
    padding :15px;
    color : #FFF;
    font-weight: bolder;
    background-color: red;
    margin: 0 auto;
}
form#mail_form #form_submit_button{
        display:none;
}

form#mail_form input[type="button"]{
    padding : 9px 15px;
    vertical-align : middle;
    line-height : 1;
    background : #5cb85c;
    border : 1px solid #4cae4c;
    border-radius : 3px;
    color : #ffffff;
    font-family : inherit;
    -webkit-appearance : none;
    font-size : 100%;
}

form#mail_form input[type="button"]:hover{
    cursor : pointer;
    background : #449d44;
    border : 1px solid #398439;
}


/* --responsive----------------------------------------------------------------------------------------------------------------- */

/* 640pixel start */
@media screen and ( max-width : 640px ){

    form#mail_form{
        width : 95%;
    }

    form#mail_form dl{
        overflow : visible;
    }

    form#mail_form dl dt{
        width : auto;
        float : none;
        text-align : left;
        padding : 10px 0 5px;
        font-weight : bold;
    }

    form#mail_form dl dd{
        width : auto;
        float : none;
        border-top : none;
        padding : 0px 0 13px 0px;
    }

    form#mail_form dl dt span{
        font-weight : normal;
    }


    /* -- for JavaScript ここから -------------------------------------------------------------------------------- */

    form#mail_form dl dt span.required,
    form#mail_form dl dt span.optional{
        margin-right : 1em;
        margin-bottom : 2em;
    }


    /* -- for JavaScript ここまで -------------------------------------------------------------------------------- */

    form#mail_form #form_submit_button{
        margin-left : 0;
    }

    form#mail_form input#phone,
    form#mail_form input#schedule,
    form#mail_form input#schedule2{
        width : 50%;
    }

}
/* 640pixel end */

/* popup */
#modal.white-popup {
    position: relative;
    background: #FFF;
    padding: 20px;
    width: 90%;
    margin: 20px auto;
}

#modal .title{
    width: 100%;
    margin: 0;
    color: #FFF;
    font-size: 2em;
    font-weight: 900;
    font-family: 
        "Hiragino Kaku Gothic StdN",
	YuGothic,    /* Mac用 */
	'Yu Gothic', /* Windows用 */
        "メイリオ", 
        sans-serif;
    text-align: center;
    background-color: #67cfee;
}

#modal div{
    margin : 20px auto;
    text-align: center;
}

#modal dl{
    width : 90%;
    margin : 0 auto;
    overflow : hidden;
}

#modal dl dt{
    clear : both;
    width : 20%;
    float : left;
    border-top : 1px solid #cccccc;
    padding : 15px 0;
    text-align : right;
    overflow : hidden;
}

#modal dl dd{
    width : 75%;
    float : right;
    text-align: left;
    border-top : 1px solid #cccccc;
    padding : 15px 0 15px 5%;
}

#modal dl dt:first-child,
#modal dl dt:first-child+dd{
    border : none;
}

#modal pre {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Verdana, Arial, sans-serif;
    color: #454545;
    font-size: 90%;
    line-height: 1.8;
}

#modal .send {
    width: 300px;
    font-size: 2em;
    font-weight: bold;
    margin: 20px auto;
    padding: 0.5em 1em;
    text-decoration: none;
    background: #00dd1c;/*ボタン色*/
    color: #FFF;
    border-bottom: solid 4px #627295;
    border-radius: 3px;
}
#modal .send:active {/*ボタンを押したとき*/
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
}
#modal .send:hover {
    cursor: pointer;
}
#modal .back {
    padding: 0.5em 1em;
    text-align: left;
}
#modal .back:hover {
    cursor: pointer;
}

/* 640pixel start */
@media screen and ( max-width : 640px ){

    #modal {
        width : 95%;
    }

    #modal dl{
        overflow : visible;
    }

    #modal dl dt{
        width : auto;
        float : none;
        text-align : left;
        padding : 10px 0 5px;
        font-weight : bold;
    }

    #modal dl dd{
        width : auto;
        float : none;
        border-top : none;
        padding : 0px 0 13px 0px;
    }
    #modal .title {
        font-size : 1em;
    }
    #modal .send {
        width: 80%;
        font-size: 1.2em;
    }
}
/* 640pixel end */
