@charset "UTF-8";
/*! sanitize.css v2.0.0 | CC0 1.0 Public Domain | github.com/jonathantneal/sanitize.css */
/*
 * Normalization
 */
:root {
  -ms-overflow-style: -ms-autohiding-scrollbar;
  overflow-y: scroll;
  -webkit-text-size-adjust: 100%; }

audio:not([controls]) {
  display: none; }

button {
  overflow: visible; }

details {
  display: block; }

input[type="number"] {
  width: auto; }
input[type="search"] {
  -webkit-appearance: textfield; }
  input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none; }

main {
  display: block; }

summary {
  display: block; }

pre {
  overflow: auto; }

progress {
  display: inline-block; }

small {
  font-size: 75%; }

template {
  display: none; }

textarea {
  overflow: auto; }

[hidden] {
  display: none; }

/*
 * Universal inheritance
 */
*,
::before,
::after {
  box-sizing: inherit; }

* {
  font-size: inherit;
  line-height: inherit; }

::before,
::after {
  text-decoration: inherit;
  vertical-align: inherit; }

/*
 * Opinionated defaults
 */
*,
::before,
::after {
  border-style: solid;
  border-width: 0; }

* {
  margin: 0;
  padding: 0; }

:root {
  box-sizing: border-box;
  cursor: default;
  font: 100%/1.5 sans-serif;
  text-rendering: optimizeLegibility; }

html {
  background-color: #FFFFFF;
  color: #000000; }

a {
  text-decoration: none; }

audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle; }

button,
input,
select,
textarea {
  background-color: transparent; }

button,
input,
select,
textarea {
  color: inherit;
  font-family: inherit;
  font-style: inherit;
  font-weight: inherit; }

button,
[type="button"],
[type="date"],
[type="datetime"],
[type="datetime-local"],
[type="email"],
[type="month"],
[type="number"],
[type="password"],
[type="reset"],
[type="search"],
[type="submit"],
[type="tel"],
[type="text"],
[type="time"],
[type="url"],
[type="week"],
select,
textarea {
  min-height: 1.5em; }

code,
kbd,
pre,
samp {
  font-family: monospace, monospace; }

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

