@charset "utf-8";

/* common
------------------------------------------------------------------------------------------------------------- */

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

html,
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
textarea,
p,
blockquote,
th,
td {
    margin: 0;
    padding: 0;
}

html,
body {
    width: 100%;
}

html {
    font-size: 62.5%;
    -webkit-tap-highlight-color: rgba(148, 34, 67, 0.1);
    -webkit-font-smoothing: antialiased;
    height: 100%;
}

body {
    font-family: verdana, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 1;
    color: #202020;
    background: #ffffff;
    min-height: 100%;
}

body.oldie {
    min-width: 1200px;
}

table {
    /* border-collapse: collapse; */
    border-spacing: 0;
    empty-cells: show;
}

img {
    vertical-align: bottom;
    height: auto;
    line-height: 1;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: 10px;
    font-size: 1.0rem;
}

ol,
ul {
    list-style-type: none;
}

table {
    text-align: left;
}

input,
select,
textarea {
    font-family: verdana, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    font-size: 1.6rem;
}

a,
a:link,
a:visited {
    color: #307294;
    text-decoration: none;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

.no_link {
    color: #307294;
}

a:hover,
a:active {
    color: #c90915;
    text-decoration: none;
}

.disnon {
    display: none !important;
}

.spOnly {
    display: none !important;
}

.pcOnly {
    display: block !important;
}

@media only screen and (max-width: 768px) {
    .spOnly {
        display: block !important;
    }

    .pcOnly {
        display: none !important;
    }
}


/*.svg{
display: block;
width: 100%;
height: auto;
}*/

a {
    color: #202020;
}


/* clearfix
------------------------------------------------------------------------------------------------------------- */

.cf:after {
    /*for modern browser*/
    content: " ";
    display: block;
    height: 0;
    clear: both;
    line-height: 0;
    visibility: hidden;
}

.cf {
    zoom: 1;
    /*for IE 5.5-7*/
}


/* fade
------------------------------------------------------------------------------------------------------------- */

.fade {
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

.fade:hover {
    opacity: 0.6;
    filter: alpha(opacity=60);
}


/* icon font
------------------------------------------------------------------------------------------------------------- */

@font-face {
    font-family: 'iconfont';
    src: url('../font/fontello.eot?61044763');
    src: url('../font/fontello.eot?61044763#iefix') format('embedded-opentype'), url('../font/fontello.woff?61044763') format('woff'), url('../font/fontello.ttf?61044763') format('truetype'), url('../font/fontello.svg?61044763#fontello') format('svg');
    font-weight: normal;
    font-style: normal;
}


/* txt
------------------------------------------------------------------------------------------------------------- */

.txtC {
    text-align: center !important;
}

.txtR {
    text-align: right !important;
}

.txtL {
    text-align: left !important;
}

.fs08 {
    font-size: 8px;
    font-size: 0.8rem !important;
}


/*renders 9px */

.fs09 {
    font-size: 9px;
    font-size: 0.9rem !important;
}


/*renders 9px */

.fs10 {
    font-size: 10px;
    font-size: 1rem !important;
}


/*renders 10px */

.fs11 {
    font-size: 11px;
    font-size: 1.1rem !important;
}


/*renders 11px */

.fs12 {
    font-size: 12px;
    font-size: 1.2rem !important;
}


/*renders 12px */

.fs13 {
    font-size: 13px;
    font-size: 1.3rem !important;
}


/*renders 13px */

.fs14 {
    font-size: 14px;
    font-size: 1.4rem !important;
}


/*renders 14px */

.fs15 {
    font-size: 15px;
    font-size: 1.5rem !important;
}


/*renders 15px */

.fs16 {
    font-size: 16px;
    font-size: 1.6rem !important;
}


/*renders 16px */

.fs17 {
    font-size: 17px;
    font-size: 1.7rem !important;
}


/*renders 17px */

.fs18 {
    font-size: 18px;
    font-size: 1.8rem !important;
}


/*renders 18px */

.fs19 {
    font-size: 19px;
    font-size: 1.9rem !important;
}


/*renders 19px */

.fs20 {
    font-size: 20px;
    font-size: 2rem !important;
}


/*renders 20px */

.fs21 {
    font-size: 21px;
    font-size: 2.1rem !important;
}


/*renders 21px */

.fs22 {
    font-size: 22px;
    font-size: 2.2rem !important;
}


/*renders 22px */

.fs23 {
    font-size: 23px;
    font-size: 2.3rem !important;
}


/*renders 23px */

.fs24 {
    font-size: 24px;
    font-size: 2.4rem !important;
}


/*renders 24px */

.fs25 {
    font-size: 25px;
    font-size: 2.5rem !important;
}


/*renders 25px */

.fs26 {
    font-size: 26px;
    font-size: 2.6rem !important;
}


/*renders 26px */

em {
    font-weight: bold;
    font-style: normal;
}

strong {
    text-decoration: underline;
    font-weight: normal;
}


/* margin
------------------------------------------------------------------------------------------------------------- */

.m0 {
    margin: 0 !important;
}

.m10 {
    margin: 10px !important;
}

.m20 {
    margin: 20px !important;
}

.m30 {
    margin: 30px !important;
}

.m40 {
    margin: 40px !important;
}

.m50 {
    margin: 50px !important;
}

.ml10 {
    margin-left: 10px !important;
}

.ml20 {
    margin-left: 20px !important;
}

.ml30 {
    margin-left: 30px !important;
}

.ml40 {
    margin-left: 40px !important;
}

.ml50 {
    margin-left: 50px !important;
}

.mr10 {
    margin-right: 10px !important;
}

.mr20 {
    margin-right: 20px !important;
}

.mr30 {
    margin-right: 30px !important;
}

.mr40 {
    margin-right: 40px !important;
}

.mr50 {
    margin-right: 50px !important;
}

.mt10 {
    margin-top: 10px !important;
}

.mt20 {
    margin-top: 20px !important;
}

.mt30 {
    margin-top: 30px !important;
}

.mt40 {
    margin-top: 40px !important;
}

.mt50 {
    margin-top: 50px !important;
}

.mb10 {
    margin-bottom: 10px !important;
}

.mb20 {
    margin-bottom: 20px !important;
}

.mb30 {
    margin-bottom: 30px !important;
}

.mb40 {
    margin-bottom: 40px !important;
}

.mb50 {
    margin-bottom: 50px !important;
}

.mlr10 {
    margin-left: 10px !important;
    margin-right: 10px !important;
}

.mlr20 {
    margin-left: 20px !important;
    margin-right: 20px !important;
}

.mlr30 {
    margin-left: 30px !important;
    margin-right: 30px !important;
}

.mlr40 {
    margin-left: 40px !important;
    margin-right: 40px !important;
}

.mlr50 {
    margin-left: 50px !important;
    margin-right: 50px !important;
}

.mtb10 {
    margin-top: 10px !important;
    margin-bottom: 10px !important;
}

.mtb20 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
}

.mtb30 {
    margin-top: 30px !important;
    margin-bottom: 30px !important;
}

.mtb40 {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
}

.mtb50 {
    margin-top: 50px !important;
    margin-bottom: 50px !important;
}


/* padding
------------------------------------------------------------------------------------------------------------- */

.p10 {
    padding: 10px !important;
}

.p20 {
    padding: 20px !important;
}

.p30 {
    padding: 30px !important;
}

.p40 {
    padding: 40px !important;
}

.p50 {
    padding: 50px !important;
}

.pl10 {
    padding-left: 10px !important;
}

.pl20 {
    padding-left: 20px !important;
}

.pl30 {
    padding-left: 30px !important;
}

.pl40 {
    padding-left: 40px !important;
}

.pl50 {
    padding-left: 50px !important;
}

.pr10 {
    padding-right: 10px !important;
}

.pr20 {
    padding-right: 20px !important;
}

.pr30 {
    padding-right: 30px !important;
}

.pr40 {
    padding-right: 40px !important;
}

.pr50 {
    padding-right: 50px !important;
}

.pt10 {
    padding-top: 10px !important;
}

.pt20 {
    padding-top: 20px !important;
}

.pt30 {
    padding-top: 30px !important;
}

.pt40 {
    padding-top: 40px !important;
}

.pt50 {
    padding-top: 50px !important;
}

.pb10 {
    padding-bottom: 10px !important;
}

.pb20 {
    padding-bottom: 20px !important;
}

.pb30 {
    padding-bottom: 30px !important;
}

.pb40 {
    padding-bottom: 40px !important;
}

.pb50 {
    padding-bottom: 50px !important;
}

.plr10 {
    padding-left: 10px !important;
    padding-right: 10px !important;
}

.plr20 {
    padding-left: 20px !important;
    padding-right: 20px !important;
}

.plr30 {
    padding-left: 30px !important;
    padding-right: 30px !important;
}

.plr40 {
    padding-left: 40px !important;
    padding-right: 40px !important;
}

.plr50 {
    padding-left: 50px !important;
    padding-right: 50px !important;
}

.ptb10 {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
}

.ptb20 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
}

