/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary {
    display: block
}

audio,canvas,progress,video {
    display: inline-block;
    vertical-align: baseline
}

audio:not([controls]) {
    display: none;
    height: 0
}

[hidden],template {
    display: none
}

a {
    background-color: transparent
}

a:active,a:hover {
    outline: 0
}

abbr[title] {
    border-bottom: 1px dotted
}

b,strong {
    font-weight: bold
}

dfn {
    font-style: italic
}

mark {
    background: #ff0;
    color: #000
}

small {
    font-size: 80%
}

sub,sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sup {
    top: -0.5em
}

sub {
    bottom: -0.25em
}

img {
    border: 0
}

svg:not(:root) {
    overflow: hidden
}

figure {
    margin: 0
}

hr {
    -moz-box-sizing: content-box;
    box-sizing: content-box;
    height: 0
}

pre {
    overflow: auto
}

code,kbd,pre,samp {
    font-family: monospace, monospace;
    font-size: 1em
}

button,input,optgroup,select,textarea {
    color: inherit;
    font: inherit;
    margin: 0
}

button {
    overflow: visible
}

button,select {
    text-transform: none
}

button,html input[type="button"],input[type="reset"],input[type="submit"] {
    -webkit-appearance: button;
    cursor: pointer
}

button[disabled],html input[disabled] {
    cursor: default
}

button::-moz-focus-inner,input::-moz-focus-inner {
    border: 0;
    padding: 0
}

input {
    line-height: normal
}

input[type="checkbox"],input[type="radio"] {
    box-sizing: border-box;
    padding: 0
}

input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button {
    height: auto
}

input[type="search"] {
    -webkit-appearance: textfield;
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box;
    box-sizing: content-box
}

input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none
}

fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: .35em .625em .75em
}

legend {
    border: 0;
    padding: 0
}

textarea {
    overflow: auto
}

