@charset "UTF-8";
/* CSS Document */
.w5p {
  width: 5%; }

.w10p {
  width: 10%; }

.w15p {
  width: 15%; }

.w20p {
  width: 20%; }

.w25p {
  width: 25%; }

.w30p {
  width: 30%; }

.w35p {
  width: 35%; }

.w40p {
  width: 40%; }

.w45p {
  width: 45%; }

.w50p {
  width: 50%; }

.w55p {
  width: 55%; }

.w60p {
  width: 60%; }

.w65p {
  width: 65%; }

.w70p {
  width: 70%; }

.w75p {
  width: 75%; }

.w80p {
  width: 80%; }

.w85p {
  width: 85%; }

.w90p {
  width: 90%; }

.w95p {
  width: 95%; }

.w100p {
  width: 100%; }

.left {
  text-align: left; }

.center {
  text-align: center; }

.right {
  text-align: right; }

.noBoderb {
  border-bottom: none !important; }

/*********/
/* reset */
/*********/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

img {
  vertical-align: bottom; }

/***********************************************/
/* HTML5 display-role reset for older browsers */
/***********************************************/
body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: 500;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  -webkit-print-color-adjust: exact;
  letter-spacing: 0.02em;
  color: #333;
  line-height: 1;
  background-color: #fff !important; }
  @media only screen and (max-width: 767px) {
    body.nav-on {
      overflow: hidden; } }
  body .page-head {
    background: url("../img/bg_page-head-student.jpg") top left no-repeat;
    background-position: top center;
    background-size: cover; }
  body.about .page-head {
    background: url("../img/bg_page-head-about.jpg") top left no-repeat;
    background-position: top center;
    background-size: cover; }
  body.corporate .page-head {
    background: url("../img/bg_page-head-corporate.jpg") top left no-repeat;
    background-position: top center;
    background-size: cover; }

ol, ul {
  list-style: none; }
  ol li, ul li {
    margin-bottom: 5px; }

div, p {
  text-align: justify; }

b, strong {
  font-weight: bold; }

a {
  color: #333;
  text-decoration: none; }

a[href^="tel:"] {
  font-family: "arial";
  font-weight: bold; }
  @media print, screen and (min-width: 768px) {
    a[href^="tel:"] {
      pointer-events: none;
      text-decoration: none !important; } }
  @media only screen and (max-width: 767px) {
    a[href^="tel:"] {
      color: #0194ea;
      text-decoration: underline; } }

a[href^="mailto:"] {
  font-family: "arial";
  color: #0194ea;
  text-decoration: underline; }