.ptb30 {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
}

.ptb40 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
}

.ptb50 {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
}


/* Line-Height
--------------------------------------------------------------------------------------------------------------*/

.lh10 {
    line-height: 10px !important;
}

.lh11 {
    line-height: 11px !important;
}

.lh12 {
    line-height: 12px !important;
}

.lh13 {
    line-height: 13px !important;
}

.lh14 {
    line-height: 14px !important;
}

.lh15 {
    line-height: 15px !important;
}

.lh16 {
    line-height: 16px !important;
}

.lh17 {
    line-height: 17px !important;
}

.lh18 {
    line-height: 18px !important;
}

.lh19 {
    line-height: 19px !important;
}

.lh20 {
    line-height: 20px !important;
}

.lh21 {
    line-height: 21px !important;
}

.lh22 {
    line-height: 22px !important;
}


/*  テキストインデント（段落最初の字下げ）
--------------------------------------------------------------------------------------------------------------*/

.tion {
    text-indent: 1em !important;
}


/* container
------------------------------------------------------------------------------------------------------------- */

#container {
    position: relative;
    width: 100%;
    min-width: 990px;
    height: 100%;
}

@media only screen and (max-width: 768px) {
    #container {
        min-width: 0;
    }
}


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

#header {
    width: 100%;
    min-width: 990px;
    padding: 30px 0 20px;
    background-color: #fff;
}

#headerWrap {
    width: 950px;
    margin: 0 auto;
    position: relative;
    letter-spacing: -.4em;
}

#logo a {
    display: inline-block;
    overflow: hidden;
    vertical-align: middle;
    letter-spacing: normal;
    text-indent: 150%;
    white-space: nowrap;
}

#logoTtl {
    width: 116px;
    height: 100px;
    margin-right: 20px;
    background: url(../img/common/logo.png) no-repeat left top;
}

#logoTxt {
    width: 296px;
    height: 70px;
    background: url(../img/common/logo_txt.png) no-repeat left top;
}

#headerNavPc,
#headerNavSp {
    width: 420px;
    position: absolute;
    top: -40px;
    right: 0;
    letter-spacing: -.4em;
    text-align: right;
}

#headerNavPc li,
#headerNavSp li {
    display: inline-block;
    position: relative;
    vertical-align: top;
    letter-spacing: normal;
    font-size: 14px;
    font-size: 1.4rem;
}

#headerNavPc li a,
#headerNavSp li a {
    padding: 20px 18px 20px 46px;
    background-color: #161616;
    display: inline-block;
    position: relative;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    color: #fff;
    text-decoration: none;
}

#headerNavPc li a:hover,
#headerNavSp li a:hover {
    background-color: #c90915;
}

#headerNavPc a:before,
#headerNavSp a:before {
    font-family: "iconfont";
    margin-right: 10px;
    position: absolute;
    top: 16px;
    left: 18px;
    -webkit-transition: 0.2s ease;
    -moz-transition: 0.2s ease;
    -o-transition: 0.2s ease;
    transition: 0.2s ease;
    color: #fff;
    font-size: 18px;
    font-size: 1.8rem;
}

#headerNavPc a:hover:before,
#headerNavPc a:focus:before,
#headerNavPc a:active:before,
#headerNavSp a:hover:before,
#headerNavSp a:focus:before,
#headerNavSp a:active:before {
    -webkit-transform: scale(1.3) rotate(12deg);
    transform: scale(1.3) rotate(12deg);
}

.headerHome a:before {
    content: "\e800";
}

.headerMember a:before {
    content: "\e801";
}

.headerContact a:before {
    content: "\e802";
}

@media only screen and (-webkit-min-device-pixel-ratio: 2),
only screen and (min-device-pixel-ratio: 2) {
    #logoTtl {
        background: url(../img/common/logo@2x.png) no-repeat left top;
        background-size: 116px 100px;
    }

    #logoTxt {
        background: url(../img/common/logo_txt@2x.png) no-repeat left top;
        background-size: 296px 70px;
    }
}

@media only screen and (max-width: 768px) {
    #header {
        width: 100%;
        height: 55px;
        z-index: 9998;
        min-width: 0;
        max-width: 768px;
        padding: 0;
    }

    #headerWrap {
        width: 100%;
        display: table;
    }

    #logo {
        width: 55%;
        padding-top: 10px;
        padding-left: 4px;
        display: table-cell;
        vertical-align: top;
    }

    #logoTtl {
        width: 45px;
        height: 39px;
        margin-right: 3px;
        background: url(../img/common/logo.png) no-repeat left top;
        background-size: 45px 39px;
    }

    #logoTxt {
        width: 99px;
        height: 31px;
        background: url(../img/common/logo_txt_sp.png) no-repeat left top;
        background-size: 99px 31px;
    }

    #headerNavSp {
        width: 45%;
        height: 55px;
        position: relative;
        top: 0;
        vertical-align: top;
        text-align: right;
    }

    #headerNavSp {
        display: table-cell !important;
    }

    #headerNavSp ul {
        display: table;
        position: absolute;
        top: 0;
        right: 0;
    }

    #headerNavSp li {
        width: 51px;
        height: 55px;
        display: table-cell;
        vertical-align: top;
    }

    #headerNavSp li a {
        width: 51px;
        height: 55px;
        padding: 20px 3px 6px;
        border-left: 1px solid #404040;
        font-size: 10px;
        font-size: 1.0rem;
    }

    #headerNavSp ul li:first-child a {
        border-left: 0;
    }

    #headerNavSp li a:hover {
        background-color: #161616;
    }

    #headerNavSp a:before {
        width: 100%;
        margin-right: 0;
        top: 10px;
        left: 0;
        text-align: center;
    }

    #headerNavSp a img {
        margin: 18px auto 0;
        display: block;
    }

    .headerMenu {
        display: inline-block !important;
    }

    #header.open .headerMenu a {
        background-color: #c90915;
    }

    .headerMenu a:before {
        content: "\e808";
    }

    .headerMenu a img {
        margin-top: 19px;
    }

    #headerNavSp a:hover:before,
    #headerNavSp a:focus:before,
    #headerNavSp a:active:before {
        -webkit-transform: scale(1) rotate(0deg);
        transform: scale(1) rotate(0deg);
    }
}

@media only screen and (max-width:414px) {
    //JS　ブレイクポイント用設定
    /*header{
    max-width:414px;
    }*/
}


/* nav
------------------------------------------------------------------------------------------------------------- */

#gnav {
    width: 100%;
    min-width: 990px;
    height: 78px;
    background-color: rgba(22, 22, 22, 0.5);
    position: relative;
    z-index: 9999;
}

#gnav ul {
    width: 950px;
    margin: 0 auto;
    border-right: 1px solid #b4b4b4;
    display: table;
}

#gnav li {
    width: 20%;
    border-left: 1px solid #b4b4b4;
    display: table-cell;
}

#top #gnav ul {
    border-right: 1px solid #9fbcb9;
}

#top #gnav li {
    border-left: 1px solid #9fbcb9;
}

#gnav a {
    padding: 30px 5px;
    display: block;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    color: #fff;
    text-align: center;
    text-decoration: none;
}

#gnav a:hover {
    background-color: rgba(29, 38, 39, 0.8);
}