optgroup {
    font-weight: bold
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

td,th {
    padding: 0
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 100;
    src: url(/common/font/NotoSansJapanese/NotoSansJP-Thin.otf) format("opentype")
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 200;
    src: url(/common/font/NotoSansJapanese/NotoSansJP-Light.otf) format("opentype")
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 300;
    src: url(/common/font/NotoSansJapanese/NotoSansJP-DemiLight.otf) format("opentype")
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 400;
    src: local("NotoSansJP-Regular.otf"),url(/common/font/NotoSansJapanese/NotoSansJP-Regular.otf) format("opentype")
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 500;
    src: url(/common/font/NotoSansJapanese/NotoSansJP-Medium.otf) format("opentype")
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 700;
    src: url(/common/font/NotoSansJapanese/NotoSansJP-Bold.otf) format("opentype")
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 900;
    src: url(/common/font/NotoSansJapanese/NotoSansJP-Black.otf) format("opentype")
}

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

*:before,*:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

html {
    font-size: 62.5%;
    -webkit-tap-highlight-color: transparent
}

body {
    width: 100%;
    height: 100%;
    color: #5c5c5c;
    font-family: 'Open Sans', Helvetica, Arial, "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.6rem;
    line-height: 1.5;
    word-wrap: break-word;
    overflow-wrap: break-word;
    background-color: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

@media print {
    html {
        padding: 0
    }

    body {
        width: 100% !important;
        margin: 0 auto;
        clear: both;
        overflow: auto;
        -webkit-print-color-adjust: exact
    }

    .m-001, .m-008, .m-012 {
        display: none
    }
    .m-008.printed{
        display: block;
        margin-top:-80px;
    }
    .Slide {
        height: 393px !important
    }
    
}

h1,h2,h3,h4,h5,h6 {
    font-weight: 400;
    margin: 20px 0
}

h1 small,h2 small,h3 small,h4 small,h5 small,h6 small {
    font-size: 65%;
    line-height: 1
}

h5,h6 {
    margin: 10px 0
}

h1 {
    font-size: 2.8rem;
    line-height: 1.176470588235294
}

h1:first-child {
    margin-top: 0
}

h2 {
    font-size: 2.2rem;
    line-height: 1.307692307692308
}

h3 {
    font-size: 1.8rem;
    line-height: 1.333333333333333
}

h4 {
    font-size: 1.6rem;
    line-height: 1.3
}

h5 {
    font-size: 1.4rem;
    line-height: 1.166666666666667
}

h6 {
    font-size: 1.2rem;
    line-height: 1.1875
}

p {
    line-height: 1.7;
    font-size: 1.6rem;
    font-weight: 400;
    text-align: left;
    word-break: normal;
    word-wrap: normal;
    margin: 1.6rem 0;
    font-feature-settings: "palt"
}

img {
    max-width: 100%;
    height: auto
}

.heading {
    font-size: 2.2rem;
    line-height: 1.2
}

.heading.heading--border:after {
    border-bottom: 1px solid #b2b2b2;
    content: '';
    display: block;
    padding-top: .5em;
    width: 28px
}
.heading.heading--boxed{
    background-color:#e7e7e7;
    border:1px solid #d6d5d5;
    padding:10px 15px;
}
.heading.heading--dotted{
    border-bottom:1px dotted #aaa;
    padding-bottom:10px;
}
.heading.heading--l-border{
    border-left:2px solid #666;
    padding-left:10px;
}

.heading.mtb30{
    margin:30px 0;
}
.heading.mtb40{
    margin:40px 0;
}

.heading.heading--01 {
    font-size: 2.8rem;
    line-height: 1.2;
    text-indent: -2px
}

.heading.heading--01.heading--border:after {
    width: 28px
}

.heading.heading--02 {
    font-size: 2.2rem;
    line-height: 1.307692307692308
}

.heading.heading--02.heading--border:after {
    width: 26px
}

.heading.heading--03 {
    font-size: 1.8rem;
    line-height: 1.333333333333333
}

.heading.heading--03.heading--border:after {
    width: 24px
}

.heading.heading--04 {
    font-size: 1.6rem;
    line-height: 1.3
}

.heading.heading--04.heading--border:after {
    width: 22px
}

.heading.heading--05 {
    font-size: 1.4rem;
    line-height: 1.166666666666667
}

.heading.heading--05.heading--border:after {
    width: 20px
}

.heading.heading--06 {
    font-size: 1.2rem;
    line-height: 1.1875
}

.heading.heading--06.heading--border:after {
    width: 18px
}

.text {
    margin: 0 0 10px;
    font-size: 1.6rem
}

.text--small {
    font-size: 1.4rem
}

.text--normal {
    font-size: 1.6rem
}

.text--medium {
    font-size: 1.8rem
}

.text--large {
    font-size: 2rem
}

.text--xlarge {
    font-size: 2.2rem
}

.text--indent {
    text-indent: 1em
}

.font10 {
    font-size: 1.0rem !important
}

.font12 {
    font-size: 1.2rem !important
}

.font14 {
    font-size: 1.4rem !important
}

.font16 {
    font-size: 1.6rem !important
}

.font18 {
    font-size: 1.8rem !important
}

.font20 {
    font-size: 2.0rem !important
}

.font22 {
    font-size: 2.2rem !important
}

.font24 {
    font-size: 2.4rem !important
}

.font26 {
    font-size: 2.6rem !important
}

.font28 {
    font-size: 2.8rem !important
}

.font30 {
    font-size: 3.0rem !important
}

.indent {
    text-indent: 1em
}

.bold {
    font-weight: 600
}

@media print, screen and (max-width: 640px) {
    h1,.heading.heading--01 {
        font-size:2.2rem;
        line-height: 1.2
    }
}

a {
    color: #e4032e;
    text-decoration: none;
    outline: 0
}

a:hover,a:focus {
    color: #98021f;
    text-decoration: underline
}

a.link {
    text-decoration: none
}

a.link:hover,a.link:focus {
    text-decoration: underline
}

a.link:focus {
    outline: thin dotted;
    outline: 5px auto -webkit-focus-ring-color;
    outline-offset: -2px
}

a.link--primary {
    color: #e4032e
}

a.link--primary:hover,a.link--primary:focus {
    color: #98021f
}

a.link--secondary {
    color: #5c5c5c
}

a.link--secondary:hover,a.link--secondary:focus {
    color: #5c5c5c
}

a.link--arrow-r {
    font-size: 1.6rem;
    font-weight: 500;
    display: block;
    background: url(/common/img/NavArrow-Right.png) no-repeat left center;
    line-height: 30px;
    height: 30px;
    padding-left: 28px
}

a.link--download {
    display: inline-block;
    background: url(/common/img/Icon-Download.png) no-repeat left center;
    padding-left: 28px
}

.button,a.button {
    display: inline-block;
    padding: 12px;
    font-size: 1.4rem;
    line-height: 1.5;
    text-align: center;
    background-color: #fff;
    border: 1px solid #e5e5e5
}

.button:hover,.button:focus,a.button:hover,a.button:focus {
    text-decoration: none;
    background-color: #eeeeee
}

.button--small,a.button--small {
    font-size: 1.2rem;
    padding: 10px
}

.button--medium,a.button--medium {
    font-size: 1.4rem;
    padding: 16px
}

.button--large,a.button--large {
    font-size: 1.6rem;
    padding: 20px
}

.button--full,a.button--full {
    width: 100%
}

.button--arrow,a.button--arrow {
    padding-left: 60px;
    padding-right: 60px;
    background: url(/common/img/Nav_Right.png) right 10px center no-repeat;
    background-size: 20px 15px
}

.button--primary,a.button--primary {
    background-color: #e4032e;
    color: #ffffff;
    border: none
}

.button--primary:hover,.button--primary:focus,a.button--primary:hover,a.button--primary:focus {
    background-color: #98021f;
    color: #ffffff
}

.button--secondary,a.button--secondary {
    background-color: #dddddd;
    color: #5c5c5c;
    border: none
}

.button--secondary:hover,.button--secondary:focus,a.button--secondary:hover,a.button--secondary:focus {
    background-color: #cccccc;
    color: #5c5c5c
}

@media print, screen and (max-width: 640px) {
    .button--block {
        width:100%;
        display: block
    }
}

.border {
    border-style: solid;
    border-color: #e5e5e6;
    border-width: 0
}

.border--top {
    border-top-width: 1px
}

.border--bottom {
    border-bottom-width: 1px
}

.border--left {
    border-left-width: 1px
}

.border--right {
    border-right-width: 1px
}

input,textarea,button {
    font-family: "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "helvetica", "arial", sans-serif;
    font-size: initial
}

ul {
    list-style: none;
    margin-bottom: 1.5em;
    margin-left: 0;
    padding-left: 0
}

ul li {
    margin-bottom: 10px;
    padding-left: 1.8em;
    background: url(/common/img/Bullet.png) no-repeat left 8px top 0.55em
}

ul li ul {
    margin-top: 10px
}

button,input[type="button"],input[type="reset"],input[type="submit"] {
    border: 0;
    -webkit-appearance: button;
    cursor: pointer;
    padding: 12px
}

input:focus {
    outline: 0;
    border-color: #737272
}

button[disabled],html input[disabled] {
    cursor: default
}

button::-moz-focus-inner,input::-moz-focus-inner {
    border: 0;
    padding: 0
}

.NoTablet {
    display: none
}

.pc {
    display: none
}

.sp {
    display: block
}

.no_bullets>li {
    padding-left: 0px;
    background: none !important
}

@media print, screen and (min-width: 640px) {
    .pc {
        display:block
    }

    .sp {
        display: none
    }
}

.TabletFullWidth {
    float: none;
    position: relative;
    margin-left: 0;
    margin-right: 0;
    width: 100%
}

.tbl {
    width: 100%;
    border-collapse: collapse
}

.tbl th,.tbl td {
    border: 1px solid #e5e5e5;
    vertical-align: top
}

.tbl th {
    background: #eee;
    padding: 10px;
    font-weight: 400
}

.tbl td {
    padding: 10px
}

.tbl.tbl--01 th {
    text-align: left
}

.tbl.tbl--02 th,.tbl.tbl--02 td {
    background: #fff;
    border: 0
}

.tbl .no_bdr_btm {
    border-bottom: none
}

.align-left {
    text-align: left
}

.align-right {
    text-align: right
}

.align-center {
    text-align: center
}

.mt0 {
    margin-top: 0px !important
}

.mb0 {
    margin-bottom: 0px !important
}

.ml0 {
    margin-left: 0px !important
}

.mr0 {
    margin-right: 0px !important
}

.pt0 {
    padding-top: 0px !important
}

.pb0 {
    padding-bottom: 0px !important
}

.pl0 {
    padding-left: 0px !important
}

.pr0 {
    padding-right: 0px !important
}

.mt1 {
    margin-top: 1px !important
}

.mb1 {
    margin-bottom: 1px !important
}

.ml1 {
    margin-left: 1px !important
}

.mr1 {
    margin-right: 1px !important
}

.pt1 {
    padding-top: 1px !important
}

.pb1 {
    padding-bottom: 1px !important
}

.pl1 {
    padding-left: 1px !important
}

.pr1 {
    padding-right: 1px !important
}

.mt2 {
    margin-top: 2px !important
}

.mb2 {
    margin-bottom: 2px !important
}

.ml2 {
    margin-left: 2px !important
}

.mr2 {
    margin-right: 2px !important
}

.pt2 {
    padding-top: 2px !important
}

.pb2 {
    padding-bottom: 2px !important
}

.pl2 {
    padding-left: 2px !important
}

.pr2 {
    padding-right: 2px !important
}

.mt3 {
    margin-top: 3px !important
}

.mb3 {
    margin-bottom: 3px !important
}

.ml3 {
    margin-left: 3px !important
}

.mr3 {
    margin-right: 3px !important
}

.pt3 {
    padding-top: 3px !important
}

.pb3 {
    padding-bottom: 3px !important
}

.pl3 {
    padding-left: 3px !important
}

.pr3 {
    padding-right: 3px !important
}

.mt4 {
    margin-top: 4px !important
}

.mb4 {
    margin-bottom: 4px !important
}

.ml4 {
    margin-left: 4px !important
}

.mr4 {
    margin-right: 4px !important
}

.pt4 {
    padding-top: 4px !important
}

.pb4 {
    padding-bottom: 4px !important
}

.pl4 {
    padding-left: 4px !important
}

.pr4 {
    padding-right: 4px !important
}

.mt5 {
    margin-top: 5px !important
}

.mb5 {
    margin-bottom: 5px !important
}

.ml5 {
    margin-left: 5px !important
}

.mr5 {
    margin-right: 5px !important
}

.pt5 {
    padding-top: 5px !important
}

.pb5 {
    padding-bottom: 5px !important
}

.pl5 {
    padding-left: 5px !important
}

.pr5 {
    padding-right: 5px !important
}

.mt6 {
    margin-top: 6px !important
}

.mb6 {
    margin-bottom: 6px !important
}

.ml6 {
    margin-left: 6px !important
}

.mr6 {
    margin-right: 6px !important
}

.pt6 {
    padding-top: 6px !important
}

.pb6 {
    padding-bottom: 6px !important
}

.pl6 {
    padding-left: 6px !important
}

.pr6 {
    padding-right: 6px !important
}

.mt7 {
    margin-top: 7px !important
}

.mb7 {
    margin-bottom: 7px !important
}

.ml7 {
    margin-left: 7px !important
}

.mr7 {
    margin-right: 7px !important
}

.pt7 {
    padding-top: 7px !important
}

.pb7 {
    padding-bottom: 7px !important
}

.pl7 {
    padding-left: 7px !important
}

.pr7 {
    padding-right: 7px !important
}

.mt8 {
    margin-top: 8px !important
}

.mb8 {
    margin-bottom: 8px !important
}

.ml8 {
    margin-left: 8px !important
}

.mr8 {
    margin-right: 8px !important
}

.pt8 {
    padding-top: 8px !important
}

.pb8 {
    padding-bottom: 8px !important
}

.pl8 {
    padding-left: 8px !important
}

.pr8 {
    padding-right: 8px !important
}

.mt9 {
    margin-top: 9px !important
}

.mb9 {
    margin-bottom: 9px !important
}

.ml9 {
    margin-left: 9px !important
}

.mr9 {
    margin-right: 9px !important
}

.pt9 {
    padding-top: 9px !important
}

.pb9 {
    padding-bottom: 9px !important
}

.pl9 {
    padding-left: 9px !important
}

.pr9 {
    padding-right: 9px !important
}

.mt10 {
    margin-top: 10px !important
}

.mb10 {
    margin-bottom: 10px !important
}

.ml10 {
    margin-left: 10px !important
}

.mr10 {
    margin-right: 10px !important
}

.pt10 {
    padding-top: 10px !important
}

.pb10 {
    padding-bottom: 10px !important
}

.pl10 {
    padding-left: 10px !important
}

.pr10 {
    padding-right: 10px !important
}

.mt15 {
    margin-top: 15px !important
}

.mb15 {
    margin-bottom: 15px !important
}

.ml15 {
    margin-left: 15px !important
}

.mr15 {
    margin-right: 15px !important
}

.pt15 {
    padding-top: 15px !important
}

.pb15 {
    padding-bottom: 15px !important
}

.pl15 {
    padding-left: 15px !important
}

.pr15 {
    padding-right: 15px !important
}

.mt20 {
    margin-top: 20px !important
}

.mb20 {
    margin-bottom: 20px !important
}

.ml20 {
    margin-left: 20px !important
}

.mr20 {
    margin-right: 20px !important
}

.pt20 {
    padding-top: 20px !important
}

.pb20 {
    padding-bottom: 20px !important
}

.pl20 {
    padding-left: 20px !important
}

.pr20 {
    padding-right: 20px !important
}

.mt25 {
    margin-top: 25px !important
}

.mb25 {
    margin-bottom: 25px !important
}

.ml25 {
    margin-left: 25px !important
}

.mr25 {
    margin-right: 25px !important
}

.pt25 {
    padding-top: 25px !important
}

.pb25 {
    padding-bottom: 25px !important
}

.pl25 {
    padding-left: 25px !important
}

.pr25 {
    padding-right: 25px !important
}

.mt30 {
    margin-top: 30px !important
}

.mb30 {
    margin-bottom: 30px !important
}

.ml30 {
    margin-left: 30px !important
}

.mr30 {
    margin-right: 30px !important
}

.pt30 {
    padding-top: 30px !important
}

.pb30 {
    padding-bottom: 30px !important
}

.pl30 {
    padding-left: 30px !important
}

.pr30 {
    padding-right: 30px !important
}

.mt35 {
    margin-top: 35px !important
}

.mb35 {
    margin-bottom: 35px !important
}

.ml35 {
    margin-left: 35px !important
}

.mr35 {
    margin-right: 35px !important
}

.pt35 {
    padding-top: 35px !important
}

.pb35 {
    padding-bottom: 35px !important
}

.pl35 {
    padding-left: 35px !important
}

.pr35 {
    padding-right: 35px !important
}

.mt40 {
    margin-top: 40px !important
}

.mb40 {
    margin-bottom: 40px !important
}

.ml40 {
    margin-left: 40px !important
}

.mr40 {
    margin-right: 40px !important
}

.pt40 {
    padding-top: 40px !important
}

.pb40 {
    padding-bottom: 40px !important
}

.pl40 {
    padding-left: 40px !important
}

.pr40 {
    padding-right: 40px !important
}

.mt45 {
    margin-top: 45px !important
}

.mb45 {
    margin-bottom: 45px !important
}

.ml45 {
    margin-left: 45px !important
}

.mr45 {
    margin-right: 45px !important
}

.pt45 {
    padding-top: 45px !important
}

.pb45 {
    padding-bottom: 45px !important
}

.pl45 {
    padding-left: 45px !important
}

.pr45 {
    padding-right: 45px !important
}

.mt50 {
    margin-top: 50px !important
}

.mb50 {
    margin-bottom: 50px !important
}

.ml50 {
    margin-left: 50px !important
}

.mr50 {
    margin-right: 50px !important
}

.pt50 {
    padding-top: 50px !important
}

.pb50 {
    padding-bottom: 50px !important
}

.pl50 {
    padding-left: 50px !important
}

.pr50 {
    padding-right: 50px !important
}

.mt55 {
    margin-top: 55px !important
}

.mb55 {
    margin-bottom: 55px !important
}

.ml55 {
    margin-left: 55px !important
}

.mr55 {
    margin-right: 55px !important
}

.pt55 {
    padding-top: 55px !important
}

.pb55 {
    padding-bottom: 55px !important
}

.pl55 {
    padding-left: 55px !important
}

.pr55 {
    padding-right: 55px !important
}

.mt60 {
    margin-top: 60px !important
}

.mb60 {
    margin-bottom: 60px !important
}

.ml60 {
    margin-left: 60px !important
}

.mr60 {
    margin-right: 60px !important
}

.pt60 {
    padding-top: 60px !important
}

.pb60 {
    padding-bottom: 60px !important
}

.pl60 {
    padding-left: 60px !important
}

.pr60 {
    padding-right: 60px !important
}

.mt65 {
    margin-top: 65px !important
}

.mb65 {
    margin-bottom: 65px !important
}

.ml65 {
    margin-left: 65px !important
}

.mr65 {
    margin-right: 65px !important
}

.pt65 {
    padding-top: 65px !important
}

.pb65 {
    padding-bottom: 65px !important
}

.pl65 {
    padding-left: 65px !important
}

.pr65 {
    padding-right: 65px !important
}

.mt70 {
    margin-top: 70px !important
}

.mb70 {
    margin-bottom: 70px !important
}

.ml70 {
    margin-left: 70px !important
}

.mr70 {
    margin-right: 70px !important
}

.pt70 {
    padding-top: 70px !important
}

.pb70 {
    padding-bottom: 70px !important
}

.pl70 {
    padding-left: 70px !important
}

.pr70 {
    padding-right: 70px !important
}

.mt75 {
    margin-top: 75px !important
}

.mb75 {
    margin-bottom: 75px !important
}

.ml75 {
    margin-left: 75px !important
}

.mr75 {
    margin-right: 75px !important
}

.pt75 {
    padding-top: 75px !important
}

.pb75 {
    padding-bottom: 75px !important
}

.pl75 {
    padding-left: 75px !important
}

.pr75 {
    padding-right: 75px !important
}

.mt80 {
    margin-top: 80px !important
}

.mb80 {
    margin-bottom: 80px !important
}

.ml80 {
    margin-left: 80px !important
}

.mr80 {
    margin-right: 80px !important
}

.pt80 {
    padding-top: 80px !important
}

.pb80 {
    padding-bottom: 80px !important
}

.pl80 {
    padding-left: 80px !important
}

.pr80 {
    padding-right: 80px !important
}

.mt85 {
    margin-top: 85px !important
}

.mb85 {
    margin-bottom: 85px !important
}

.ml85 {
    margin-left: 85px !important
}

.mr85 {
    margin-right: 85px !important
}

.pt85 {
    padding-top: 85px !important
}

.pb85 {
    padding-bottom: 85px !important
}

.pl85 {
    padding-left: 85px !important
}

.pr85 {
    padding-right: 85px !important
}

.mt90 {
    margin-top: 90px !important
}

.mb90 {
    margin-bottom: 90px !important
}

.ml90 {
    margin-left: 90px !important
}

.mr90 {
    margin-right: 90px !important
}

.pt90 {
    padding-top: 90px !important
}

.pb90 {
    padding-bottom: 90px !important
}

.pl90 {
    padding-left: 90px !important
}

.pr90 {
    padding-right: 90px !important
}

.mt95 {
    margin-top: 95px !important
}

.mb95 {
    margin-bottom: 95px !important
}

.ml95 {
    margin-left: 95px !important
}

.mr95 {
    margin-right: 95px !important
}

.pt95 {
    padding-top: 95px !important
}

.pb95 {
    padding-bottom: 95px !important
}

.pl95 {
    padding-left: 95px !important
}

.pr95 {
    padding-right: 95px !important
}

.mt100 {
    margin-top: 100px !important
}

.mb100 {
    margin-bottom: 100px !important
}

.ml100 {
    margin-left: 100px !important
}

.mr100 {
    margin-right: 100px !important
}

.pt100 {
    padding-top: 100px !important
}

.pb100 {
    padding-bottom: 100px !important
}

.pl100 {
    padding-left: 100px !important
}

.pr100 {
    padding-right: 100px !important
}

.g-container {
    margin-right: auto;
    margin-left: auto;
    padding-left: 15px;
    padding-right: 15px
}

@media print, screen and (min-width: 992px) {
    .g-container {
        max-width:1000px
    }
}

.g-container-fluid {
    margin-right: auto;
    margin-left: auto;
    padding-left: 15px;
    padding-right: 15px
}

.g-row {
    margin-left: -15px;
    margin-right: -15px
}

.g-col-xs-1,.g-col-sm-1,.g-col-md-1,.g-col-lg-1,.g-col-xs-2,.g-col-sm-2,.g-col-md-2,.g-col-lg-2,.g-col-xs-3,.g-col-sm-3,.g-col-md-3,.g-col-lg-3,.g-col-xs-4,.g-col-sm-4,.g-col-md-4,.g-col-lg-4,.g-col-xs-5,.g-col-sm-5,.g-col-md-5,.g-col-lg-5,.g-col-xs-6,.g-col-sm-6,.g-col-md-6,.g-col-lg-6,.g-col-xs-7,.g-col-sm-7,.g-col-md-7,.g-col-lg-7,.g-col-xs-8,.g-col-sm-8,.g-col-md-8,.g-col-lg-8,.g-col-xs-9,.g-col-sm-9,.g-col-md-9,.g-col-lg-9,.g-col-xs-10,.g-col-sm-10,.g-col-md-10,.g-col-lg-10,.g-col-xs-11,.g-col-sm-11,.g-col-md-11,.g-col-lg-11,.g-col-xs-12,.g-col-sm-12,.g-col-md-12,.g-col-lg-12 {
    position: relative;
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px
}

.g-col-xs-1,.g-col-xs-2,.g-col-xs-3,.g-col-xs-4,.g-col-xs-5,.g-col-xs-6,.g-col-xs-7,.g-col-xs-8,.g-col-xs-9,.g-col-xs-10,.g-col-xs-11,.g-col-xs-12 {
    float: left
}

.g-col-xs-12 {
    width: 100%
}

.g-col-xs-11 {
    width: 91.66666667%
}

.g-col-xs-10 {
    width: 83.33333333%
}

.g-col-xs-9 {
    width: 75%
}

.g-col-xs-8 {
    width: 66.66666667%
}

.g-col-xs-7 {
    width: 58.33333333%
}

.g-col-xs-6 {
    width: 50%
}

.g-col-xs-5 {
    width: 41.66666667%
}

.g-col-xs-4 {
    width: 33.33333333%
}

.g-col-xs-3 {
    width: 25%
}

.g-col-xs-2 {
    width: 16.66666667%
}

.g-col-xs-1 {
    width: 8.33333333%
}

.g-col-xs-pull-12 {
    right: 100%
}

.g-col-xs-pull-11 {
    right: 91.66666667%
}

.g-col-xs-pull-10 {
    right: 83.33333333%
}

.g-col-xs-pull-9 {
    right: 75%
}

.g-col-xs-pull-8 {
    right: 66.66666667%
}

.g-col-xs-pull-7 {
    right: 58.33333333%
}

.g-col-xs-pull-6 {
    right: 50%
}

.g-col-xs-pull-5 {
    right: 41.66666667%
}

.g-col-xs-pull-4 {
    right: 33.33333333%
}

.g-col-xs-pull-3 {
    right: 25%
}

.g-col-xs-pull-2 {
    right: 16.66666667%
}

.g-col-xs-pull-1 {
    right: 8.33333333%
}

.g-col-xs-pull-0 {
    right: auto
}

.g-col-xs-push-12 {
    left: 100%
}

.g-col-xs-push-11 {
    left: 91.66666667%
}

.g-col-xs-push-10 {
    left: 83.33333333%
}

.g-col-xs-push-9 {
    left: 75%
}

.g-col-xs-push-8 {
    left: 66.66666667%
}

.g-col-xs-push-7 {
    left: 58.33333333%
}

.g-col-xs-push-6 {
    left: 50%
}

.g-col-xs-push-5 {
    left: 41.66666667%
}

.g-col-xs-push-4 {
    left: 33.33333333%
}

.g-col-xs-push-3 {
    left: 25%
}

.g-col-xs-push-2 {
    left: 16.66666667%
}

.g-col-xs-push-1 {
    left: 8.33333333%
}

.g-col-xs-push-0 {
    left: auto
}

.g-col-xs-offset-12 {
    margin-left: 100%
}

.g-col-xs-offset-11 {
    margin-left: 91.66666667%
}

.g-col-xs-offset-10 {
    margin-left: 83.33333333%
}

.g-col-xs-offset-9 {
    margin-left: 75%
}

.g-col-xs-offset-8 {
    margin-left: 66.66666667%
}

.g-col-xs-offset-7 {
    margin-left: 58.33333333%
}

.g-col-xs-offset-6 {
    margin-left: 50%
}

.g-col-xs-offset-5 {
    margin-left: 41.66666667%
}

.g-col-xs-offset-4 {
    margin-left: 33.33333333%
}

.g-col-xs-offset-3 {
    margin-left: 25%
}

.g-col-xs-offset-2 {
    margin-left: 16.66666667%
}

.g-col-xs-offset-1 {
    margin-left: 8.33333333%
}

.g-col-xs-offset-0 {
    margin-left: 0%
}

@media print, screen and (min-width: 640px) {
    .g-col-sm-1,.g-col-sm-2,.g-col-sm-3,.g-col-sm-4,.g-col-sm-5,.g-col-sm-6,.g-col-sm-7,.g-col-sm-8,.g-col-sm-9,.g-col-sm-10,.g-col-sm-11,.g-col-sm-12 {
        float:left
    }

    .g-col-sm-12 {
        width: 100%
    }

    .g-col-sm-11 {
        width: 91.66666667%
    }

    .g-col-sm-10 {
        width: 83.33333333%
    }

    .g-col-sm-9 {
        width: 75%
    }

    .g-col-sm-8 {
        width: 66.66666667%
    }

    .g-col-sm-7 {
        width: 58.33333333%
    }

    .g-col-sm-6 {
        width: 50%
    }

    .g-col-sm-5 {
        width: 41.66666667%
    }

    .g-col-sm-4 {
        width: 33.33333333%
    }

    .g-col-sm-3 {
        width: 25%
    }

    .g-col-sm-2 {
        width: 16.66666667%
    }

    .g-col-sm-1 {
        width: 8.33333333%
    }

    .g-col-sm-pull-12 {
        right: 100%
    }

    .g-col-sm-pull-11 {
        right: 91.66666667%
    }

    .g-col-sm-pull-10 {
        right: 83.33333333%
    }

    .g-col-sm-pull-9 {
        right: 75%
    }

    .g-col-sm-pull-8 {
        right: 66.66666667%
    }

    .g-col-sm-pull-7 {
        right: 58.33333333%
    }

    .g-col-sm-pull-6 {
        right: 50%
    }

    .g-col-sm-pull-5 {
        right: 41.66666667%
    }

    .g-col-sm-pull-4 {
        right: 33.33333333%
    }

    .g-col-sm-pull-3 {
        right: 25%
    }

    .g-col-sm-pull-2 {
        right: 16.66666667%
    }

    .g-col-sm-pull-1 {
        right: 8.33333333%
    }

    .g-col-sm-pull-0 {
        right: auto
    }

    .g-col-sm-push-12 {
        left: 100%
    }

    .g-col-sm-push-11 {
        left: 91.66666667%
    }

    .g-col-sm-push-10 {
        left: 83.33333333%
    }

    .g-col-sm-push-9 {
        left: 75%
    }

    .g-col-sm-push-8 {
        left: 66.66666667%
    }

    .g-col-sm-push-7 {
        left: 58.33333333%
    }

    .g-col-sm-push-6 {
        left: 50%
    }

    .g-col-sm-push-5 {
        left: 41.66666667%
    }

    .g-col-sm-push-4 {
        left: 33.33333333%
    }

    .g-col-sm-push-3 {
        left: 25%
    }

    .g-col-sm-push-2 {
        left: 16.66666667%
    }

    .g-col-sm-push-1 {
        left: 8.33333333%
    }

    .g-col-sm-push-0 {
        left: auto
    }

    .g-col-sm-offset-12 {
        margin-left: 100%
    }

    .g-col-sm-offset-11 {
        margin-left: 91.66666667%
    }

    .g-col-sm-offset-10 {
        margin-left: 83.33333333%
    }

    .g-col-sm-offset-9 {
        margin-left: 75%
    }

    .g-col-sm-offset-8 {
        margin-left: 66.66666667%
    }

    .g-col-sm-offset-7 {
        margin-left: 58.33333333%
    }

    .g-col-sm-offset-6 {
        margin-left: 50%
    }

    .g-col-sm-offset-5 {
        margin-left: 41.66666667%
    }

    .g-col-sm-offset-4 {
        margin-left: 33.33333333%
    }

    .g-col-sm-offset-3 {
        margin-left: 25%
    }

    .g-col-sm-offset-2 {
        margin-left: 16.66666667%
    }

    .g-col-sm-offset-1 {
        margin-left: 8.33333333%
    }

    .g-col-sm-offset-0 {
        margin-left: 0%
    }
}

.clearfix:before,.clearfix:after,.g-container:before,.g-container:after,.g-container-fluid:before,.g-container-fluid:after,.g-row:before,.g-row:after {
    content: " ";
    display: table
}

.clearfix:after,.g-container:after,.g-container-fluid:after,.g-row:after {
    clear: both
}

.center-block {
    display: block;
    margin-left: auto;
    margin-right: auto
}

.pull-right {
    float: right !important
}

.pull-left {
    float: left !important
}

.no-padding {
    padding-left: 0;
    padding-right: 0
}

.hide {
    display: none !important
}

.show {
    display: block !important
}

.invisible {
    visibility: hidden
}

.text-hide {
    font: 0/0 a;
    color: transparent;
    text-shadow: none;
    background-color: transparent;
    border: 0
}

.hidden {
    display: none !important
}

.affix {
    position: fixed
}

.l-container {
    margin: auto
}

.l-header {
    height: 60px
}

@media print, screen and (min-width: 640px) {
    .l-header {
        height:0
    }
}

.l-main {
    width: 100%
}

/* add 2019/06/03 EU style */
.l-hero img {
	height: auto;
	max-width: 100%;
	width: 100%;
	margin-top:95px;
}

@media print, screen and (max-width: 639px) {
	.l-hero img {
		margin-top:34px;
	}
}


.l-breadcrumb {
    min-height: 20px;
    font-size: 16px;
    margin-bottom: 40px
}

.l-breadcrumb ul {
    max-width: 1000px;
    margin: 0 auto
}

.l-breadcrumb li {
    display: inline;
    background: none;
    padding: 0;
    font-feature-settings: "palt"
}

.l-breadcrumb li a {
    background-position: right center;
    background-repeat: no-repeat;
    color: #5c5c5c;
    margin-right: 8px;
    padding-right: 20px;
    background-image: url(/common/img/BreadcrumbArrow.jpg)
}

.l-breadcrumb li:last-child a {
    background-image: none
}

.l-breadcrumb li:last-child a.Current {
    text-decoration: none
}

@media print, screen and (min-width: 640px) {
    .l-breadcrumb {
        margin-bottom:50px
    }
}

.l-submenu {
    max-width: 970px;
    margin: 0 auto 30px
}

.l-content {
    position: relative
}

.l-content .l-content-header {
    position: relative;
    margin-bottom: 10px
}

.l-content .l-content-header:after {
    content: " ";
    display: table;
    clear: both
}

.l-content .l-content-header:before {
    content: " ";
    display: table
}

.l-content .l-content-body {
    margin-bottom: 30px
}

.l-content .l-content-footer {
    border-top: 1px solid #e5e5e6;
    padding: 0 15px;
    margin: 0 -15px
}

@media print, screen and (min-width: 640px) {
    .l-content .l-content-footer {
        margin:0 0 60px 0;
        padding: 0
    }
}

.l-footer {
    width: 100%
}

.l-section {
    margin-bottom: 30px
}

@media print {
	.g-col-sm-8 {
        width: 100% !important;
	}
    .small-image-print-80 {
		width: 80% !important;
		margin: 0 auto !important;
	}
    .small-image-print-60 {
		width: 60% !important;
		margin: 0 auto !important;
	}
    .small-image-print-40 {
		width: 40% !important;
		margin: 0 auto !important;
	}
    .small-image-print-20 {
		width: 20% !important;
		margin: 0 auto !important;
	}
    .small-image-print-15 {
		width: 15% !important;
		margin: 0 auto !important;
	}
}


/* ----------------------------------------- */
/* cookie message */
/* ----------------------------------------- */
#CookiesNsk .container {
	margin-right: auto;
	margin-left: auto;
	padding-left: 15px;
	padding-right: 15px;
}

@media(min-width:768px) {
	#CookiesNsk .container {
		width: 750px;
	}
}