.sideMenu {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 30;
  text-align: left; }
  @media print, screen and (min-width: 768px) {
    .sideMenu {
      width: 240px;
      height: 100vh;
      overflow-x: hidden;
      overflow-y: hidden;
      border-right: 1px solid #ccc; }
      .sideMenu.open {
        padding-right: 257px; } }
  @media only screen and (max-width: 767px) {
    .sideMenu {
      width: 100%;
      border-bottom: 1px solid #ccc; } }
  .sideMenu .sideMenu-inner {
    margin: 0;
    padding: 0;
    height: 100%; }
    @media print, screen and (min-width: 768px) {
      .sideMenu .sideMenu-inner {
        overflow-y: scroll;
        width: calc(100% + 17px);
        padding-right: 17px; } }
    @media only screen and (max-width: 767px) {
      .sideMenu .sideMenu-inner.open {
        position: fixed;
        width: 100%;
        height: 100%;
        overflow: auto;
        z-index: 10;
        background-color: rgba(0, 0, 0, 0.6); }
        .sideMenu .sideMenu-inner.open .list-parent, .sideMenu .sideMenu-inner.open .sns {
          display: block; } }
    @media only screen and (max-width: 767px) {
      .sideMenu .sideMenu-inner.close .list-parent, .sideMenu .sideMenu-inner.close .sns {
        display: none; } }
    @media only screen and (max-width: 767px) {
      .sideMenu .sideMenu-inner #sideMenu-footer {
        display: none; } }
    .sideMenu .sideMenu-inner #sideMenu-footer span {
      display: none; }
  @media only screen and (max-width: 767px) {
    .sideMenu .header {
      height: 50px;
      background-color: #fff; } }
  @media only screen and (max-width: 767px) {
    .sideMenu .header .logo {
      display: table;
      margin-right: 60px; } }
  @media print, screen and (min-width: 768px) {
    .sideMenu .header .logo .utokyo {
      width: 100%;
      height: 110px;
      text-align: center;
      display: table; } }
  @media only screen and (max-width: 767px) {
    .sideMenu .header .logo .utokyo {
      display: table-cell;
      vertical-align: middle;
      text-align: left;
      width: 100%;
      padding-left: 20px; } }
  .sideMenu .header .logo .utokyo a {
    display: table-cell;
    vertical-align: middle; }
    @media only screen and (max-width: 767px) {
      .sideMenu .header .logo .utokyo a {
        display: block; } }
    @media print, screen and (min-width: 768px) {
      .sideMenu .header .logo .utokyo a img {
        width: 170px;
        vertical-align: middle; } }
    @media only screen and (max-width: 767px) {
      .sideMenu .header .logo .utokyo a img {
        width: 100px;
        max-width: 85%; } }
  @media only screen and (max-width: 767px) {
    .sideMenu .header .logo .career {
      display: table-cell;
      text-align: right;
      width: 100%; } }
  .sideMenu .header .logo .career h1 a {
    display: block; }
  @media only screen and (max-width: 767px) {
    .sideMenu .header .logo .career h1 img {
      height: 50px; } }
  .sideMenu .header .nav {
    overflow: hidden;
    /*メニューボタンのエフェクト*/ }
    @media print, screen and (min-width: 768px) {
      .sideMenu .header .nav {
        display: none; } }
    .sideMenu .header .nav .nav-button,
    .sideMenu .header .nav .nav-button span {
      display: inline-block;
      -webkit-transition: all 0.4s;
      transition: all 0.4s;
      -webkit-box-sizing: border-box;
      box-sizing: border-box; }
    .sideMenu .header .nav .nav-button {
      display: block;
      cursor: pointer;
      position: absolute;
      overflow: hidden;
      top: 10px;
      right: 15px; }
      .sideMenu .header .nav .nav-button:hover {
        border-bottom: none; }
    .sideMenu .header .nav .nav-button {
      z-index: 20;
      width: 30px;
      height: 40px;
      background-color: #fff; }
    .sideMenu .header .nav .nav-button span {
      position: absolute;
      right: 0;
      width: 100%;
      height: 2px;
      background-color: #008895;
      border-radius: 4px; }
    .sideMenu .header .nav .nav-button span:nth-of-type(1) {
      top: 0; }
    .sideMenu .header .nav .nav-button span:nth-of-type(2) {
      top: 9px; }
    .sideMenu .header .nav .nav-button span:nth-of-type(3) {
      top: 18px; }
    .sideMenu .header .nav .nav-button.active span:nth-of-type(1) {
      -webkit-transform: translateY(8px) rotate(-45deg);
      transform: translateY(8px) rotate(-45deg); }
    .sideMenu .header .nav .nav-button.active span:nth-of-type(2) {
      opacity: 0; }
    .sideMenu .header .nav .nav-button.active span:nth-of-type(3) {
      -webkit-transform: translateY(-8px) rotate(45deg);
      transform: translateY(-8px) rotate(45deg); }
    .sideMenu .header .nav p {
      position: absolute;
      content: "";
      width: 30px;
      height: 9px;
      left: 0;
      bottom: 6px;
      background: url("../img/icon_menu.png") no-repeat;
      background-size: 30px auto;
      background-position: bottom center; }
      .sideMenu .header .nav p span {
        display: none !important; }
    .sideMenu .header .nav .nav-button.active p {
      background: url("../img/icon_menu_close.png") no-repeat;
      background-size: 30px auto;
      background-position: bottom center; }
  .sideMenu .sns {
    background-color: #fff; }
    @media print, screen and (min-width: 768px) {
      .sideMenu .sns {
        padding: 20px 0 30px 0;
        width: 240px; } }
    @media only screen and (max-width: 767px) {
      .sideMenu .sns {
        display: none;
        width: 100%;
        padding: 20px 0 30px 0; } }
    .sideMenu .sns ul {
      display: table;
      width: 100%; }
      .sideMenu .sns ul li {
        display: table-cell;
        text-align: center; }
        .sideMenu .sns ul li a {
          display: inline-block; }
          .sideMenu .sns ul li a:hover {
            opacity: 0.9; }
        @media print, screen and (min-width: 768px) {
          .sideMenu .sns ul li img {
            width: 30px; } }
        @media only screen and (max-width: 767px) {
          .sideMenu .sns ul li img {
            width: 40px; } }

.list-parent {
  position: relative;
  z-index: 100;
  font-size: 14px;
  background: #fff;
  color: #333; }
  @media print, screen and (min-width: 768px) {
    .list-parent {
      width: 240px;
      display: block !important; } }
  @media only screen and (max-width: 767px) {
    .list-parent {
      display: none; } }
  .list-parent > li {
    list-style-type: none;
    margin: 0;
    padding: 0;
    color: #333;
    border-bottom: 1px solid #dcdcdc; }
    @media only screen and (max-width: 767px) {
      .list-parent > li:first-child {
        border-top: 1px solid #dcdcdc; }
      .list-parent > li ul {
        background-color: #fff5db; }
        .list-parent > li ul li {
          border-top: 1px solid #dcdcdc; }
      .list-parent > li.student ul {
        background-color: #def3ec; }
      .list-parent > li.corporate ul {
        background-color: #e1f1f9; } }
    @media print, screen and (min-width: 768px) {
      .list-parent > li:hover {
        background-color: #fff5db; }
        .list-parent > li:hover ul {
          background-color: #fff5db; }
        .list-parent > li:hover.student {
          background-color: #def3ec; }
          .list-parent > li:hover.student ul {
            background-color: #def3ec; }
        .list-parent > li:hover.corporate {
          background-color: #e1f1f9; }
          .list-parent > li:hover.corporate ul {
            background-color: #e1f1f9; } }
    @media print, screen and (min-width: 768px) {
      .list-parent > li:hover ul {
        display: block; } }
    .list-parent > li:hover ul li a:hover {
      background-color: #fff; }
      @media print, screen and (min-width: 768px) {
        .list-parent > li:hover ul li a:hover {
          margin-right: -17px; } }
      @media print, screen and (min-width: 768px) {
        .list-parent > li:hover ul li a:hover:after {
          right: 27px; } }
    .list-parent > li a {
      position: relative;
      display: block;
      color: #333;
      text-decoration: none;
      line-height: 15px; }
      @media print, screen and (min-width: 768px) {
        .list-parent > li a {
          padding: 10px 20px 10px 15px; } }
      .list-parent > li a:hover {
        text-decoration: underline; }
      @media print, screen and (min-width: 768px) {
        .list-parent > li a:after {
          display: block;
          position: absolute;
          content: "";
          top: 50%;
          right: 10px;
          margin-top: -4px;
          width: 5px;
          height: 5px;
          border-top: 2px solid #10506c;
          border-right: 2px solid #10506c;
          -webkit-transform: rotate(45deg);
          transform: rotate(45deg); } }
  .list-parent ul {
    height: 100%;
    margin: 0;
    overflow-y: auto; }
    @media print, screen and (min-width: 768px) {
      .list-parent ul {
        border-radius: 0 0 3px 0;
        -webkit-box-shadow: 2px 2px 2px #ccc, 0px 0px 0px #aaa inset;
        box-shadow: 2px 2px 2px #ccc, 0px 0px 0px #aaa inset;
        border-left: 1px solid #ccc; } }
    @media print, screen and (min-width: 768px) {
      .list-parent ul {
        width: 240px;
        left: 240px;
        display: none;
        position: fixed;
        top: 0;
        width: 240px;
        padding-right: 17px; } }
    @media only screen and (max-width: 767px) {
      .list-parent ul {
        display: none; } }
    .list-parent ul li {
      margin-bottom: 0; }
      .list-parent ul li.head {
        padding: 160px 0 50px 0;
        margin: 0 20px;
        text-align: center;
        color: #10506c;
        font-size: 18px;
        font-weight: bold; }
        @media only screen and (max-width: 767px) {
          .list-parent ul li.head {
            display: none; } }
      .list-parent ul li a {
        padding: 11px 30px 11px 15px;
        color: #10506c;
        font-weight: bold; }
      @media print, screen and (min-width: 768px) {
        .list-parent ul li:last-child {
          margin-bottom: 30px; } }
      @media print, screen and (min-width: 768px) {
        .list-parent ul li.layer a {
          padding-left: 29px; } }
      @media only screen and (max-width: 767px) {
        .list-parent ul li.layer a {
          padding-left: 2em; } }
  @media print, screen and (min-width: 768px) {
    .list-parent li.manyMenu div > a:after {
      content: none; } }
  .list-parent li.manyMenu ul {
    background-color: #fff5db; }
    .list-parent li.manyMenu ul li {
      position: relative; }
      @media only screen and (max-width: 767px) {
        .list-parent li.manyMenu ul li:after {
          display: block;
          position: absolute;
          content: "";
          top: 50%;
          right: 15px;
          margin-top: -4px;
          width: 5px;
          height: 5px;
          border-top: 2px solid #10506c;
          border-right: 2px solid #10506c;
          -webkit-transform: rotate(45deg);
          transform: rotate(45deg); } }
  .list-parent li.manyMenu.about div a span {
    position: relative; }
    .list-parent li.manyMenu.about div a span:before {
      content: "";
      position: absolute;
      background: url("../img/icon_menu_about.png") top left no-repeat; }
      @media print, screen and (min-width: 768px) {
        .list-parent li.manyMenu.about div a span:before {
          width: 87px;
          height: 48px;
          bottom: 40px;
          left: 0;
          right: 0;
          margin: 0 auto;
          background-size: 100% auto; } }
      @media only screen and (max-width: 767px) {
        .list-parent li.manyMenu.about div a span:before {
          width: 40px;
          height: 22px;
          left: -50px;
          top: 50%;
          background-size: 40px auto;
          margin-top: -11px; } }
    .list-parent li.manyMenu.about div a span:after {
      content: none; }
  .list-parent li.manyMenu.student div a span {
    position: relative; }
    .list-parent li.manyMenu.student div a span:before {
      content: "";
      position: absolute;
      background: url("../img/icon_menu_student.png") top left no-repeat; }
      @media print, screen and (min-width: 768px) {
        .list-parent li.manyMenu.student div a span:before {
          width: 76px;
          height: 66px;
          bottom: 40px;
          left: 0;
          right: 0;
          margin: 0 auto;
          background-size: 100% auto; } }
      @media only screen and (max-width: 767px) {
        .list-parent li.manyMenu.student div a span:before {
          width: 35px;
          height: 30px;
          left: -45px;
          top: 50%;
          background-size: 35px auto;
          margin-top: -15px; } }
    .list-parent li.manyMenu.student div a span:after {
      content: none; }
  .list-parent li.manyMenu.student ul {
    background-color: #def3ec; }
  .list-parent li.manyMenu.corporate div a span {
    position: relative; }
    .list-parent li.manyMenu.corporate div a span:before {
      content: "";
      position: absolute;
      background: url("../img/icon_menu_corporate.png") top left no-repeat; }
      @media print, screen and (min-width: 768px) {
        .list-parent li.manyMenu.corporate div a span:before {
          width: 51px;
          height: 75px;
          bottom: 40px;
          left: 0;
          right: 0;
          margin: 0 auto;
          background-size: 100% auto; } }
      @media only screen and (max-width: 767px) {
        .list-parent li.manyMenu.corporate div a span:before {
          width: 24px;
          height: 35px;
          left: -34px;
          top: 50%;
          background-size: 24px auto;
          margin-top: -17px; } }
    .list-parent li.manyMenu.corporate div a span:after {
      content: none; }
  .list-parent li.manyMenu.corporate ul {
    background-color: #e1f1f9; }
  @media only screen and (max-width: 767px) {
    .list-parent li.manyMenu div {
      position: relative;
      display: block;
      width: 100%; } }
  .list-parent li.manyMenu div a {
    font-weight: bold;
    color: #10506c;
    text-align: center; }
    @media print, screen and (min-width: 768px) {
      .list-parent li.manyMenu div a {
        padding: 120px 0 30px 0; } }
    @media only screen and (max-width: 767px) {
      .list-parent li.manyMenu div a {
        padding: 20px 0; } }
  @media only screen and (max-width: 767px) {
    .list-parent li.manyMenu div .plus {
      background-color: #10506c;
      position: absolute;
      top: 0;
      right: 0;
      width: 15%;
      height: 100%; } }
  @media only screen and (max-width: 767px) {
    .list-parent li.manyMenu div .plus span {
      position: relative;
      width: 100%;
      height: 100%;
      display: block; } }
  @media only screen and (max-width: 767px) {
    .list-parent li.manyMenu div .plus span:before {
      content: "";
      width: 16px;
      height: 1px;
      background-color: #fff;
      display: block;
      position: absolute;
      right: 50%;
      top: 50%;
      margin-right: -8px;
      margin-top: -1px;
      -webkit-transition: 300ms;
      transition: 300ms; } }
  @media only screen and (max-width: 767px) {
    .list-parent li.manyMenu div .plus span:after {
      content: "";
      width: 1px;
      height: 16px;
      background-color: #fff;
      display: block;
      position: absolute;
      right: 50%;
      top: 50%;
      margin-top: -8px;
      -webkit-transition: 300ms;
      transition: 300ms; } }
  @media only screen and (max-width: 767px) {
    .list-parent li.manyMenu div .plus.active span:after {
      content: none; } }

.contents {
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }
  @media print, screen and (min-width: 768px) {
    .contents {
      padding-left: 240px; } }
  @media only screen and (max-width: 767px) {
    .contents {
      padding-top: 50px; } }
  @media print, screen and (min-width: 768px) {
    .contents.form {
      padding-left: 0; } }
  @media only screen and (max-width: 767px) {
    .contents.form {
      padding-top: 20px; } }
  .contents.form h2 {
    background-color: #edf1f4;
    font-weight: bold;
    border-bottom: 2px solid #10506c;
    line-height: 1.3em;
    font-size: 18px;
    padding: 22px; }
    @media print, screen and (min-width: 768px) {
      .contents.form h2 {
        margin: 40px 0 20px 0; } }
    @media only screen and (max-width: 767px) {
      .contents.form h2 {
        margin: 0 0 20px 0; } }
  .contents.form table {
    width: 100%;
    display: inline-table; }
    .contents.form table th {
      width: 26%;
      padding: 10px 2%;
      font-weight: bold; }
      @media only screen and (max-width: 767px) {
        .contents.form table th {
          display: block;
          width: 96%; } }
    .contents.form table td {
      width: 66%;
      padding: 10px 2%; }
      @media only screen and (max-width: 767px) {
        .contents.form table td {
          display: block;
          width: 96%; } }
  .contents.form input[type="text"], .contents.form input[type="password"] {
    padding: 8px 2% !important;
    border: 1px solid #ccc;
    border-radius: 4px;
    letter-spacing: 0.05em; }
    @media only screen and (max-width: 767px) {
      .contents.form input[type="text"], .contents.form input[type="password"] {
        font-size: 16px; } }
  .contents.form textarea {
    width: 96%;
    padding: 8px 2%;
    border: 1px solid #ccc;
    border-radius: 4px;
    letter-spacing: 0.05em; }
    @media only screen and (max-width: 767px) {
      .contents.form textarea {
        font-size: 16px; } }
  .contents.form select {
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    letter-spacing: 0.05em; }
    @media only screen and (max-width: 767px) {
      .contents.form select {
        font-size: 16px; } }
  .contents.form input[size="40"], .contents.form input[size="50"], .contents.form input[size="60"], .contents.form input[size="70"], .contents.form input[size="80"], .contents.form input[size="90"], .contents.form input[size="100"] {
    width: 96% !important; }
  .contents.form input[size="30"] {
    width: 50% !important; }
  .contents.form input[size="3"] {
    width: 40px; }
  .contents.form input[size="4"] {
    width: 50px; }
  .contents.form input[type="button"] {
    padding: 5px 10px !important;
    border: 1px solid #ccc;
    border-radius: 4px;
    letter-spacing: 0.05em; }
  .contents.form input[type="radio"] {
    margin-top: 0;
    width: 15px;
    height: 15px; }
  .contents.form input:focus, .contents.form textarea:focus, .contents.form select:focus {
    -webkit-box-shadow: 0 0 3px #10506c;
    box-shadow: 0 0 3px #10506c;
    border: 1px solid #10506c; }
  .contents.form p {
    font-size: 14px; }
  .contents.form .hissu {
    background: red;
    font-size: 12px;
    font-weight: bold;
    padding: 1px 5px;
    margin-left: 5px; }
  .contents.form .Warning {
    color: #cc0000; }
    .contents.form .Warning img {
      max-width: initial;
      display: inline;
      margin: 3px 3px 3px 0; }
      @media only screen and (max-width: 767px) {
        .contents.form .Warning img {
          width: 18px; } }
  .contents.form .caution {
    background-color: #fff5db;
    padding: 1px 5px; }
  .contents.form .RegistBlock {
    width: 100%;
    margin-bottom: 50px;
    margin-left: 0; }
    .contents.form .RegistBlock div {
      width: auto !important; }
  .contents.form .RegistOperate {
    text-align: center; }
    @media print, screen and (min-width: 768px) {
      .contents.form .RegistOperate {
        margin-top: 50px; } }
    @media only screen and (max-width: 767px) {
      .contents.form .RegistOperate {
        margin-top: 20px; } }
    .contents.form .RegistOperate .Reset {
      background-color: #eee;
      color: #000;
      display: inline-block;
      font-size: 15px;
      border: 2px solid #eee;
      padding: 8px 40px !important;
      border-radius: 20px;
      font-size: 14px;
      cursor: pointer;
      margin: 10px; }
      @media only screen and (max-width: 767px) {
        .contents.form .RegistOperate .Reset {
          -webkit-appearance: none;
          border-radius: 30px; } }
      .contents.form .RegistOperate .Reset:hover {
        background-color: #fff;
        -webkit-transition: 0.3s;
        transition: 0.3s; }
    .contents.form .RegistOperate .Button {
      background-color: #10506c;
      color: #fff;
      display: inline-block;
      font-size: 15px;
      border: 2px solid #10506c;
      padding: 8px 40px !important;
      border-radius: 20px;
      font-size: 14px;
      cursor: pointer;
      margin: 10px; }
      @media only screen and (max-width: 767px) {
        .contents.form .RegistOperate .Button {
          -webkit-appearance: none;
          border-radius: 30px; } }
      .contents.form .RegistOperate .Button:hover {
        background-color: #fff;
        color: #10506c;
        -webkit-transition: 0.3s;
        transition: 0.3s; }

.swiper-wrap {
  z-index: -1;
  width: 100%; }
  @media print, screen and (min-width: 768px) {
    .swiper-wrap {
      position: fixed;
      top: 0; } }
  @media only screen and (max-width: 767px) {
    .swiper-wrap {
      position: absolute;
      top: 50px; } }
  @media print, screen and (min-width: 768px) {
    .swiper-wrap .swiper-container {
      margin-right: 240px; } }
  .swiper-wrap .swiper-container .swiper-wrapper .swiper-slide img {
    width: 100%;
    vertical-align: top; }
  .swiper-wrap .swiper-container .swiper-pagination-bullet {
    background-color: #fff; }
  .swiper-wrap .swiper-container .swiper-pagination-bullets {
    bottom: 20px; }

@media only screen and (max-width: 767px) {
  #top {
    background-color: #f0fbff; } }

#top .contents-inner h2 {
  text-align: center;
  margin-bottom: 30px; }
  @media only screen and (max-width: 767px) {
    #top .contents-inner h2 img {
      max-width: 50%; } }
  #top .contents-inner h2 span {
    display: block;
    margin-top: 20px;
    font-size: 16px;
    color: #10506c;
    font-weight: bold; }

#top .contents-inner .news {
  border-bottom: 1px solid #10506c; }
  @media print, screen and (min-width: 768px) {
    #top .contents-inner .news {
      display: table;
      margin: 0 auto;
      width: 100%; } }
  #top .contents-inner .news p {
    display: inline; }
  #top .contents-inner .news a[target="_blank"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    #top .contents-inner .news a[target="_blank"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_window.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 12px;
      height: 12px;
      background-size: 12px auto; }
  #top .contents-inner .news a[href$=".pdf"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    #top .contents-inner .news a[href$=".pdf"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_pdf.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  #top .contents-inner .news a[href$=".doc"] p,
  #top .contents-inner .news a[href$=".docx"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    #top .contents-inner .news a[href$=".doc"] p:after,
    #top .contents-inner .news a[href$=".docx"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_doc.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  #top .contents-inner .news a[href$=".xls"] p,
  #top .contents-inner .news a[href$=".xlsx"] p,
  #top .contents-inner .news a[href$=".csv"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    #top .contents-inner .news a[href$=".xls"] p:after,
    #top .contents-inner .news a[href$=".xlsx"] p:after,
    #top .contents-inner .news a[href$=".csv"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_excel.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  #top .contents-inner .news a[href$=".txt"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    #top .contents-inner .news a[href$=".txt"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_file.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  @media print, screen and (min-width: 768px) {
    #top .contents-inner .news .date li a {
      display: table; }
      #top .contents-inner .news .date li a span {
        display: table-cell; }
      #top .contents-inner .news .date li a p {
        display: table-cell;
        vertical-align: top; } }

.contents-inner {
  background-color: #fff; }
  .contents-inner .link-more {
    text-align: center; }
    .contents-inner .link-more a {
      background-color: #10506c;
      color: #fff;
      display: inline-block;
      font-size: 15px;
      position: relative;
      border: 2px solid #10506c; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .link-more a {
          padding: 8px 60px;
          border-radius: 20px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .link-more a {
          padding: 12px 60px;
          border-radius: 25px; } }
      .contents-inner .link-more a:after {
        display: block;
        position: absolute;
        content: "";
        top: 50%;
        right: 15px;
        margin-top: -4px;
        width: 5px;
        height: 5px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
      .contents-inner .link-more a:hover {
        -webkit-transition: 0.3s;
        transition: 0.3s;
        background-color: #fff;
        color: #10506c;
        border: 2px solid #10506c; }
        .contents-inner .link-more a:hover:after {
          border-top: 2px solid #10506c;
          border-right: 2px solid #10506c; }
  .contents-inner .swiper-event {
    width: 100%;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    list-style: none; }
    @media print, screen and (min-width: 768px) {
      .contents-inner .swiper-event {
        margin-bottom: 50px; } }
    @media only screen and (max-width: 767px) {
      .contents-inner .swiper-event {
        margin-bottom: 30px; } }
    @media print, screen and (min-width: 768px) {
      .contents-inner .swiper-event .swiper-wrapper {
        padding: 0 50px; } }
    @media only screen and (max-width: 767px) {
      .contents-inner .swiper-event .swiper-wrapper {
        padding: 0 20px; } }
    .contents-inner .swiper-event .swiper-wrapper .swiper-slide {
      background-color: #fff; }
      .contents-inner .swiper-event .swiper-wrapper .swiper-slide:not(:first-child) {
        border-left: 1px solid #ccc; }
      .contents-inner .swiper-event .swiper-wrapper .swiper-slide a {
        color: #10506c;
        display: block;
        position: relative; }
        .contents-inner .swiper-event .swiper-wrapper .swiper-slide a:after {
          content: "";
          position: absolute;
          top: 0;
          left: 0;
          background: url("../img/icon_triangle_01.png") top left no-repeat;
          width: 18px;
          height: 18px; }
        .contents-inner .swiper-event .swiper-wrapper .swiper-slide a:hover {
          text-decoration: underline; }
          .contents-inner .swiper-event .swiper-wrapper .swiper-slide a:hover .photo {
            background-color: #000; }
            .contents-inner .swiper-event .swiper-wrapper .swiper-slide a:hover .photo span {
              bottom: 0; }
            .contents-inner .swiper-event .swiper-wrapper .swiper-slide a:hover .photo img {
              -webkit-transform: scale(1.2);
              transform: scale(1.2);
              opacity: 0.8; }
      .contents-inner .swiper-event .swiper-wrapper .swiper-slide .photo {
        position: relative;
        overflow: hidden; }
        .contents-inner .swiper-event .swiper-wrapper .swiper-slide .photo img {
          width: 100%;
          height: 170px;
          -webkit-transition: -webkit-transform 0.3s linear;
          transition: -webkit-transform 0.3s linear;
          transition: transform 0.3s linear;
          transition: transform 0.3s linear, -webkit-transform 0.3s linear;
          -o-object-fit: cover;
          object-fit: cover;
          font-family: 'object-fit: cover;'; }
        .contents-inner .swiper-event .swiper-wrapper .swiper-slide .photo span {
          position: absolute;
          bottom: -60px;
          left: 0;
          z-index: 2;
          width: 100%;
          height: 60px;
          background: rgba(16, 80, 106, 0.7);
          -webkit-transition: .3s;
          transition: .3s;
          line-height: 60px;
          text-align: center;
          color: #fff; }
      .contents-inner .swiper-event .swiper-wrapper .swiper-slide .title {
        font-weight: bold;
        padding: 20px 25px 10px 25px;
        letter-spacing: 0.1em;
        line-height: 1.2em;
        font-size: 17px; }
      .contents-inner .swiper-event .swiper-wrapper .swiper-slide .text {
        padding: 0 25px 20px 25px;
        font-size: 15px;
        line-height: 1.5em; }
    .contents-inner .swiper-event .swiper-button-prev {
      background-image: none;
      background-color: rgba(25, 181, 134, 0.7); }
      @media print, screen and (min-width: 768px) {
        .contents-inner .swiper-event .swiper-button-prev {
          width: 100px;
          height: 100px;
          top: 50%;
          right: 10px;
          margin-top: -50px;
          border-radius: 50px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .swiper-event .swiper-button-prev {
          width: 70px;
          height: 70px;
          top: 50%;
          right: 10px;
          margin-top: -35px;
          border-radius: 35px; } }
      .contents-inner .swiper-event .swiper-button-prev:after {
        display: block;
        position: absolute;
        content: "";
        top: 50%;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
        @media print, screen and (min-width: 768px) {
          .contents-inner .swiper-event .swiper-button-prev:after {
            left: 37px;
            width: 30px;
            height: 30px;
            margin-top: -15px;
            border-bottom: 6px solid #fff;
            border-left: 6px solid #fff; } }
        @media only screen and (max-width: 767px) {
          .contents-inner .swiper-event .swiper-button-prev:after {
            left: 26px;
            width: 20px;
            height: 20px;
            margin-top: -10px;
            border-bottom: 4px solid #fff;
            border-left: 4px solid #fff; } }
      .contents-inner .swiper-event .swiper-button-prev.swiper-button-disabled {
        pointer-events: auto; }
    .contents-inner .swiper-event .swiper-button-next {
      background-image: none;
      background-color: rgba(25, 181, 134, 0.7); }
      @media print, screen and (min-width: 768px) {
        .contents-inner .swiper-event .swiper-button-next {
          width: 100px;
          height: 100px;
          top: 50%;
          right: 10px;
          margin-top: -50px;
          border-radius: 50px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .swiper-event .swiper-button-next {
          width: 70px;
          height: 70px;
          top: 50%;
          right: 10px;
          margin-top: -35px;
          border-radius: 35px; } }
      .contents-inner .swiper-event .swiper-button-next:after {
        display: block;
        position: absolute;
        content: "";
        top: 50%;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
        @media print, screen and (min-width: 768px) {
          .contents-inner .swiper-event .swiper-button-next:after {
            right: 37px;
            width: 30px;
            height: 30px;
            margin-top: -15px;
            border-top: 6px solid #fff;
            border-right: 6px solid #fff; } }
        @media only screen and (max-width: 767px) {
          .contents-inner .swiper-event .swiper-button-next:after {
            right: 26px;
            width: 20px;
            height: 20px;
            margin-top: -10px;
            border-top: 4px solid #fff;
            border-right: 4px solid #fff; } }
      .contents-inner .swiper-event .swiper-button-next.swiper-button-disabled {
        pointer-events: auto; }
  .contents-inner .event {
    background-color: #f0fbff; }
    .contents-inner .event .event-inner {
      padding: 60px 0;
      margin: 0 auto; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .event .event-inner {
          max-width: 1300px;
          background: url("../img/bg_diamond.png") no-repeat;
          background-position: top center;
          background-attachment: fixed;
          background-size: 1150px auto; } }
      .contents-inner .event .event-inner ul {
        overflow: hidden;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        margin: 0 auto;
        padding: 0 50px 35px 50px; }
        .contents-inner .event .event-inner ul li {
          width: 300px;
          float: left;
          background-color: #fff;
          border-left: 1px solid #ccc;
          -webkit-box-sizing: border-box;
          box-sizing: border-box;
          margin-bottom: 0;
          color: #10506c; }
          .contents-inner .event .event-inner ul li:first-child {
            border-left: 1px solid #f0fbff; }
          .contents-inner .event .event-inner ul li a {
            color: #10506c;
            display: block;
            position: relative; }
            .contents-inner .event .event-inner ul li a:after {
              content: "";
              position: absolute;
              top: 0;
              left: 0;
              background: url("../img/icon_triangle_01.png") top left no-repeat;
              width: 18px;
              height: 18px; }
            .contents-inner .event .event-inner ul li a:hover {
              text-decoration: underline; }
              .contents-inner .event .event-inner ul li a:hover .photo {
                background-color: #000; }
                .contents-inner .event .event-inner ul li a:hover .photo span {
                  bottom: 0; }
                .contents-inner .event .event-inner ul li a:hover .photo img {
                  -webkit-transform: scale(1.2);
                  transform: scale(1.2);
                  opacity: 0.8; }
          .contents-inner .event .event-inner ul li .photo {
            position: relative;
            overflow: hidden; }
            .contents-inner .event .event-inner ul li .photo img {
              width: 300px;
              height: 170px;
              -o-object-fit: cover;
              object-fit: cover;
              font-family: 'object-fit: cover;';
              -webkit-transition: -webkit-transform 0.3s linear;
              transition: -webkit-transform 0.3s linear;
              transition: transform 0.3s linear;
              transition: transform 0.3s linear, -webkit-transform 0.3s linear; }
            .contents-inner .event .event-inner ul li .photo span {
              position: absolute;
              bottom: -60px;
              left: 0;
              z-index: 2;
              width: 100%;
              height: 60px;
              background: rgba(16, 80, 106, 0.7);
              -webkit-transition: .3s;
              transition: .3s;
              line-height: 60px;
              text-align: center;
              color: #fff; }
          .contents-inner .event .event-inner ul li .title {
            font-weight: bold;
            padding: 20px 25px 10px 25px;
            letter-spacing: 0.1em;
            line-height: 1.2em;
            font-size: 17px; }
          .contents-inner .event .event-inner ul li .text {
            padding: 0 25px 20px 25px;
            font-size: 15px;
            line-height: 1.5em; }
        @media print, screen and (max-width: 1556px) {
          .contents-inner .event .event-inner ul {
            width: 1000px;
            margin: 0 auto; } }
  @media print, screen and (max-width: 1556px) and (min-width: 768px) {
    .contents-inner .event .event-inner ul li:last-child {
      display: none; } }
        @media print, screen and (max-width: 1256px) {
          .contents-inner .event .event-inner ul {
            width: auto;
            margin: 0 auto; }
            .contents-inner .event .event-inner ul li {
              width: auto;
              float: initial;
              display: table-cell;
              width: 33%; }
              .contents-inner .event .event-inner ul li .photo img {
                width: 100%; } }
  .contents-inner.list {
    background-color: #f0fbff; }
    .contents-inner.list .event .event-inner {
      padding: 0;
      background: none; }
      @media print, screen and (min-width: 768px) {
        .contents-inner.list .event .event-inner ul {
          padding: 0 50px 0 50px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner.list .event .event-inner ul {
          padding: 30px 20px 0 20px; } }
      .contents-inner.list .event .event-inner ul li {
        margin-bottom: 50px;
        border-left: 1px solid #ccc;
        border-right: 1px solid #ccc;
        margin-right: -1px; }

@media print, screen and (max-width: 1556px) and (min-width: 768px) {
  .contents-inner.list .event .event-inner ul li:last-child {
    display: block; } }
        @media print, screen and (max-width: 1256px) {
          .contents-inner.list .event .event-inner ul li {
            float: left;
            display: block;
            width: 50%; } }
        @media only screen and (max-width: 767px) {
          .contents-inner.list .event .event-inner ul li {
            width: 100%;
            margin-bottom: 30px;
            margin-right: 0;
            border: none; } }
    .contents-inner.list .pager {
      padding: 10px 0 60px 0; }
  @media print, screen and (min-width: 768px) {
    .contents-inner.newslist .news {
      padding-top: 0;
      background: none; } }
  @media only screen and (max-width: 767px) {
    .contents-inner.newslist .news {
      padding-top: 30px; } }
  @media print, screen and (min-width: 768px) {
    .contents-inner.newslist .news .news-inner {
      max-width: 1200px;
      padding: 0 50px;
      margin-bottom: 60px; } }
  @media print, screen and (min-width: 768px) {
    .contents-inner.newslist .news .news-inner .list {
      padding-right: 0; } }
  .contents-inner.newslist .news p {
    display: inline; }
  .contents-inner.newslist .news a[target="_blank"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    .contents-inner.newslist .news a[target="_blank"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_window.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 12px;
      height: 12px;
      background-size: 12px auto; }
  .contents-inner.newslist .news a[href$=".pdf"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    .contents-inner.newslist .news a[href$=".pdf"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_pdf.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  .contents-inner.newslist .news a[href$=".doc"] p,
  .contents-inner.newslist .news a[href$=".docx"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    .contents-inner.newslist .news a[href$=".doc"] p:after,
    .contents-inner.newslist .news a[href$=".docx"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_doc.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  .contents-inner.newslist .news a[href$=".xls"] p,
  .contents-inner.newslist .news a[href$=".xlsx"] p,
  .contents-inner.newslist .news a[href$=".csv"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    .contents-inner.newslist .news a[href$=".xls"] p:after,
    .contents-inner.newslist .news a[href$=".xlsx"] p:after,
    .contents-inner.newslist .news a[href$=".csv"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_excel.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  .contents-inner.newslist .news a[href$=".txt"] p {
    position: relative;
    padding-right: 18px;
    margin-right: 3px; }
    .contents-inner.newslist .news a[href$=".txt"] p:after {
      content: "";
      position: absolute;
      background: url("../img/icon_file.png") no-repeat;
      bottom: 4px;
      margin-left: 3px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  @media print, screen and (min-width: 768px) {
    .contents-inner.newslist .news .date li a {
      display: table; }
      .contents-inner.newslist .news .date li a span {
        display: table-cell; }
      .contents-inner.newslist .news .date li a p {
        display: table-cell;
        vertical-align: top; } }
  .contents-inner.detail .link-more {
    margin-top: 60px; }
  .contents-inner.qa .free dl dt {
    float: none;
    color: #10506c;
    border-radius: 5px;
    letter-spacing: 0.05em;
    overflow: hidden;
    display: table;
    background-color: #10506c;
    color: #fff; }
    @media print, screen and (min-width: 768px) {
      .contents-inner.qa .free dl dt {
        width: 100%;
        padding: 10px 15px;
        margin-bottom: 20px; } }
    @media only screen and (max-width: 767px) {
      .contents-inner.qa .free dl dt {
        width: 92%;
        padding: 10px 4%;
        margin-bottom: 15px; } }
    .contents-inner.qa .free dl dt span {
      display: table-cell;
      padding-right: 1em;
      width: 22px;
      font-family: "arial"; }
    .contents-inner.qa .free dl dt div {
      display: table-cell; }
  .contents-inner.qa .free dl dd {
    display: block;
    margin-left: 0;
    overflow: hidden;
    min-height: 25px;
    margin-bottom: 30px; }
    @media print, screen and (min-width: 768px) {
      .contents-inner.qa .free dl dd {
        width: 100%;
        padding: 10px 15px; } }
    @media only screen and (max-width: 767px) {
      .contents-inner.qa .free dl dd {
        width: 92%;
        padding: 10px 4%; } }
    .contents-inner.qa .free dl dd span {
      font-family: "arial";
      font-weight: bold;
      color: #f00; }
      @media print, screen and (min-width: 768px) {
        .contents-inner.qa .free dl dd span {
          display: table-cell;
          padding-right: 1em;
          width: 22px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner.qa .free dl dd span {
          float: left;
          padding-right: 0.2em; } }
    @media print, screen and (min-width: 768px) {
      .contents-inner.qa .free dl dd div {
        display: table-cell; } }
  .contents-inner.intern table {
    width: 100%;
    display: inline-table; }
    .contents-inner.intern table tr th {
      width: 15%;
      white-space: nowrap;
      font-family: "arial"; }
      @media only screen and (max-width: 767px) {
        .contents-inner.intern table tr th {
          padding: 5px 8px; } }
    .contents-inner.intern table tr td {
      width: 85%; }
      @media only screen and (max-width: 767px) {
        .contents-inner.intern table tr td {
          padding: 5px 10px; } }
    .contents-inner.intern table tr a:after {
      top: auto;
      bottom: 3px;
      margin-top: 0; }
  .contents-inner.jobs table {
    display: table;
    width: 100%; }
    .contents-inner.jobs table td:first-child {
      width: 20%; }
    .contents-inner.jobs table td:last-child {
      width: 80%; }
  .contents-inner .news {
    padding: 60px 0;
    background-image: url("../img/bg_dot.png"); }
    .contents-inner .news .news-inner {
      max-width: 1300px;
      margin: 0 auto; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .news .news-inner {
          position: relative; } }
      @media print, screen and (min-width: 768px) {
        .contents-inner .news .news-inner .head {
          float: left;
          overflow: hidden;
          width: 220px;
          padding-left: 50px; } }
      @media print, screen and (min-width: 768px) {
        .contents-inner .news .news-inner .head h2 {
          text-align: left !important; } }
      @media print, screen and (min-width: 768px) {
        .contents-inner .news .news-inner .link-more {
          position: absolute;
          top: 100px;
          left: 50px; } }
      .contents-inner .news .news-inner .list {
        overflow: hidden; }
        @media print, screen and (min-width: 768px) {
          .contents-inner .news .news-inner .list {
            padding-right: 50px; } }
        @media only screen and (max-width: 767px) {
          .contents-inner .news .news-inner .list {
            padding: 0 20px;
            margin-bottom: 30px; } }
        .contents-inner .news .news-inner .list ul {
          background: url("../img/line_dot.png") top repeat-x;
          padding-top: 1px; }
          .contents-inner .news .news-inner .list ul li {
            margin-bottom: 0;
            background: url("../img/line_dot.png") bottom repeat-x;
            line-height: 1.2em;
            position: relative; }
            .contents-inner .news .news-inner .list ul li:hover {
              text-decoration: underline; }
            .contents-inner .news .news-inner .list ul li a {
              display: block;
              color: #10506c;
              padding: 15px 10px;
              font-size: 15px; }
            .contents-inner .news .news-inner .list ul li span {
              float: left;
              width: 110px;
              font-family: "arial";
              letter-spacing: 0.05em; }
            .contents-inner .news .news-inner .list ul li p {
              overflow: hidden; }
      @media print, screen and (max-width: 1556px) {
        .contents-inner .news .news-inner {
          width: 1000px;
          margin: 0 auto; } }
      @media print, screen and (max-width: 1256px) {
        .contents-inner .news .news-inner {
          width: auto;
          margin: 0 auto; } }
  @media only screen and (max-width: 1256px) and (max-width: 767px) {
    .contents-inner .news .news-inner .list ul li span {
      display: block;
      float: initial;
      width: 100%;
      margin-bottom: 5px; } }
  @media only screen and (max-width: 1256px) and (max-width: 767px) {
    .contents-inner .news .news-inner .list ul li p {
      display: block;
      width: 100%; } }
  .contents-inner .about {
    background: url("../img/bg_top_about.jpg") bottom left no-repeat; }
    @media print, screen and (min-width: 768px) {
      .contents-inner .about {
        height: 550px;
        background-attachment: fixed;
        background-size: cover;
        margin-bottom: 140px; } }
    @media only screen and (max-width: 767px) {
      .contents-inner .about {
        background: url("../img/bg_top_about.jpg") top -55px left no-repeat #b8cad6;
        background-size: 100% auto; } }
    .contents-inner .about .about-inner {
      margin: 0 auto;
      color: #fff;
      height: 100%; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .about .about-inner {
          max-width: 1300px;
          position: relative; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .about .about-inner {
          overflow: hidden; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .about .about-inner .grad-bg {
          background: linear-gradient(135deg, #2286b7, #1db586), url("../img/bg_top_about.jpg") bottom no-repeat;
          margin: 0 20px 50px 20px; } }
      @media print, screen and (min-width: 768px) {
        .contents-inner .about .about-inner .lead {
          position: absolute;
          bottom: -70px;
          padding: 0 50px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .about .about-inner .lead {
          padding: 0 20px;
          margin-top: 100px; } }
      @media print, screen and (min-width: 768px) {
        .contents-inner .about .about-inner .lead .lead-inner {
          background: linear-gradient(135deg, #2286b7, #1db586), url("../img/bg_top_about.jpg") bottom no-repeat;
          float: left;
          width: 430px;
          padding: 60px 50px 60px 60px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .about .about-inner .lead .lead-inner {
          width: 100%;
          padding: 50px 0 30px 0; } }
      .contents-inner .about .about-inner .lead .lead-inner span {
        font-weight: bold;
        margin-bottom: 40px;
        display: block;
        font-size: 24px; }
        @media print, screen and (min-width: 768px) {
          .contents-inner .about .about-inner .lead .lead-inner span {
            line-height: 1.4em; } }
        @media only screen and (max-width: 767px) {
          .contents-inner .about .about-inner .lead .lead-inner span {
            text-align: center;
            line-height: 1.6em; } }
      .contents-inner .about .about-inner .lead .lead-inner ul {
        margin-bottom: 40px; }
        .contents-inner .about .about-inner .lead .lead-inner ul li {
          position: relative;
          padding-left: 14px; }
          @media only screen and (max-width: 767px) {
            .contents-inner .about .about-inner .lead .lead-inner ul li {
              line-height: 1.2em; } }
          .contents-inner .about .about-inner .lead .lead-inner ul li:not(:first-child) {
            margin-top: 10px; }
          .contents-inner .about .about-inner .lead .lead-inner ul li:before {
            content: "";
            position: absolute;
            top: 50%;
            left: 0;
            height: 0;
            width: 0;
            margin-top: -3px;
            border: 3px solid #fff;
            border-radius: 3px; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .about .about-inner .link-menu {
          position: absolute;
          bottom: -70px;
          right: 50px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .about .about-inner .link-menu {
          margin: 0 20px; } }
      @media print, screen and (min-width: 768px) {
        .contents-inner .about .about-inner .link-menu ul {
          overflow: hidden;
          display: table;
          width: 480px; } }
      .contents-inner .about .about-inner .link-menu ul li {
        float: left;
        margin: 0; }
        @media print, screen and (min-width: 768px) {
          .contents-inner .about .about-inner .link-menu ul li {
            display: block; } }
        .contents-inner .about .about-inner .link-menu ul li a {
          background-color: #fff;
          height: 140px;
          width: 140px;
          display: block;
          border-radius: 140px;
          -webkit-box-sizing: border-box;
          box-sizing: border-box;
          border: 2px solid #10506c;
          vertical-align: middle;
          text-align: center;
          font-size: 14px;
          color: #10506c;
          font-weight: bold;
          text-decoration: none; }
          .contents-inner .about .about-inner .link-menu ul li a span {
            position: relative;
            top: 82px; }
          .contents-inner .about .about-inner .link-menu ul li a:hover {
            background-color: #10506c;
            color: #fff;
            -webkit-transition: 300ms;
            transition: 300ms; }
            .contents-inner .about .about-inner .link-menu ul li a:hover:after {
              content: "";
              position: absolute;
              top: 0;
              left: 0;
              border: 2px solid #fff;
              display: block;
              width: 100%;
              height: 100%;
              border-radius: 70px;
              -webkit-box-sizing: border-box;
              box-sizing: border-box; }
        .contents-inner .about .about-inner .link-menu ul li:not(:first-child) {
          margin-left: 30px; }
        .contents-inner .about .about-inner .link-menu ul li.guide a {
          position: relative; }
          .contents-inner .about .about-inner .link-menu ul li.guide a:before {
            content: "";
            position: absolute;
            top: 50%;
            left: 0;
            right: 0;
            margin: 0 auto;
            width: 32px;
            height: 32px;
            margin-top: -26px;
            background: url("../img/icon_info.png") no-repeat; }
          .contents-inner .about .about-inner .link-menu ul li.guide a:hover:before {
            content: "";
            position: absolute;
            top: 50%;
            left: 0;
            right: 0;
            margin: 0 auto;
            width: 32px;
            height: 32px;
            margin-top: -26px;
            background: url("../img/icon_info_on.png") no-repeat; }
        .contents-inner .about .about-inner .link-menu ul li.staff a {
          position: relative; }
          .contents-inner .about .about-inner .link-menu ul li.staff a:before {
            content: "";
            position: absolute;
            top: 50%;
            left: 0;
            right: 0;
            margin: 0 auto;
            width: 32px;
            height: 32px;
            margin-top: -26px;
            background: url("../img/icon_staff.png") no-repeat; }
          .contents-inner .about .about-inner .link-menu ul li.staff a:hover:before {
            content: "";
            position: absolute;
            top: 50%;
            left: 0;
            right: 0;
            margin: 0 auto;
            width: 32px;
            height: 32px;
            margin-top: -26px;
            background: url("../img/icon_staff_on.png") no-repeat; }
        .contents-inner .about .about-inner .link-menu ul li.contact a {
          position: relative; }
          .contents-inner .about .about-inner .link-menu ul li.contact a:before {
            content: "";
            position: absolute;
            top: 50%;
            left: 0;
            right: 0;
            margin: 0 auto;
            width: 32px;
            height: 32px;
            margin-top: -26px;
            background: url("../img/icon_mail.png") no-repeat; }
          .contents-inner .about .about-inner .link-menu ul li.contact a:hover:before {
            content: "";
            position: absolute;
            top: 50%;
            left: 0;
            right: 0;
            margin: 0 auto;
            width: 32px;
            height: 32px;
            margin-top: -26px;
            background: url("../img/icon_mail_on.png") no-repeat; }
      @media print, screen and (max-width: 1256px) {
        .contents-inner .about .about-inner {
          width: auto;
          margin: 0 auto; }
          .contents-inner .about .about-inner .lead .lead-inner {
            width: auto; }
          .contents-inner .about .about-inner .link-menu ul {
            width: 140px; }
            .contents-inner .about .about-inner .link-menu ul li {
              float: none; }
              .contents-inner .about .about-inner .link-menu ul li:not(:first-child) {
                margin-left: 0;
                margin-top: 20px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .about .about-inner .link-menu {
          margin: 0 10px; }
          .contents-inner .about .about-inner .link-menu ul {
            overflow: hidden;
            width: 100%;
            display: table;
            position: relative;
            padding-bottom: 290px;
            width: 260px;
            margin: 0 auto; }
            .contents-inner .about .about-inner .link-menu ul li {
              display: table-cell; }
              .contents-inner .about .about-inner .link-menu ul li:not(:first-child) {
                margin-top: 0; }
              .contents-inner .about .about-inner .link-menu ul li a {
                width: 124px;
                height: 124px; }
                .contents-inner .about .about-inner .link-menu ul li a span {
                  top: 74px;
                  font-size: 12px; }
              .contents-inner .about .about-inner .link-menu ul li.guide {
                position: absolute;
                top: 0;
                left: 0; }
              .contents-inner .about .about-inner .link-menu ul li.staff {
                position: absolute;
                bottom: 50px;
                left: 0;
                right: 0;
                margin: 0 auto; }
                .contents-inner .about .about-inner .link-menu ul li.staff a {
                  margin: 0 auto; }
              .contents-inner .about .about-inner .link-menu ul li.contact {
                position: absolute;
                top: 0;
                right: 0; } }
  .contents-inner .footer-link {
    background-color: #eee; }
    .contents-inner .footer-link .footer-link-inner {
      overflow: hidden; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .footer-link .footer-link-inner {
          max-width: 1200px;
          margin: 0 auto;
          padding: 0 50px; } }
      .contents-inner .footer-link .footer-link-inner ul {
        float: right; }
        @media only screen and (max-width: 767px) {
          .contents-inner .footer-link .footer-link-inner ul {
            margin: 0 20px; } }
        .contents-inner .footer-link .footer-link-inner ul li {
          float: left;
          margin-bottom: 0; }
          @media print, screen and (min-width: 768px) {
            .contents-inner .footer-link .footer-link-inner ul li:not(:first-child) {
              margin-left: 40px; } }
          @media only screen and (max-width: 767px) {
            .contents-inner .footer-link .footer-link-inner ul li:not(:first-child) {
              margin-left: 30px; } }
          .contents-inner .footer-link .footer-link-inner ul li a {
            padding: 20px 0;
            display: block;
            color: #10506c;
            position: relative; }
            @media print, screen and (min-width: 768px) {
              .contents-inner .footer-link .footer-link-inner ul li a {
                font-size: 14px; } }
            @media only screen and (max-width: 767px) {
              .contents-inner .footer-link .footer-link-inner ul li a {
                font-size: 12px; } }
            .contents-inner .footer-link .footer-link-inner ul li a:before {
              display: block;
              position: absolute;
              content: "";
              top: 50%;
              left: -12px;
              margin-top: -4px;
              width: 5px;
              height: 5px;
              border-top: 1px solid #10506c;
              border-right: 1px solid #10506c;
              -webkit-transform: rotate(45deg);
              transform: rotate(45deg); }
            .contents-inner .footer-link .footer-link-inner ul li a:hover {
              text-decoration: underline; }
  .contents-inner .footer {
    background-color: #212b37;
    color: #fff; }
    @media print, screen and (min-width: 768px) {
      .contents-inner .footer {
        padding: 60px 50px; } }
    @media only screen and (max-width: 767px) {
      .contents-inner .footer {
        padding-top: 40px; } }
    @media print, screen and (min-width: 768px) {
      .contents-inner .footer .footer-inner {
        max-width: 1200px;
        margin: 0 auto;
        display: table;
        width: 100%; } }
    @media only screen and (max-width: 767px) {
      .contents-inner .footer .footer-inner {
        text-align: center; } }
    .contents-inner .footer .footer-inner .title {
      font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .footer .footer-inner .title {
          display: table-cell; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .footer .footer-inner .title {
          padding: 0 20px; } }
      .contents-inner .footer .footer-inner .title .logo {
        font-size: 24px; }
        @media print, screen and (min-width: 768px) {
          .contents-inner .footer .footer-inner .title .logo {
            margin-bottom: 25px; } }
        @media only screen and (max-width: 767px) {
          .contents-inner .footer .footer-inner .title .logo {
            margin-bottom: 20px;
            text-align: center; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .footer .footer-inner .title ul {
          margin-bottom: 20px;
          text-align: center; } }
      @media print, screen and (min-width: 768px) {
        .contents-inner .footer .footer-inner .title ul li {
          float: left;
          margin-bottom: 0; } }
      @media print, screen and (min-width: 768px) {
        .contents-inner .footer .footer-inner .title ul li a {
          font-size: 14px;
          color: #ccc; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .footer .footer-inner .title ul li a {
          font-size: 12px;
          color: #fff; } }
      .contents-inner .footer .footer-inner .title ul li a:hover {
        text-decoration: underline; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .footer .footer-inner .title ul li:not(:first-child) {
          border-left: 1px solid #ccc;
          margin-left: 10px;
          padding-left: 10px; } }
    @media print, screen and (min-width: 768px) {
      .contents-inner .footer .footer-inner .address {
        display: table-cell;
        text-align: right; } }
    @media only screen and (max-width: 767px) {
      .contents-inner .footer .footer-inner .address {
        text-align: center; } }
    @media print, screen and (min-width: 768px) {
      .contents-inner .footer .footer-inner .address p {
        margin-bottom: 25px;
        text-align: right; } }
    @media only screen and (max-width: 767px) {
      .contents-inner .footer .footer-inner .address p {
        font-size: 12px;
        margin-bottom: 40px;
        padding: 0 20px;
        text-align: center; } }
    .contents-inner .footer .footer-inner .address span {
      font-family: "arial"; }
      @media print, screen and (min-width: 768px) {
        .contents-inner .footer .footer-inner .address span {
          color: #ccc;
          display: block;
          font-size: 14px; } }
      @media only screen and (max-width: 767px) {
        .contents-inner .footer .footer-inner .address span {
          font-size: 12px;
          background-color: #fff;
          padding: 15px 20px;
          display: block;
          color: #10506c; } }

@media print, screen and (min-width: 768px) {
  .page-head {
    margin-bottom: 100px; } }

@media only screen and (max-width: 767px) {
  .page-head {
    background-size: 200% auto;
    margin-bottom: 30px; } }

.page-head .page-head-inner {
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4); }
  .page-head .page-head-inner h2 {
    vertical-align: middle;
    text-align: center;
    color: #fff;
    font-weight: bold; }
    @media print, screen and (min-width: 768px) {
      .page-head .page-head-inner h2 {
        padding: 100px 50px;
        font-size: 28px; } }
    @media only screen and (max-width: 767px) {
      .page-head .page-head-inner h2 {
        padding: 60px 30px;
        font-size: 22px;
        letter-spacing: 0.05em; } }
  .page-head .page-head-inner .bread {
    background-color: rgba(255, 255, 255, 0.7); }
    .page-head .page-head-inner .bread .bread-inner {
      display: inline-block;
      width: 100%;
      margin: 0 auto; }
      .page-head .page-head-inner .bread .bread-inner ul {
        overflow: hidden;
        float: right; }
        @media print, screen and (min-width: 768px) {
          .page-head .page-head-inner .bread .bread-inner ul {
            padding: 10px 0 8px 0;
            margin: 0 30px; } }
        @media only screen and (max-width: 767px) {
          .page-head .page-head-inner .bread .bread-inner ul {
            padding: 8px 0 6px 0;
            margin: 0 20px; } }
        .page-head .page-head-inner .bread .bread-inner ul li {
          float: left;
          margin-bottom: 0;
          padding: 5px 0;
          font-weight: bold;
          letter-spacing: 0.05em; }
          @media print, screen and (min-width: 768px) {
            .page-head .page-head-inner .bread .bread-inner ul li {
              font-size: 14px; } }
          @media only screen and (max-width: 767px) {
            .page-head .page-head-inner .bread .bread-inner ul li {
              font-size: 12px; } }
          .page-head .page-head-inner .bread .bread-inner ul li a {
            text-decoration: underline; }
            .page-head .page-head-inner .bread .bread-inner ul li a:hover {
              text-decoration: none; }
          .page-head .page-head-inner .bread .bread-inner ul li:not(:first-child) {
            margin-left: 30px;
            position: relative; }
            .page-head .page-head-inner .bread .bread-inner ul li:not(:first-child):before {
              display: block;
              position: absolute;
              content: "";
              top: 50%;
              left: -18px;
              margin-top: -4px;
              width: 5px;
              height: 5px;
              border-top: 2px solid #10506c;
              border-right: 2px solid #10506c;
              -webkit-transform: rotate(45deg);
              transform: rotate(45deg); }

.free {
  max-width: 1200px;
  margin: 0 auto;
  line-height: 1.5em; }
  @media print, screen and (min-width: 768px) {
    .free {
      padding: 0 50px 100px 50px;
      font-size: 15px; } }
  @media only screen and (max-width: 767px) {
    .free {
      padding: 0 20px 60px 20px;
      font-size: 14px; } }
  .free p {
    margin: 10px 0; }
  .free a {
    color: #10506c;
    text-decoration: underline; }
    .free a:hover {
      text-decoration: none; }
  .free a[target="_blank"] {
    position: relative;
    padding-right: 14px;
    margin-right: 3px; }
    .free a[target="_blank"]:after {
      content: "";
      position: absolute;
      background: url("../img/icon_window.png") no-repeat;
      top: 50%;
      right: 0;
      margin-top: -7px;
      width: 12px;
      height: 12px;
      background-size: 12px auto; }
  .free a[href$=".pdf"] {
    position: relative;
    padding-right: 13px;
    margin-right: 3px; }
    .free a[href$=".pdf"]:after {
      content: "";
      position: absolute;
      background: url("../img/icon_pdf.png") no-repeat;
      top: 50%;
      right: 0;
      margin-top: -9px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  .free a[href$=".doc"],
  .free a[href$=".docx"] {
    position: relative;
    padding-right: 13px;
    margin-right: 3px; }
    .free a[href$=".doc"]:after,
    .free a[href$=".docx"]:after {
      content: "";
      position: absolute;
      background: url("../img/icon_doc.png") no-repeat;
      top: 50%;
      right: 0;
      margin-top: -9px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  .free a[href$=".xls"],
  .free a[href$=".xlsx"],
  .free a[href$=".csv"] {
    position: relative;
    padding-right: 13px;
    margin-right: 3px; }
    .free a[href$=".xls"]:after,
    .free a[href$=".xlsx"]:after,
    .free a[href$=".csv"]:after {
      content: "";
      position: absolute;
      background: url("../img/icon_excel.png") no-repeat;
      top: 50%;
      right: 0;
      margin-top: -9px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  .free a[href$=".txt"] {
    position: relative;
    padding-right: 13px;
    margin-right: 3px; }
    .free a[href$=".txt"]:after {
      content: "";
      position: absolute;
      background: url("../img/icon_file.png") no-repeat;
      top: 50%;
      right: 0;
      margin-top: -9px;
      width: 11px;
      height: 14px;
      background-size: 11px auto; }
  .free img {
    margin: 20px auto;
    display: block; }
    @media print, screen and (min-width: 768px) {
      .free img {
        max-width: 70%; } }
    @media only screen and (max-width: 767px) {
      .free img {
        width: 100%; } }
  .free h3 {
    background-color: #edf1f4;
    font-weight: bold;
    border-bottom: 2px solid #10506c;
    line-height: 1.3em; }
    @media print, screen and (min-width: 768px) {
      .free h3 {
        font-size: 18px;
        margin: 50px 0 20px 0;
        padding: 22px; } }
    @media only screen and (max-width: 767px) {
      .free h3 {
        font-size: 16px;
        margin: 40px 0 20px 0;
        padding: 15px 20px; } }
  .free h4 {
    font-weight: bold;
    text-indent: -20px;
    margin: 10px 0 10px 24px; }
    .free h4:before {
      content: '';
      display: inline-block;
      width: 12px;
      height: 12px;
      margin-right: 8px;
      background-color: #10506c;
      -webkit-transform: rotate(45deg);
      transform: rotate(45deg); }
  .free h5 {
    background-color: #edf1f4;
    display: table;
    color: #10506c;
    padding: 10px 15px;
    margin: 20px 0 10px 0;
    font-weight: bold; }
  .free dl {
    margin: 10px 0; }
    .free dl dt {
      float: left;
      font-weight: bold;
      color: #10506c; }
    .free dl dd {
      margin-left: 70px; }
    .free dl.list dt {
      float: none;
      background-color: #edf1f4;
      padding: 10px;
      letter-spacing: 0.05em; }
    .free dl.list dd {
      margin-left: 0;
      padding: 10px 0; }
      @media print, screen and (min-width: 768px) {
        .free dl.list dd {
          margin-bottom: 30px; } }
      @media only screen and (max-width: 767px) {
        .free dl.list dd {
          margin-bottom: 20px; } }
  .free ol {
    margin: 20px 0 20px 5px;
    counter-reset: li; }
    .free ol > li {
      padding-left: 1em;
      text-indent: -1em; }
      .free ol > li:before {
        font-weight: bold;
        counter-increment: li;
        content: counter(li) ". ";
        color: #10506c; }
    .free ol ol {
      margin: 5px 2em; }
    .free ol ul {
      margin: 5px 1.5em; }
  .free ul {
    margin-left: 2em; }
    .free ul > li {
      list-style-type: none;
      position: relative;
      text-indent: -0; }
      .free ul > li:before {
        content: "";
        position: absolute;
        background-color: #10506c;
        top: 0.425em;
        left: -1em;
        height: 8px;
        width: 8px;
        border-radius: 50%; }
    .free ul ol {
      margin: 5px 0.5em; }
    .free ul ul {
      margin: 5px 2em;
      padding-left: 1.5em; }
  .free table {
    border-collapse: collapse;
    display: block;
    padding-bottom: 10px; }
    .free table tr th {
      background-color: #10506c;
      color: #fff;
      vertical-align: middle;
      border: 1px solid #ccc;
      padding: 10px 15px; }
    .free table tr td {
      border: 1px solid #ccc;
      padding: 10px 15px; }
    @media only screen and (max-width: 767px) {
      .free table.noBorder tr:not(:first-child) {
        display: block;
        margin-top: 10px; } }
    .free table.noBorder tr th {
      background-color: #fff;
      color: #10506c;
      font-weight: bold;
      border: none;
      vertical-align: top;
      text-align: left;
      padding: 2px 5px 2px 0; }
      @media only screen and (max-width: 767px) {
        .free table.noBorder tr th {
          display: block;
          width: 100%; } }
    .free table.noBorder tr td {
      border: none;
      padding: 2px 0; }
      @media only screen and (max-width: 767px) {
        .free table.noBorder tr td {
          display: block;
          width: 100%; } }
  .free .border {
    border: 2px solid #10506c;
    margin: 20px 0; }
    @media print, screen and (min-width: 768px) {
      .free .border {
        padding: 20px 25px; } }
    @media only screen and (max-width: 767px) {
      .free .border {
        padding: 15px 20px; } }
  .free .twoColumn {
    width: 100%;
    margin: 20px 0;
    overflow: hidden; }
    @media print, screen and (min-width: 768px) {
      .free .twoColumn > div {
        width: 48%;
        float: left; } }
    @media print, screen and (min-width: 768px) {
      .free .twoColumn > div:not(:first-child) {
        margin-left: 4%; } }
    .free .twoColumn > div img {
      max-width: 100%;
      width: 100%;
      vertical-align: top; }
    .free .twoColumn > div a:after {
      content: none; }
    .free .twoColumn > div a[target="_blank"] {
      position: static;
      padding-right: 0;
      margin-right: 0; }
  .free .threeColumn {
    width: 100%;
    margin: 20px 0;
    overflow: hidden; }
    @media print, screen and (min-width: 768px) {
      .free .threeColumn > div {
        width: 31%;
        float: left; } }
    @media print, screen and (min-width: 768px) {
      .free .threeColumn > div:not(:first-child) {
        margin-left: 3.5%; } }
    .free .threeColumn > div img {
      max-width: 100%;
      width: 100%;
      vertical-align: top; }
    .free .threeColumn > div a:after {
      content: none; }
    .free .threeColumn > div a[target="_blank"] {
      position: static;
      padding-right: 0;
      margin-right: 0; }
  .free .fourColumn {
    width: 100%;
    margin: 20px 0;
    overflow: hidden; }
    @media print, screen and (min-width: 768px) {
      .free .fourColumn > div {
        width: 22%;
        float: left; } }
    @media print, screen and (min-width: 768px) {
      .free .fourColumn > div:not(:first-child) {
        margin-left: 4%; } }
    .free .fourColumn > div img {
      max-width: 100%;
      width: 100%;
      vertical-align: top; }
    .free .fourColumn > div a:after {
      content: none; }
    .free .fourColumn > div a[target="_blank"] {
      position: static;
      padding-right: 0;
      margin-right: 0; }
  .free .detail-title {
    text-align: center;
    margin-bottom: 50px;
    font-weight: bold; }
    @media print, screen and (min-width: 768px) {
      .free .detail-title {
        font-size: 30px; } }
    @media only screen and (max-width: 767px) {
      .free .detail-title {
        font-size: 18px;
        margin-top: 30px;
        margin-bottom: 20px; } }
    .free .detail-title span {
      border-bottom: 2px solid #10506c;
      line-height: 1.6em; }
  .free .detail-date {
    font-family: "arial";
    text-align: right;
    margin-bottom: 50px; }
    @media print, screen and (min-width: 768px) {
      .free .detail-date {
        font-size: 18px; } }
    @media only screen and (max-width: 767px) {
      .free .detail-date {
        font-size: 15px;
        margin-bottom: 20px; } }
  .free .link-more a {
    text-decoration: none; }

.work {
  max-width: 1200px;
  margin: 0 auto;
  line-height: 1.5em;
  padding: 0 50px 100px 50px;
  font-size: 15px; }
  @media only screen and (max-width: 767px) {
    .work {
      padding: 0 20px 60px 20px;
      font-size: 14px; } }
  @media print, screen and (min-width: 768px) {
    .work .internal-link {
      text-align: center; } }
  .work .internal-link ul {
    overflow: hidden; }
    @media print, screen and (min-width: 768px) {
      .work .internal-link ul {
        display: inline-block; } }
    @media only screen and (max-width: 767px) {
      .work .internal-link ul {
        margin: 30px 0 20px 0; } }
    .work .internal-link ul li {
      float: left;
      width: 40px;
      height: 40px;
      background-color: #fff;
      border: 2px solid #10506c;
      border-radius: 50px;
      margin-bottom: 20px;
      margin-right: 8px; }
      .work .internal-link ul li:before {
        content: none; }
      .work .internal-link ul li a {
        display: table-cell;
        height: 100%;
        vertical-align: middle;
        height: 40px;
        width: 40px;
        text-align: center;
        font-weight: bold;
        color: #10506c;
        text-decoration: underline; }
        .work .internal-link ul li a:hover {
          text-decoration: none; }
      .work .internal-link ul li:hover {
        position: relative; }
        .work .internal-link ul li:hover:after {
          display: block;
          position: absolute;
          content: "";
          top: 50px;
          left: 50%;
          margin-left: -4px;
          width: 5px;
          height: 5px;
          border-top: 2px solid #10506c;
          border-right: 2px solid #10506c;
          -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
          z-index: 11; }
  .work table {
    border-collapse: collapse;
    padding-bottom: 10px;
    width: 100%;
    text-align: left;
    margin-bottom: 8px; }
    .work table tr th {
      background-color: #10506c;
      color: #fff;
      vertical-align: middle;
      border: 1px solid #ccc;
      padding: 5px 10px;
      width: 50%; }
      .work table tr th a {
        color: #fff; }
    .work table tr td {
      border: 1px solid #ccc;
      padding: 5px 10px;
      width: 50%; }
      .work table tr td a {
        color: #10506c;
        text-decoration: underline; }
    .work table tr:nth-child(odd) {
      background-color: #f0fbff; }
    .work table tr:hover td {
      background-color: #b8d5e0; }
  .work h4 {
    font-weight: bold;
    text-indent: -20px;
    margin: 10px 0 10px 24px;
    font-size: 18px; }
    .work h4:before {
      content: '';
      display: inline-block;
      width: 12px;
      height: 12px;
      margin-right: 8px;
      background-color: #10506c;
      -webkit-transform: rotate(45deg);
      transform: rotate(45deg); }
  .work .pageTop {
    text-align: right;
    margin-bottom: 60px; }
    .work .pageTop a {
      color: #10506c;
      position: relative;
      text-decoration: underline;
      font-size: 14px; }
      .work .pageTop a:after {
        display: block;
        position: absolute;
        content: "";
        top: 50%;
        left: -14px;
        margin-top: -3px;
        width: 5px;
        height: 5px;
        border-top: 2px solid #10506c;
        border-right: 2px solid #10506c;
        -webkit-transform: rotate(315deg);
        transform: rotate(315deg); }

@media print, screen and (min-width: 768px) {
  .staffList {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 50px 100px 50px; } }

@media only screen and (max-width: 767px) {
  .staffList {
    padding: 40px 20px 60px 20px; } }

.staffList .box {
  overflow: hidden;
  clear: both; }
  .staffList .box:not(:first-child) {
    margin-top: 50px;
    padding-top: 60px;
    border-top: 1px solid #ccc; }
  @media print, screen and (min-width: 768px) {
    .staffList .box .photo {
      float: left;
      width: 50%;
      width: 42%; } }
  .staffList .box .photo img {
    margin-top: 0; }
    @media print, screen and (min-width: 768px) {
      .staffList .box .photo img {
        max-width: none;
        width: 500px;
        -webkit-box-shadow: 6px 6px 10px #999;
        box-shadow: 6px 6px 10px #999; } }
    @media print, screen and (max-width: 1556px) {
      .staffList .box .photo img {
        width: 100%; } }
    @media only screen and (max-width: 767px) {
      .staffList .box .photo img {
        width: 100%; } }
  @media print, screen and (min-width: 768px) {
    .staffList .box .profile {
      padding-left: 550px; } }
  @media print, screen and (max-width: 1556px) {
    .staffList .box .profile {
      padding-left: 46%; } }
  @media only screen and (max-width: 767px) {
    .staffList .box .profile {
      padding-left: 0; } }
  @media print, screen and (min-width: 768px) {
    .staffList .box .profile .position {
      margin-bottom: 30px; } }
  @media only screen and (max-width: 767px) {
    .staffList .box .profile .position {
      margin-bottom: 20px; } }
  .staffList .box .profile .position span {
    background-color: #10506c;
    color: #fff; }
    @media print, screen and (min-width: 768px) {
      .staffList .box .profile .position span {
        padding: 8px 30px;
        border-radius: 50px;
        display: inline-block; } }
    @media only screen and (max-width: 767px) {
      .staffList .box .profile .position span {
        padding: 8px 2%;
        display: block;
        width: 96%;
        text-align: center;
        border-top: 1px solid #ccc; } }
    @media print, screen and (min-width: 768px) {
      .staffList .box .profile .position span:not(:first-child) {
        margin-left: 15px; } }
  .staffList .box .profile .name {
    font-weight: bold; }
    @media print, screen and (min-width: 768px) {
      .staffList .box .profile .name {
        position: relative;
        font-size: 28px;
        margin-bottom: 10px; } }
    @media only screen and (max-width: 767px) {
      .staffList .box .profile .name {
        font-size: 22px;
        margin-bottom: 5px; } }
    @media print, screen and (min-width: 768px) {
      .staffList .box .profile .name:before {
        content: "";
        position: absolute;
        top: 50%;
        left: -100px;
        width: 90px;
        height: 2px;
        margin-top: -1px;
        background-color: #10506c; } }
    @media print, screen and (max-width: 1256px) {
      .staffList .box .profile .name:before {
        left: -60px;
        width: 50px; } }
  @media print, screen and (min-width: 768px) {
    .staffList .box .profile .kana {
      margin-bottom: 30px; } }
  @media only screen and (max-width: 767px) {
    .staffList .box .profile .kana {
      margin-bottom: 20px; } }
  .staffList .box .profile .mail {
    background: #edf1f4;
    display: inline-block; }
    @media print, screen and (min-width: 768px) {
      .staffList .box .profile .mail {
        padding: 15px 30px;
        margin-top: 30px;
        float: right; } }
    @media only screen and (max-width: 767px) {
      .staffList .box .profile .mail {
        padding: 10px 15px;
        margin-top: 20px; } }
  .staffList .box .profile h4 {
    margin-top: 30px; }

.pager {
  overflow: hidden;
  text-align: center; }
  .pager ul {
    display: inline-block;
    border-radius: 5px;
    border: 1px solid #ccc;
    background-color: #fff; }
    @media only screen and (max-width: 767px) {
      .pager ul {
        margin: 0 10%;
        width: 80%; } }
    .pager ul li {
      float: left;
      width: 45px;
      margin-bottom: 0;
      border-left: 1px solid #ccc;
      -webkit-box-sizing: border-box;
      box-sizing: border-box; }
      @media print, screen and (min-width: 768px) {
        .pager ul li {
          height: 40px;
          line-height: 40px; } }
      @media only screen and (max-width: 767px) {
        .pager ul li {
          display: none;
          height: 44px;
          line-height: 44px; } }
      .pager ul li.prev {
        border: none;
        width: 70px;
        border-top-left-radius: 5px;
        border-bottom-left-radius: 5px; }
        @media only screen and (max-width: 767px) {
          .pager ul li.prev {
            display: block;
            width: 50%; } }
        .pager ul li.prev a {
          font-size: 14px; }
      .pager ul li.next {
        width: 70px;
        border-top-right-radius: 5px;
        border-bottom-right-radius: 5px; }
        @media only screen and (max-width: 767px) {
          .pager ul li.next {
            display: block;
            width: 50%; } }
        .pager ul li.next a {
          font-size: 14px; }
      .pager ul li.active, .pager ul li:hover {
        background-color: #10506c; }
        .pager ul li.active a, .pager ul li:hover a {
          color: #fff; }
      .pager ul li.off {
        background-color: #eee; }
        .pager ul li.off a {
          color: #999;
          pointer-events: none; }
      .pager ul li a {
        display: block;
        color: #10506c;
        font-size: 15px;
        font-family: "arial"; }

.pagetop {
  background-color: rgba(25, 136, 189, 0.7);
  display: none;
  position: fixed;
  bottom: 15px;
  right: 15px;
  font-size: 1.5rem;
  width: 50px;
  height: 50px;
  border-radius: 50px;
  cursor: pointer;
  z-index: 9; }
  .pagetop:after {
    left: 16px;
    width: 15px;
    height: 15px;
    margin-top: -7px;
    border-top: 4px solid #fff;
    border-right: 4px solid #fff;
    display: block;
    position: absolute;
    content: "";
    top: 50%;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg); }
  @media print, screen and (min-width: 768px) {
    .pagetop:hover {
      background-color: rgba(25, 181, 134, 0.7);
      -webkit-transition: 0.3s;
      transition: 0.3s; } }
  .pagetop span {
    display: none; }
