@CHARSET "UTF-8";

/* -------------------------------------------------------------------------*/
/* bace
/* -------------------------------------------------------------------------*/

body{ margin: 0 auto; }

p{ font-size: 15px; line-height: 1.9; }
h1{ font-size: 24px; margin-bottom: 20px; color: #333333; }
h2{ font-size: 20px; margin-bottom: 10px; color: #333333; }
h3{ font-size: 18px; font-weight: normal; margin-bottom: 10px; color: #333333; }
h4{ display: inline-block; margin-bottom: 10px; font-weight:bold; padding: 4px 8px; color: #ffffff; background-color: #0000ff; }

@media screen and ( max-width:767px ){
    p{ font-size: 14px; line-height: 1.5;}
    h1{ font-size: 18px; margin-bottom: 10px; }
    h2{ font-size: 15px; margin-bottom: 10px; }
    h3{ font-size: 13px; font-weight: normal; margin-bottom: 10px; }
}



/* -------------------------------------------------------------------------*/
/* header
/* -------------------------------------------------------------------------*/

.header{
    width: 100%;
    padding: 0;
    margin: 0 auto;
    line-height: 1;
}

@media screen and ( max-width:767px ){
    .header{
        width: auto ;
        height: 52px;
        -webkit-box-shadow: 0px 0px 5px 2px rgba(0,0,0,0.1);
        box-shadow: 0px 0px 5px 2px rgba(0,0,0,0.1);
    }
}

.header .visible-sp img {
    text-align: left;
    padding-top: 17px;
    padding-left: 15px;
}


@media screen and ( max-width:767px ){
    .hidden-sp{
        display: none;
    }
}

.visible-sp{
    display: none;
}

@media screen and ( max-width:767px ){
    .visible-sp{
        display: block;
    }
}



/* -------------------------------------------------------------------------*/
/* body
/* -------------------------------------------------------------------------*/
.body-wrap{
    overflow: hidden;   /* 無駄な空白削除のため */
    max-width: 767px;
    margin: 0 auto;
    padding: 0 10px;
}
@media screen and ( max-width:767px ){
    .body-wrap{
        padding: 0;
    }
}

body.responsive{
    font-family: 'Yu Gothic M','Yu Gothic',YuGothic,'ＭＳ Ｐゴシック','メイリオ',Meiryo,sans-serif;
    font-size: 15px;
    line-height: 1.4;
    text-align: left;
    text-justify: auto;
}

@media screen and (max-width: 767px) {
    body.responsive {
        font-size: 12px;
        line-height: 1.7;
    }
}

@media print{
    body.responsive {
        background-color: #ffffff;
    }
}



/* -------------------------------------------------------------------------*/
/* main section
/* -------------------------------------------------------------------------*/

.mainSec{
    width: 100%;
    padding: 0;
    margin: 40px auto 40px;
}

@media screen and ( max-width:767px ){
    .mainSec{
        width: auto;
        padding: 0 10px;
        font-size: 13px;
    }
}


/*-- formBox ---*/
.mainSec .formBox table{
    width: 100%;
    border-collapse: separate;
    border-spacing: 1px;
    background-color: #dddddd;
    margin-bottom: 20px;
    table-layout: fixed;
}

.mainSec .formBox table th{
    width: 20%;
    /*max-width: 146px;*/
    padding: 9px 13px;
    border: 1px solid #ffffff;
    background-color: #f5f4f2;
    vertical-align: middle;
}

.mainSec .formBox table td{
    width: 80%;
    padding: 9px 13px;
    background-color: #ffffff;
    vertical-align: middle;
}

.mainSec .formBox table td p textarea{
    width: 100%;
}

@media screen and ( max-width: 768px ){
    .mainSec .formBox table th{
        width: auto;
        display: block;
    }
    .mainSec .formBox table td{
        width: auto;
        display: block;
    }
}


/*-- formBox2 ---*/
.mainSec .formBox2 table{
    width: 100%;
    border-collapse: separate;
    border-spacing: 1px;
    background-color: #dddddd;
    margin-bottom: 20px;
    /*table-layout: fixed;*/
}

.mainSec .formBox2 table th{
    width: 22%;
    padding: 9px 13px;
    border: 1px solid #ffffff;
    background-color: #f5f4f2;
    vertical-align: middle;
}

.mainSec .formBox2 table td{
    width: 26%;
    padding: 9px 13px;
    background-color: #ffffff;
    vertical-align: middle;
}

@media screen and ( max-width: 768px ){
    .mainSec .formBox2 table thead{
        display:none;
    }
    .mainSec .formBox2 table  tbody th{
        width: auto;
        display: block;
    }
    .mainSec .formBox2 table  tbody td{
        width: auto;
        display: block;
    }
    .mainSec .formBox2 table tbody td::before{
        content: attr(data-label);
        float:left; /* 見出し改行なし */
        /*display: block; 見出し改行*/
        margin-bottom: 3px;
        font-weight:bold;
    }
}


/*-- formButton ---*/
.mainSec .formButton {
    margin-top: 30px;
    margin-bottom: 35px;
}

.mainSec .formButton span {
    display: inline;
    vertical-align: top;
    margin-right: 30px;
}

@media screen and ( max-width:767px ){
    .mainSec .formButton span {
        width: 30%;
        margin-right: 15px;
    }
}

.mainSec .formBox p.formButton {
    text-align: center;
}


/*-- Decoration ---*/
.required{ color: #ff0000; margin: 0 1px;}
.int1{ margin-left: 2em;}

textarea{
    vertical-align: top;
    resize: none;
    margin-top: 0.5em;
    margin-bottom: 0.5em;
    width: 95%;
}

span.choices{
    vertical-align: top;
    margin-right: 2em;
}

@media screen and ( max-width:767px ){
    span.choices{ margin-right: 0.5em;}
    .int1{ margin-left: 3em;}
    input{ margin-left:1em;}
}

label.choices{
    vertical-align: top;
    margin-left: 0.5em;
}

.no-new-line {
    white-space: pre;
}

/*-- btn ---*/
.btn {
    display: inline-block;
    width: 180px;
    height: 50px;
    border-radius: 3px;
    font-size: 16px;
    font-weight: bold;
    color: #ffffff;
    text-decoration: none;
    border: none;
    background-image: linear-gradient(0deg, #52a9b8 0%, #91c8d2 100%);
    transition: .4s;
}

.btn:hover {
    background-image: linear-gradient(0deg, #52a9b8 50%, #91c8d2 100%);
}

@media screen and ( max-width:767px ){
    .btn {
        width: 120px;
        height: 28px;
        font-size: 12px;
    }
}