@media only screen and (max-width: 768px) {
    #gnav {
        min-width: 0;
        height: auto;
        background-color: #8a8a8a;
        display: none;
    }

    #gnav ul {
        width: 100%;
        border-right: none;
        display: block;
    }

    #gnav li {
        width: 100%;
        border-top: 1px solid #b4b4b4;
        border-left: none;
        display: block;
    }

    #gnav ul li:first-child {
        border-top: none;
    }

    #gnav a {
        padding: 15px 28px 15px 10px;
        display: block;
        position: relative;
        color: #fff;
        text-align: left;
        font-size: 16px;
        font-size: 1.6rem;
    }

    #gnav a:after {
        content: "";
        width: 8px;
        height: 12px;
        background: url(../img/common/arrow_icon_05.png) no-repeat left top;
        background-size: 8px 12px;
        display: block;
        position: absolute;
        top: 18px;
        right: 15px;
    }
}


/* contents
------------------------------------------------------------------------------------------------------------- */

#contents {
    width: 950px;
    min-width: 950px;
    margin: 0 auto;
}

#top #contents {
    width: 100%;
    overflow: visible;
}

@media only screen and (max-width: 768px) {
    #contents {
        width: 100%;
        min-width: 0;
    }
}


/* mainSec
------------------------------------------------------------------------------------------------------------- */

#mainSec {
    width: 670px;
    position: relative;
    z-index: 9999;
    float: right
}

@media only screen and (max-width: 768px) {
    #mainSec {
        width: 100%;
        min-width: 0;
        padding: 0 10px;
        float: none;
    }
}


/* contentsArea
------------------------------------------------------------------------------------------------------------- */

#contentsArea {
    position: relative;
    width: 100%;
    text-align: center;
}

#contentsArea.inPage {
    padding-top: 70px;
}

#contentsAreaWrap {
    position: relative;
    margin: 0 auto;
    padding: 70px 0 0 0;
    width: 1180px;
    height: 100%;
    text-align: left;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.8;
}

@media only screen and (max-width: 768px) {
    #contentsArea {
        position: relative;
        padding-left: 0;
        width: 100%;
        text-align: center;
    }
}


/* headTtl
------------------------------------------------------------------------------------------------------------- */

.headTtl01 {
    font-size: 26px;
    font-size: 2.6rem;
    padding: 10px 0px 10px 35px;
    position: relative;
    font-weight: normal;
}

.headTtl01:before {
    content: '';
    width: 23px;
    height: 25px;
    display: block;
    background: url(../img/common/head_icon_01.png) no-repeat left top;
    background-size: contain;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
}

.headTtl02 {
    font-size: 22px;
    font-size: 2.2rem;
    margin-top: 15px;
    padding: 10px 0 15px;
    border-bottom: 1px solid #c22520;
    font-weight: normal;
}

.headTtl02 .note {
    font-size: 14px;
    font-size: 1.4rem;
}

.headTtl03 {
    margin-top: 40px;
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: 400;
    line-height: 28px;
}

.contentsDetailSec h3.headTtl03 {
    color: darkred;
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold;
}

.headTtl04 {
    margin-top: 40px;
    font-size: 22px;
    font-size: 1.8rem;
    font-weight: bold;
}

h4 {
    display: block;
    font-size: 1em;
    font-weight: 600;
    padding: 15px 0 5px 0;
}

@media only screen and (max-width: 768px) {
    .headTtl01 {
        padding: 5px 0 3px 32px;
        font-size: 20px;
        font-size: 2.0rem;
    }

    .headTtl01:before {
        width: 24px;
        height: 26px;
        background-image: url(../img/common/head_icon_01_sp.png);
        background-size: 24px 26px;
    }

    .headTtl02 {
        padding: 10px 0;
        font-size: 18px;
        font-size: 1.8rem;
        line-height: 1.2;
    }

    .headTtl03 {
        font-size: 20px;
        font-size: 2.0rem;
        font-weight: 600;
    }
}


/* footer
------------------------------------------------------------------------------------------------------------- */

#footer {
    min-width: 990px;
    margin-top: 40px;
}

#footer a {
    color: #161616;
}

#top #footer {
    margin-top: 0;
}

#footerSec01 {
    width: 100%;
    min-width: 990px;
    padding: 10px 0 60px;
    background-color: #dcdcdc;
}

#footerSec01Wrap {
    width: 992px;
    margin: 0 auto;
    position: relative;
}

#footerSec01Nav > ul {
    overflow: hidden;
}

#footerSec01Nav .navSec {
    width: 33.333%;
    margin-top: 30px;
    padding: 0 21px 2px;
    float: left;
}

#footerSec01Nav .navSec dt a {
    padding: 18px 20px;
    border: 1px solid #161616;
    display: block;
    position: relative;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    text-decoration: none;
}

#footerSec01Nav .navSec dt a:hover {
    background-color: #161616;
    color: #fff;
}

#footerSec01Nav .navSec dt a:after {
    content: "";
    width: 7px;
    height: 10px;
    display: block;
    background: url(../img/common/arrow_icon_02.png) no-repeat left top;
    background-size: 7px 10px;
    position: absolute;
    top: 22px;
    right: 15px;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

#footerSec01Nav .navSec dt a:hover:after {
    background-image: url(../img/common/arrow_icon_04.png);
    right: 10px;
}

#footerSec01Nav .navSec dd {
    margin-left: 20px;
}

#footerSec01Nav .navSec dd li {
    margin-top: 15px;
}

#footerSec01Nav .navSec dd li:first-child {
    margin-top: 20px;
}

#footerSec01Nav .navSec dd a {
    padding-left: 18px;
    background: url(../img/common/arrow_icon_03.png) no-repeat 0 6px;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    font-size: 16px;
    font-size: 1.6rem;
}

#footerSec01Nav .navSec dd a:hover {
    color: #7b7b7b;
    text-decoration: none;
}

#footerSubNav {
    margin-top: 50px;
}

#footerSubNav ul {
    margin-left: 5px;
}

#footerSubNav li {
    display: inline-block;
    position: relative;
    vertical-align: top;
    letter-spacing: normal;
    font-size: 14px;
    font-size: 1.4rem;
}

#footerSubNav li a {
    padding: 5px 10px 5px 46px;
    display: inline-block;
    position: relative;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

#footerSubNav a:before {
    font-family: "iconfont";
    margin-right: 10px;
    position: absolute;
    top: 5px;
    left: 18px;
    -webkit-transition: 0.2s ease;
    -moz-transition: 0.2s ease;
    -o-transition: 0.2s ease;
    transition: 0.2s ease;
    color: #161616;
    font-size: 18px;
    font-size: 1.8rem;
}

#footerSubNav li a:hover {
    color: #7b7b7b;
    text-decoration: none;
}

#footerSubNav a:hover:before,
#footerSubNav a:focus:before,
#footerSubNav a:active:before {
    -webkit-transform: scale(1.3) rotate(12deg);
    transform: scale(1.3) rotate(12deg);
}

#footerMember a:before {
    content: "\e801";
}

#footerContact a:before {
    content: "\e802";
}

#pageTop {
    display: none;
    position: fixed;
    right: 18px;
    bottom: 40px;
    z-index: 99999;
}

#pageTop a {
    width: 60px;
    height: auto;
    padding: 60px 5px 15px;
    border: 2px solid #161616;
    display: block;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    font-size: 11px;
    font-size: 1.1rem;
    text-align: center;
    text-decoration: none;
}

#pageTop a:hover {
    background-color: #161616;
    color: #fff;
}

#pageTop a:before {
    font-family: "iconfont";
    content: "\e807";
    width: 100%;
    margin: 0 auto;
    display: block;
    position: absolute;
    left: 0;
    top: 10px;
    -webkit-transition: 0.2s ease;
    -moz-transition: 0.2s ease;
    -o-transition: 0.2s ease;
    transition: 0.2s ease;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    font-size: 45px;
    font-size: 4.5rem;
    text-align: center;
}

#pageTop a:hover:before,
#pageTop a:focus:before,
#pageTop a:active:before {
    top: 5px;
    color: #fff;
}

#footerSec02 {
    width: 100%;
    min-width: 950px;
    padding: 40px 0;
    background-color: #fff;
}

#footerSec02Wrap {
    width: 950px;
    margin: 0 auto;
    position: relative;
}

#footerSec02Wrap h3 {
    font-size: 1.1em;
    margin-bottom: 1em;
}


#footerSec02Link li {
    margin-left: 15px;
    display: inline-block;
    letter-spacing: normal;
}

#footerSec02Link ul li:first-child {
    margin-left: 0;
}