@media(min-width:992px) {
	#CookiesNsk .container {
		width: 970px;
	}
}

@media(min-width:1200px) {
	#CookiesNsk .container {
		width: 1170px;
	}
}

#CookiesNsk .container:before,
#CookiesNsk .container:after {
	content: " ";
	display: table;
}

#CookiesNsk .container:after {
	clear: both;
}

#CookiesNsk .Container {
	margin: auto;
}


/* ----------------------------------------- */
/* Cookies */
/* ----------------------------------------- */
#CookiesNsk {
	background-color: #fff;
	border-bottom: 1px solid #e5e5e6;
	display: none;
	position: fixed;
	top: 0;
	left:0;
	width: 100%;
	z-index: 1000
}

#CookiesNsk .Container {
	padding: 15px
}

#CookiesNsk .Container:before,
#CookiesNsk .Container:after {
	content: " ";
	display: table
}

#CookiesNsk .Container:after {
	clear: both
}

#CookiesNsk .Container:before,
#CookiesNsk .Container:after {
	content: " ";
	display: table
}

#CookiesNsk .Container:after {
	clear: both
}

#CookiesNsk .Buttons {
	float: right;
	margin-left: 60px
}

#CookiesNsk .Buttons:before,
#CookiesNsk .Buttons:after {
	content: " ";
	display: table
}

