@charset "UTF-8";
/*-------------------------------------------------------------------------------

  HTML5 :: modify.css
  2016.01 Accelight Inc.

-------------------------------------------------------------------------------*/
/*-------------------------------------------------------------------------------
 変数定義
-------------------------------------------------------------------------------*/
/*
----- 色名接頭辞 -----
白：white
灰：gray
黒：black
鮮やかな：vivid
くすんだ：dull
明るい：brigt
暗い：dark
*/
/*----- グレースケールの定義 -----*/
/*----- 基本色の定義 -----*/
/* メインカラー */
/* サブカラー */
/* メインカラー明るめ*/
/* フォント */
/* リンクテキスト */
/* リンクテキスト ホバー時 */
/* 必須マーク */
/*----- breakpointの定義 -----*/
/*-------------------------------------------------------------------------------
　@mixin
-------------------------------------------------------------------------------*/
/* text-indent:-9999pxの代わり */
/* before,after要素 */
/* before,after要素 インライン */
/* 三角右向きアイコン */
/* media query */
/*-------------------------------------------------------------------------------
web font　定義
-------------------------------------------------------------------------------*/
@font-face {
  font-family: 'icomoon';
  src: url("../fonts/icomoon.eot?kxzv91");
  src: url("../fonts/icomoon.eot?kxzv91#iefix") format("embedded-opentype"), url("../fonts/icomoon.ttf?kxzv91") format("truetype"), url("../fonts/icomoon.woff?kxzv91") format("woff"), url("../fonts/icomoon.svg?kxzv91#icomoon") format("svg");
  font-weight: normal;
  font-style: normal; }