#footerSec02Link li a {
    padding: 6px 10px;
    border: 1px solid #161616;
    background-color: #fff;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    display: inline-block;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    font-size: 16px;
    font-size: 1.6rem;
    text-decoration: none;
}

#footerSec02Link li a:hover {
    background-color: #161616;
    color: #fff;
}


/* footer用著作権表示　*/

#copyright {
    margin-top: 40px;
    font-size: 14px;
    font-size: 1.4rem;
}

@media only screen and (max-width: 768px) {
    #footer {
        width: 100%;
        min-width: 0;
        margin-top: 0;
        position: relative;
    }

    #footerSec01 {
        min-width: 0;
        padding: 0;
        position: static;
    }

    #footerSec01Wrap {
        width: 100%;
        position: static;
    }

    #footerSec01Nav {
        border-top: 1px solid #161616;
        font-size: 15px;
        font-size: 1.5rem;
    }

    #footerSec01Nav .navSec {
        width: 50%;
        margin-top: 0;
        padding: 0;
    }

    #footerSec01Nav .navSec dt a {
        padding: 18px 20px 18px 10px;
        border-top: none;
        border-left: none;
    }

    #footerSec01Nav ul .navSec:nth-child(2n) dt a {
        border-right: none;
    }

    #footerSec01Nav .navSec dt a:after {
        top: 21px;
        right: 10px;
    }

    #footerSec01Nav .navSec dt a:hover:after {
        right: 5px;
    }

    /*
#pageTop {
        width: 80px;
        height: 80px;
        position: absolute;
        right: 0;
        bottom: 0;
        z-index: 10;
        background-color: #dcdcdc;
    }
    #pageTop a {
        width: 80px;
        height: 80px;
        padding: 53px 5px 15px;
        font-size: 10px;
        font-size: 1.0rem;
    }
    #pageTop a:before {
        top: 10px; 
}
*/
    #footerSec02 {
        min-width: 100%;
        padding: 30px 10px;
    }

    #footerSec02Wrap {
        width: 100%;
    }

    #footerSec02Link li {
        margin: 0 10px 10px 0;
        display: inline-block;
    }

    #footerSec02Link li a {
        font-size: 13px;
        font-size: 1.3rem;
    }

    #copyright {
        margin-top: 60px;
        font-size: 10px;
        font-size: 1.0rem;
    }

}


/* topicpath
------------------------------------------------------------------------------------------------------------- */

#topicPath {
    width: 950px;
    margin: 0 auto;
    padding: 20px 0 30px;
    font-size: 16px;
    font-size: 1.6rem;
}

#topicPath .topicPathItem {
    display: inline-block;
    margin-right: 25px;
    padding-right: 20px;
    position: relative;
}

#topicPath .linkItem a {
    color: #307294;
    display: block;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

#topicPath .linkItem a:hover {
    color: #c90915;
    text-decoration: none;
}

#topicPath .topicPathItem.linkItem:after {
    content: "＞";
    position: absolute;
    top: 0;
    bottom: 0;
    right: -12px;
    margin: auto;
}

#topicPath .topicPathItem.secondPath:after {
    content: "＞";
    position: absolute;
    top: 0;
    bottom: 0;
    right: -12px;
    margin: auto;
}

@media only screen and (max-width: 768px) {
    #topicPath {
        width: 100%;
        margin: 0 auto;
        padding: 20px 10px;
        font-size: 12px;
        font-size: 1.2rem;
    }

    #topicPath .topicPathItem {
        margin-right: 15px;
        margin-bottom: 10px;
        padding-right: 5px;
    }
}


/* sideNav
------------------------------------------------------------------------------------------------------------- */

#sideNav {
    width: 240px;
    margin-right: 40px;
    float: left;
}

#sideNav .sideNavInner {
    background: #f5f5f5;
    overflow: hidden;
}

#sideNav .sideNavInner > nav {
    padding-bottom: 10px;
}

#sideNav .sideNavTtl {
    padding: 20px 15px;
    background: #cc1824;
    color: #fff;
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: normal;
}

#sideNav .navWrap {
    padding: 10px 15px 5px;
}

#sideNav .navWrap .navLv01 a,
#sideNav .navWrap .navLv01 span {
    font-size: 16px;
    font-size: 1.6rem;
    padding: 18px 5px;
    position: relative;
    display: block;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    color: #202020;
    text-decoration: none;
    cursor: pointer;
}

#sideNav .navWrap .navLv01 a:after,
#sideNav .navWrap .navLv01 span:after {
    content: '';
    width: 7px;
    height: 10px;
    display: block;
    background: url(../img/common/arrow_icon_11.png) no-repeat left top;
    background-size: contain;
    position: absolute;
    right: 5px;
    top: 0;
    bottom: 0;
    margin: auto;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

#sideNav .navWrap .navLv01 a:hover,
#sideNav .navWrap .navLv01 span:hover {
    color: #cc1824;
}

#sideNav .navWrap .navLv01 a:hover:after,
#sideNav .navWrap .navLv01 span:hover:after,
#sideNav .navWrap .navLv01 a.active:after {
    background: url(../img/common/arrow_icon_12.png) no-repeat left top;
    background-size: contain;
    right: 0;
}

#sideNav .navWrap .navLv01.openTtl a:after,
#sideNav .navWrap .navLv01.openTtl span:after {
    width: 10px;
    height: 7px;
    background: url(../img/common/arrow_icon_13.png) no-repeat left top;
    background-size: contain;
    -moz-transform: rotateZ(180deg);
    -webkit-transform: rotateZ(180deg);
    -o-transform: rotateZ(180deg);
    -ms-transform: rotateZ(180deg);
}

#sideNav .navWrap .navLv01.openTtl a:hover:after,
#sideNav .navWrap .navLv01.openTtl span:hover:after,
#sideNav .navWrap .navLv01.open.activeParent a:after,
#sideNav .navWrap .navLv01.open.activeParent span:after {
    background: url(../img/common/arrow_icon_16.png) no-repeat left top;
    background-size: contain;
    top: 5px;
    right: 5px;
}

#sideNav .navWrap .navLv01.open a,
#sideNav .navWrap .navLv01.open span {
    border-bottom: 1px solid #dcdcdc;
}

#sideNav .navWrap .navLv01 a.active,
#sideNav .navWrap .navLv01.open.activeParent a,
#sideNav .navWrap .navLv01.open.activeParent span {
    color: #cc1824;
}

#sideNav .navWrap .navLv01.open a:after,
#sideNav .navWrap .navLv01.open span:after {
    -moz-transform: rotateZ(0deg);
    -webkit-transform: rotateZ(0deg);
    -o-transform: rotateZ(0deg);
    -ms-transform: rotateZ(0deg);
}

#sideNav .navWrap .navLv01.open a:hover:after,
#sideNav .navWrap .navLv01.open span:hover:after,
#sideNav .navWrap .navLv01.open.activeParent a:after,
#sideNav .navWrap .navLv01.open.activeParent span:after {
    top: -5px;
    right: 5px;
}

#sideNav .navWrap .navLv01:not(:first-of-type) {
    border-top: 1px solid #dcdcdc;
}

#sideNav .navWrap .navLv02 {
    display: none;
    font-size: 14px;
    font-size: 1.4rem;
}

#sideNav .navWrap li a {
    display: block;
    padding: 15px 20px;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    color: #202020;
    text-decoration: none;
}

#sideNav .navWrap li a:hover,
#sideNav .navWrap li a.active {
    color: #cc1824;
}

#sideNav .navWrap li:not(:first-of-type) {
    border-top: 1px dotted #dcdcdc;
}

#sideNav .listLink {
    margin: -10px 15px 20px;
}

#sideNav .listLink a {
    display: block;
    padding: 8px 0;
    position: relative;
    border: 2px solid #616161;
    text-align: center;
    text-decoration: none;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    color: #202020;
}

#sideNav .listLink a:after {
    position: absolute;
    content: "";
    width: 7px;
    height: 11px;
    background: url(../img/common/arrow_icon_06.png) no-repeat left top;
    background-size: contain;
    display: block;
    top: 0;
    bottom: 0;
    right: 10px;
    margin: auto;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    color: #202020;
}

#sideNav .listLink a:hover {
    background-color: #cc1824;
    border-color: #cc1824;
    color: #fff;
}

#sideNav .listLink a:hover:after {
    right: 5px;
    background: url(../img/common/arrow_icon_07.png) no-repeat left top;
    background-size: contain;
}