#CookiesNsk .Buttons:after {
	clear: both
}

#CookiesNsk .Buttons:before,
#CookiesNsk .Buttons:after {
	content: " ";
	display: table
}

#CookiesNsk .Buttons:after {
	clear: both
}

#CookiesNsk .Buttons .Cell {
	float: left;
	padding-bottom: 3px;
	padding-top: 3px
}

#CookiesNsk .Buttons .Cell.First {
	border-right: 1px solid #e5e5e6;
	padding-right: 29px
}

#CookiesNsk .Buttons .Cell.Second {
	padding-left: 20px;
}

#CookiesNsk .Close {
	width: 30px;
}

#CookiesNsk .Close img {
	margin-top:10px;
}

#CookiesNsk h4 {
	font-family: inherit;
	font-weight: 500;
	line-height: 1.1;
	color: inherit;
	margin-top: 10px;
	margin-bottom: 10px;
	font-size: 18px;
}

@media only screen and (-webkit-min-device-pixel-ratio:1.5),
only screen and (min--moz-device-pixel-ratio:1.5),
only screen and (min-device-pixel-ratio:1.5) {
	#CookiesNsk h4 {
		font-weight: 300;
		font-size: 21px;
		line-height: 26px
	}
}


@media(max-width:768px) {
	#CookiesNsk h4 {
		font-size: 20px;
		line-height: 26px
	}
}