select {
  -moz-appearance: none;
  -webkit-appearance: none; }
  select::-ms-expand {
    display: none; }
  select::-ms-value {
    color: currentColor; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

textarea {
  resize: vertical; }

::selection {
  background-color: #B3D4FC;
  color: #4c2b03;
  text-shadow: none; }

[aria-busy="true"] {
  cursor: progress; }

[aria-controls] {
  cursor: pointer; }

[aria-disabled] {
  cursor: default; }

[hidden][aria-hidden="false"] {
  clip: rect(0 0 0 0);
  display: inherit;
  position: absolute; }
  [hidden][aria-hidden="false"]:focus {
    clip: auto; }

html {
  box-sizing: border-box; }

*, *::after, *::before {
  box-sizing: inherit; }

ul.nobullet {
  list-style-type: none;
  margin: 0;
  padding: 0; }

a {
  transition: .5s; }
  a img {
    border: none; }

.cols::after {
  clear: both;
  content: "";
  display: table; }

html, body {
  font-size: 13px;
  font-size: 1rem;
  line-height: 1.4;
  font-family: Meiryo, Verdana, "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", sans-serif; }

body {
  border-top: 8px solid #0b2450; }

.block {
  background: url(../images/bar.png) no-repeat right top;
  padding-top: 5px;
  border: 1px solid #d2d2d2; }

.txt-body {
  padding: 10px; }

/* header ========== */
header {
  background: url(../images/share/header_bg.png) repeat-x left top;
  border-bottom: 2px solid #d4d2d0;
  margin-bottom: 20px; }

.header-inner {
  width: 1000px;
  margin: 0 auto;
  height: 104px;
  position: relative;
  overflow: hidden; }
  .header-inner::after {
    clear: both;
    content: "";
    display: table; }
  .header-inner .ttl {
    margin-top: 17px; }
  .header-inner .copy {
    position: absolute;
    right: 0;
    top: -10px; }
  .header-inner .col-r {
    position: absolute;
    right: 0;
    top: 0; }

.lv2 .header-inner .ttl {
  margin-top: 10px; }
.lv2 .header-inner .mailmagazine {
  background-color: #0b2450;
  border-bottom-left-radius: 6px;
  border-bottom-right-radius: 6px;
  margin-bottom: 10px;
  padding: 6px 10px; }
  .lv2 .header-inner .mailmagazine::after {
    clear: both;
    content: "";
    display: table; }
  .lv2 .header-inner .mailmagazine p {
    float: left;
    font-size: 12px;
    color: #fff;
    padding-top: 3px;
    margin-right: 12px;
    font-weight: bold; }
  .lv2 .header-inner .mailmagazine input[type="text"] {
    background-color: #fff;
    border: 1px solid #484848;
    width: 140px;
    vertical-align: top;
    margin-right: 5px; }

/* totop =========== */
.totopInner {
  width: 1000px;
  margin: 0 auto; }
  .totopInner::after {
    clear: both;
    content: "";
    display: table; }
  .totopInner a {
    float: right; }

/* footer ========== */
footer .nav-bar {
  background-color: #0b2450;
  padding: 5px 5px 7px; }
  footer .nav-bar ul {
    text-align: center; }
    footer .nav-bar ul li {
      display: inline-block;
      border-right: 1px solid #fff;
      line-height: 0;
      padding-right: 13px;
      margin-right: 9px; }
      footer .nav-bar ul li a {
        color: #fff;
        font-size: 12px;
        line-height: 1; }
      footer .nav-bar ul li:last-of-type {
        border: none; }
footer address {
  text-align: center;
  font-style: normal;
  font-size: 10px;
  padding-top: 10px;
  padding-bottom: 30px; }

/* contents ======== */
#container {
  width: 1000px;
  margin: 0 auto;
  padding-bottom: 20px; }

/* key visual */
.kv {
  margin-bottom: 20px; }
  .kv .col-l {
    width: 300px;
    float: left; }
    .kv .col-l .txt-body p {
      font-size: 13px; }
    .kv .col-l .mailmagazine {
      border-top: 1px solid #014195;
      padding: 10px;
      background-color: #f2f2f2; }
      .kv .col-l .mailmagazine .txt-body {
        padding: 26px 10px 27px; }
      .kv .col-l .mailmagazine p {
        font-size: 13px; }
      .kv .col-l .mailmagazine form {
        margin-top: 10px; }
      .kv .col-l .mailmagazine input[type="text"] {
        border: 1px solid #484848;
        background-color: #fff;
        width: 190px;
        vertical-align: middle;
        font-size: 14px;
        line-height: 1.7;
        padding-left: 3px;
        padding-right: 3px; }
      .kv .col-l .mailmagazine button {
        vertical-align: middle;
        margin-left: 8px; }
    .kv .col-l .banner {
      margin-top: 10px; }
  .kv .col-r {
    width: 678px;
    float: right; }
  .kv .slider .screen {
    width: 676px;
    height: 351px;
    position: relative; }
    .kv .slider .screen .item {
      position: absolute;
      top: 0;
      left: 0;
      z-index: 10;
      opacity: 0;
      -webkit-transition: 0.5s;
      -moz-transition: 0.5s;
      transition: 0.5s; }
      .kv .slider .screen .item.active {
        z-index: 20;
        opacity: 1; }
  .kv .slider .tab-container {
    border-top: 1px solid #dd1e1e;
    position: relative; }
    .kv .slider .tab-container .tabs {
      list-style-type: none; }
      .kv .slider .tab-container .tabs::after {
        clear: both;
        content: "";
        display: table; }
      .kv .slider .tab-container .tabs li {
        float: left; }
        .kv .slider .tab-container .tabs li a {
          display: block; }
          .kv .slider .tab-container .tabs li a img {
            width: 169px;
            height: auto; }
    .kv .slider .tab-container .currentframe {
      position: absolute;
      top: 0;
      left: 0;
      border: 4px solid #dd1e1e;
      width: 169px;
      height: 107px;
      z-index: 50; }
      .kv .slider .tab-container .currentframe img {
        position: absolute;
        top: -12px;
        left: 50%;
        margin-left: -14px; }

_::content, _:future, .kv .col-l .txt-body:not(*:root) {
  padding: 26px 10px 25px; }

@-moz-document url-prefix() {
  .kv .col-l .txt-body {
    padding: 26px 10px 21px; } }
@media screen and (-webkit-min-device-pixel-ratio: 0) {
  .kv .col-l .txt-body {
    padding: 26px 10px 25px; } }
@media all and (-ms-high-contrast: none) {
  .kv .col-l .txt-body {
    padding: 26px 10px 22px; } }
.list-container {
  position: relative; }
  .list-container .tab-container .tabs {
    list-style-type: none; }
    .list-container .tab-container .tabs::after {
      clear: both;
      content: "";
      display: table; }
    .list-container .tab-container .tabs li {
      float: left;
      margin-right: 5px; }
      .list-container .tab-container .tabs li a {
        display: block;
        width: 132px;
        height: 36px;
        text-indent: -9999px; }
      .list-container .tab-container .tabs li:first-of-type a {
        background: url(../images/share/tab01.png) no-repeat left top; }
      .list-container .tab-container .tabs li:first-of-type.current a {
        background-image: url(../images/share/tab01_on.png); }
      .list-container .tab-container .tabs li:nth-of-type(2) a {
        background: url(../images/share/tab02.png) no-repeat left top; }
      .list-container .tab-container .tabs li:nth-of-type(2).current a {
        background-image: url(../images/share/tab02_on.png); }
      .list-container .tab-container .tabs li:last-of-type a {
        background: url(../images/share/tab03.png) no-repeat left top; }
      .list-container .tab-container .tabs li:last-of-type.current a {
        background-image: url(../images/share/tab03_on.png); }

.list-contents {
  border: 6px solid #014195;
  background-color: #014195;
  padding-bottom: 6px;
  overflow: hidden; }
  .list-contents .list {
    max-height: 655px;
    overflow: hidden;
    position: relative;
    display: none; }
    .list-contents .list.active {
      display: block; }
    .list-contents .list ul {
      list-style-type: none; }
      .list-contents .list ul::after {
        clear: both;
        content: "";
        display: table; }
      .list-contents .list ul li {
        background-color: #fff; }
        .list-contents .list ul li a {
          display: block; }
          .list-contents .list ul li a::after {
            clear: both;
            content: "";
            display: table; }
          .list-contents .list ul li a figure {
            float: left;
            position: relative;
            margin-right: 10px;
            overflow: hidden; }
            .list-contents .list ul li a figure .olimg {
              position: absolute;
              width: 100%;
              height: 100%;
              left: 0;
              top: 0;
              bottom: 0;
              text-align: center;
              background-color: #fff;
              display: table;
              opacity: 0;
              -webkit-transition: 0.3s;
              -moz-transition: 0.3s;
              transition: 0.3s; }
              .list-contents .list ul li a figure .olimg .olimg_inner {
                height: 100%;
                display: table-cell;
                vertical-align: middle; }
                .list-contents .list ul li a figure .olimg .olimg_inner img {
                  vertical-align: middle; }
          .list-contents .list ul li a .intv-info {
            padding: 10px; }
            .list-contents .list ul li a .intv-info .company, .list-contents .list ul li a .intv-info .position, .list-contents .list ul li a .intv-info .name, .list-contents .list ul li a .intv-info .excerpt {
              color: #000; }
            .list-contents .list ul li a .intv-info .name {
              font-size: 18px; }
              .list-contents .list ul li a .intv-info .name small {
                font-size: 14px; }
            .list-contents .list ul li a .intv-info .company {
              font-size: 14px; }
            .list-contents .list ul li a .intv-info .position {
              font-size: 14px; }
            .list-contents .list ul li a .intv-info .excerpt p {
              font-size: 12px; }
          .list-contents .list ul li a:hover figure .olimg {
            opacity: 1; }
    .list-contents .list .latest li {
      width: 50%;
      float: left;
      border-top: 6px solid #014195;
      position: relative; }
      .list-contents .list .latest li:nth-of-type(2n) {
        border-left: 6px solid #014195; }
      .list-contents .list .latest li:first-of-type, .list-contents .list .latest li:nth-of-type(2) {
        border-top: none; }
      .list-contents .list .latest li figure {
        overflow: hidden; }
      .list-contents .list .latest li a {
        display: block; }
        .list-contents .list .latest li a figure {
          position: absolute;
          height: 100%;
          width: 169px;
          left: 0;
          top: 0;
          bottom: 0;
          background-size: cover !important;
          background-position: center center;
          background-repeat: no-repeat;
          background-color: #fff; }
          .list-contents .list .latest li a figure .olimg {
            position: absolute;
            width: 100%;
            height: 100%;
            left: 0;
            top: 0;
            bottom: 0;
            text-align: center;
            background-color: #fff; }
            .list-contents .list .latest li a figure .olimg .olimg_inner {
              height: 100%;
              display: table-cell;
              vertical-align: middle; }
              .list-contents .list .latest li a figure .olimg .olimg_inner img {
                vertical-align: middle; }
        .list-contents .list .latest li a .intv-info {
          margin-left: 175px; }
    .list-contents .list .past li {
      width: 33.333%;
      float: left;
      border-top: 6px solid #014195;
      border-right: 6px solid #014195;
      position: relative; }
      .list-contents .list .past li:nth-of-type(3n) {
        border-right: none; }
      .list-contents .list .past li img {
        width: 110px;
        height: auto; }
      .list-contents .list .past li a .intv-info {
        padding: 5px; }
        .list-contents .list .past li a .intv-info .name {
          font-size: 16px; }
        .list-contents .list .past li a .intv-info .position {
          font-size: 13px; }
        .list-contents .list .past li a .intv-info .company {
          font-size: 13px; }
      .list-contents .list .past li:first-of-type, .list-contents .list .past li:nth-of-type(2), .list-contents .list .past li:nth-of-type(3) {
        border-top: none; }
      .list-contents .list .past li figure {
        overflow: hidden; }
      .list-contents .list .past li a {
        display: block; }
        .list-contents .list .past li a figure {
          position: absolute;
          height: 100%;
          width: 110px;
          left: 0;
          top: 0;
          bottom: 0;
          background-size: cover !important;
          background-position: center center;
          background-repeat: no-repeat;
          background-color: #fff; }
        .list-contents .list .past li a .intv-info {
          margin-left: 115px; }
    .list-contents .list .latest + .past li:first-of-type, .list-contents .list .latest + .past li:nth-of-type(2), .list-contents .list .latest + .past li:nth-of-type(3) {
      border-top: 6px solid #014195; }
  .list-contents .close {
    text-align: center;
    padding: 20px 0 5px;
    color: #fff;
    display: none; }
    .list-contents .close span {
      background: url(../images/share/cross.png) no-repeat left top;
      padding-left: 27px;
      margin-top: 12px; }

.single .list-contents {
  position: absolute;
  width: 100%;
  top: 36px;
  left: 0;
  z-index: 100; }
  .single .list-contents .list {
    max-height: 400px;
    overflow: hidden;
    position: relative; }

/* article ============================== */
.content {
  border-right: 1px solid #8a8a8a;
  border-bottom: 1px solid #8a8a8a;
  border-left: 1px solid #8a8a8a; }

.article-title {
  background: url(../images/share/title_bg.png) no-repeat left top;
  position: relative;
  min-height: 111px; }
  .article-title .col-l {
    padding: 20px;
    margin-top: 18px; }
    .article-title .col-l .company {
      color: #fff;
      font-size: 20px; }
    .article-title .col-l h1 {
      color: #fff;
      font-size: 30px; }
  .article-title .col-r {
    position: absolute;
    right: 20px;
    top: 20px; }

article .official {
  padding: 4px 20px;
  text-align: right;
  font-size: 13px; }
  article .official a {
    color: #002584;
    margin-left: 1em; }
article .kv {
  border-top: 1px solid #d9d9d9;
  border-bottom: 3px solid #d9d9d9;
  position: relative;
  margin-bottom: 0; }
  article .kv .message {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    padding: 15px;
    text-align: center;
    background-color: rgba(255, 255, 255, 0.6); }
    article .kv .message h2 {
      color: #000;
      font-size: 22px;
      font-weight: 400; }
article .profile {
  border-bottom: 1px solid #e4e4e4;
  background-image: -webkit-linear-gradient( bottom , #f6f6f6, #fff);
  background-image: linear-gradient(to top, #f6f6f6, #fff);
  padding: 30px 95px; }
  article .profile p {
    font-size: 16px;
    line-height: 1.7;
    margin: 0; }
article .article-body {
  padding: 30px 95px; }
  article .article-body .lead {
    font-size: 16px;
    margin-bottom: 30px; }
  article .article-body .text-body::after {
    clear: both;
    content: "";
    display: table; }
  article .article-body .text-body img.alignright {
    float: right;
    margin-left: 20px;
    margin-bottom: 10px; }
  article .article-body .text-body img.alignleft {
    float: left;
    margin-right: 20px;
    margin-bottom: 10px; }
  article .article-body .text-body img.aligncenter {
    display: block;
    margin: 0 auto;
    margin: 10px 0; }
  article .article-body .text-body h3 {
    font-size: 16px;
    color: #014195;
    margin-bottom: 17px; }
  article .article-body .text-body p {
    font-size: 16px;
    margin-bottom: 1.5em; }
  article .article-body .editor {
    margin-top: 40px;
    margin-bottom: 0;
    font-size: 16px; }
  article .article-body .coope {
    font-size: 16px;
    margin: 20px 0; }
  article .article-body .date {
    margin-bottom: 0;
    font-size: 16px; }

.ad {
  margin: 0 95px 30px;
  border: 1px solid #a0aacb;
  background-color: #f4f4f4;
  padding: 8px 10px;
  position: relative; }
  .ad::after {
    clear: both;
    content: "";
    display: table; }
  .ad .col-l .adbanner {
    float: left;
    margin-right: 10px;
    padding-top: 4px; }
  .ad .col-l .ad-body {
    width: 70%; }
.ad .col-l .ad-body p {
font-size: 12px; }
  .ad .col-r {
    position: absolute;
    right: 10px;
    top: 17px; }

.related {
  border-top: 1px solid #8a8a8a;
  background: url(../images/article/related-bg.png) repeat left top; }
  .related .related-inner {
    width: 1000px;
    margin: 0 auto;
    position: relative;
    background-color: #fff;
    padding: 35px 0 23px 15px; }
    .related .related-inner h4 {
      text-indent: -9999px;
      background: url(../images/article/related-ttl.png) no-repeat left top;
      width: 408px;
      height: 32px;
      position: absolute;
      top: -17px;
      margin-left: -15px; }
    .related .related-inner .items {
      list-style-type: none; }
      .related .related-inner .items::after {
        clear: both;
        content: "";
        display: table; }
      .related .related-inner .items li {
        width: 33%;
        float: left; }
        .related .related-inner .items li::after {
          clear: both;
          content: "";
          display: table; }
        .related .related-inner .items li a {
          color: #000; }
        .related .related-inner .items li figure img {
          float: left;
          margin-right: 10px;
          border: 1px solid #014195;
          width: 120px;
          height: auto; }
        .related .related-inner .items li figure .c-name {
          font-size: 16px;
          margin-bottom: 3px;
          margin-left: 78px; }
        .related .related-inner .items li figure .p-name {
          font-size: 13px;
          margin-left: 78px; }