@media only screen and (max-width: 768px) {
    #sideNav {
        width: 100%;
        margin-top: 50px;
        float: none;
    }

    #sideNav .sideNavInner {
        margin: 0 10px;
    }

    #sideNav .navWrap {
        padding: 10px 10px 5px;
    }

    #sideNav .listLink a {
        padding: 12px 0;
    }
}


/* sideBottomNav
------------------------------------------------------------------------------------------------------------- */

#sideBottomNav {
    width: 100%;
    position: relative;
    z-index: 9999;
}

#sideNav .sideNavInner + #sideBottomNav {
    margin-top: 30px;
}

#sideBottomNav li {
    width: 100%;
    vertical-align: top;
    margin-top: 20px;
}

#sideBottomNav li:first-child {
    margin-top: 0;
}

#sideBottomNav a {
    width: 100%;
    height: 120px;
    position: relative;
    border: 1px solid #c8c8c8;
    background-color: #fff;
    display: table;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    color: #202020;
    text-decoration: none;
    line-height: 1.5;
}

#sideBottomNav a span {
    display: table-cell;
    vertical-align: middle;
    width: 124px;
}

#sideBottomNav a:hover {
    color: #c90915;
    border: 1px solid #c90915;
}

#sideBottomNav a:before {
    content: "";
    width: 114px;
    display: table-cell;
    vertical-align: middle;
    background-repeat: no-repeat;
    -webkit-transition: 0.2s ease;
    -moz-transition: 0.2s ease;
    -o-transition: 0.2s ease;
    transition: 0.2s ease;
}

#sideBottomNav01 a:before {
    height: 73px;
    background-image: url(../img/common/service_banner_icon_01.png);
    background-position: 20px center;
    background-size: 77px 73px;
}

#sideBottomNav02 a:before {
    height: 70px;
    background-image: url(../img/common/service_banner_icon_02.png);
    background-position: 28px center;
    background-size: 58px 70px;
}

#sideBottomNav03 a:before {
    height: 58px;
    background-image: url(../img/common/service_banner_icon_03.png);
    background-position: 20px center;
    background-size: 80px 58px;
}

#sideBottomNav04 a:before {
    height: 45px;
    background-image: url(../img/common/service_banner_icon_04.png);
    background-position: 15px center;
    background-size: 83px 45px;
}

#sideBottomNav a:hover:before,
#sideBottomNav a:focus:before,
#sideBottomNav a:active:before {
    -webkit-transform: scale(1.1) translateZ(0);
    transform: scale(1.1) translateZ(0);
}

@media only screen and (max-width: 768px) {
    #sideBottomNav {
        min-width: 100%;
        padding: 15px 10px 25px;
        background-color: #f5f5f5;
        letter-spacing: -.4em;
    }

    #sideBottomNav a {
        padding: 16px 5px;
    }

    #sideBottomNav li {
        box-sizing: border-box;
        width: 49%;
        margin-top: 10px;
        padding: 0;
        float: left;
        display: inline-block;
        letter-spacing: normal;
        text-align: center;
        font-size: 14px;
    }

    #sideBottomNav li:first-child {
        margin-top: 10px;
    }

    #sideBottomNav li:nth-of-type(2n + 1) {
        margin-right: 1%;
    }

    #sideBottomNav li:nth-of-type(2n) {
        margin-left: 1%;
    }

    #sideBottomNav a {
        height: 105px;
    }

    #sideBottomNav a span {
        width: auto;
        display: block;
    }

    #sideBottomNav a:before {
        margin: 0 auto 10px;
        display: block;
    }

    #sideBottomNav01 a:before,
    #sideBottomNav02 a:before,
    #sideBottomNav03 a:before,
    #sideBottomNav04 a:before {
        background-position: center center;
    }

    #sideBottomNav03 a,
    #sideBottomNav04 a {
        padding-top: 20px;
    }

    /*#sideBottomNav03 a:before,
    #sideBottomNav04 a:before{margin-bottom:12px;}*/
    #sideBottomNav01 a:before {
        width: 50px;
        height: 48px;
        background-size: contain;
    }

    #sideBottomNav02 a:before {
        width: 40px;
        height: 48px;
        background-size: contain;
    }

    #sideBottomNav03 a:before {
        width: 59px;
        height: 42px;
        background-size: contain;
    }

    #sideBottomNav04 a:before {
        width: 70px;
        height: 42px;
        background-size: contain;
    }
}


/* linkType01・linkType02
------------------------------------------------------------------------------------------------------------- */

.linkType02 {
    overflow: hidden;
}

.linkType03 {
    width: 100%;
    display: table;
}

.linkType03 ul {
    width: 50%;
    display: table-cell;
    vertical-align: top;
}

.linkType03 ul:first-child {
    padding-right: 20px;
}

.linkType03 ul:last-child {
    padding-left: 20px;
}

.linkType01 li {
    margin-top: 22px;
}

.linkType02 li {
    width: 50%;
    margin-top: 22px;
    float: left;
}

.linkType02 li:nth-child(2n + 1) {
    padding-right: 20px;
}

.linkType02 li:nth-child(2n) {
    padding-left: 20px;
}

.linkType03 li {
    margin-top: 22px;
}

.linkType01 li a,
.linkType02 li a,
.linkType03 li a {
    padding-left: 18px;
    background: url(../img/common/arrow_icon_01.png) no-repeat 0 8px;
    background-size: 7px 11px;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    display: block;
    position: relative;
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 1.5;
}

.linkType01 li a:hover,
.linkType02 li a:hover,
.linkType03 li a:hover {
    color: #c90915;
    text-decoration: none;
}

.linkType01 li.pdf a:after,
.linkType02 li.pdf a:after,
.linkType03 li.pdf a:after {
    content: "";
    width: 30px;
    height: 30px;
    margin-left: 5px;
    background: url(../img/common/pdf_icon.png) no-repeat center center;
    background-size: 30px 30px;
    display: inline-block;
    position: relative;
    top: -5px;
    vertical-align: middle;
}

@media only screen and (max-width: 768px) {
    .linkType03 {
        display: block;
    }

    .linkType03 ul {
        width: 100%;
        display: block;
    }

    .linkType03 ul:first-child,
    .linkType03 ul:last-child {
        padding-left: 0;
    }

    .linkType01 li a {
        background-size: 7px 11px;
    }

    .linkType02 li {
        width: 100%;
        float: none;
    }

    .linkType02 li:nth-child(2n + 1) {
        padding-right: 0;
    }

    .linkType02 li:nth-child(2n) {
        padding-left: 0;
    }

    .linkType01 li.pdf a:after,
    .linkType02 li.pdf a:after {
        margin-left: 0;
        background-size: 20px 20px;
        top: -3px;
    }
}


/* tableType01・tableType02・tableType03
------------------------------------------------------------------------------------------------------------- */

.tableType01,
.tableType02,
.tableType03 {
    margin-top: 30px;
}

.tableType01 table,
.tableType02 table,
.tableType03 table {
    width: 100%;
}

.tableType01 th,
.tableType01 td,
.tableType02 th,
.tableType02 td,
.tableType03 th,
.tableType03 td {
    padding: 15px;
    background-color: #fff;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.3em;
}

.tableType01 th,
.tableType03 th {
    border: 1px solid #c8c8c8;
    background-color: #f5f5f5;
}

.tableType02 th {
    border: 1px solid #c8c8c8;
}

.tableType01 td,
.tableType02 td,
.tableType03 td {
    border-right: 1px dotted #c8c8c8;
    border-bottom: 1px dotted #c8c8c8;
}

.tableType01 tr td:first-child,
.tableType02 tr td:first-child,
.tableType03 tr td:first-child {
    border-left: 1px solid #c8c8c8;
}

.tableType01 tr td:last-child,
.tableType02 tr td:last-child,
.tableType03 tr td:last-child {
    border-right: 1px solid #c8c8c8;
}

.tableType01 tr:last-child td,
.tableType02 tr:last-child td,
.tableType03 tr:last-child td {
    border-bottom: 1px solid #c8c8c8;
}

.tableType03 tr td:first-child {
    width: 30%;
}

.tableType_s {
    font-size: 11px;
    font-weight: 400;
}


/* detailTxt
------------------------------------------------------------------------------------------------------------- */