@media(max-width:350px) {
	#CookiesNsk h4 {
		font-size: 18px;
		line-height: 22px
	}
}

/* ----------------------------------------- */
@media print {
	#CookiesNsk .Container {
		width: 100%
		display: none
	}
}


/* ----------------------------------------- */
@media(min-width:970px) {
	#CookiesNsk .Container {
		width: 970px
	}
}


/* ----------------------------------------- */
@media(max-width:970px) {
	#CookiesNsk .Container {
		padding-left: 15px;
		padding-right: 15px
	}
}


/* ----------------------------------------- */
#CookiesNsk .Btn {
	background-color: #e4032e;
	border: 0;
	color: #fff;
	padding: 12px
}

#CookiesNsk input[type=submit].Btn {
	border: 0
}

#CookiesNsk a.Btn {
	display: inline-block
}

#CookiesNsk a.Btn:hover {
	text-decoration: none
}

#CookiesNsk .Btn:hover {
	background-color: #98021f;
	color: #fff
}





/* 以下TCI8/26公開作業分 */
/* 共通部分 */
/* 共通部分 */
.heading_h2 {
	margin: 0 0 30px 0;
	font-weight: bold;
	font-size: 2.2rem;
}
.l-content-footerArea {
    margin: 60px 0;
    padding: 0;
}

