@charset "utf-8";

/*-----------------------------------
radius
-----------------------------------*/
ul.check,
ul.list,
ol.num,
.box dl,
.one-box dl,
.txt-box,
.sup,
.list-box dl{
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
}
.box dt,
.one-box dt{
    border-radius: 5px 5px 0 0;
    -webkit-border-radius: 5px 5px 0 0;
    -moz-border-radius: 5px 5px 0 0;  
}

/*-----------------------------------
bkg
-----------------------------------*/
ul.check,
ul.list,
ol.num,
.box dl,
.one-box dl,
.txt-box,
.list-box dl{
    background: #F4FBFB;
    border: 1px solid #D3EFEF;
}

/*-----------------------------------
common
-----------------------------------*/
h3{
    font-weight: bold;
}
h4{
    padding: 0 0 0 10px;
    border-left: 4px solid #333;
    font-weight: bold;
    line-height: 1.5;
}
.sup{
    background: #f7f7f7;
    font-size: 85%;
    color: #296160;
}
p.sup{
    padding: 0.8em 1.5em 0.8em 2.5em;
    text-indent: -1em;
}
div.sup{
    margin-top: 10px;
    padding-left: 1em;
    text-indent: -1em;
}
.num .sup{
    background: none;
}
p.link{
    text-align: right;
}
p.link a{
    min-height: 16px;
    padding-right: 18px;
    background: url(/static/image/icon/blank.png) 100% 2px no-repeat;
    -webkit-background-size: 14px 14px;
    -moz-background-size: 14px 14px;
    -o-background-size: 14px 14px;
    -ms-background-size: 14px 14px;
    background-size: 14px 14px;
}

/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    section{
        margin-bottom: 35px;
        padding-bottom: 35px;
        border-bottom: 1px dotted #333;
    }
    section:last-child{
        border-bottom: none;
    }
    h3{
        margin: 0 0 20px;
        font-size: 150%;
    }
    h4{
        margin: 35px 0 15px;
        font-size: 120%;
    }
    section p.period{
        margin-top: 25px;
    }
}

/*--Small screens--*/
@media only screen and (max-width: 40em){
    section{
        padding-top: 5px;
        margin-bottom: 20px;
        padding-bottom: 25px;
        border-bottom: 1px dotted #333;
    }
    h3{
        margin: 0 0 0.9375em;
        font-size: 115%;
    }
    h4{
        margin: 20px 0 10px;
        font-size: 105%;
    }
    section p.period{
        margin-top: 20px;
    }
}

/*-----------------------------------
ul,ol
-----------------------------------*/
section ol li{
    list-style-type: decimal;
}
section ul.list li,
section .box li,
section .one-box li,
section .list-box li{
    list-style-type: disc;
}
ul.check li{
    margin-bottom: 5px;
    padding-left: 22px;
    background: url(/static/image/icon/checkbox.png) left 5px no-repeat;
    -webkit-background-size: 15px 15px;
    -moz-background-size: 15px 15px;
    -o-background-size: 15px 15px;
    -ms-background-size: 15px 15px;
    background-size: 15px 15px;
}
ul.list li,
ol.num li,
.box li,
.one-box li,
.list-box li{
    margin-bottom: 5px;
}
ul.check li:last-child,
ul.list li:last-child,
ol.num li:last-child,
.box li:last-child,
.one-box li:last-child,
.list-box li:last-child{
    margin-bottom: 0;
}

/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    ul.check{
        margin: 25px 0;
        padding: 20px 30px;
    }
    ul.list,
    ol.num{
        margin: 25px 0;
        padding: 20px 30px 20px 50px;
    }
    .box li,
    .one-box li,
    .list-box li{
        margin-left: 8px;
    }
}

/*--Small screens--*/
@media only screen and (max-width: 40em){
    ul.check{
        margin: 20px 0;
        padding: 15px 20px;
    }
    ul.list,
    ol.num{
        margin: 20px 0;
        padding: 15px 20px 15px 40px;
    }
    .box li,
    .one-box li,
    .list-box li{
        margin-left: 15px;
    }
}

/*-----------------------------------
box
-----------------------------------*/
.box dt,
.one-box dt,
.list-box dt{
    background: #D3EFEF;
    font-size: 105%;
    font-weight: bold;
    text-align: center;
}
.one-box dt{
    text-align: left;
}
.box ul,
.one-box ul,
.list-box ul{
    margin-left: 10px;
}

/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    .box,
    .one-box,
    .list-box{
        margin: 25px 0;
    }
    .box dl{
        float: left;
        width: 49%;
        padding: 20px 30px;
    }
    .box dl:first-child{
        margin-right: 2%;
    }
    .one-box dl{
        margin-bottom: 20px;
        padding: 20px 30px;
    }
    .one-box dl:last-child{
        margin-bottom: 0;
    }
    .list-box dl{
        margin-bottom: 20px;
        padding: 20px 30px;
    }
    .list-box dl:last-child{
        margin-bottom: 0;
    }
    .box dt,
    .one-box dt,
    .list-box dt{
        margin: -20px -30px 20px;
        padding: 10px 30px;
    }
}

/*--Small screens--*/
@media only screen and (max-width: 40em){
    .box,
    .one-box,
    .list-box{
        margin:20px 0;
    }
    .box dl,
    .one-box dl,
    .list-box dl{
        margin-bottom: 10px;
        padding: 15px 20px;
    }
    .box dl:last-child,
    .one-box dl:last-child,
    .list-box dl:last-child{
        margin-bottom: 0;
    }
    .box dt,
    .one-box dt,
    .list-box dt{
        margin: -15px -20px 10px;
        padding: 5px 20px;
    }
}