.detailTxt {
    text-align: justify;
    text-justify: inter-ideograph;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.5;
}

@media only screen and (max-width: 768px) {
    .detailTxt {
        margin-top: 20px;
        font-size: 15px;
        font-size: 1.5rem;
        line-height: 1.5;
    }

    .detailTxt .movie {
        height: 0;
        padding-top: 30px;
        padding-bottom: 56.25%;
        position: relative;
        overflow: hidden;
    }

    .detailTxt .movie iframe {
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
    }

    .detailTxt p {
        margin-top: 20px;
    }
}


/* detailTxt_right
------------------------------------------------------------------------------------------------------------- */

.detailTxt_right {
    text-align: right;
    margin-top: 20px;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.5;
}


/* detailTxt_small
------------------------------------------------------------------------------------------------------------- */

.detailTxt_small {
    text-align: left;
    margin-top: 20px;
    font-size: 16px;
    font-size: 1.2rem;
    line-height: 1.5;
}

.detailTxt_right .movie {
    height: 0;
    padding-top: 30px;
    padding-bottom: 56.25%;
    position: relative;
    overflow: hidden;
}

.detailTxt_right .movie iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.detailTxt_right p {
    margin-top: 20px;
}


}

/* boxTxt01
------------------------------------------------------------------------------------------------------------- */

.boxTxt01 {
    margin-top: 30px;
    padding: 20px;
    border: 1px solid #c8c8c8;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8;
}

.boxTxt01 h3 {
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8;
    font-weight: normal;
}

/* btnType01・btnType02・btnType03・btnType04
------------------------------------------------------------------------------------------------------------- */

.btnType01,
.btnType02,
.btnType03,
.btnType04 {
    margin-top: 40px;
}

.btnType01 ul,
.btnType02 ul,
.btnType03 ul,
.btnType04 ul {
    width: 100%;
    display: table;
}

.btnType01 li,
.btnType02 li,
.btnType03 li,
.btnType04 li {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
}

.btnType01 li {
    width: 50%;
}

.btnType02 li {
    width: 33.333%;
}

.btnType03 li,
.btnType04 li {
    width: 25%;
}

.btnType01 li a,
.btnType02 li a,
.btnType03 li a,
.btnType04 li a {
    margin: 0 auto;
    padding: 12px 0;
    /* padding: 12px 22px 12px 10px; */
    border: 2px solid #616161;
    display: table-cell;
    position: relative;
    vertical-align: middle;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    color: #161616;
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 1.2;
    text-decoration: none;
}

.btnType01 li a {
    width: 327px;
}

.btnType01 li:last-child a {
    left: 8px;
}

.btnType02 li a {
    width: 217px;
}

.btnType02 li:nth-child(2) a {
    left: 3px;
}

.btnType02 li:last-child a {
    left: 7px;
}

.btnType03 li a {
    width: 160px;
    /* padding: 48px 22px 48px 10px; */
    padding: 48px 0;
}

.btnType04 li a {
    width: 160px;
}

.btnType03 li:nth-child(2) a,
.btnType04 li:nth-child(2) a {
    left: 2px;
}

.btnType03 li:nth-child(3) a,
.btnType04 li:nth-child(3) a {
    left: 4px;
}

.btnType03 li:last-child a,
.btnType04 li:last-child a {
    left: 7px;
}

.btnType01 li a:hover,
.btnType02 li a:hover,
.btnType03 li a:hover,
.btnType04 li a:hover {
    border: 2px solid #c90915;
    background-color: #c90915;
    color: #fff;
}

.btnType01 li a:after,
.btnType02 li a:after,
.btnType03 li a:after,
.btnType04 li a:after {
    content: "";
    width: 7px;
    height: 10px;
    display: block;
    background: url(../img/common/arrow_icon_18.png) no-repeat left top;
    background-size: contain;
    position: absolute;
    right: 12px;
    top: 0;
    bottom: 0;
    margin: auto;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

.btnType01 li a:hover:after,
.btnType02 li a:hover:after,
.btnType03 li a:hover:after,
.btnType04 li a:hover:after {
    right: 7px;
    background: url(../img/common/arrow_icon_19.png) no-repeat left top;
    background-size: contain;
}

@media only screen and (max-width: 768px) {

    .btnType01,
    .btnType02,
    .btnType03,
    .btnType04 {
        margin-top: 30px;
        overflow: hidden;
    }

    .btnType01 ul,
    .btnType02 ul,
    .btnType03 ul,
    .btnType04 ul {
        display: block;
    }

    .btnType01 li,
    .btnType02 li {
        width: 100%;
        margin-top: 10px;
        display: block;
    }

    .btnType01 li a,
    .btnType02 li a {
        width: 100%;
        padding: 14px 10px;
        display: block;
    }

    .btnType03 li,
    .btnType04 li {
        width: 50%;
        margin-top: 10px;
        float: left;
        display: table;
    }

    .btnType03 ul li:nth-child(2n + 1),
    .btnType04 ul li:nth-child(2n + 1) {
        padding-right: 5px;
    }

    .btnType03 ul li:nth-child(2n),
    .btnType04 ul li:nth-child(2n) {
        padding-left: 5px;
    }

    .btnType03 li a,
    .btnType04 li a {
        width: 90%;
        padding: 28px 22px 28px 10px;
    }

    .btnType01 li:last-child a {
        left: 0;
    }

    .btnType02 li:nth-child(2) a {
        left: 0;
    }

    .btnType02 li:last-child a {
        left: 0;
    }

    .btnType03 li:nth-child(2) a,
    .btnType04 li:nth-child(2) a {
        left: 0;
    }

    .btnType03 li:nth-child(3) a,
    .btnType04 li:nth-child(3) a {
        left: 0;
    }

    .btnType03 li:last-child a,
    .btnType04 li:last-child a {
        left: 0;
    }
}

/* imgTextSec
------------------------------------------------------------------------------------------------------------- */

.imgTextSec {
    margin-top: 30px;
    overflow: hidden;
}

.imgTextSec .imgLeft {
    width: 230px;
    margin-right: 24px;
    margin-bottom: 20px;
    float: left;
}

.imgTextSec .imgRight {
    width: 230px;
    margin-left: 24px;
    margin-bottom: 20px;
    float: right;
}

.imgTextSec .detailTxt p {
    margin-top: 30px;
}

.imgTextSec .detailTxt p:first-of-type {
    margin-top: 0;
}

.imgTextSec .detailTxt .movie {
    text-align: center;
}

.imgTextSec .headTtl03:first-of-type {
    margin-top: 0;
}

@media only screen and (max-width: 768px) {

    .imgTextSec .imgLeft,
    .imgTextSec .imgRight {
        width: 190px;
        margin: 0 auto;
        float: none;
        display: block;
    }

    .imgTextSec .imgLeft img,
    .imgTextSec .imgRight img {
        width: 190px;
        height: auto;
    }

    .imgTextSec .detailTxt {
        margin-top: 20px;
        font-size: 15px;
        font-size: 1.5rem;
        line-height: 1.5;
    }

    .imgTextSec .detailTxt .movie {
        height: 0;
        padding-top: 30px;
        padding-bottom: 56.25%;
        position: relative;
        overflow: hidden;
    }

    .imgTextSec .detailTxt .movie iframe {
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
    }

    .imgTextSec .detailTxt p {
        margin-top: 20px;
    }

    .imgTextSec .headTtl03:first-of-type {
        margin-top: 20px;
    }
}

/* dataListType01
------------------------------------------------------------------------------------------------------------- */

.dataListType01 {
    margin-top: 40px;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.5;
}

.dataListType01 dt {
    font-weight: bold;
}

.dataListType01 dd {
    margin-top: 22px;
}

/* a-form
------------------------------------------------------------------------------------------------------------- */

.aform form {
    overflow: hidden;
}

.aform-header {
    display: none;
}

.aform-content {
    margin-top: 30px;
}

.aform table {
    width: 100%;
}

.aform th {
    width: 40%;
    padding: 10px 10px 8px 0;
    font-size: 16px;
    font-size: 1.6rem;
    vertical-align: top;
    white-space: nowrap;
    font-weight: normal;
}

.aform th .required {
    display: inline-block;
    vertical-align: middle;
    color: #c90915;
    font-size: 13px;
    font-size: 1.3rem;
}

.aform th .required:after {
    content: "必須";
    margin-left: 3px;
}

.aform .aform-hdln {
    margin: 0 !important;
    padding: 0 !important;
    border-bottom: none !important;
    font-weight: 600;
}

.aform .aform-hdln th {
    padding: 30px 0 15px;
    border-bottom: 1px solid #c22520;
    font-size: 22px;
    font-size: 2.2rem;
}

.aform .aform-hdln + tr th {
    padding-top: 30px;
}

.aform .aform-hdln + tr td {
    padding-top: 28px;
}

.aform td {
    padding: 8px 0;
    vertical-align: top;
    text-align: left;
}

.aform .typeD td {
    text-align: left;
}

.aform .aform-text,
.aform .aform-email,
.aform .aform-tel,
.aform .aform-textarea,
.aform .aform-select,
.aform .aform-url {
    width: 100%;
    padding: 8px 5px !important;
    border: 1px solid #c8c8c8 !important;
}

.aform input.validation-failed,
.aform textarea.validation-failed {
    border: 1px solid #ff3300 !important;
    color: #ff3300;
}

.aform label {
    margin: 0 auto;
    display: inline-block;
    cursor: pointer;
}

.aform label .aform-checkbox {
    margin-right: 8px;
}

.aform .validation-advice {
    margin: 10px 0 !important;
    padding: 10px;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.4;
    text-align: left;
}

.aform .validation-advice img {
    display: none;
}

.aform .submit {
    width: 330px;
    margin: 40px auto 0;
    position: relative;
}

.aform .submit input {
    width: 330px;
    padding: 12px 22px 12px 10px;
    border: 2px solid #616161;
    background-color: #fff;
    display: block;
    position: relative;
    vertical-align: middle;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 1.2;
    text-decoration: none;
    cursor: pointer;
}

.aform .submit input:hover {
    border: 2px solid #c90915;
    background-color: #c90915;
    color: #fff;
}

.aform .submit:after {
    content: "";
    width: 7px;
    height: 10px;
    display: block;
    background: url(../img/common/arrow_icon_18.png) no-repeat left top;
    background-size: contain;
    position: absolute;
    right: 12px;
    top: 0;
    bottom: 0;
    margin: auto;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

.aform .submit:hover:after {
    right: 7px;
    background: url(../img/common/arrow_icon_19.png) no-repeat left top;
    background-size: contain;
}

.aform table + p {
    margin-top: 30px;
}

.aform .alignL,
.aform .alignR {
    margin-top: 40px;
    display: inline-block;
}

.aform .alignL {
    margin-right: 30px;
}

div.aform p.powerdby {
    display: none !important;
}

@media only screen and (max-width: 768px) {

    .aform th,
    .aform td {
        width: 100%;
        display: block;
    }

    .aform .aform-hdln + tr td {
        padding-top: 8px;
    }

    .aform .submit {
        width: 100%;
        margin: 20px auto 0;
    }

    .aform .submit input {
        width: 100%;
    }
}

/* newsListSec
------------------------------------------------------------------------------------------------------------- */

#newsListSec h1 {
    padding-left: 34px;
    background: url(/icon/h1_amd_logo.png) no-repeat left center;
    font-size: 30px;
    font-size: 3.0rem;
}

#newsListSec h1 span {
    margin-left: 20px;
    display: inline-block;
    font-size: 20px;
    font-size: 2.0rem;
}