/* テクニカルジャーナルページ */
.tr_tech_pdfConts {
	display: block;
	width: 130px;
	margin: 0 30px 0 0;
}
.tr_tech_pdfConts img {
	width: 130px;
    border: 1px solid #e5e5e5;
}
.tr_tech_pdfConts th, .tr_tech_pdfConts td {
	display: block;
}
.tr_tech_commentary {
	display: block;
}

.tr_tech_commentary td {
	display: block;
}

.tr_tech_pdfConts th {
  width: 130px;
  background: #fff;
  margin: 0 0 10px 0;
}

.tbl tbody.tbody_tech {
  display: flex;
}

.tbl tbody.tbody_tech th, .tbl tbody.tbody_tech td {
  border: none;
  padding: 0;
}

.tech_bold {
	position: relative;
	font-size: 18px;
	font-weight: bold;
	margin: 0 0 20px 0;
}

.tech_bold::before {
	content: '';
	display: inline-block;
	background: #737272;
	width: 10px;
	height: 1px;
	margin: 0 5px 0 0;
	vertical-align: middle;
}

.tech_j-h3 {
	font-size: 14px;
	margin: 0 0 15px 0;
}

.heading_h2.global {
    font-size: 22px;
	margin: 0 0 30px 0;
	font-weight: bold;
}

