@charset 'UTF-8';
body
{
    background: #f4f5f8;
}
body img
{
    -webkit-backface-visibility: hidden;
}

.hide
{
    display: none;
}

.header
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    height: 40px;

    background: #fff; 

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
.header-inner
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    width: calc(100% - 30px);
    max-width: 980px;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.header-title
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    text-decoration: none;

    color: #2e3136; 

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.header-title img
{
    margin-right: 4px;
}
.header-title p
{
    font-size: 14px; 

    margin-top: 0;
}
.header-support
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.header-link
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    margin-right: 2px; 

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.header-link a
{
    font-size: 12px;

    position: relative;

    display: block;

    margin-right: 18px;
    padding-left: 15px; 

    text-decoration: none;

    color: #039;
}
.header-link a::before
{
    position: absolute;
    top: 50%;
    left: 0;

    display: block;

    width: 0;
    height: 0;

    content: '';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);

    border-width: 4.5px 0 4.5px 6px;
    border-style: solid;
    border-color: transparent transparent transparent #818796;
}
.header-link a.anchor_link::before
{
    border-width: 6px 4.5px 0 4.5px;
    border-color: #818796 transparent transparent transparent;
}
.header-fontsize
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    padding-left: 20px;

    border-left: 1px solid #bbbfc9; 

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.header-fontsize dt
{
    font-size: 12px;

    margin-right: 10px;

    color: #2e3136;
}
.header-fontsize dd
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.header-fontsize dd a
{
    font-size: 12px;

    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    width: 48px;
    height: 22px;

    text-align: center;
    text-decoration: none; 

    color: #039;
    border: 1px solid #707070;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
.header-fontsize dd a:nth-child(1)
{
    border-right: 0; 
    border-radius: 11px 0 0 11px;
}
.header-fontsize dd a:nth-child(3)
{
    border-left: 0; 
    border-radius: 0 11px 11px 0;
}
.header-fontsize dd a.active
{
    color: #fff; 
    background: #707070;
}

.visual
{
    -webkit-box-sizing: border-box;
            box-sizing: border-box; 
    padding: 50px 15px 110px;

    background: url('../img/visual_pc.png');
    background-size: cover;
}
.visual-inner
{
    width: 100%;
    max-width: 980px;
    margin: 0 auto;
}
.visual-title
{
    padding-bottom: 24px;
}
.visual-title span
{
    font-size: 2.4em;
    font-weight: bold; 

    display: inline-block;

    margin-bottom: 8px;
    padding: 0 4px;

    color: #fff;
    background: #039;
}
.visual-text
{
    font-size: 1em;
    line-height: 1.8; 

    margin-top: 0;

    color: #fff;
    color: #fff;
    text-shadow: 0 0 10px rgba(0, 51, 153, .8);
}
.visual-text span
{
    display: inline-block;

    margin-bottom: 4px; 
    padding: 0 4px;

    color: #fff;
    background: #039;
}

.index
{
    padding: 0 15px;
}
.index-wrapper
{
    position: relative;

    width: 100%;
    max-width: 980px;
    margin: -60px auto 100px;

    background: #fff;
    -webkit-box-shadow: 0 0 50px rgba(0, 0, 0, .3);
            box-shadow: 0 0 50px rgba(0, 0, 0, .3);
}
.index-tab
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    height: 60px;
}
.index-tab li
{
    font-size: 1.2em;

    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    width: 50%;

    cursor: pointer;

    color: #fff; 
    background: transparent -webkit-gradient(linear, left top, left bottom, from(#0650cb), to(#032866)) 0 0 no-repeat;
    background: transparent linear-gradient(180deg, #0650cb 0%, #032866 100%) 0 0 no-repeat;


    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
.index-tab li.active
{
    cursor: default; 

    color: #2e3136;
    background: #fff;
}
.index-tab li.b{	border-right:0.5px solid #FFF;border-left:0.5px solid #FFF;}
.index-list
{
    display: none; 

    padding: 40px 30px 10px;
}
.index-list.active
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
}
.index-list li
{
    width: calc((100% - 58px) / 3); 
    margin-right: 29px;
    margin-bottom: 30px;
}
.index-list li:nth-child(3n)
{
    margin-right: 0;
}
.index-list li img
{
    display: block;

    width: 100%;
    height: auto;

    border-radius: 5px 5px 0 0;
}
.index-list li .trigger
{
    font-size: 1.1em;

    position: relative;

    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    width: 100%;
    padding: 6px 6px 6px 38px;

    -webkit-transition: .3s background ease;
            transition: .3s background ease; 
    text-decoration: none;

    color: #fff;
    background: transparent -webkit-gradient(linear, left top, left bottom, from(#0650cb), to(#032866)) 0 0 no-repeat;
    background: transparent linear-gradient(180deg, #0650cb 0%, #032866 100%) 0 0 no-repeat;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.index-list li .trigger::before
{
    position: absolute;
    top: 50%;
    left: 10px;

    width: 20px;
    height: 20px;

    content: '';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%); 

    border-radius: 100%;
    background: #fff;
}
.index-list li .trigger::after
{
    position: absolute;
    top: 50%;
    left: 18px; 

    display: block;

    width: 0;
    height: 0;

    content: '';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);

    border-width: 4px 0 4px 6px;
    border-style: solid;
    border-color: transparent transparent transparent #0650cb;
}
.index-list li .trigger svg
{
    display: inline;

    width: 10px;
    height: 10px;
    margin-left: 4px; 

    fill: #fff;
    fill-rule: evenodd;
}
.index-list li .box
{
    padding: 15px 10px;

    border: 1px solid #bbbfca;
    border-radius: 0 0 5px 5px;
}
.index-list li .box .source
{
    font-size: .9em;
    font-weight: bold; 

    margin-top: 0;
}
.index-list li .box .link
{
    font-size: .9em;

    position: relative;

    display: inline-block;

    padding-left: 8px; 

    -webkit-transition: .3s color ease;
            transition: .3s color ease;

    color: #039;
}
.index-list li .box .link::after
{
    position: absolute;
    top: 50%;
    left: 0; 

    display: block;

    width: 0;
    height: 0;

    content: '';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);

    border-width: 4.5px 0 4.5px 6px;
    border-style: solid;
    border-color: transparent transparent transparent #818796;
}
.index-list li .box .link:hover
{
    text-decoration: none;
}
.index-list li .box .data
{
    margin-top: 0;
}
.index-list li .box .data span
{
    font-size: .9em; 

    display: block;

    margin-left: 1em;
    padding-left: 1em;

    text-indent: -1em;
}
.index-list li .box .data span:nth-child(2)
{
    margin-left: 2em;
    padding-left: 1em;

    text-indent: -1em;
}
.index-list li .box .data span:nth-child(3)
{
    margin-left: 3em;
    padding-left: 1em;

    text-indent: -1em;
}
.index-list li .box .data span:nth-child(4)
{
    margin-left: 3em;
    padding-left: 1em;

    text-indent: -1em;
}
.index-list li .nobox{
	border:none !important;
}

.pagetop
{
    font-size: 1em;

    position: relative;

    display: block;

    padding: 8px 15px 8px 36px;

    text-decoration: none;

    border-radius: 5px 5px 0 0; 
    background: #fff;
}
.pagetop:before
{
    position: absolute;
    top: 50%;
    left: 15px;

    display: block;

    width: 0;
    height: 0;

    content: '';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%); 

    border-width: 0 6.5px 9px 6.5px;
    border-style: solid;
    border-color: transparent transparent #039 transparent;
}
.pagetop-wrapper
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    max-width: 980px;
    margin: 0 auto;
    padding: 0 15px;

    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

.footer
{
    padding: 15px 15px 20px; 

    background: #fff;
}
.footer-inner
{
    max-width: 980px;
    margin: 0 auto;
}
.footer-project
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    margin-bottom: 24px; 

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.footer-project a
{
    display: block;

    width: 159px;
    height: 49px; 
    margin-right: 20px;
}
.footer-project img
{
    display: block; 

    width: 100%;
    height: auto;
}
.footer-project p
{
    font-size: 14px; 

    margin-top: 0;
}
.footer-link
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: start;
}
.footer-link li
{
    display: inline-block;
}
.footer-link a
{
    font-size: 12px;

    position: relative;

    display: block;

    margin-right: 20px;
    padding-left: 12px;

    text-decoration: none;
}
.footer-link a::after
{
    position: absolute;
    top: 50%;
    left: 0; 

    display: block;

    width: 0;
    height: 0;

    content: '';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);

    border-width: 4.5px 0 4.5px 6px;
    border-style: solid;
    border-color: transparent transparent transparent #818796;
}
.footer-link a:hover
{
    text-decoration: none;
}

.content-header
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    width: calc(100% - 30px);
    max-width: 980px;
    margin: 53px auto 22px; 

    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.content-header img
{
    margin-right: 20px;
}
.content-header h1
{
    font-size: 2em;
    font-weight: bold; 

    margin-top: 5px;

    color: #039;
}

.content-viewer
{
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    width: calc(100% - 30px);
    max-width: 980px;
    margin: 0 auto 100px;
    padding: 20px;

    background: #fff;
    -webkit-box-shadow: 0 0 50px rgba(0, 0, 0, .3);
            box-shadow: 0 0 50px rgba(0, 0, 0, .3);
}

.content-notes
{
    margin-top: 30px; 
    padding: 30px;

    background: #e6f1ff;
}
.content-notes p
{
    font-size: 14px; 

    position: relative;

    margin: 0;
    padding-left: 1em;
}
.content-notes p::before
{
    position: absolute;
    top: 0;
    left: 0;

    display: block; 

    content: '※';
}

.breadcrumb
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}
.breadcrumb.bottom
{
    width: calc(100% - 30px);
    max-width: 980px; 
    margin: 20px auto 60px;
}
.breadcrumb li
{
    font-size: .857em;

    margin-right: 24px; 

    color: #2e3136;
}
.breadcrumb a
{
    font-size: 1em;

    position: relative;

    display: block; 

    text-decoration: underline;

    color: #039;
}
.breadcrumb a::after
{
    font-size: .8em;

    position: absolute;
    top: 50%;
    right: -14px;

    display: block;

    content: '>';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%); 

    color: #6f737f;
}
.breadcrumb a:hover
{
    text-decoration: none;
}