#newsListSec {
    width: 100%;
    min-width: 950px;
    background-color: #fff;
    position: relative;
    z-index: 9999;
}

#newsListInner {
    width: 950px;
    margin: 0 auto;
    padding: 40px 0;
    position: relative;
}

#newsList dl {
    margin-top: 16px;
}

#newsList dt {
    font-size: 16px;
    font-size: 1.4rem;
    line-height: 1.8;
}

#newsList dt span[class^="newsType"] {
    margin-left: 20px;
    padding: 2px 8px;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    font-size: 14px;
    font-size: 1.2rem;
}

#newsList dt .newsType01 {
    background-color: #bae5dc;
}

#newsList dt .newsType02 {
    background-color: #bccbf4;
}

#newsList dt .newsType03 {
    background-color: #f2c0f5;
}

#newsList dt .newsType04 {
    background-color: #eedc92;
}

#newsList dd {
    margin-top: 8px;
    margin-left: 10px;
    line-height: normal;
}

#newsList dd a {
    padding-left: 18px;
    background: url(../img/common/arrow_icon_01.png) no-repeat 0 7px;
    background-size: 7px 11px;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    display: block;
    color: #307294;
    font-size: 16px;
    font-size: 1.5rem;
    line-height: 1.;
}

#newsList dd a:hover {
    color: #c90915;
    text-decoration: none;
}

#updateListLink a {
    position: absolute;
    top: 40px;
    right: 0;
    width: 20%;
    padding: 8px 15px 8px;
    border: 2px solid #616161;
    display: block;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
    text-decoration: none;
    color: #616161;
}

#updateListLink a:after {
    content: "";
    width: 7px;
    height: 11px;
    display: block;
    background: url(../img/common/arrow_icon_06.png) no-repeat left top;
    background-size: 7px 11px;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 15px;
    -webkit-transition: 0.4s ease;
    -moz-transition: 0.4s ease;
    -o-transition: 0.4s ease;
    transition: 0.4s ease;
}

#updateListLink a:hover {
    background-color: #c90915;
    border: 2px solid #c90915;
    color: #fff;
}

#updateListLink a:hover:after {
    background-image: url(../img/common/arrow_icon_07.png);
    right: 10px;
}

@media only screen and (max-width: 768px) {
    #newsListSec h1 {
        padding: 5px 0 3px 32px;
        background-image: url(/icon/h1_amd_logo.png);
        background-size: 24px 26px;
        font-size: 22px;
        font-size: 2.2rem;
    }

    #newsListSec h1 span {
        margin-left: 20px;
        display: inline-block;
        font-size: 18px;
        font-size: 1.8rem;
    }

    #newsListSec {
        min-width: 100%;
    }

    #newsListInner {
        width: 100%;
        padding: 30px 10px 20px;
    }

    #newsList dl:first-of-type {
        margin-top: 30px;
    }

    #newsList dl:not(:first-of-type) {
        margin-top: 30px;
    }

    #newsList dd {
        margin-left: 0;
    }

    #newsList dd a {
        background-size: 7px 11px;
    }

    #updateListLink {
        margin-top: 30px;
    }

    #updateListLink a {
        position: relative;
        top: 0;
        width: 100%;
        padding: 12px 15px 10px;
        display: block;
        text-align: center;
    }
}

.seminarList {
    margin-left: 20px;
    padding: 2px 8px;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    font-size: 14px;
    font-size: 1.2rem;
}

.seminarList .Type01 {
    background-color: #bae5dc;
}

.seminarList .Type02 {
    background-color: #bccbf4;
}

.seminarList .Type03 {
    background-color: #f2c0f5;
}

.seminarList .Type04 {
    background-color: #eedc92;
}

#seminarList {
    margin-top: 8px;
    margin-left: 10px;
}

.headTtl03 .prize_cap {
    color: #ee0000;
}

/*　概要　審査員項目　*/

li .shinsa {
    margin-left: 1em;
}

.note_sr {
    color: #555;
    text-align: right;
    font-size: 0.8em;
    margin-top: 0.6em;
}

/* レスポンシブph　*/

.res_ph {
    margin-top: 1em;
    width: 100%;
    max-width: 100%;
    height: auto;
}

/* ムービーマージン　*/

.movie_box {
    margin-top: 1.2em;
    margin-bottom: 1.8em;
}

.movie-wrap {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
}

.movie-wrap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* ムービー　代替サムネイル　マージン */

.movie-wrap img {
    position: absolute;
    top: 0;
    left: 0;
    width: auto;
    height: 100%;
}

/* 箇条書きの行間調整　*/

dd .no_link {
    font-size: 0.8em;
}

/*　ムービーページ　未公開表示　*/

.underc_img {
    width: 100%;
    max-width: 100%;
    height: auto;
    background: url('/movie/under_c.jpg');
}

.underc_text {
    color: cadetblue;
    font-size: 1.2em;
    font-weight: bold;
    margin-top: 1.2em;
    margin-bottom: 3.0em;
}

/* セミナーページ */

#seminar_top {}