.ul_textList {
	margin: 0 0 40px 0;
}
.ul_textList li:last-of-type {
	margin: 0;
}

@media(max-width:414px) {

	.tbl tbody.tbody_tech {
		display: block;
	}
	.tbl .tr_tech_pdfConts {
		flex-direction: inherit;
		margin: 0 0 20px 0;
	}

	.tr_tech_pdfConts th {
		margin: 0 30px 0 0;
	}
}

@media all and (-ms-high-contrast: none) {
	.tbl {
		table-layout:fixed;
	}
	.tr_tech_commentary {
		width: calc(100% - 160px);
	}
}

/* TOPページ */
.l-content .l-content-footer.top-footer {
    border-top: none;
}

/* 研究開発ページ */
.imgBox_right {
	width: 300px;
}
.box_flex {
	display: flex;
}
.textBox_left {
	padding: 0 30px 0 0px;
}
.textBox_left p {
	margin: 0 0 14px 0;
}
.textBox_left p:last-of-type {
    margin: 0;
}
.textBox_left .m-015__text {
	margin: 0;
}
.heading_h1 {
	font-size: 24px;
	font-weight: normal;
    margin: 0 0 30px 0;
}
.heading_h1::after {
    border-bottom: 1px solid #b2b2b2;
    content: '';
    display: block;
    padding-top: .5em;
    width: 28px;
}
.heading_h3, .heading_h2-red {
	position: relative;
	font-size: 18px;
	font-weight: bold;
	color: #E4032E;
	margin: 0 0 10px 0;
}
.heading_h3::before, .heading_h2-red::before {
	content: '';
	display: inline-block;
	background: #E4032E;
	width: 10px;
	height: 1px;
	vertical-align: middle;
	margin: 0 5px 0 0;
}