[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

/* ホームアイコン */
.icon-house:before {
  content: "\e901"; }

/* 別タブで開くアイコン */
.icon-window:after {
  content: "\e903";
  margin: 0 0 0 6px; }

/*-------------------------------------------------------------------------------

body

-------------------------------------------------------------------------------*/
body {
  margin: 0; }

/*-------------------------------------------------------------------------------

全体共通パーツ

-------------------------------------------------------------------------------*/
.category section a, .single section a, .page section a {
  text-decoration: underline; }

footer {
  background: url(../img/topbg01.png) center center/cover no-repeat;
  border-top: 1px solid #f2f2f2; }

/*-------------------------------------------------------------------------------



ホーム


-------------------------------------------------------------------------------*/
.home {
  /*--------------------------------------------------
  メインビジュアル
  --------------------------------------------------*/
  /* end .main-v */
  /*--------------------------------------------------
  メインコンテンツ
  --------------------------------------------------*/
  /* end .contents-wrap */
  /* ニュース */
  /* end .news */
  /*main-v変更*/
  /* mainv改修 */ }
  .home .main-v {
    width: 100%;
    margin: 55px 0 15px 0;
    /* コントローラー */
    /* ページャー */ }
    @media (max-width: 768px) {
      .home .main-v {
        margin: 55px 0 0 0; } }
    @media screen and (min-width: 768px) {
      .home .main-v {
        margin: 0; } }
    .home .main-v .main-v-inner {
      background: url(../img/main-v02.png) center center/cover no-repeat, url(../img/main-v.png) center top/auto 470px no-repeat, url(../img/main-v01.png) center center/cover no-repeat; }
      .home .main-v .main-v-inner .message {
        max-width: 750px;
        margin: 0 auto;
        padding-top: 118px; }
        @media (max-width: 425px) {
          .home .main-v .main-v-inner .message {
            padding-top: 60px; } }
        .home .main-v .main-v-inner .message p {
          text-align: center;
          line-height: 2.2em;
          font-size: 120%;
          font-weight: bold;
          padding: 20px 10px; }
          .home .main-v .main-v-inner .message p span {
            font-size: 108%;
            background-color: white;
            padding: 1px 10px 1px 10px;
            border-radius: 5px; }
            .home .main-v .main-v-inner .message p span .nobr {
              font-size: 100%;
              padding: 0; }
            @media (max-width: 451px) {
              .home .main-v .main-v-inner .message p span {
                font-size: 90%;
                padding: 1px 5px 1px 5px; }
                .home .main-v .main-v-inner .message p span span.nobr {
                  white-space: nowrap;
                  font-size: 100%; } }
    .home .main-v img {
      display: block; }
      @media screen and (min-width: 768px) {
        .home .main-v img {
          margin: 0 auto;
          max-height: 480px; } }
    .home .main-v .bx-controls {
      position: absolute;
      bottom: -40px;
      z-index: 500; }
    .home .main-v .bx-pager-item {
      display: inline-block; }
    .home .main-v .bx-pager-item a {
      text-indent: -9999px;
      display: block;
      background: #808080; }
    .home .main-v .bx-pager-item .active {
      background: #a90000; }
    .home .main-v .bx-controls-direction {
      display: none; }
  .home main {
    padding: 0;
    /*max-width: 1000px;*/
    margin: 0 auto; }
  .home .contents-wrap {
    padding: 0;
    max-width: inherit; }
  .home section {
    float: none;
    width: 100%;
    max-width: 1040px;
    margin: 0 auto;
    padding: 20px 20px 50px 20px; }
    @media screen and (min-width: 768px) {
      .home section .btn {
        clear: both;
        text-align: center; }
        .home section .btn a {
          padding: 12px 90px 12px 90px; } }
    .home section h2 {
      border-bottom: 0;
      padding-top: 2em;
      text-align: center;
      padding-left: 0;
      font-weight: bold;
      font-size: 140%; }
      .home section h2::before {
        background: url(../img/ico-hoshi.png) center center/contain no-repeat;
        content: "";
        display: block;
        position: absolute;
        left: 50%;
        top: -1em;
        bottom: auto;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        width: 4em;
        height: 4em; }
      .home section h2 + p {
        text-align: center; }
        .home section h2 + p span {
          background: #fff;
          border-radius: 25px;
          padding: 5px 1.5em;
          font-weight: bold; }
          @media (max-width: 456px) {
            .home section h2 + p span {
              display: block; } }
          .home section h2 + p span .nobr {
            padding: 0; }
            @media (max-width: 456px) {
              .home section h2 + p span .nobr {
                white-space: nowrap;
                display: inline; } }
  .home .menu {
    background: url(../img/topbg01.png) center center/cover no-repeat; }
    .home .menu .menu_inner {
      max-width: 870px;
      margin: 0 auto;
      padding: 60px 30px; }
      .home .menu .menu_inner .menu-content {
        display: flex;
        justify-content: space-between; }
        @media (max-width: 540px) {
          .home .menu .menu_inner .menu-content {
            flex-wrap: wrap; } }
        .home .menu .menu_inner .menu-content .menu-box {
          width: 30%;
          text-align: center;
          background: #f6f1e1;
          box-shadow: 6px 8px 12px 0 rgba(0, 0, 0, 0.3);
          position: relative; }
          .home .menu .menu_inner .menu-content .menu-box:active {
            transform: translateY(4px);
            box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2); }
          @media (max-width: 540px) {
            .home .menu .menu_inner .menu-content .menu-box {
              width: 100%;
              margin-bottom: 20px; } }
          .home .menu .menu_inner .menu-content .menu-box::before {
            /* 背景の表示設定 */
            /*content: "";
            position: absolute;
            margin: auto;
            bottom: -15px;
            left: calc( 50% - 15px );
            width: 30px;
            height: 30px;
            border-radius: 50%;
            background: $color-main;*/ }
          .home .menu .menu_inner .menu-content .menu-box::after {
            /* くの字の表示設定 */
            /*content: "";
            position: absolute;
            margin: auto;
            bottom: 0;
            left: 8px;
            width: 8px;
            height: 8px;
            border-top: 3px solid #fff;
            border-right: 3px solid #fff;
            transform: rotate(135deg);
            bottom: -4px;
            left: calc( 50% - 6px );*/ }
          .home .menu .menu_inner .menu-content .menu-box:nth-of-type(2) {
            background: #f8f7f4; }
          .home .menu .menu_inner .menu-content .menu-box:nth-of-type(3) img {
            margin-right: 18px; }
          .home .menu .menu_inner .menu-content .menu-box a {
            display: block;
            padding: 20px 10px; }
          .home .menu .menu_inner .menu-content .menu-box img {
            height: 120px; }
          .home .menu .menu_inner .menu-content .menu-box h2 {
            border-bottom: 0px;
            margin-top: 0;
            padding: 5px;
            height: 2.5em;
            line-height: 1.3em;
            font-weight: bold;
            font-size: 120%; }
            .home .menu .menu_inner .menu-content .menu-box h2::before {
              display: none; }
          .home .menu .menu_inner .menu-content .menu-box p {
            font-size: 96%;
            font-weight: bold; }
  .home .newsup {
    background: #f8f7f4; }
    .home .newsup section {
      display: flex;
      justify-content: space-between;
      padding: 20px 0; }
      @media (max-width: 540px) {
        .home .newsup section {
          flex-wrap: wrap; } }
      .home .newsup section .news {
        width: 69%; }
        @media (max-width: 540px) {
          .home .newsup section .news {
            width: 100%;
            margin-bottom: 20px; } }
        .home .newsup section .news .news-box {
          background: #fff;
          padding: 10px 20px;
          display: flex;
          flex-wrap: wrap;
          justify-content: space-around;
          align-content: space-between;
          height: auto; }
          .home .newsup section .news .news-box .ico {
            text-indent: -9999px;
            width: 55px; }
          .home .newsup section .news .news-box .ico-jspfad_news {
            background: url("../img/ico-jspfad.png") center center/contain no-repeat; }
          .home .newsup section .news .news-box .ico-atl_news {
            background: url("../img/ico-atl.png") center center/contain no-repeat; }
          .home .newsup section .news .news-box .ico-hamnet_news {
            background: url("../img/ico-hamv2.png") center center/contain no-repeat; }
          .home .newsup section .news .news-box .ico-carrier_news {
            background: url("../img/ico-carrier.png") center center/contain no-repeat; }
          .home .newsup section .news .news-box .ico-new {
            background: url("../img/ico-new.png") center center/contain no-repeat; }
          .home .newsup section .news .news-box .ico-thesis {
            background: url("../img/ico-thesis.png") center center/contain no-repeat; }
          .home .newsup section .news .news-box .ico-event {
            background: url("../img/ico-event.png") center center/contain no-repeat; }
          .home .newsup section .news .news-box a time, .home .newsup section .news .news-box a span {
            text-decoration: underline;
            font-weight: bold; }
          @media (max-width: 540px) {
            .home .newsup section .news .news-box .btn {
              width: 100%; } }
      .home .newsup section .pickup-area {
        width: 29%; }
        @media (max-width: 540px) {
          .home .newsup section .pickup-area {
            width: 100%;
            margin-bottom: 20px; } }
        .home .newsup section .pickup-area .pickup-box {
          padding: 20px 10px;
          text-align: center;
          background: #fff; }
          @media (max-width: 540px) {
            .home .newsup section .pickup-area .pickup-box {
              padding: 30px; } }
          .home .newsup section .pickup-area .pickup-box img {
            box-shadow: 5px 5px 5px #00000040;
            border-radius: 8px;
            width: 100%;
            /*&:active {//ボタンクリック時の上下動作
              transform: translateY(3px);
              box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2);
            }*/ }
          .home .newsup section .pickup-area .pickup-box a i::after {
            display: none; }
  .home .kiso {
    background: #f6f1e1; }
    .home .kiso h2 + p {
      text-align: center; }
    .home .kiso h3 {
      text-align: center;
      border-bottom: 0;
      position: relative;
      padding: 0 65px;
      margin: 50px 0 35px; }
      .home .kiso h3::before {
        position: absolute;
        top: calc(50% - 1px);
        left: 0;
        width: 100%;
        height: 1px;
        content: '';
        background: #000; }
      .home .kiso h3 span {
        position: relative;
        padding: 0 1em;
        background: #f6f1e1; }
    .home .kiso .top-qa dl {
      background: #fff; }
      .home .kiso .top-qa dl dt {
        padding: 20px 20px 0;
        display: flex;
        font-weight: bold;
        align-items: center; }
        .home .kiso .top-qa dl dt:before {
          content: "Q";
          color: #fff;
          font-weight: bold;
          background-color: #b01823;
          border: 2px solid #b01823;
          padding: 5px 10px;
          border-radius: 3px;
          margin-right: 10px;
          height: 25px; }
      .home .kiso .top-qa dl dd {
        padding: 10px 20px 20px 20px;
        display: flex;
        border-bottom: 10px solid #f6f1e1; }
        .home .kiso .top-qa dl dd:before {
          content: "A";
          color: #b01823;
          font-weight: bold;
          background-color: #fff;
          border: 2px solid #b01823;
          padding: 5px 11px;
          border-radius: 3px;
          margin-right: 10px;
          height: 25px; }
    .home .kiso .top-qa .top-qa-flex-box {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
      margin-bottom: 30px; }
      .home .kiso .top-qa .top-qa-flex-box::after {
        content: "";
        display: block;
        width: 33%; }
      .home .kiso .top-qa .top-qa-flex-box p.top-qa-btn {
        border-left: solid 8px #6d4528;
        background: #fff;
        margin-bottom: 8px;
        line-height: 1.5;
        border-radius: 0 15px 15px 0;
        padding: 0;
        font-weight: bold;
        list-style-type: none !important;
        box-shadow: 3px 3px 3px #c3c3c3;
        display: inline-block;
        position: relative;
        width: 32%; }
        @media (max-width: 768px) {
          .home .kiso .top-qa .top-qa-flex-box p.top-qa-btn {
            width: 100%; } }
        .home .kiso .top-qa .top-qa-flex-box p.top-qa-btn a.top-qa-btn {
          display: inline-block;
          width: auto;
          padding: 0.6em 1em;
          width: 100%;
          box-sizing: border-box; }
    .home .kiso .e-area {
      display: flex;
      justify-content: space-around;
      margin-bottom: 30px;
      flex-wrap: wrap; }
      .home .kiso .e-area .e-box {
        background: #fff;
        padding: 20px;
        width: 30%;
        box-sizing: border-box; }
        @media (max-width: 590px) {
          .home .kiso .e-area .e-box {
            width: 100%;
            margin-bottom: 10px; } }
    .home .kiso p.kiso-text {
      text-align: center;
      font-weight: bold; }
  .home .sodan section .sodan-menu {
    display: flex;
    justify-content: center; }
    @media (max-width: 540px) {
      .home .sodan section .sodan-menu {
        flex-wrap: wrap; } }
    .home .sodan section .sodan-menu .sodan-box {
      padding: 30px;
      text-align: center; }
      @media (max-width: 659px) {
        .home .sodan section .sodan-menu .sodan-box {
          padding: 20px; } }
      .home .sodan section .sodan-menu .sodan-box img {
        height: 250px; }
        @media (max-width: 659px) {
          .home .sodan section .sodan-menu .sodan-box img {
            height: 140px; } }
        @media (max-width: 540px) {
          .home .sodan section .sodan-menu .sodan-box img {
            height: 180px; } }
        @media (max-width: 375px) {
          .home .sodan section .sodan-menu .sodan-box img {
            height: 140px; } }
  .home .sodan section .has_text_align_center {
    font-weight: bold;
    /*-----------------------------追記------*/ }
  .home .linkarea {
    background: #f6f1e1; }
    .home .linkarea section {
      /*追加*/ }
      .home .linkarea section .banner-area {
        display: flex;
        flex-wrap: wrap;
        justify-content: center; }
        @media (max-width: 540px) {
          .home .linkarea section .banner-area {
            flex-wrap: wrap; } }
        .home .linkarea section .banner-area .banner-box {
          width: 32%;
          box-shadow: 5px 5px 5px #0000002e;
          border-radius: 7px;
          box-sizing: border-box;
          background: linear-gradient(to bottom, #FFf 60%, #ffe9b6);
          margin-bottom: 20px; }
          .home .linkarea section .banner-area .banner-box:hover {
            opacity: 0.8; }
          .home .linkarea section .banner-area .banner-box:active {
            transform: translateY(3px);
            box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2); }
          @media (max-width: 540px) {
            .home .linkarea section .banner-area .banner-box {
              width: 100%;
              margin-bottom: 20px; } }
          .home .linkarea section .banner-area .banner-box:nth-of-type(1) {
            background: linear-gradient(to bottom, #FFf 60%, #c6e3f0);
            margin-right: 1%; }
            .home .linkarea section .banner-area .banner-box:nth-of-type(1) a img {
              padding: 10px 10px 8px 8px;
              box-sizing: border-box; }
            .home .linkarea section .banner-area .banner-box:nth-of-type(1) a p {
              padding-top: 75px; }
            .home .linkarea section .banner-area .banner-box:nth-of-type(1) a p::before {
              background: url("../img/banner-jspfad.png") center center/contain no-repeat;
              height: 60px; }
          .home .linkarea section .banner-area .banner-box:nth-of-type(2) {
            background: linear-gradient(to bottom, #FFf 60%, #c0dc98);
            margin-right: 1%; }
            .home .linkarea section .banner-area .banner-box:nth-of-type(2) a img {
              padding: 6px;
              box-sizing: border-box; }
            .home .linkarea section .banner-area .banner-box:nth-of-type(2) a p::before {
              background: url("../img/banner-ham.png") center center/contain no-repeat; }
          .home .linkarea section .banner-area .banner-box:nth-of-type(3) {
            background: linear-gradient(to bottom, #FFf 60%, #f5b9b8); }
            .home .linkarea section .banner-area .banner-box:nth-of-type(3) a img {
              padding: 9px;
              box-sizing: border-box; }
            .home .linkarea section .banner-area .banner-box:nth-of-type(3) a p {
              padding-top: 75px; }
              .home .linkarea section .banner-area .banner-box:nth-of-type(3) a p::before {
                background: url("../img/banner-atl.png") center center/contain no-repeat;
                height: 60px; }
              @media (max-width: 540px) {
                .home .linkarea section .banner-area .banner-box:nth-of-type(3) a p {
                  padding-top: 65px; }
                  .home .linkarea section .banner-area .banner-box:nth-of-type(3) a p::before {
                    height: 60px; } }
          .home .linkarea section .banner-area .banner-box:nth-of-type(4) {
            width: 32%; }
            @media (max-width: 768px) {
              .home .linkarea section .banner-area .banner-box:nth-of-type(4) {
                width: 100%; } }
            .home .linkarea section .banner-area .banner-box:nth-of-type(4) a p {
              padding-top: 90px; }
              .home .linkarea section .banner-area .banner-box:nth-of-type(4) a p::before {
                left: calc( 50% - 136px );
                width: 260px;
                height: 90px;
                top: 0; }
              @media (max-width: 540px) {
                .home .linkarea section .banner-area .banner-box:nth-of-type(4) a p {
                  padding-top: 60px; }
                  .home .linkarea section .banner-area .banner-box:nth-of-type(4) a p::before {
                    height: 59px; } }
          .home .linkarea section .banner-area .banner-box a {
            display: block;
            padding: 10px;
            text-align: center;
            height: 100%; }
            .home .linkarea section .banner-area .banner-box a img {
              height: 50px; }
            .home .linkarea section .banner-area .banner-box a p {
              text-align: left;
              margin-bottom: 5px;
              padding-top: 60px;
              position: relative;
              text-align: center;
              font-weight: bold; }
              .home .linkarea section .banner-area .banner-box a p::before {
                content: "";
                position: absolute;
                height: 48px;
                width: 100%;
                top: 5px;
                left: 0;
                background: url("../img/banner-career.png") center center/contain no-repeat; }
            .home .linkarea section .banner-area .banner-box a i::after {
              display: none; }
      .home .linkarea section .latest {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between; }
        .home .linkarea section .latest .latest-box {
          width: 48%;
          display: flex;
          flex-direction: column;
          justify-content: space-between; }
          @media (max-width: 768px) {
            .home .linkarea section .latest .latest-box {
              width: 100%; } }
      .home .linkarea section h3 {
        text-align: center;
        border-bottom: 0;
        position: relative;
        padding: 0 18px;
        margin: 50px 0 35px; }
        .home .linkarea section h3:before {
          position: absolute;
          top: calc(50% - 1px);
          left: 0;
          width: 100%;
          height: 1px;
          content: '';
          background: #000; }
        .home .linkarea section h3 span {
          position: relative;
          padding: 0 1em;
          background: #f6f1e1; }
      .home .linkarea section p {
        text-align: center;
        font-weight: bold; }
  .home .wrap__box {
    position: relative; }
  .home .menu__box {
    position: relative;
    max-width: 940px;
    margin: 0 auto;
    z-index: 2; }
    .home .menu__box a {
      color: #fff; }
    .home .menu__box h4 {
      font-size: 20px;
      font-weight: normal;
      padding: 30px 0 10px 15px; }
      .home .menu__box h4 img {
        margin-left: 20px;
        vertical-align: middle; }
      @media screen and (min-width: 768px) {
        .home .menu__box h4 {
          font-size: 30px; } }
    .home .menu__box p {
      font-size: 105%;
      padding: 0 0 0 15px; }
  .home .menu__box_url_1, .home .menu__box_url_3, .home .menu__box_url_5 {
    background-color: #6d4528;
    padding: 10px; }
  .home .menu__box_url_2 a, .home .menu__box_url_4 a {
    color: #6d4528; }
  .home .news {
    /* アイコン */ }
    .home .news ul {
      overflow: hidden;
      width: 100%;
      margin: 0 0 30px 0; }
    .home .news li {
      border-bottom: 1px solid #cccccc;
      padding: 0;
      margin: 0; }
      .home .news li:before {
        display: none; }
      .home .news li a {
        display: block;
        padding: 5px 0 5px 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis; }
        @media screen and (min-width: 768px) {
          .home .news li a {
            padding: 15px 0 15px 0; } }
    .home .news time, .home .news span {
      display: block; }
      @media screen and (min-width: 768px) {
        .home .news time, .home .news span {
          display: inline; } }
    .home .news time {
      color: #000;
      padding: 0 20px 0 0; }
    .home .news .ico {
      display: inline-block;
      padding: 1px 8px 1px 8px;
      border-radius: 2px;
      color: #fff;
      font-size: 81%;
      font-weight: bold;
      margin: 0 10px 0 0; }
    .home .news .ico-new {
      background: #BF9239; }
  .home .general img {
    width: 100%; }
    @media screen and (min-width: 768px) {
      .home .general img {
        width: 30%;
        float: left;
        margin: 0 15px 15px 0; } }
  .home .main-v .main-v-inner {
    background: url(../img/main-v02.png) center center/cover no-repeat, url(../img/main-v01.png) center center/cover no-repeat; }
    .home .main-v .main-v-inner .main-v-inner-wrap {
      max-width: 1100px;
      margin: 0 auto;
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      align-items: stretch; }
      .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box1 {
        height: auto;
        width: 720px;
        background: url(../img/main-v-v2.png) center top/auto 470px no-repeat;
        min-height: 500px; }
        .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box1 .message {
          max-width: 690px; }
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box1 .message p {
            font-size: 114%; }
      .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 {
        background: #f6f1e1;
        max-width: 300px;
        font-size: 80%;
        width: 300px;
        display: flex;
        flex-direction: column;
        margin-bottom: 30px;
        justify-content: space-around; }
        @media (max-width: 1036px) {
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 {
            margin-bottom: 0; } }
        @media (max-width: 540px) {
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 {
            flex-wrap: wrap; } }
        .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 p.shiro {
          background: #fff;
          border-radius: 8px;
          padding: 8px 1.5em 5px;
          font-weight: bold;
          text-align: center;
          max-width: 92%;
          box-sizing: border-box;
          margin: 7.559999999999995px auto;
          font-size: 115%; }
          @media (max-width: 960px) {
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 p.shiro {
              margin-top: 20px; } }
        .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box {
          width: 92%;
          box-shadow: 5px 5px 5px #0000002e;
          border-radius: 7px;
          box-sizing: border-box;
          background: linear-gradient(to bottom, #FFf 60%, #ffe9b6);
          margin: 0 auto;
          margin-bottom: 10px; }
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:hover {
            opacity: 0.8; }
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:active {
            transform: translateY(3px);
            box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2); }
          @media (max-width: 540px) {
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box {
              width: 100%;
              margin-bottom: 20px; } }
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(1) {
            background: linear-gradient(to bottom, #FFf 60%, #c6e3f0); }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(1) a img {
              padding: 10px 10px 8px 8px;
              box-sizing: border-box; }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(1) a p {
              padding-top: 50px;
              margin: 0; }
              .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(1) a p:before {
                background: url("../img/banner-jspfad.png") center center/contain no-repeat;
                height: 52px;
                top: 12px; }
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(2) {
            background: linear-gradient(to bottom, #FFf 60%, #c0dc98); }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(2) a img {
              padding: 6px;
              box-sizing: border-box; }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(2) a p {
              margin: 0; }
              .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(2) a p:before {
                background: url("../img/banner-ham.png") center center/contain no-repeat;
                height: 45px;
                top: 10px; }
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(3) {
            background: linear-gradient(to bottom, #FFf 60%, #f5b9b8); }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(3) a img {
              padding: 9px;
              box-sizing: border-box; }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(3) a p {
              padding-top: 50px;
              margin: 0; }
              .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(3) a p::before {
                background: url("../img/banner-atl.png") center center/contain no-repeat;
                height: 51px;
                top: 13px; }
              @media (max-width: 540px) {
                .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(3) a p {
                  padding-top: 65px; }
                  .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(3) a p::before {
                    height: 60px; } }
          .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box a {
            display: block;
            padding: 10px;
            text-align: center;
            height: 100%;
            height: 95px;
            width: 276px;
            box-sizing: border-box; }
            @media (max-width: 1036px) {
              .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box a {
                width: 100%; } }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box a img {
              height: 50px; }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box a p {
              text-align: left;
              margin-bottom: 5px;
              padding-top: 60px;
              position: relative;
              text-align: center;
              font-weight: bold; }
              .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box a p::before {
                content: "";
                position: absolute;
                height: 48px;
                width: 100%;
                top: 5px;
                left: 0;
                background: url("../img/banner-career.png") center center/contain no-repeat; }
            .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box a i::after {
              display: none; }
  .home main {
    min-height: auto; }
  .home #wrap {
    min-height: auto; }
  @media (max-width: 1036px) {
    .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 {
      width: 100%;
      max-width: none; }
    .home .sp-noshow {
      display: none; }
    .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box1 {
      min-height: 470px; }
    .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(1) {
      background: linear-gradient(to bottom, #FFf 80%, #c6e3f0); }
    .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(2) {
      background: linear-gradient(to bottom, #FFf 80%, #c0dc98); }
    .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box:nth-of-type(3) {
      background: linear-gradient(to bottom, #FFf 80%, #f5b9b8); } }
  @media (max-width: 540px) {
    .home .main-v .main-v-inner .main-v-inner-wrap .main-v-inner-box2 .banner-box {
      width: 90%; } }
  @media (max-width: 540px) {
    .home .menu {
      display: none; } }
  .home .menu .menu_inner {
    max-width: 1040px;
    padding: 15px 10px 5px; }
    .home .menu .menu_inner .guideline-banner-wrap {
      margin-top: 20px;
      margin-bottom: 10px; }
      .home .menu .menu_inner .guideline-banner-wrap:hover {
        opacity: 0.8; }
      .home .menu .menu_inner .guideline-banner-wrap a {
        display: block;
        box-sizing: border-box; }
        .home .menu .menu_inner .guideline-banner-wrap a img {
          box-shadow: 5px 5px 5px #0000002e;
          border-radius: 22px; }
    .home .menu .menu_inner .tel-banner-wrap {
      margin-bottom: 20px;
      background-color: #fff;
      border-radius: 21px; }
      .home .menu .menu_inner .tel-banner-wrap a.tel-banner {
        display: block;
        box-sizing: border-box; }
        .home .menu .menu_inner .tel-banner-wrap a.tel-banner:hover {
          opacity: 0.8; }
        .home .menu .menu_inner .tel-banner-wrap a.tel-banner img {
          box-shadow: 5px 5px 5px #0000002e;
          border-radius: 21px;
          border: 1px solid #D7C7D7;
          display: block;
          box-sizing: border-box; }
    .home .menu .menu_inner .menu-content {
      flex-wrap: wrap; }
      .home .menu .menu_inner .menu-content .menu-ico-wrap {
        width: 32%;
        margin-bottom: 20px;
        display: block;
        box-sizing: border-box;
        border-radius: 10px;
        background-color: #fff; }
        .home .menu .menu_inner .menu-content .menu-ico-wrap a {
          width: 100%;
          display: block;
          box-sizing: border-box; }
          .home .menu .menu_inner .menu-content .menu-ico-wrap a:hover {
            opacity: 0.8; }
          .home .menu .menu_inner .menu-content .menu-ico-wrap a img {
            box-shadow: 5px 5px 5px #0000002e;
            border-radius: 10px;
            display: block;
            box-sizing: border-box; }
  .home .menu-sp {
    background: url(../img/topbg01.png) center center/cover no-repeat; }
    @media (min-width: 540px) {
      .home .menu-sp {
        display: none; } }
    .home .menu-sp .menu_inner {
      max-width: 1040px;
      padding: 15px 10px 5px;
      text-align: center; }
      .home .menu-sp .menu_inner .guideline-banner-wrap {
        margin: 0 0px 7px;
        box-sizing: border-box; }
        .home .menu-sp .menu_inner .guideline-banner-wrap a {
          display: block;
          box-sizing: border-box; }
          .home .menu-sp .menu_inner .guideline-banner-wrap a img {
            box-shadow: 5px 5px 5px #0000002e;
            border-radius: 28px; }
      .home .menu-sp .menu_inner .tel-banner-wrap-sp {
        margin-bottom: 10px;
        background-color: #fff;
        border-radius: 31px; }
        .home .menu-sp .menu_inner .tel-banner-wrap-sp .tel-banner-sp:hover {
          opacity: 0.8; }
        .home .menu-sp .menu_inner .tel-banner-wrap-sp .tel-banner-sp img {
          box-shadow: 5px 5px 5px #0000002e;
          border-radius: 31px;
          border: 1px solid #D7C7D7; }
      .home .menu-sp .menu_inner .menu-content {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap; }
        .home .menu-sp .menu_inner .menu-content a {
          width: 48%;
          margin-bottom: 10px; }
          .home .menu-sp .menu_inner .menu-content a img {
            box-shadow: 5px 5px 5px #0000002e; }
  .home .flex-box {
    display: flex;
    justify-content: space-evenly;
    gap: 10px; }
    @media (max-width: 768px) {
      .home .flex-box p.btn {
        width: 50%;
        box-sizing: border-box; }
        .home .flex-box p.btn a {
          width: 100%;
          box-sizing: border-box; } }

/* end .home */
 /*-------------------------------------------------------------------------------

  下層共通パーツ

  -------------------------------------------------------------------------------*/
.ct-title-default article h1 {
  background: url(../img/page-bg.jpg) center center/cover no-repeat;
  height: 255px;
  text-align: center;
  font-size: 240%; }
  .ct-title-default article h1 span {
    margin: 0 auto;
    padding: 100px 20px 0;
    color: #000;
    font-size: 120%;
    display: block; }
.ct-title-default article section h2 {
  border-bottom: 0;
  padding-top: 2em;
  text-align: center;
  padding-left: 0;
  font-weight: bold;
  font-size: 140%;
  height: auto; }
  @media (max-width: 768px) {
    .ct-title-default article section h2 {
      margin-top: 0; } }
  .ct-title-default article section h2::before {
    background: url(../img/ico-hoshi.png) center center/contain no-repeat;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: -1em;
    bottom: auto;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 4em;
    height: 4em; }
.ct-title-default article section h3 {
  font-weight: bold;
  padding-left: 1.5em;
  font-size: 122%;
  margin-top: 30px; }
  .ct-title-default article section h3::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    background: #6d4528;
    width: 1em;
    height: 1em;
    background: url(../img/ico-hoshi1v3.png) center center/contain no-repeat;
    bottom: 0.5em;
    top: 2px; }
    @media (max-width: 768px) {
      .ct-title-default article section h3::before {
        top: 5px; } }
.ct-title-default article section h4 {
  font-weight: bold;
  border-bottom: 0;
  border-left: 5px solid #6d4528;
  padding: 3px 3px 3px 0.5em;
  margin-bottom: 20px; }
.ct-title-default article section h5 {
  font-size: 100%;
  margin-bottom: 8px;
  font-weight: bold; }
.ct-title-default article section a::hover {
  opacity: 0.6; }
.ct-title-default article section .right {
  text-align: right; }
.ct-title-default article section .category-news-list {
  height: auto;
  font-size: 120%;
  text-align: left;
  border-bottom: 1px solid #d9d9d9;
  padding-top: 0; }
  .ct-title-default article section .category-news-list::before {
    display: none; }
  .ct-title-default article section .category-news-list time {
    margin-right: 0.5em; }
  .ct-title-default article section .category-news-list .read-more {
    margin-top: -15px; }
.ct-title-default article section span.strong {
  font-size: 120%;
  letter-spacing: 0.2em;
  background: linear-gradient(transparent 70%, #FCFF8E 70%); }
.ct-title-default article section ul li ul {
  margin-top: 15px; }
  .ct-title-default article section ul li ul li::before {
    width: 9px;
    height: 2px; }
.ct-title-default article .side-contents .local-nav h2::before {
  display: none; }
@media (max-width: 960px) {
  .ct-title-default article .side-contents .local-nav ul li ul {
    display: block; } }

.has-text-align-right {
  text-align: right; }

section table.facility-list {
  font-size: 89%; }
  section table.facility-list tbody .th-1 {
    width: 90px; }
  section table.facility-list td {
    padding: 8px 3px 8px 9px;
    line-height: 1.2; }
section table.optout {
  font-size: 89%; }
  section table.optout tbody th {
    padding: 8px 3px 8px 9px; }
  section table.optout tbody .th-1 {
    width: 90px; }
  section table.optout tbody .th-3 {
    width: 100px; }
  section table.optout td {
    padding: 8px 3px 8px 9px;
    line-height: 1.5; }
section table.t01 {
  font-size: 89%; }
  section table.t01 tbody th {
    padding: 8px 3px 8px 9px;
    width: 150px; }
  section table.t01 tbody td {
    padding: 8px 3px 8px 9px;
    line-height: 1.5; }

article .side-contents .local-nav ul li.current ul {
  display: block; }
article .side-contents .local-nav ul li.current:hover ul {
  position: relative;
  right: auto;
  width: 100%;
  top: auto; }
article .side-contents .local-nav ul li.current-parent ul {
  display: block; }
article .side-contents .local-nav ul li.current-parent:hover ul {
  position: relative;
  right: auto;
  width: 100%;
  top: auto; }

.has_text_align_center {
  text-align: center; }

.category section h2 + p, .single section h2 + p, .page section h2 + p {
  margin-top: 30px; }

/*モーダルを開くボタン*/
.modal-open {
  	/*position: fixed;
  	display: flex;
      align-items: center;
      justify-content: center;
      top: 50%;
      left: 50%;
  	width: 300px;
  	height: 50px;
  	font-weight: bold;
  	color: #fff;
  	background: #000;
  	margin: auto;
  	cursor: pointer;
  	transform: translate(-50%,-50%);
  */ }

/*モーダル本体の指定 + モーダル外側の背景の指定*/
.modal-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 0.5);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box; }

/*モーダル本体の擬似要素の指定*/
.modal-container:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%; }

/*モーダル本体に「active」クラス付与した時のスタイル*/
.modal-container.active {
  opacity: 1;
  visibility: visible; }

/*モーダル枠の指定*/
.modal-body {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 500px;
  width: 90%; }

/*モーダルを閉じるボタンの指定*/
.modal-close {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: -40px;
  right: -40px;
  width: 40px;
  height: 40px;
  font-size: 40px;
  color: #fff;
  cursor: pointer; }

/*モーダル内のコンテンツの指定*/
.modal-content {
  background: #fff;
  text-align: left;
  padding: 30px; }

/*サイドバー下のバナー*/
@media (max-width: 768px) {
  .side-contents .left-banner li {
    text-align: center;
    padding-top: 10px; } }
@media (max-width: 768px) {
  .side-contents .left-banner li img {
    width: 80%; } }

/*------------------------------------------------------------------

flex系

-------------------------------------------------------------------------*/
.flex-wrap {
  display: flex;
  justify-content: space-around;
  width: 100%;
  flex-wrap: wrap;
  align-items: flex-start;
  margin-bottom: 30px; }
  .flex-wrap .flex-50 {
    max-width: 50%;
    width: 50%; }
  .flex-wrap .flex-70 {
    max-width: 68%;
    width: 68%; }
  .flex-wrap .flex-30 {
    max-width: 28%;
    width: 28%; }
    .flex-wrap .flex-30 img {
      max-height: 320px; }
  .flex-wrap .fukidashi-right-area {
    position: relative;
    display: inline-block;
    background-color: #fff;
    border: solid 2px #525252;
    padding: 16px;
    max-width: 100%;
    text-align: left;
    border-radius: 15px;
    box-sizing: border-box;
    width: 100%; }
    .flex-wrap .fukidashi-right-area::before, .flex-wrap .fukidashi-right-area::after {
      content: "";
      position: absolute;
      top: 50%;
      left: -26px;
      -webkit-transform: translateX(0%);
      transform: translateX(0%); }
    .flex-wrap .fukidashi-right-area::before {
      border: solid 12px transparent;
      border-right: solid 12px #525252; }
    .flex-wrap .fukidashi-right-area::after {
      border: solid 14px transparent;
      border-right: solid 14px #fff;
      margin-left: 1px;
      margin-top: -2px; }
    .flex-wrap .fukidashi-right-area p {
      margin: 0;
      padding: 0; }
  .flex-wrap .fukidashi-left-area {
    position: relative;
    display: inline-block;
    background-color: #fff;
    border: solid 2px #525252;
    padding: 16px;
    max-width: 100%;
    text-align: left;
    border-radius: 15px;
    box-sizing: border-box;
    width: 100%; }
    .flex-wrap .fukidashi-left-area::before, .flex-wrap .fukidashi-left-area::after {
      content: "";
      position: absolute;
      top: 50%;
      right: -36px;
      -webkit-transform: translateX(-50%);
      transform: translateX(-50%); }
    .flex-wrap .fukidashi-left-area::before {
      border: solid 12px transparent;
      border-left: solid 12px #525252; }
    .flex-wrap .fukidashi-left-area::after {
      border: solid 14px transparent;
      border-left: solid 14px #fff;
      margin-right: -1px;
      margin-top: -2px; }
    .flex-wrap .fukidashi-left-area p {
      margin: 0;
      padding: 0; }

/*-----------------------------------------------
QAのリスト
-------------------------------------------------*/
ul.qa-ichiran {
  padding: 0;
  position: relative;
  margin-left: 20px; }
  ul.qa-ichiran li {
    border-left: solid 8px #6d4528;
    /*左側の線*/
    background: #fff8ef;
    /*背景色*/
    margin-bottom: 8px;
    /*下のバーとの余白*/
    line-height: 1.5;
    border-radius: 0 15px 15px 0;
    /*右側の角だけ丸く*/
    padding: 0;
    font-weight: bold;
    list-style-type: none !important;
    box-shadow: 3px 3px 3px #c3c3c3; }
    ul.qa-ichiran li:active {
      transform: translateY(3px);
      /*下に動く*/
      box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2); }
    ul.qa-ichiran li::before {
      display: none; }
    ul.qa-ichiran li:after {
      content: "";
      display: block;
      position: absolute;
      top: 50%;
      right: 15px;
      width: 5px;
      height: 5px;
      margin: -3px 0 0 0;
      border-top: 1px solid #333333;
      border-right: 1px solid #333333;
      -webkit-transform: rotate(45deg);
      -moz-transform: rotate(45deg);
      transform: rotate(45deg); }
    ul.qa-ichiran li a {
      display: block;
      padding: 0.6em 1em; }
  ul.qa-ichiran > ol, ul.qa-ichiran > ul {
    margin-bottom: 0; }
    ul.qa-ichiran > ol li a, ul.qa-ichiran > ul li a {
      padding: 0.2em 0.5em; }

/*    >ol, >ul {
      >li {
        //border-left: solid 8px #6d4528;
        background: #fff8ef;
        margin-bottom: 8px;
        //line-height: 1.5;
        border-radius: 0 15px 15px 0;
        padding: 0;
        font-weight: bold;
        //list-style-type: none !important;
        box-shadow: 3px 3px 3px #c3c3c3;
      }
    }
  }
}*/
.font-size-large24 {
  font-size: 133%; }

.red {
  color: red; }

.bottom-img {
  min-height: 450px;
  width: 100%;
  position: relative; }
  @media (max-width: 768px) {
    .bottom-img {
      min-height: 300px;
      text-align: center; } }
  @media (max-width: 768px) {
    .bottom-img ul {
      text-align: left; } }
  .bottom-img img {
    right: 0;
    position: absolute;
    width: 50%;
    top: 0px;
    z-index: -10; }
    @media (max-width: 768px) {
      .bottom-img img {
        position: relative; } }

.has-text-align-center {
  text-align: center; }

/*------------------------------------------------------------------

HTLV1について（一般の方向け））

-------------------------------------------------------------------------*/
.htlv1_introduction .flex-wrap, .htlv1-2 .flex-wrap {
  margin-bottom: 30px; }
.htlv1_introduction main section h3, .htlv1-2 main section h3 {
  line-height: 1.2;
  font-size: 156%;
  margin-top: 80px; }
.htlv1_introduction main section h4, .htlv1-2 main section h4 {
  font-size: 135%; }
@media (max-width: 768px) {
  .htlv1_introduction main section, .htlv1-2 main section {
    font-size: 89%; } }

.htlv1-2 .font-size-large24 {
  font-size: 100%; }
.htlv1-2 main section h3 {
  font-size: 122%; }
.htlv1-2 main section h4 {
  font-size: 107%; }
.htlv1-2 .flex-wrap .fukidashi-right-area::before, .htlv1-2 .flex-wrap .fukidashi-right-area::after {
  top: 45%; }
.htlv1-2 .flex-wrap .flex-50 {
  width: 45%; }
.htlv1-2 .flex-wrap .flex-70 {
  width: 60%; }

/*------------------------------------------------------------------

初めてご利用になる方へ

-------------------------------------------------------------------------*/
.introduction section h4 {
  margin-bottom: 10px !important; }
.introduction section p {
  margin-bottom: 10px; }
.introduction section .btn {
  margin-bottom: 50px; }

/*------------------------------------------------------------------

新着情報

-------------------------------------------------------------------------*/
.ico {
  text-indent: -9999px;
  width: 55px;
  display: inline-block;
  padding: 1px 8px 1px 8px;
  border-radius: 2px;
  color: #fff;
  font-size: 81%;
  font-weight: bold;
  margin: 0 10px 0 0; }

.ico-jspfad_news {
  background: url("../img/ico-jspfad.png") center center/contain no-repeat; }

.ico-atl_news {
  background: url("../img/ico-atl.png") center center/contain no-repeat; }

.ico-hamnet_news {
  background: url("../img/ico-hamv2.png") center center/contain no-repeat; }

.ico-carrier_news {
  background: url("../img/ico-carrier.png") center center/contain no-repeat; }

.ico-new {
  background: url("../img/ico-new.png") center center/contain no-repeat; }

.ico-thesis {
  background: url("../img/ico-thesis.png") center center/contain no-repeat; }

.ico-event {
  background: url("../img/ico-event.png") center center/contain no-repeat; }

/*------------------------------------------------------------------

疑問別・・・ページ

-------------------------------------------------------------------------*/
.qa article section {
  padding: 0 0 0 10px; }
  .qa article section ul.qa-ichiran {
    padding: 0;
    position: relative;
    margin-left: 20px; }
    .qa article section ul.qa-ichiran li {
      border-left: solid 8px #6d4528;
      /*左側の線*/
      background: #fff8ef;
      /*背景色*/
      margin-bottom: 8px;
      /*下のバーとの余白*/
      line-height: 1.5;
      border-radius: 0 15px 15px 0;
      /*右側の角だけ丸く*/
      padding: 0;
      font-weight: bold;
      list-style-type: none !important;
      box-shadow: 3px 3px 3px #c3c3c3; }
      .qa article section ul.qa-ichiran li:active {
        transform: translateY(3px);
        /*下に動く*/
        box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2); }
      .qa article section ul.qa-ichiran li::before {
        display: none; }
      .qa article section ul.qa-ichiran li:after {
        content: "";
        display: block;
        position: absolute;
        top: 50%;
        right: 15px;
        width: 5px;
        height: 5px;
        margin: -3px 0 0 0;
        border-top: 1px solid #333333;
        border-right: 1px solid #333333;
        -webkit-transform: rotate(45deg);
        -moz-transform: rotate(45deg);
        transform: rotate(45deg); }
      .qa article section ul.qa-ichiran li a {
        display: block;
        padding: 0.6em 1em; }
  .qa article section ul.kome {
    list-style: none;
    padding-left: 0;
    margin-left: 0; }
    .qa article section ul.kome li {
      margin-bottom: 1em;
      padding: 0 0 0 2em; }
      .qa article section ul.kome li::before {
        content: "※";
        margin-right: 0.5em;
        background: none;
        top: 0px; }
  .qa article section ul.check {
    margin-top: 0; }
  .qa article section dl.mokuji {
    padding: 20px;
    border-radius: 15px;
    background: #fffaf6; }
    .qa article section dl.mokuji dt {
      padding-top: 10px; }
  .qa article section dl dt {
    padding: 30px 0 0 0;
    display: flex;
    font-weight: bold;
    align-items: center; }
    .qa article section dl dt:before {
      content: "Q";
      color: #fff;
      font-weight: bold;
      background-color: #b01823;
      border: 2px solid #b01823;
      padding: 1px 10px 7px;
      border-radius: 3px;
      margin-right: 10px;
      margin-top: -0.4em;
      height: 25px; }
  .qa article section dl dd {
    padding: 10px 0 0 0;
    display: flex; }
    .qa article section dl dd:before {
      content: "A";
      color: #b01823;
      font-weight: bold;
      background-color: #fff;
      border: 2px solid #b01823;
      padding: 5px 11px;
      border-radius: 3px;
      margin-right: 10px;
      height: 25px; }
    .qa article section dl dd a {
      position: relative;
      padding-left: 10px; }
      .qa article section dl dd a:before {
        content: "";
        position: absolute;
        top: .35em;
        left: 0;
        width: 0;
        height: 0;
        border-width: 5px;
        border-style: solid;
        border-color: transparent transparent transparent #6d4528; }

.category main, .single main, .page main {
  font-size: 120%; }
  @media (max-width: 768px) {
    .category main section h3, .single main section h3, .page main section h3 {
      line-height: 1.2em; } }
.category article h1 span, .single article h1 span, .page article h1 span {
  color: #520d13;
  font-size: 100%;
  text-shadow: 0px 0px 20px #fff, 0px 0px 20px #fff, 0px 0px 20px #fff, 0px 0px 20px #fff, 0px 0px 20px #fff, 0px 0px 20px #fff; }
  @media (max-width: 768px) {
    .category article h1 span, .single article h1 span, .page article h1 span {
      font-size: 80%;
      line-height: 1.2em; } }

 /*-------------------------------------------------------------------------------

 e-learning

  -------------------------------------------------------------------------------*/
section .iframe-wrap {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 53%;
  overflow: hidden; }
  section .iframe-wrap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

 /*-------------------------------------------------------------------------------

 3大カテゴリ共通パーツ

  -------------------------------------------------------------------------------*/
.hamnet article h1 span,
.jspfad article h1 span,
.atl article h1 span {
  text-indent: -9999px; }
.hamnet article section h2::before,
.jspfad article section h2::before,
.atl article section h2::before {
  background: url(../img/ico-hana.png) center center/contain no-repeat; }
.hamnet article section h3::before,
.jspfad article section h3::before,
.atl article section h3::before {
  background: url(../img/ico-hana1.png) center center/contain no-repeat; }
.hamnet article section .btn a,
.jspfad article section .btn a,
.atl article section .btn a {
  background: #529500;
  color: #fff;
  border: 1px solid #529500;
  box-shadow: 3px 3px 5px #c3c3c3; }
  .hamnet article section .btn a::before,
  .jspfad article section .btn a::before,
  .atl article section .btn a::before {
    border-top: 2px solid #fff;
    border-right: 2px solid #fff; }
  .hamnet article section .btn a i::after,
  .jspfad article section .btn a i::after,
  .atl article section .btn a i::after {
    display: none; }
.hamnet article section .btn a:hover,
.jspfad article section .btn a:hover,
.atl article section .btn a:hover {
  background: #fff;
  color: #529500; }
  .hamnet article section .btn a:hover::before,
  .jspfad article section .btn a:hover::before,
  .atl article section .btn a:hover::before {
    border-color: #529500; }
.hamnet article section .btn a:active,
.jspfad article section .btn a:active,
.atl article section .btn a:active {
  transform: translateY(2px);
  box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2); }
.hamnet article section ul.kome,
.jspfad article section ul.kome,
.atl article section ul.kome {
  list-style: none;
  padding-left: 0;
  margin-left: 0; }
  .hamnet article section ul.kome li,
  .jspfad article section ul.kome li,
  .atl article section ul.kome li {
    margin-bottom: 1em;
    padding: 0 0 0 2em; }
    .hamnet article section ul.kome li::before,
    .jspfad article section ul.kome li::before,
    .atl article section ul.kome li::before {
      content: "※";
      margin-right: 0.5em;
      background: none;
      top: 0px; }
.hamnet article section .p-kome,
.jspfad article section .p-kome,
.atl article section .p-kome {
  text-indent: -1.5em;
  padding-left: 1.5em; }
.hamnet article section .kakko,
.jspfad article section .kakko,
.atl article section .kakko {
  margin-left: 2.5em; }
  .hamnet article section .kakko li,
  .jspfad article section .kakko li,
  .atl article section .kakko li {
    list-style-type: none;
    counter-increment: cnt;
    position: relative;
    margin-bottom: 20px; }
    .hamnet article section .kakko li::before,
    .jspfad article section .kakko li::before,
    .atl article section .kakko li::before {
      content: "(" counter(cnt) ")";
      display: inline-block;
      margin-left: -3.5em;
      width: 3em;
      text-align: right;
      position: absolute;
      top: 0;
      left: 0; }
.hamnet article section .c-top,
.jspfad article section .c-top,
.atl article section .c-top {
  margin-bottom: 30px; }
  @media (max-width: 426px) {
    .hamnet article section .c-top img.pc-img,
    .jspfad article section .c-top img.pc-img,
    .atl article section .c-top img.pc-img {
      display: none; } }
  @media (min-width: 426px) {
    .hamnet article section .c-top img.sp-img,
    .jspfad article section .c-top img.sp-img,
    .atl article section .c-top img.sp-img {
      display: none; } }
  .hamnet article section .c-top .top-box:nth-of-type(1) ul li a time,
  .jspfad article section .c-top .top-box:nth-of-type(1) ul li a time,
  .atl article section .c-top .top-box:nth-of-type(1) ul li a time {
    padding-right: 1em; }
  .hamnet article section .c-top h3,
  .jspfad article section .c-top h3,
  .atl article section .c-top h3 {
    color: #372B29;
    text-align: center;
    padding: 0.25em 0 0.1em;
    border-top: solid 1px #FFE3B0;
    border-bottom: solid 1px #FFE3B0;
    background: repeating-linear-gradient(-45deg, #FFF5DF, #FFF5DF 3px, #FFE3B0 3px, #FFE3B0 7px);
    margin-top: 0; }
    .hamnet article section .c-top h3::before,
    .jspfad article section .c-top h3::before,
    .atl article section .c-top h3::before {
      display: none; }
  .hamnet article section .c-top .top-btn,
  .jspfad article section .c-top .top-btn,
  .atl article section .c-top .top-btn {
    display: flex;
    justify-content: center;
    flex-wrap: wrap; }
    @media (max-width: 425px) {
      .hamnet article section .c-top .top-btn .btn,
      .jspfad article section .c-top .top-btn .btn,
      .atl article section .c-top .top-btn .btn {
        width: 100%; } }
  .hamnet article section .c-top .btn,
  .jspfad article section .c-top .btn,
  .atl article section .c-top .btn {
    margin: 0;
    text-align: center; }
    .hamnet article section .c-top .btn a,
    .jspfad article section .c-top .btn a,
    .atl article section .c-top .btn a {
      background: #529500;
      color: #fff;
      border: 1px solid #529500;
      box-shadow: 3px 3px 5px #c3c3c3;
      text-decoration: none; }
      .hamnet article section .c-top .btn a::before,
      .jspfad article section .c-top .btn a::before,
      .atl article section .c-top .btn a::before {
        border-top: 2px solid #fff;
        border-right: 2px solid #fff; }
      .hamnet article section .c-top .btn a i::after,
      .jspfad article section .c-top .btn a i::after,
      .atl article section .c-top .btn a i::after {
        display: none; }
      .hamnet article section .c-top .btn a span,
      .jspfad article section .c-top .btn a span,
      .atl article section .c-top .btn a span {
        white-space: nowrap; }
    .hamnet article section .c-top .btn a:hover,
    .jspfad article section .c-top .btn a:hover,
    .atl article section .c-top .btn a:hover {
      background: #fff;
      color: #529500; }
      .hamnet article section .c-top .btn a:hover::before,
      .jspfad article section .c-top .btn a:hover::before,
      .atl article section .c-top .btn a:hover::before {
        border-color: #529500; }
    .hamnet article section .c-top .btn a:active,
    .jspfad article section .c-top .btn a:active,
    .atl article section .c-top .btn a:active {
      transform: translateY(2px);
      box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2); }
  .hamnet article section .c-top p,
  .jspfad article section .c-top p,
  .atl article section .c-top p {
    padding: 0 20px 20px;
    margin: 0; }
  .hamnet article section .c-top .patient .btn,
  .jspfad article section .c-top .patient .btn,
  .atl article section .c-top .patient .btn {
    padding: 0 10px 20px; }
.hamnet article section .c-top-news ul li:before,
.jspfad article section .c-top-news ul li:before,
.atl article section .c-top-news ul li:before {
  content: none; }
.hamnet article .top-box,
.jspfad article .top-box,
.atl article .top-box {
  margin-bottom: 30px; }

.pankuzu {
  margin: 20px 0 30px 0;
  font-size: 1rem;
  font-weight: bold;
  letter-spacing: -0.4em;
  max-width: 1000px;
  margin: 20px auto 30px;
  padding: 0 20px;
  box-sizing: border-box; }
  .pankuzu > * {
    display: inline-block;
    letter-spacing: normal; }
  @media (max-width: 960px) {
    .pankuzu {
      margin-left: 10px; } }
  @media (max-width: 768px) {
    .pankuzu {
      margin-bottom: 10px; } }
  .pankuzu a:after {
    width: 6px;
    height: 6px;
    margin: -2px 7px 0 10px;
    content: '';
    display: inline-block;
    vertical-align: middle;
    border-bottom: solid 1px #000;
    border-left: solid 1px #000;
    -moz-transform: rotate(-135deg);
    -ms-transform: rotate(-135deg);
    -webkit-transform: rotate(-135deg);
    transform: rotate(-135deg); }

.side-contents .left-banner .icon-window {
  display: none; }

.l-modal--img img {
  max-height: 88vh; }

.facility-list tbody tr td.color01 {
  background: #ccd2df; }
.facility-list tbody tr td.color02 {
  background: #ffd6cc; }
.facility-list tbody tr td.color03 {
  background: #dce6f2; }
.facility-list tbody tr td.color04 {
  background: #e9f6dc; }
.facility-list tbody tr td.color05 {
  background: #d0ecef; }
.facility-list tbody tr td.color06 {
  background: #ffebcc; }
.facility-list tbody tr td.color07 {
  background: #ccefdc; }
.facility-list tbody tr td.color08 {
  background: #ffe0eb; }
.facility-list tbody tr td.color09 {
  background: #f2dcdb; }

section a.no-iconwindow .icon-window {
  display: none; }
  section a.no-iconwindow .icon-window:after {
    content: none; }
section a.no-iconwindow:after {
  content: none; }

@media (max-width: 960px) {
  .side-contents {
    margin-bottom: 0; } }

section .iframe-wrap {
  margin: 50px 0; }
  @media (max-width: 768px) {
    section .iframe-wrap {
      margin: 30px 0; } }

 /*-------------------------------------------------------------------------------

  HMAねっと

  -------------------------------------------------------------------------------*/
.hamnet article {
  background: linear-gradient(to bottom, #fff, #ebf4da); }
  .hamnet article h1 {
    background: url(../img/ham-mainv.jpg) center center/cover no-repeat;
    border-bottom: 25px solid #64a500;
    border-image: linear-gradient(to right, #ffffff 0%, #9bd200 30%, #9bd200 70%, #fff 100%);
    border-image-slice: 1; }
    .hamnet article h1 span {
      background: url(../img/ham-mainv-logo.png) bottom center/contain no-repeat;
      max-width: 420px;
      padding: 100px 20px 0;
      color: transparent; }
      @media (max-width: 767px) {
        .hamnet article h1 span {
          padding-top: 80px;
          max-width: 300px; } }
  .hamnet article section {
    background: #fff;
    padding: 20px; }
    .hamnet article section h3::before {
      filter: invert(17%) sepia(91%) saturate(7085%) hue-rotate(128deg) brightness(100%) contrast(106%); }
    .hamnet article section h4 {
      border-color: #017f01; }
    .hamnet article section a {
      color: #5F432E; }
  .hamnet article .side-contents {
      /*.side-contents {
        .left-banner {
          li {
            @media(max-width:768px) {
              text-align: center;
              padding-top: 10px;
	    }
            img {
              @media(max-width:768px) {
                width: 80%;
              }
            }
          }
        }
      }*/ }
    .hamnet article .side-contents .local-nav {
      background: #eef6ea; }
      .hamnet article .side-contents .local-nav h2 {
        background: -webkit-linear-gradient(top, #529500, #9bd200);
        background: linear-gradient(to bottom, #529500, #9bd200); }
        .hamnet article .side-contents .local-nav h2 a {
          color: #fff; }
      .hamnet article .side-contents .local-nav ul li a {
        color: #000; }
      .hamnet article .side-contents .local-nav ul li.current > a {
        background: #529500;
        color: #fff; }
      @media (min-width: 768px) {
        .hamnet article .side-contents .local-nav ul li ul li {
          background-color: #529500; } }
  .hamnet article dl.qa-list dt {
    padding: 30px 0 0 0;
    display: flex;
    font-weight: bold; }
    .hamnet article dl.qa-list dt:before {
      content: "Q";
      color: #fff;
      font-weight: bold;
      padding: 5px 10px;
      border-radius: 3px;
      margin-right: 10px;
      margin-top: -0.4em;
      height: 25px;
      background-color: #EEA759;
      border: 1px solid #EEA759; }
  .hamnet article dl.qa-list dd {
    padding: 10px 0 0 0;
    display: flex; }
    .hamnet article dl.qa-list dd:before {
      content: "A";
      font-weight: bold;
      background-color: #fff;
      padding: 5px 11px;
      border-radius: 3px;
      margin-right: 10px;
      height: 25px;
      color: #EEA759;
      border: 1px solid #EEA759; }
    .hamnet article dl.qa-list dd .table-wrap {
      white-space: inherit; }
      @media (min-width: 768px) {
        .hamnet article dl.qa-list dd .table-wrap th.kouteki-shien {
          width: 130px; } }
.hamnet .ham_qa .table-wrap {
  margin-top: 10px;
  margin-bottom: 0px; }
  .hamnet .ham_qa .table-wrap table {
    margin-top: 0px;
    margin-bottom: 0px; }
    .hamnet .ham_qa .table-wrap table th {
      text-align: center; }
.hamnet .ham_qa ol li {
  margin-bottom: 10px; }
.hamnet .ham_qa figure.ham_img {
  text-align: center;
  margin: 0; }
  .hamnet .ham_qa figure.ham_img img {
    width: 180px; }
    @media (max-width: 768px) {
      .hamnet .ham_qa figure.ham_img img {
        width: 120px; } }
.hamnet .ham_qa .flex-wrap {
  display: flex;
  justify-content: space-around;
  width: 100%;
  flex-wrap: wrap;
  align-items: flex-start;
  margin-bottom: 10px; }
  .hamnet .ham_qa .flex-wrap img {
    width: 250px; }
    @media (max-width: 768px) {
      .hamnet .ham_qa .flex-wrap img {
        width: 120px; } }
.hamnet .ham_qa .two-inline-colomns img {
  width: 250px; }
  @media (max-width: 768px) {
    .hamnet .ham_qa .two-inline-colomns img {
      width: 120px; } }
.hamnet .ham_qa .four-inline-items img {
  width: 120px; }
.hamnet .ham_qa .three-inline-items img {
  width: 180px; }
  @media (max-width: 768px) {
    .hamnet .ham_qa .three-inline-items img {
      width: 120px; } }
.hamnet .ham_qa .two-column-items {
  gap: 10px;
  justify-content: space-around; }
  .hamnet .ham_qa .two-column-items img {
    height: 300px;
    width: auto; }
    @media (max-width: 768px) {
      .hamnet .ham_qa .two-column-items img {
        height: 200px; } }
.hamnet .wrap main article section .btn a {
  background: -webkit-linear-gradient(top, #529500, #9bd200);
  background: linear-gradient(to bottom, #529500, #9bd200);
  border: none;
  transition: background 0.2s; }
  .hamnet .wrap main article section .btn a:hover {
    background: #FFAB65;
    color: #fff; }
    .hamnet .wrap main article section .btn a:hover:before {
      border-color: #fff; }

/*ハムトップ、メインビジュアル改修*/
.hamnet-title .hamnet-title-inner {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  justify-content: space-around; }
  .hamnet-title .hamnet-title-inner .hamnet-logo1 {
    width: 450px;
    overflow: hidden;
    height: 255px; }
    .hamnet-title .hamnet-title-inner .hamnet-logo1 img {
      margin-top: 20px; }
      @media (max-width: 960px) {
        .hamnet-title .hamnet-title-inner .hamnet-logo1 img {
          margin-top: 90px;
          width: 255px; } }
    .hamnet-title .hamnet-title-inner .hamnet-logo1 p.hamnet-logo-txt1 {
      font-size: 37%;
      line-height: 1.3;
      letter-spacing: 0;
      color: #21301c;
      text-align: left; }
      @media (max-width: 960px) {
        .hamnet-title .hamnet-title-inner .hamnet-logo1 p.hamnet-logo-txt1 {
          display: none; } }
  .hamnet-title .hamnet-title-inner .hamnet-logo2 {
    width: 450px; }
    .hamnet-title .hamnet-title-inner .hamnet-logo2 p.hamnet-sub-title {
      font-size: 60%;
      margin: 0;
      color: #E78665;
      text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, -1px 0 #FFF, -1px 0 0 #FFF, 1px 0 0 #FFF;
      line-height: 1;
      margin-top: 35px; }
    .hamnet-title .hamnet-title-inner .hamnet-logo2 img {
      max-width: 100%;
      height: auto;
      padding-top: 21px;
      width: 350px; }
    @media (max-width: 960px) {
      .hamnet-title .hamnet-title-inner .hamnet-logo2 {
        display: none; } }

/*-------------------------------------------------------------------------------

  JSPFAD

  -------------------------------------------------------------------------------*/
.jspfad article {
  background: url(../img/jspfad-bg2_v3.png) center bottom/auto 250px repeat-x, linear-gradient(to bottom, #fff 60%, #d5e8f9);
  padding-bottom: 250px; }
  @media (max-width: 960px) {
    .jspfad article {
      padding-bottom: 0; } }
  .jspfad article h1 {
    background: url(../img/jspfad-bg.jpg) center right/cover no-repeat;
    position: relative; }
    .jspfad article h1 span {
      background: url(../img/JSPFADlogo_20221221.jpg) top left/contain no-repeat;
      padding: 195px 0 0;
      color: transparent;
      max-width: 1000px; }
      @media (max-width: 960px) {
        .jspfad article h1 span {
          background: url(../img/jspfad-top-logo.png) center center/contain no-repeat;
          max-width: 350px; } }
    .jspfad article h1:after {
      /*content:'JSPFAD （HTLV-1感染者コホート共同研究班）は
      HTLV-1感染者（HTLV-1キャリア）の方から 定期的に
      （1年に1回程度） 血液を採取させていただき
      その検査結果を解析することにより 重篤な疾患の前兆をつかみ
      将来的な治療や発症予防に
      つなげていこうとする研究グループです。';*/ }
  .jspfad article section {
    background: #fff;
    padding: 20px; }
    .jspfad article section a {
      color: #0068c6; }
      .jspfad article section a:hover {
        color: #3790e0; }
    .jspfad article section h3::before {
      filter: invert(41%) sepia(99%) saturate(7044%) hue-rotate(234deg) brightness(228%) contrast(110%); }
    .jspfad article section h4 {
      border-color: #3790e0; }
    .jspfad article section .btn a {
      background: #3790e0;
      color: #fff;
      border: 1px solid #3790e0;
      text-decoration: none; }
      .jspfad article section .btn a::before {
        border-top: 2px solid #fff;
        border-right: 2px solid #fff; }
    .jspfad article section .btn a:hover {
      background: #fff;
      color: #3790e0; }
      .jspfad article section .btn a:hover::before {
        border-color: #3790e0; }
    .jspfad article section .c-top h3 {
      color: #2170b7;
      border-top: solid 1px #3790e0;
      border-bottom: solid 1px #3790e0;
      background: repeating-linear-gradient(-45deg, #E5F1FB, #E5F1FB 3px, #CAE1F6 3px, #CAE1F6 7px); }
      .jspfad article section .c-top h3::before {
        display: none; }
    .jspfad article section .c-top .btn a {
      background: #3790e0;
      color: #fff;
      border: 1px solid #3790e0; }
      .jspfad article section .c-top .btn a::before {
        border-top: 2px solid #fff;
        border-right: 2px solid #fff; }
    .jspfad article section .c-top .btn a:hover {
      background: #fff;
      color: #3790e0; }
      .jspfad article section .c-top .btn a:hover::before {
        border-color: #3790e0; }
  .jspfad article .side-contents .local-nav {
    background: #eff6fd; }
    .jspfad article .side-contents .local-nav h2 {
      background-color: #3790e0; }
      .jspfad article .side-contents .local-nav h2 a {
        color: #fff; }
    .jspfad article .side-contents .local-nav ul li a {
      color: #000; }
    .jspfad article .side-contents .local-nav ul li.current > a {
      background: #3790e0;
      color: #fff; }
    @media (min-width: 768px) {
      .jspfad article .side-contents .local-nav ul li ul li {
        background-color: #2e5489; } }
@media (max-width: 960px) {
  .jspfad .table-wrap {
    display: block;
    white-space: normal;
    box-sizing: border-box; }
    .jspfad .table-wrap table {
      display: block;
      box-sizing: border-box; }
      .jspfad .table-wrap table tr, .jspfad .table-wrap table th, .jspfad .table-wrap table td {
        width: 100%;
        display: block;
        box-sizing: border-box; }
      .jspfad .table-wrap table thead {
        display: block;
        box-sizing: border-box; }
      .jspfad .table-wrap table tbody {
        display: block;
        box-sizing: border-box; } }

.jspfad-sub-title {
  display: block;
  position: absolute;
  top: 10px;
  color: #fff;
  font-size: 40%;
  line-height: 1.8;
  left: calc(50% - 200px);
  text-align: left; }
  @media (max-width: 960px) {
    .jspfad-sub-title {
      display: none; } }

.jspfad-title .jspfad-title-inner {
  max-width: 1000px;
  margin: 0 auto; }
  .jspfad-title .jspfad-title-inner .jspfad-logo {
    width: 255px;
    background: url(../img/JSPFADlogo_20221221.jpg) top left/contain no-repeat;
    overflow: hidden;
    height: 255px; }
    @media (max-width: 960px) {
      .jspfad-title .jspfad-title-inner .jspfad-logo {
        background: url(../img/jspfad-top-logo.png) center center/contain no-repeat;
        max-width: 350px;
        margin: 0 auto; } }
    .jspfad-title .jspfad-title-inner .jspfad-logo .jspfad-logo-txt1 {
      margin-top: 120px;
      font-size: 35%;
      line-height: 1.3;
      letter-spacing: 0; }
      @media (max-width: 960px) {
        .jspfad-title .jspfad-title-inner .jspfad-logo .jspfad-logo-txt1 {
          display: none; } }
    .jspfad-title .jspfad-title-inner .jspfad-logo .jspfad-logo-txt2 {
      font-size: 42%;
      line-height: 1.3;
      letter-spacing: 0; }
      @media (max-width: 960px) {
        .jspfad-title .jspfad-title-inner .jspfad-logo .jspfad-logo-txt2 {
          display: none; } }

 /*-------------------------------------------------------------------------------

  ATL

  -------------------------------------------------------------------------------*/
.atl article {
  background: linear-gradient(to bottom, #fff, #fbeeeb); }
  .atl article h1 {
    background: url(../img/atl-mainv.jpg) center center/cover no-repeat; }
    .atl article h1 span {
      background: url(../img/atl-mainv-logo.png) bottom center/contain no-repeat;
      max-width: 400px;
      padding: 100px 20px 0;
      color: transparent; }
  .atl article section {
    background: #fff;
    padding: 20px; }
    .atl article section h3::before {
      filter: invert(72%) sepia(26%) saturate(6428%) hue-rotate(-52deg) brightness(105%) contrast(102%); }
    .atl article section h4 {
      border-color: #ff8765; }
    .atl article section a {
      color: #ff8765; }
    .atl article section .btn a {
      background: #ff8765;
      color: #fff;
      border: 1px solid #ff8765; }
      .atl article section .btn a::before {
        border-top: 2px solid #fff;
        border-right: 2px solid #fff; }
    .atl article section .btn a:hover {
      background: #fff;
      color: #ff8765; }
      .atl article section .btn a:hover::before {
        border-color: #ff8765; }
    .atl article section .c-top h3 {
      color: #e44343;
      border-top: solid 1px #ff8765;
      border-bottom: solid 1px #ff8765;
      background: repeating-linear-gradient(-45deg, #FFEAE4, #FFEAE4 3px, #FFDBD2 3px, #FFDBD2 7px); }
      .atl article section .c-top h3::before {
        display: none; }
    .atl article section .c-top .btn a {
      background: #ff8765;
      color: #fff;
      border: 1px solid #ff8765; }
      .atl article section .c-top .btn a::before {
        border-top: 2px solid #fff;
        border-right: 2px solid #fff; }
    .atl article section .c-top .btn a:hover {
      background: #fff;
      color: #ff8765; }
      .atl article section .c-top .btn a:hover::before {
        border-color: #ff8765; }
    .atl article section dl.qa-list dt {
      padding: 30px 0 0 0;
      display: flex;
      font-weight: bold; }
      .atl article section dl.qa-list dt:before {
        content: "Q";
        color: #fff;
        font-weight: bold;
        padding: 5px 10px;
        border-radius: 3px;
        margin-right: 10px;
        margin-top: -0.4em;
        height: 25px;
        background-color: #ff8765;
        border: 1px solid #ff8765; }
    .atl article section dl.qa-list dd {
      padding: 10px 0 0 0;
      display: flex; }
      .atl article section dl.qa-list dd:before {
        content: "A";
        font-weight: bold;
        background-color: #fff;
        padding: 5px 11px;
        border-radius: 3px;
        margin-right: 10px;
        height: 25px;
        color: #ff8765;
        border: 1px solid #ff8765; }
    .atl article section .facility-list tbody tr td.color01 {
      background: #ccd2df; }
    .atl article section .facility-list tbody tr td.color02 {
      background: #ffd6cc; }
    .atl article section .facility-list tbody tr td.color03 {
      background: #dce6f2; }
    .atl article section .facility-list tbody tr td.color04 {
      background: #e9f6dc; }
    .atl article section .facility-list tbody tr td.color05 {
      background: #d0ecef; }
    .atl article section .facility-list tbody tr td.color06 {
      background: #ffebcc; }
    .atl article section .facility-list tbody tr td.color07 {
      background: #ccefdc; }
    .atl article section .facility-list tbody tr td.color08 {
      background: #ffe0eb; }
    .atl article section .facility-list tbody tr td.color09 {
      background: #f2dcdb; }
  .atl article .side-contents .local-nav {
    background: #fef2ef; }
    .atl article .side-contents .local-nav h2 {
      background-color: #ff8765; }
      .atl article .side-contents .local-nav h2 a {
        color: #fff; }
    .atl article .side-contents .local-nav ul li a {
      color: #000; }
    .atl article .side-contents .local-nav ul li.current > a {
      background: #ff8765;
      color: #fff; }
    @media (min-width: 768px) {
      .atl article .side-contents .local-nav ul li ul li {
        background-color: #c96443; } }
  .atl article table.trials_table tbody {
    font-size: 89%; }
    .atl article table.trials_table tbody tr .th-1 {
      width: 400px; }
    .atl article table.trials_table tbody tr .th-3 {
      width: 80px; }
  .atl article table.no-white-space {
    white-space: normal; }

 /*-------------------------------------------------------------------------------

  404ページ

  -------------------------------------------------------------------------------*/
@media screen and (min-width: 768px) {
  .error-404 h1 {
    margin: 0 0 20px 0; }
  .error-404 section {
    float: none;
    width: 100%; } }
h1.primary span {
  color: #520d13 !important;
  font-size: 100% !important;
  text-shadow: 0px 0px 20px #fff, 0px 0px 20px #fff, 0px 0px 20px #fff, 0px 0px 20px #fff, 0px 0px 20px #fff, 0px 0px 20px #fff; }
  @media (max-width: 768px) {
    h1.primary span {
      font-size: 80% !important;
      padding-top: 50px !important; } }

.errorpage-404 {
  text-align: center;
  margin-top: 80px; }
  .errorpage-404 p {
    font-size: 120%;
    margin-bottom: 80px;
    font-weight: bold; }
    @media (max-width: 768px) {
      .errorpage-404 p {
        font-size: 113%; } }
  .errorpage-404 p.btn a {
    font-size: 120%;
    padding: 7px 60px;
    min-width: 300px; }
    @media (max-width: 768px) {
      .errorpage-404 p.btn a {
        font-size: 113%;
        min-width: 0; } }

/*-------------------------------------------------------------------------------


お問い合わせ


-------------------------------------------------------------------------------*/
section .mw_wp_form table th.required:after {
  float: right; }
section .mw_wp_form table .mwform-checkbox-field.horizontal-item + .horizontal-item {
  margin-left: 0; }
section .mw_wp_form table .mwform-checkbox-field.horizontal-item label {
  margin: 0 0 0 1em; }
  section .mw_wp_form table .mwform-checkbox-field.horizontal-item label input {
    margin: 0 5px 0 -1.4em; }
  section .mw_wp_form table .mwform-checkbox-field.horizontal-item label span {
    white-space: normal; }
section .mw_wp_form table th, section .mw_wp_form table td {
  word-break: break-all; }
section .mw_wp_form table textarea {
  width: 91%; }
@media (max-width: 959px) {
  section .mw_wp_form .table-wrap table {
    white-space: normal;
    display: block;
    box-sizing: border-box; } }
@media (max-width: 768px) {
  section .mw_wp_form table tbody {
    display: block; }
    section .mw_wp_form table tbody tr {
      display: block; }
      section .mw_wp_form table tbody tr th,
      section .mw_wp_form table tbody tr td {
        display: block;
        width: 100%; }
        section .mw_wp_form table tbody tr th .size-m,
        section .mw_wp_form table tbody tr td .size-m {
          width: 91%; }
        section .mw_wp_form table tbody tr th textarea,
        section .mw_wp_form table tbody tr td textarea {
          width: 91%;
          height: 60px; }
        section .mw_wp_form table tbody tr th select,
        section .mw_wp_form table tbody tr td select {
          width: 91%; }
          section .mw_wp_form table tbody tr th select option,
          section .mw_wp_form table tbody tr td select option {
            width: 91%;
            white-space: normal; } }

section .mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: 0px; }

.inquiry section {
  width: 100%;
  float: none; }
  .inquiry section .table-wrap {
    white-space: inherit; }
  .inquiry section table th, .inquiry section table td {
    width: 100%;
    display: block;
    padding: 1%; }
    @media screen and (min-width: 768px) {
      .inquiry section table th, .inquiry section table td {
        width: inherit;
        display: table-cell; } }
  @media screen and (min-width: 768px) {
    .inquiry section table th {
      width: 30%; } }
.inquiry .side-contents {
  display: none; }

/* end .inquiry */
 /*-------------------------------------------------------------------------------

 関連リンク集

  -------------------------------------------------------------------------------*/
.links article section ul li {
  margin-bottom: 2em; }
  .links article section ul li a {
    display: block;
    font-size: 120%;
    font-weight: bold; }
  .links article section ul li span {
    display: block;
    font-size: 120%;
    font-weight: bold;
    color: #6d4528; }

 /*-------------------------------------------------------------------------------

 初めての方へページ

  -------------------------------------------------------------------------------*/
.arrow-area {
  padding: 10px; }
  .arrow-area .arrow-tr {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px; }
    .arrow-area .arrow-tr .arrow-box {
      background: #f6f4f2;
      padding: 10px;
      border-radius: 15px; }
      .arrow-area .arrow-tr .arrow-box:nth-of-type(1) {
        width: 30%;
        text-align: center; }
      .arrow-area .arrow-tr .arrow-box:nth-of-type(3) {
        width: 60%;
        padding: 10px 10px 10px 30px; }
      .arrow-area .arrow-tr .arrow-box p {
        font-size: 120%;
        position: relative;
        margin-bottom: 0; }
        .arrow-area .arrow-tr .arrow-box p::before {
          content: "";
          position: absolute;
          top: -65px;
          left: calc( 50% - 40px );
          height: 60px;
          width: 80px; }
        .arrow-area .arrow-tr .arrow-box p.pc::before {
          background: url(../img/pc.png) center center/contain no-repeat; }
        .arrow-area .arrow-tr .arrow-box p.senmonka::before {
          background: url(../img/senmonka.png) center center/contain no-repeat; }
        .arrow-area .arrow-tr .arrow-box p.net::before {
          background: url(../img/net.png) center center/contain no-repeat; }
        .arrow-area .arrow-tr .arrow-box p.question::before {
          background: url(../img/question.png) center center/contain no-repeat; }
      .arrow-area .arrow-tr .arrow-box ul li {
        font-size: 110%; }
        .arrow-area .arrow-tr .arrow-box ul li:before {
          content: none; }
        .arrow-area .arrow-tr .arrow-box ul li a {
          font-weight: bold; }
          .arrow-area .arrow-tr .arrow-box ul li a .icon-window {
            display: none; }
    .arrow-area .arrow-tr .arrow-round {
      position: relative;
      display: block;
      width: 10%;
      height: 7px;
      border-radius: 5px;
      background-color: #9c816d; }
      .arrow-area .arrow-tr .arrow-round::before {
        content: "";
        position: absolute;
        top: 6px;
        right: -2px;
        display: block;
        width: 25px;
        height: 7px;
        border-radius: 5px;
        background-color: #9c816d;
        transform: rotate(-45deg); }
      .arrow-area .arrow-tr .arrow-round::after {
        content: "";
        position: absolute;
        bottom: 6px;
        right: -2px;
        display: block;
        width: 25px;
        height: 7px;
        border-radius: 5px;
        background-color: #9c816d;
        transform: rotate(45deg); }
  .arrow-area .arrow-tr-01 .arrow-box {
    background-color: #cee5e9; }
  .arrow-area .arrow-tr-01 .box-height01 {
    padding-top: 97.87px;
    padding-bottom: 17.87px; }
  .arrow-area .arrow-tr-02 .arrow-box {
    background-color: #e3e7c1; }
  .arrow-area .arrow-tr-02 .box-height01 {
    padding-top: 97.87px;
    padding-bottom: 17.87px; }
  .arrow-area .arrow-tr-03 .arrow-box {
    background-color: #f2d99e; }
  .arrow-area .arrow-tr-03 .box-height02 {
    padding-top: 117.87px;
    padding-bottom: 37.87px; }
  .arrow-area .arrow-tr-04 .arrow-box {
    background-color: #facbc8; }
  .arrow-area .arrow-tr-04 .box-height01 {
    padding-top: 97.87px;
    padding-bottom: 17.87px; }
  .arrow-area .arrow-tr-04 .arrow-box:nth-of-type(3) {
    width: 60%;
    padding: 47.795px 10px 47.795px 30px; }

 /*-------------------------------------------------------------------------------

 オンライン相談ページ

  -------------------------------------------------------------------------------*/
.aligncenter {
  text-align: center; }

.lp-img img {
  max-width: 500px;
  margin: 0 auto; }
  @media (max-width: 520px) {
    .lp-img img {
      width: 100%; } }

.qr-img {
  margin: 0; }
  .qr-img img {
    max-width: 150px; }

section .btn a {
  text-decoration: none; }

.onlinecounseling article section h3 {
  margin-top: 50px; }
.onlinecounseling article section h5 {
  font-size: 107%;
  margin-top: 5px;
  position: relative;
  padding: 0 0 0 1em; }
  .onlinecounseling article section h5::before {
    content: "";
    display: block;
    position: absolute;
    top: 10px;
    left: 4px;
    width: 10px;
    height: 10px;
    background: #6d4528; }
.onlinecounseling article section .table-wrap {
  white-space: normal;
  margin-top: 0; }
.onlinecounseling article section .online-dr {
  margin-top: 5px;
  font-size: 90%; }
  .onlinecounseling article section .online-dr tbody th {
    white-space: nowrap;
    font-weight: normal;
    padding: 8px; }
  .onlinecounseling article section .online-dr tbody .dr-img {
    min-width: 150px; }
  .onlinecounseling article section .online-dr tbody .dr-name {
    white-space: nowrap; }
    .onlinecounseling article section .online-dr tbody .dr-name span {
      display: block;
      font-size: 65%; }

 /*-------------------------------------------------------------------------------

 pick up

  -------------------------------------------------------------------------------*/
.pickup .side-contents {
  display: none; }

 /*-------------------------------------------------------------------------------

 guidelines

  -------------------------------------------------------------------------------*/
.guidelines section p {
  margin: 0 0 15px 0; }
.guidelines section .iframe-wrap {
  margin: 0 0 60px; }
  @media (max-width: 768px) {
    .guidelines section .iframe-wrap {
      margin: 0 0 50px; } }
.guidelines .side-contents {
  display: none; }

 /*-------------------------------------------------------------------------------

 guideline

  -------------------------------------------------------------------------------*/
.guideline .qa {
  margin-top: 80px;
  word-break: break-all;
  word-wrap: break-word; }
  .guideline .qa .q {
    display: flex;
    gap: 15px; }
  .guideline .qa .a .a-txt {
    margin-top: 10px;
    padding: 0 0 0 2em;
    position: relative;
    display: inline-block;
    background-color: #fff;
    border: solid 2px #525252;
    padding: 16px;
    max-width: 100%;
    text-align: left;
    border-radius: 15px;
    box-sizing: border-box;
    width: 100%; }
    @media (max-width: 768px) {
      .guideline .qa .a .a-txt {
        line-height: 1.5;
        font-size: 89%; } }
    .guideline .qa .a .a-txt:before {
      content: "";
      position: absolute;
      top: 50%;
      right: -36px;
      -webkit-transform: translateX(-50%);
      transform: translateX(-50%);
      border: solid 12px transparent;
      border-left: solid 12px #525252; }
    .guideline .qa .a .a-txt:after {
      content: "";
      position: absolute;
      top: 50%;
      right: -36px;
      -webkit-transform: translateX(-50%);
      transform: translateX(-50%);
      border: solid 14px transparent;
      border-left: solid 14px #fff;
      margin-right: -1px;
      margin-top: -2px; }
  .guideline .qa .q-txt {
    width: 100%;
    position: relative; }
    .guideline .qa .q-txt div {
      position: absolute;
      transform: translateY(-50%);
      top: 50%;
      box-sizing: border-box;
      position: relative;
      display: inline-block;
      background-color: #fff;
      border: solid 2px #525252;
      padding: 16px;
      max-width: 100%;
      text-align: left;
      border-radius: 15px;
      box-sizing: border-box;
      width: 100%; }
      @media (max-width: 768px) {
        .guideline .qa .q-txt div {
          line-height: 1.5;
          font-size: 89%; } }
      .guideline .qa .q-txt div:before {
        content: "";
        position: absolute;
        top: 45%;
        left: -26px;
        -webkit-transform: translateX(0%);
        transform: translateX(0%);
        border: solid 12px transparent;
        border-right: solid 12px #525252; }
      .guideline .qa .q-txt div:after {
        content: "";
        position: absolute;
        top: 45%;
        left: -26px;
        -webkit-transform: translateX(0%);
        transform: translateX(0%);
        border: solid 14px transparent;
        border-right: solid 14px #fff;
        margin-left: 1px;
        margin-top: -2px; }
  .guideline .qa .a > div {
    display: flex;
    justify-content: space-between;
    align-items: flex-start; }
    @media (max-width: 768px) {
      .guideline .qa .a > div {
        width: 100%; } }
  .guideline .qa .a03 img {
    margin: 20px 10px; }
  .guideline .qa .q img, .guideline .qa .a img {
    object-fit: contain;
    max-width: 180px; }
    @media (max-width: 768px) {
      .guideline .qa .q img, .guideline .qa .a img {
        max-width: 100px; } }
  @media (max-width: 768px) {
    .guideline .qa .q01 img, .guideline .qa .q03 img {
      max-width: 80px; } }
.guideline .wrap main {
  font-size: 130%; }

 /*-------------------------------------------------------------------------------

 douga

  -------------------------------------------------------------------------------*/
.douga main article section img.ico-movie {
  max-height: 30px;
  margin: 0 10px; }
.douga main article section .iframe-width-wrap {
  max-width: 560px; }
  .douga main article section .iframe-width-wrap .iframe-wrap {
    margin-top: 0; }

 /*-------------------------------------------------------------------------------

 ondemand

  -------------------------------------------------------------------------------*/
.ondemand01 .mw_wp_form label, .ondemand02 .mw_wp_form label {
  margin: 0;
  padding: 0; }

/*# sourceMappingURL=modify.css.map */