#seminar_part {
    margin-left: 1em;
    margin-right: 1em;
    /*   * @media only screen and (max-width: 768px) {
        #seminar_part {
            margin-left: 0;
            margin-right: 0;
            padding-left: 1em;
            padding-right: 1em;
        }*/
}

*/ .sympo_contents {
    display: block;
    padding-bottom: 1.2em;
}

.sympo_contents .sympo_copy {
    display: block;
    font-size: 0.85em;
    text-align: justify;
    font-weight: 400;
    line-height: 1.6em;
    letter-spacing: 0.5px;
    margin-top: 1em;
}

.sympo_contents h3 {
    font-size: 0.9em;
    position: relative;
    margin-top: 1em;
    margin-bottom: 1.2em;
    padding: .25em 0 .5em .75em;
    border-left: 6px solid #005bab;
    line-height: 1.3
}

.sympo_contents h3::after {
    position: absolute;
    left: 0;
    bottom: 0;
    content: '';
    width: 100%;
    height: 0;
    border-bottom: 1.5px solid #005bab;
}

.sympo_panel {
    display: block;
    width: 100%;
    height: auto;
    padding-bottom: 0.5em;
}

.sympo_photo {
    width: 140px;
    height: auto;
    float: left;
    margin-right: 20px;
}

.sympo_contents img {
    /* margin-right: 1em;
    margin-bottom: 1em; */
    width: 140px;
    height: auto;
    border: 1px solid #005bab;
    /* 外枠の色 */
    padding: 0;
    /* 余白 */
    background-color: #ffffff;
    /* 余白部分の色 */
    margin-bottom: 1.8em;
}

.sympo_text {
    display: block;
    position: o 200px;
    width: 100%;
    height: auto;
}

.sympo_text h4 {
    font-size: 1em;
    letter-spacing: 6px;
    margin-bottom: 0.2em;
}

.sympo_text h4:after {
    content: "氏";
    font-size: 0.8em;
    letter-spacing: 2px !important;
    font-weight: normal !important;
    vertical-align: bottom;
}

.sympo_text .title {
    font-size: 0.75em;
    font-weight: bold;
    padding: 0.2em 0.3em;
    margin-bottom: 0.5em;
    line-height: 1.4em;
}

.sympo_text p {
    font-size: 0.7em;
    line-height: 1.45em;
    margin-bottom: 1.5em;
    text-align: justify;
}

.sympo_contents .note {
    font-size: 0.8em !important;
    font-weight: normal !important;
}

.sympo_contents .note_b {
    font-size: 0.9em !important;
}

.sympo_contents .contact_copy {
    display: block;
    font-size: 0.9em;
    text-align: left;
    line-height: 1.6em;
    letter-spacing: 0.5px;
    margin-top: 1em;
    margin-bottom: 0.5em;
}

/* セミナーページ内一覧　*/

.sympo_contents table {
    margin-bottom: 0.5em;
}

.tableType04 {
    margin-top: 30px;
}

.tableType04 table {
    width: 100%;
}

.tableType04 td {
    padding: 15px;
    background-color: #fff;
    font-size: 15px;
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.3em;
}

.tableType04 th {
    border: 1px solid #c8c8c8;
    background-color: #f5f5f5;
}

.tableType04 tr td:first-child {
    border: 2px solid #005bab;
    border-bottom: 2px solid #005bab;
    color: #005bab;
    text-align: center;
    vertical-align: middle;
}

.tableType04 tr td:first-child {
    width: 20%;
}

@media only screen and (max-width: 768px) {
    .tableType04 tr td:first-child {
        width: 22%;
    }
}

.tableType04 td img {
    display: inline;
    vertical-align: middle;
}

/* セミナー　トップ　イベント名 */

.seminarTtl {
    width: 100%;
    height: auto;
    margin-top: 1.2em;
    margin-bottom: 0;
}

.seminarTtl .Ttl {
    font-size: 1.1em;
    font-weight: normal;
    padding-top: 0.5em;
    padding-bottom: 0.8em;
    border-bottom: solid 1px #005bab;
    border-left: solid 6px #005bab;
    padding-left: 12px;
    line-height: 1.2em;
}

.seminarTtl .date {
    font-size: 0.9em;
    font-weight: normal !important;
    padding-top: 0.6em;
    padding-left: 18px;
    padding-bottom: 1em;
    line-height: 1.2em;
}

.seminarTtl a {
    text-decoration: none;
}

.seminarTtl .available {
    font-size: 0.9em;
    color: #fff;
    background-color: #cc1824;
    font-weight: bold;
    line-height: 2em;
    padding: 0.2em 0.6em;
}

.seminarTtl .noavailable {
    font-size: 0.9em;
    color: #fff;
    background-color: #0022df;
    font-weight: bold;
    line-height: 2em;
    padding: 0.2em 0.6em;
}

/*　アワード作品紹介ページ用　著作権表示　*/

.copyRt {
    margin-top: 40px;
    font-size: 12px;
    font-size: 1.2rem;
}

/* 活動報告 */

#newsList .actRepTitle {
    font-size: 1em;
    font-weight: 600;
    padding-bottom: 0.5em;
    margin-bottom: 0.5em;
    border-bottom: solid 1px #ff0000;
}

td.awrad_note {
    font-size: 0.8em;
}

/* 臨時：事務所移転案内 */

#moveingDat {
    width: 950px;
    display: block;
    text-align: left;
    width: 100%;
    height: auto;
    margin: 0 0 30px;
    padding: 10px 10px;
}

figcaption {
    font-size: 0.8em !important;
    margin-top: 0.4em;
}

#contents .commission {
    margin-bottom: 4em;
}

/* 理事一覧 */
.officer-list {}


.officer-list tr td:first-child {
    width: 155px;
    border-right: none;
}

.officer-list tr td.portrait img {
    width: 140px;
    padding: 0;
}

.officer-list tr td.name-company {
    vertical-align: top !important;
    padding-left: 5px;
}

.officer-list tr td.name-company .name {
    font-size: 1.1em !important;
    margin: 5px 0 10px;
    padding: 10px 15px;
    border-left: solid 10px #c90915;
    border-bottom: solid 1px #c90915;
}

.officer-list tr td.name-company .company {
    font-size: 0.9em;
    padding-left: 15px;
    line-height: 1.8em;
}




/* 改行制御 */
@media screen and (min-width: 650px) {
    .br-pc {
        display: block;
    }

    .br-sp {
        display: none;
    }
}

@media screen and (max-width: 650px) {
    .br-pc {
        display: none;
    }

    .br-sp {
        display: block;
    }
}

/* ニュースリリース単体 */
.release_box h1 {
    font-size: 1.3em;
    line-height: 1.3em;
}

.release_box h2 {
    text-align: center;
    font-size: 1em;
    font-weight: 400;
    margin-bottom: 2em;
}

.release_box #newsList {
    margin-bottom: 1.4em !important;
}

.release_box p {
    line-height: 1.6em !important;
    margin-bottom: 1.2em;
}

.release_box h3 {
    color: darkred;
    font-size: 1em;
    margin: 2em 0 1em;
}

.release_box table {
    margin: 1em 0.5em 2em;
    font-size: 0.9em;
    background-color: rgba(250, 250, 245, 0.4);
}

.release_box table tr {
    border-top: solid 1px #000 !important;
    border-bottom: solid 1px #000 !important;

}

.release_box table tr th {
    text-align: center;
    padding: 0.8em 1em;
    font-weight: 400;
    background-color: aliceblue;
}

.release_box table tr td {
    padding: 1em;
    line-height: 1.4em;
}

.release_box table tr td.row_2 {}


.release_box .release_info_box {
    background-color: aliceblue;
    padding: 1em 2em;
    margin-bottom: 1em;
}

.release_box .release_info_box h3 {
    font-size: 0.9em !important;
    margin-top: 1em;
    margin-bottom: 1em;
    line-height: 1.6em;
}

.release_box .release_info_box p {
    font-size: 0.9em;
    line-height: 1.4em !important;
}

.release_box .release_info_box p.note {
    font-size: 0.8em;
    margin: 1em 1em;
}


.release_box .realese_pdf {
    margin-top: 1.5em;
    margin-bottom: 2em;
    text-decoration: underline;
}

.release_box li {
    margin-bottom: 0.8em;
    margin-left: 1em;
}