.txt-016_bold {
	font-size: 16px;
	font-weight: bold;
	margin: 0 0 10px 0;
}

.panel-title.m-h2_title-bold {
    font-weight: 500;
}


@media(max-width:768px) {
    .l-content-footerArea {
        margin: 40px 0 30px;
        padding: 0;
    }
}

@media(max-width:414px) {
	.sp_column-reverse {
		flex-direction: column-reverse;
	}
	.imgBox_right {
		width: 100%;
	}
	.box_flex.mb40 .textBox_left {
        margin: 30px 0 0 0;
		padding: 0;
	}
    .box_flex.mb30 .textBox_left {
        margin: 20px 0 0 0;
        padding: 0;
    }
    .sp_mb0 {
        margin-bottom: 0 !important;
    }
    .heading_h3, .heading_h2-red {
        margin: 0 0 20px 0;
    }
}

/* 以下TCI提案デザイン実装10/08~NNS作業分 */

/* 共通部分 */

.imgBox_left {
	width: 300px;
}

.textBox_right {
	padding: 0 0 0 30px;
}
.textBox_right p {
	margin: 0 0 14px 0;
}
.textBox_right p:last-of-type {
	margin: 0;
}
.textBox_right .m-015__text {
	margin: 0;
}

@media(max-width:414px) {
	.sp_column {
		flex-direction: column;
	}
	
	.imgBox_left {
		width: 100%;
	}
	.box_flex.mb40 .textBox_right {
		margin: 30px 0 0 0;
		padding: 0;
	}
	.box_flex.mb30 .textBox_right {
		margin: 20px 0 0 0;
		padding: 0;
	}
}

/* ここまで */

.l-breadcrumb {
	min-height: 20px;
	margin: 7px 0 40px;
	padding: 0 15px;
}
@media print, screen and (min-width: 640px) {
	.l-breadcrumb {
			margin: 15px 0 50px
	}
}