/*-----------------------------------
txt-box
-----------------------------------*/
.txt-box div{
    margin-bottom: 10px;
}
.txt-box div:last-child{
    margin-bottom: 0;
}

/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    .txt-box{
        margin: 25px 0;
        padding: 20px 30px;
    }
}

/*--Small screens--*/
@media only screen and (max-width: 40em){
    .txt-box{
        margin:20px 0;
        padding: 15px 20px;
    }
}

/*-----------------------------------
img-box
-----------------------------------*/
.img-box dt{
    font-weight: bold;
}
.img-box dd{
    text-align: center;
}

/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    .img-box{
        margin: 25px 0;
    }
    .img-box dl{
        float: left;
        width: 49%;
    }
    .img-box dl:first-child{
        margin-right: 2%;
    }
    .img-box dt{
        padding: 0 10px 20px;
    }
}

/*--Small screens--*/
@media only screen and (max-width: 40em){
    .img-box{
        margin:20px 0;
    }
    .img-box dl{
        margin-bottom: 20px;
    }
    .img-box dl:last-child{
        margin-bottom: 0;
    }
    .img-box dt{
        padding-bottom: 15px;
    }
}

/*--Medium screens--*/
@media only screen and (min-width: 40.063em) and (max-width: 64em) {
    .img-box dl{
        float: none;
        width: 100%;
        margin-bottom: 25px;
    }
}

/*-----------------------------------
table
-----------------------------------*/
/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    table{
        margin: 25px 0;
    }
}

/*--Small screens--*/
@media only screen and (max-width: 40em){
    table{
        margin: 20px 0;
    }
}

/*-----------------------------------
arrow
-----------------------------------*/
.box li span,
.one-box li span,
.list li span{
    color: #3d8d8b;
    font-weight: bold;
}
li .arrow{
    padding-left: 20px;
    background: url(/static/image/icon/arrow02.png) 0 5px no-repeat;
    -webkit-background-size: 15px 14px;
    -moz-background-size: 15px 14px;
    -o-background-size: 15px 14px;
    -ms-background-size: 15px 14px;
    background-size: 15px 14px;
    font-size: 95%;
}

/*-----------------------------------
picture
-----------------------------------*/
.picture{
    text-align: center;
}
.picture dt{
    margin-bottom: 15px;
    font-weight: bold;
}

/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    .picture{
        margin: 25px 0;
    }
}


/*-----------------------------------
show
-----------------------------------*/
/*--Small screens--*/
@media only screen and (max-width: 40em){
    .picture{
        margin: 20px 0;
    }
}

/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    .for-sp{
        display: none;
    }
}
/*--Small screens--*/
@media only screen and (max-width: 40em){
    .for-pc{
        display: none;
    }
}

/*-----------------------------------
top-nav
-----------------------------------*/
.top-nav li a{
    position: relative;
    background-color: #f7f7f7;
}
.top-nav li a:after{
    content:"";
    display: block;
    width: 8px;
    height: 8px;
    border-top: 2px solid #666;
    border-right: 2px solid #666;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 37%;
}
.top-nav li a,.top-nav li a:hover,.top-nav li a:visited{
    color: #333;
    text-decoration: none;
}
.top-nav li a:hover{
    background-color: #9EDDDE;
}

/*--Large screens--*/
@media print, screen and (min-width: 40.063em){
    .top-nav{
        margin-bottom: 25px;
    }
    .top-nav li{
        float: left;
        margin: 0 10px 10px 0;
        font-size: 90%;
    }
    .top-nav li:last-child{
        margin-right: 0;
    }
    .top-nav li a{
        display: block;
        padding: 8px 15px 8px 28px;
        border-radius: 5px;
        -webkit-border-radius: 5px;
        -moz-border-radius: 5px;
    }
    .top-nav li a:after{
        left: 13px;
    }
}

/*--Small screens--*/
@media only screen and (max-width: 40em){
    .top-nav{
        margin-bottom: 20px;
    }
    .top-nav ul{
        border: 1px solid #333;
        border-radius: 5px;
        -webkit-border-radius: 5px;
        -moz-border-radius: 5px;  
    }
    .top-nav li{
        font-size: 85%;
        border-bottom: 1px solid #333;
    }
    .top-nav li:last-child{
        border-bottom: none;
    }
    .top-nav li:first-child a{
        border-radius: 5px 5px 0 0;
        -webkit-border-radius: 5px 5px 0 0;
        -moz-border-radius: 5px 5px 0 0;  
    }
    .top-nav li:last-child a{
        border-radius: 0 0 5px 5px;
        -webkit-border-radius: 0 0 5px 5px;
        -moz-border-radius: 0 0 5px 5px;
    }
    .top-nav li a{
        display: block;
        padding: 6px 10px 6px 25px;
    }
    .top-nav li a:after{
        left: 10px;
    }
}

/*-----------------------------------
clear
-----------------------------------*/
.box,
.one-box,
.img-box
{
    display: block;
    min-height: 1%;
}
.box:after,
.one-box:after,
.img-box:after
{
    clear: both;
    content:".";
    display: block;
    height: 0;
    visibility: hidden;
}