.riyounoshikata
{
    width: calc(100% - 30px);
    max-width: 980px;
    margin: 0 auto 20px;
    padding: 20px; 

    background: #fff;
    -webkit-box-shadow: 0 0 50px rgba(0, 0, 0, .3);
            box-shadow: 0 0 50px rgba(0, 0, 0, .3);
}
.riyounoshikata li
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    margin-bottom: 50px; 

    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.riyounoshikata-image
{
    width: 49.77528%;
    max-width: 443px;

    -ms-flex-negative: 0;
    flex-shrink: 0;
}
.riyounoshikata-image img
{
    width: 100%;
    height: auto;
}
.riyounoshikata-text
{
    width: 48.98876%;
    padding-top: 32px; 

    -ms-flex-negative: 0;
    flex-shrink: 0;
}
.riyounoshikata-text h2
{
    font-size: 1.714em;

    margin-bottom: 24px;
    padding-bottom: 8px;

    color: #2e3136;
    border-bottom: 2px solid #039;
}
.riyounoshikata-text p
{
    font-size: 1em;

    margin: 0 0 1em 0; 

    color: #2e3136;
}

.pc_img,
.pc_view
{
    display: block;
}

.sp_img,
.sp_view
{
    display: none;
}

@media screen and (max-width: 767px)
{
    .pc_img,
    .pc_view
    {
        display: none;
    }
    .sp_img,
    .sp_view
    {
        display: block;
    }
    .header
    {
        height: 45px;
        padding: 0 15px;
    }
    .header-title img
    {
        width: 73px;
        height: auto; 
        margin-right: 3px;
    }
    .header-title p
    {
        font-size: 12px;
    }
    .header-link
    {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;

        margin-right: 2px; 

        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }
    .header-link a
    {
        font-size: 12px;

        position: relative; 

        display: block;

        margin-right: 0;

        text-decoration: none;

        color: #039;
    }
    .header-link a.anchor_link
    {
        display: none;
    }
    .header-fontsize
    {
        display: none;
    }
    .visual
    {
        padding: 45px 15px 120px; 

        background: url('../img/visual_sp.png');
        background-size: cover;
    }
    .visual-title
    {
        padding-bottom: 30px;
    }
    .visual-title span
    {
        font-size: 30px; 

        display: inline-block;

        margin-bottom: 6px;
        padding: 0 4px;
    }
    .visual-text
    {
        font-size: 13px;
        line-height: 2;
    }
    .visual-text span
    {
        font-size: 13px;
    }
    .index
    {
        padding: 0 15px;
    }
    .index-wrapper
    {
        margin: -70px auto 100px;
    }
    .index-tab
    {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;

        height: 45px;
    }
    .index-tab li
    {
        font-size: 12px;
    }
    .index-list
    {
        padding: 25px 15px 10px;
    }
    .index-list li
    {
        width: 100%; 
        margin-right: 0;
    }
    .index-list li .trigger
    {
        font-size: 16px; 

        padding: 7px 8px 7px 47px;
    }
    .index-list li .trigger::before
    {
        left: 12px; 

        width: 25px;
        height: 25px;

        content: '';
    }
    .index-list li .trigger::after
    {
        top: 50%;
        left: 22px; 

        border-width: 5px 0 5px 7px;
    }
    .index-list li .box
    {
        padding: 14px 10px 4px;

        border: 1px solid #bbbfca;
        border-radius: 0 0 5px 5px;
    }
    .index-list li .box .source
    {
        font-size: 14px;

        position: relative;

        margin-bottom: 10px;
    }
    .index-list li .box .source::before
    {
        position: absolute;
        top: 50%;
        right: 5px;

        display: block;

        width: 0;
        height: 0;

        content: '';
        -webkit-transform: translateY(-50%);
                transform: translateY(-50%);

        border-width: 10px 7.5px 0 7.5px;
        border-style: solid;
        border-color: #818796 transparent transparent transparent;
    }
    .index-list li .box .source.active::before
    {
        border-width: 0 7.5px 10px 7.5px;
        border-color: transparent transparent #818796 transparent;
    }
    .index-list li .box .text
    {
        display: none;

        margin-top: 10px; 
        padding-top: 10px;

        border-top: 1px solid #bbbfca;
    }
    .index-list li .box .link
    {
        font-size: .9em;

        -webkit-transition: .3s color ease;
                transition: .3s color ease;
    }
    .index-list li .box .data
    {
        margin-top: 0;
        margin-bottom: 10px;
    }
    .index-list li .box .data span
    {
        font-size: .9em; 

        display: block;

        margin-left: 1em;
        padding-left: 1em;

        text-indent: -1em;
    }
    .index-list li .box .data span:nth-child(2)
    {
        margin-left: 2em;
        padding-left: 1em;

        text-indent: -1em;
    }
    .index-list li .box .data span:nth-child(3)
    {
        margin-left: 3em;
        padding-left: 1em;

        text-indent: -1em;
    }
    .index-list li .box .data span:nth-child(4)
    {
        margin-left: 3em;
        padding-left: 1em;

        text-indent: -1em;
    }
    .pagetop
    {
        font-size: 1em;

        position: relative;

        display: block;

        padding: 8px 15px 8px 36px;

        text-decoration: none;

        border-radius: 5px 5px 0 0; 
        background: #fff;
    }
    .pagetop:before
    {
        position: absolute;
        top: 50%;
        left: 15px;

        display: block;

        width: 0;
        height: 0;

        content: '';
        -webkit-transform: translateY(-50%);
                transform: translateY(-50%); 

        border-width: 0 6.5px 9px 6.5px;
        border-style: solid;
        border-color: transparent transparent #039 transparent;
    }
    .pagetop-wrapper
    {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;

        max-width: 980px;
        margin: 0 auto;
        padding: 0 24px;

        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
    }
    .footer
    {
        padding: 15px 24px 20px; 

        background: #fff;
    }
    .footer-inner
    {
        max-width: 980px;
        margin: 0 auto;
    }
    .footer-project
    {
        display: block;

        margin-bottom: 24px; 

        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }
    .footer-project img
    {
        display: block;

        margin: 0 auto 10px;
    }
    .footer-project p
    {
        margin-top: 0;

        text-align: center;
    }
    .footer-link li
    {
        width: 50%; 
        margin-bottom: 20px;
    }
    .footer-link a
    {
        font-size: 11px; 

        margin-right: 0;
    }
    .content-header
    {
        width: calc(100% - 15px);
        margin: 30px auto 25px;
    }
    .content-header img
    {
        display: block;

        width: 41px;
        height: auto;
        margin-right: 15px;
    }
    .content-header h1
    {
        font-size: 19px;
        line-height: 1;

        margin-top: 6px;
    }
    .content-notes
    {
        margin-top: 12px; 
        padding: 12px;
    }
    .content-notes p
    {
        font-size: 12px;
    }
    .breadcrumb
    {
        margin-top: 0;
    }
    .breadcrumb.bottom
    {
        width: calc(100% - 30px);
        max-width: 980px; 
        margin: 20px auto 60px;
    }
    .breadcrumb li
    {
        font-size: 10px;
    }
    .breadcrumb a
    {
        font-size: 10px;
    }
    .breadcrumb a::after
    {
        font-size: 10px;
    }
    .riyounoshikata
    {
        width: calc(100% - 15px);
        padding: 20px 15px; 

        -webkit-box-shadow: 0 0 25px rgba(0, 0, 0, .3);
                box-shadow: 0 0 25px rgba(0, 0, 0, .3);
    }
    .riyounoshikata li
    {
        display: block;

        margin-bottom: 40px;
    }
    .riyounoshikata li:nth-last-child(1)
    {
        margin-bottom: 0;
    }
    .riyounoshikata li.pc_view
    {
        display: none;
    }
    .riyounoshikata-image
    {
        width: 100%;
        max-width: 100%;
        margin-bottom: 20px;
    }
    .riyounoshikata-text
    {
        width: 100%;
        padding-top: 0;
    }
    .riyounoshikata-text h2
    {
        font-size: 18px; 

        margin-bottom: 15px;
        padding-bottom: 8px;
    }
    .riyounoshikata-text p
    {
        font-size: 12px;
    }
    .riyounoshikata-text p:nth-last-child(1)
    {
        margin-bottom: 0;
    }
}
