@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=PT+Sans:wght@400;700&display=swap");
/* ---------------------------------------------------------------------------------------------------------

 common

--------------------------------------------------------------------------------------------------------- */
@media print, screen and (min-width: 1200px) {
  .wrap {
    margin-left: 140px; } }

.en {
  font-family: "PT Sans", sans-serif; }

.bg_gry {
  background: #F5F5F5; }

.bg_diagram {
  background: #148fcc;
  position: relative;
  z-index: 0; }
  .bg_diagram::before, .bg_diagram::after {
    content: '';
    background: rgba(11, 80, 115, 0.5);
    position: absolute;
    left: 0;
    z-index: -1; }
  .bg_diagram::before {
    width: 25%;
    height: 100%;
    transform: skew(-30deg);
    transform-origin: top left;
    top: 0; }
  .bg_diagram::after {
    bottom: 0;
    width: 40%;
    height: 100%;
    transform: skew(40deg);
    transform-origin: bottom left; }
  .bg_diagram .bg_diagram_img {
    width: 100%; }
    @media print, screen and (min-width: 992px) {
      .bg_diagram .bg_diagram_img {
        width: 48%; } }
  .bg_diagram .bg_diagram_txt {
    width: 100%;
    margin-bottom: 2em; }
    @media print, screen and (min-width: 992px) {
      .bg_diagram .bg_diagram_txt {
        width: 48%;
        margin-bottom: 0; } }
  .bg_diagram .bg_diagram_ttl {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 3rem;
    line-height: 1.4;
    color: #fff;
    margin-bottom: 1.5em; }
  .bg_diagram .bg_diagram_txt p {
    color: #fff;
    font-size: 1.7rem;
    line-height: 2; }

.memopad {
  border: #0b5073 solid 2px;
  padding: 1em;
  background: #fff;
  border-radius: 5px; }

.list-check li {
  display: inline-block;
  margin-right: 2em;
  padding-left: 1.5em;
  font-size: 1.4rem;
  position: relative; }
  .list-check li::before {
    content: '\f00c';
    font-family: "Font Awesome 5 Free";
    font-weight: bold;
    position: absolute;
    left: 0;
    color: #148fcc; }
  .list-check li.none::before {
    content: none; }

.clr_w {
  color: #fff; }

.clr_n {
  color: #0b5073; }

.clr_b {
  color: #148fcc; }

.page_title .container {
  height: 250px;
  display: flex;
  flex-direction: column;
  justify-content: center; }
  @media print, screen and (min-width: 992px) {
    .page_title .container {
      height: 500px; } }
.page_title h2 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  color: #fff;
  font-size: 4rem; }
  @media print, screen and (min-width: 992px) {
    .page_title h2 {
      font-size: 6rem; } }
  .page_title h2 span {
    display: block;
    font-size: 1.8rem; }
    @media print, screen and (min-width: 992px) {
      .page_title h2 span {
        font-size: 2rem; } }
.page_title.pt_biz {
  background: url("../images/pt_biz.jpg") no-repeat center center/cover; }
.page_title.pt_about {
  background: url("../images/pt_about.jpg") no-repeat center center/cover; }
.page_title.pt_company {
  background: url("../images/pt_company.jpg") no-repeat center center/cover; }
.page_title.pt_contact {
  background: url("../images/pt_contact.jpg") no-repeat center center/cover; }

.ttl_base {
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3rem;
  margin-bottom: 1em;
  letter-spacing: .05em;
  line-height: 1.4; }
  @media print, screen and (min-width: 992px) {
    .ttl_base {
      font-size: 3.6rem; } }

.subttl_base {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2rem;
  margin-bottom: 1em;
  letter-spacing: .05em;
  color: #148fcc;
  padding-left: 30px;
  position: relative; }
  .subttl_base::before {
    content: '';
    background: #148fcc;
    width: 20px;
    height: 2px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%); }

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

 about

--------------------------------------------------------------------------------------------------------- */
[class^='about_point'] {
  position: relative;
  z-index: 0; }
  [class^='about_point']::before {
    content: '';
    background: #F5F5F5;
    width: 100%;
    height: 67%;
    position: absolute;
    top: 33%;
    left: 0;
    z-index: -1; }
    @media print, screen and (min-width: 768px) {
      [class^='about_point']::before {
        height: 69%;
        top: 31%; } }
    @media print, screen and (min-width: 992px) {
      [class^='about_point']::before {
        height: 58%;
        top: 42%; } }
  @media print, screen and (min-width: 992px) {
    [class^='about_point'] .about_txt {
      display: flex;
      justify-content: space-between; } }
  @media print, screen and (min-width: 992px) {
    [class^='about_point'] .txt {
      width: 40%; } }
  [class^='about_point'] .txt .ttl {
    margin-bottom: 2em; }
    @media print, screen and (min-width: 992px) {
      [class^='about_point'] .txt .ttl {
        display: flex;
        align-items: center; } }
    [class^='about_point'] .txt .ttl h4 {
      margin: 25px auto;
      width: 100px;
      height: 100px;
      transform: rotate(45deg);
      background: #0b5073;
      display: flex;
      justify-content: center;
      align-items: center; }
      [class^='about_point'] .txt .ttl h4 span {
        display: inline-block;
        transform: rotate(-45deg);
        color: #fff;
        font-family: "Noto Serif JP", serif;
        font-weight: 700;
        font-size: 2rem; }
      @media print, screen and (min-width: 992px) {
        [class^='about_point'] .txt .ttl h4 {
          margin: 25px 35px 25px 0; } }
    [class^='about_point'] .txt .ttl p {
      font-family: "Noto Sans JP", sans-serif;
      font-weight: 700;
      font-size: 1.8rem;
      text-align: center; }
      [class^='about_point'] .txt .ttl p span {
        color: #148fcc; }
      @media print, screen and (min-width: 992px) {
        [class^='about_point'] .txt .ttl p {
          text-align: left;
          width: calc(100% - 120px); } }
  [class^='about_point'] .img {
    position: relative; }
    @media print, screen and (min-width: 992px) {
      [class^='about_point'] .img {
        width: 55%; } }
    [class^='about_point'] .img::before {
      content: '';
      font-family: "PT Sans", sans-serif;
      font-weight: 700;
      font-size: 6rem;
      line-height: 1;
      color: rgba(11, 80, 115, 0.3);
      position: absolute;
      bottom: -.35em;
      right: 0; }
      @media print, screen and (min-width: 768px) {
        [class^='about_point'] .img::before {
          font-size: 6rem; } }
      @media print, screen and (min-width: 992px) {
        [class^='about_point'] .img::before {
          font-size: 6rem; } }
      @media print, screen and (min-width: 1200px) {
        [class^='about_point'] .img::before {
          font-size: 10rem; } }

.about_point01 .img::before {
  content: 'Performance'; }

.about_point02 .img::before {
  content: 'Technique'; }

.about_point03 .img::before {
  content: 'Support'; }

.about_pr {
  background: url("../images/about_pr_bg.jpg") no-repeat center center/cover;
  margin-top: 80px; }
  .about_pr h3 {
    color: #fff;
    font-family: "Noto Serif JP", serif;
    font-size: 3rem;
    text-align: center;
    margin-bottom: 1em; }
    @media print, screen and (min-width: 992px) {
      .about_pr h3 {
        font-size: 5rem; } }
    .about_pr h3 span {
      display: inline-block;
      font-size: 2rem;
      margin: 0 1em; }
      @media print, screen and (min-width: 992px) {
        .about_pr h3 span {
          font-size: 3rem; } }
  .about_pr p {
    font-weight: bold;
    text-align: center;
    font-size: 1.8rem;
    color: #fff; }

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

 header

--------------------------------------------------------------------------------------------------------- */
.l_header {
  display: none; }
  @media print, screen and (min-width: 1200px) {
    .l_header {
      display: block;
      position: fixed;
      top: 0;
      z-index: 100;
      width: 140px;
      height: 100vh;
      background: #fff;
      text-align: center;
      display: flex;
      flex-direction: column;
      justify-content: space-between; }
      .l_header .h_logo {
        padding-top: 40px; }
      .l_header .h_contact {
        margin-top: auto; }
        .l_header .h_contact li {
          width: 100%;
          height: 90px; }
          .l_header .h_contact li [data-action],
          .l_header .h_contact li a {
            display: block;
            width: 100%;
            height: 100%;
            color: #fff;
            font-family: "Noto Serif JP", serif;
            font-weight: 700;
            padding-top: 58px;
            position: relative; }
            .l_header .h_contact li [data-action]::before,
            .l_header .h_contact li a::before {
              content: '';
              position: absolute;
              left: 50%;
              transform: translateX(-50%);
              bottom: 45px; }
        .l_header .h_contact .h_tel [data-action] {
          background: #333333; }
          .l_header .h_contact .h_tel [data-action]::before {
            background: url("../images/icon_phone_w.png");
            width: 24px;
            height: 29px; }
        .l_header .h_contact .h_map a {
          background: #0b5073; }
          .l_header .h_contact .h_map a::before {
            background: url("../images/icon_map_w.png");
            width: 18px;
            height: 28px; }
          .l_header .h_contact .h_map a:hover {
            opacity: 0.7; }
        .l_header .h_contact .h_form a {
          background: #148fcc; }
          .l_header .h_contact .h_form a::before {
            background: url("../images/icon_mail_w.png");
            width: 28px;
            height: 19px; }
          .l_header .h_contact .h_form a:hover {
            opacity: 0.7; } }

/* ---------------------------------------------------------------------------------------------------------
 PC
--------------------------------------------------------------------------------------------------------- */
.cb-gnav,
.gnav {
  height: 60px; }
  .cb-gnav .h_logo_sp,
  .gnav .h_logo_sp {
    padding-top: 20px; }

@media print, screen and (min-width: 1200px) {
  .h_logo_sp {
    display: none; }

  .cb-gnav {
    position: fixed;
    top: 0;
    left: 0;
    width: calc(100% - 140px);
    margin-left: 140px;
    background: #fff;
    z-index: 1000;
    display: none;
    height: 80px; }

  .show {
    display: block; }

  .show {
    opacity: 0;
    animation-name: fuwa;
    /*  animation-duration: 8s; */
    animation-duration: 1s;
    animation-fill-mode: forwards; }

  @keyframes fuwa {
    0% {
      opacity: 0; }
    100% {
      opacity: 1; } }
  .gnav {
    position: fixed;
    top: 0;
    left: 0;
    width: calc(100% - 140px);
    margin-left: 140px;
    background: #fff;
    z-index: 1000;
    height: 80px; }

  .navigation ul {
    height: 80px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center; }
    .navigation ul li {
      margin: 0 35px; }
    .navigation ul a {
      font-family: "Noto Serif JP", serif;
      font-weight: 700;
      font-size: 1.6rem;
      color: #333333; }
      .navigation ul a:hover {
        color: #148fcc; }
    .navigation ul .current a {
      color: #148fcc; } }
/* ---------------------------------------------------------------------------------------------------------
 SP
--------------------------------------------------------------------------------------------------------- */
@media screen and (max-width: 1200px) {
  .el_humburger {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 26px;
    height: auto;
    padding-top: 1px;
    box-sizing: border-box;
    z-index: 10000;
    transition: all 0.2s ease-in-out;
    cursor: pointer;
    pointer-events: auto; }
    .el_humburger > span {
      display: block;
      width: 100%;
      margin: 0 auto 6px;
      height: 3px;
      background: #0b5073;
      transition: all 0.2s ease-in-out; }
      .el_humburger > span:last-child {
        margin-bottom: 0; }

  .js_humburgerOpen .el_humburger > span {
    background: white; }
    .js_humburgerOpen .el_humburger > span.top {
      transform: translateY(9px) rotate(-45deg); }
    .js_humburgerOpen .el_humburger > span.middle {
      opacity: 0; }
    .js_humburgerOpen .el_humburger > span.bottom {
      transform: translateY(-9px) rotate(45deg); }

  .el_humburgerButton.el_humburgerButton__close {
    top: 2%;
    right: 2%; }

  .el_humburgerButton__close > span {
    display: block;
    width: 35px;
    margin: 0 auto;
    height: 4px;
    background: #0b5073; }
    .el_humburgerButton__close > span.el_humburgerLineTop {
      transform: translateY(5px) rotate(-45deg); }
    .el_humburgerButton__close > span.el_humburgerLineBottom {
      transform: translateY(-6px) rotate(45deg); }

  /* gnav */
  .navigation {
    display: none; }
    .navigation.js_appear {
      position: fixed;
      top: 0;
      left: 0;
      bottom: 0;
      right: 0;
      display: block;
      z-index: 9999; }

  .navigation_screen {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-color: rgba(11, 80, 115, 0.9);
    z-index: 0;
    margin-top: 0px;
    padding-top: 0px;
    overflow: auto;
    -webkit-overflow-scrolling: touch; }

  .navigation_wrapper {
    padding: 80px 30px 80px;
    text-align: center; } }
  @media screen and (max-width: 1200px) and (min-width: 768px) {
    .navigation_wrapper {
      padding: 80px 10% 80px; } }
@media screen and (max-width: 1200px) {
    .navigation_wrapper ul {
      display: block;
      margin-top: 0; }

  .navigation_item {
    margin-bottom: 10px; }
    .navigation_item > a {
      color: #0b5073;
      font-size: 1.6rem;
      font-weight: bold;
      display: block;
      padding: 1em;
      background: white; }
    .navigation_item.current a {
      background: #148fcc;
      color: #fff; }

  .js_fixed {
    position: fixed;
    width: 100%;
    height: 100%; }

  .n_tel,
  .n_fax {
    margin: 15px 0; }

  .n_tel [data-action],
  .n_fax span {
    font-family: "PT Sans", sans-serif;
    font-size: 3rem;
    font-weight: 700;
    color: white;
    padding-left: 34px;
    position: relative; }
    .n_tel [data-action]::before,
    .n_fax span::before {
      content: '';
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%); }

  .n_tel [data-action]::before {
    background: url("../images/icon_phone_w.png");
    width: 24px;
    height: 29px; }

  .n_fax span::before {
    background: url("../images/icon_fax_w.png");
    width: 26px;
    height: 26px; } }
/* ---------------------------------------------------------------------------------------------------------

 home

--------------------------------------------------------------------------------------------------------- */
.ofi-cover {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: cover;
  object-position: center center;
  font-family: 'object-fit: cover;object-position:center center;'; }

.swiper-container {
  height: 57vh;
  position: relative;
  overflow: hidden; }
  @media print, screen and (min-width: 1200px) {
    .swiper-container {
      height: 100vh; } }

.swiper-container h2 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 100; }

.top_ttl_base {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  display: flex;
  align-items: center;
  margin-bottom: 0.25em; }
  @media print, screen and (min-width: 992px) {
    .top_ttl_base {
      font-size: 2.4rem; } }
  .top_ttl_base span {
    font-size: 5.2rem;
    display: inline-block;
    margin-right: .25em; }
    @media print, screen and (min-width: 992px) {
      .top_ttl_base span {
        font-size: 7.2rem; } }

.top_msg {
  background: url("../images/bg_wave01.png") no-repeat center center;
  margin-top: 60px;
  margin-bottom: 60px;
  position: relative; }
  @media print, screen and (min-width: 992px) {
    .top_msg {
      min-height: 788px; } }
  .top_msg::before {
    content: '';
    background: url("../images/top_msg.jpg") no-repeat left 5% center/cover;
    width: 90%;
    height: 300px;
    position: absolute;
    top: 0;
    right: 0; }
    @media print, screen and (min-width: 992px) {
      .top_msg::before {
        width: 45%;
        height: 100%; } }
  .top_msg .txt {
    padding-top: 320px; }
    @media print, screen and (min-width: 992px) {
      .top_msg .txt {
        padding-top: 0;
        min-height: 788px;
        display: flex;
        flex-direction: column;
        justify-content: center; } }
  .top_msg h3 {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 2.6rem;
    color: #0b5073;
    line-height: 1.4;
    margin-bottom: .5em; }
    @media print, screen and (min-width: 992px) {
      .top_msg h3 {
        font-size: 3.2rem; } }
  .top_msg h4 {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.8rem;
    color: #148fcc;
    margin-bottom: 2em;
    padding-left: 30px;
    position: relative; }
    .top_msg h4::before {
      content: '';
      background: #148fcc;
      width: 20px;
      height: 2px;
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%); }
  .top_msg p {
    font-size: 1.7rem;
    line-height: 2; }

@media print, screen and (min-width: 992px) {
  .top_biz ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap; } }
.top_biz ul li {
  margin-bottom: 30px; }
  @media print, screen and (min-width: 992px) {
    .top_biz ul li {
      margin-bottom: 0;
      width: 48%; } }
  .top_biz ul li:hover {
    opacity: 0.7; }
  .top_biz ul li:nth-of-type(1) {
    background: url("../images/top_biz_img01.jpg"); }
  .top_biz ul li:nth-of-type(2) {
    background: url("../images/top_biz_img02.jpg"); }
  .top_biz ul li a {
    display: block;
    height: 500px;
    padding: 7em 3em 0;
    color: #fff;
    position: relative; }
    .top_biz ul li a::after {
      content: '';
      background: url("../images/arrow.png");
      width: 17px;
      height: 15px;
      position: absolute;
      right: 20px;
      bottom: 20px; }
    .top_biz ul li a h4 {
      font-family: "Noto Sans JP", sans-serif;
      font-size: 2.6rem;
      padding-bottom: 1em;
      margin-bottom: 1em;
      position: relative; }
      .top_biz ul li a h4::before {
        content: '';
        background: #fff;
        width: 20px;
        height: 3px;
        position: absolute;
        left: 0;
        bottom: 0; }
    .top_biz ul li a p {
      line-height: 2; }

.top_about {
  background: url("../images/bg_wave02.png") no-repeat center bottom 110px; }
  @media print, screen and (min-width: 992px) {
    .top_about ul {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; } }
  .top_about ul li {
    text-align: center;
    margin-bottom: 30px; }
    @media print, screen and (min-width: 992px) {
      .top_about ul li {
        text-align: left;
        margin-bottom: 0;
        width: 30%; } }
    .top_about ul li .img {
      position: relative; }
      .top_about ul li .img::before {
        font-family: "PT Sans", sans-serif;
        font-weight: 700;
        line-height: 1;
        color: #fff;
        font-size: 6rem;
        position: absolute;
        left: 0;
        bottom: 0; }
    .top_about ul li:nth-of-type(1) .img::before {
      content: '01'; }
    .top_about ul li:nth-of-type(2) .img::before {
      content: '02'; }
    .top_about ul li:nth-of-type(3) .img::before {
      content: '03'; }
  .top_about ul h4 {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 2.4rem;
    margin-top: .75em;
    margin-bottom: .75em;
    color: #0b5073; }

.top_news dl {
  border-top: #CCCCCC 1px solid; }
  .top_news dl div {
    border-bottom: #CCCCCC 1px solid;
    padding: 1em; }
    @media print, screen and (min-width: 992px) {
      .top_news dl div {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start; } }
  .top_news dl dt {
    font-weight: bold;
    display: flex;
    align-items: center; }
    @media print, screen and (min-width: 992px) {
      .top_news dl dt {
        width: 12em; } }
    .top_news dl dt span {
      color: #CC1414;
      font-size: 1.3rem;
      display: inline-block;
      margin-left: 1em; }
  @media print, screen and (min-width: 992px) {
    .top_news dl dd {
      width: calc(100% - 12em); } }

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

 business

--------------------------------------------------------------------------------------------------------- */
.biz_air {
  background: url("../images/bg_wave01.png") no-repeat center top 100px; }

.biz_duct {
  background: url("../images/bg_wave02.png") no-repeat center top 100px; }

.biz_case {
  padding: 2em; }
  @media print, screen and (min-width: 992px) {
    .biz_case {
      padding: 3em; } }
  .biz_case .biz_case_txt {
    margin-bottom: 2em; }
    @media print, screen and (min-width: 992px) {
      .biz_case .biz_case_txt {
        display: flex;
        flex-wrap: wrap;
        align-items: center; } }
    .biz_case .biz_case_txt h4 {
      font-size: 2.4rem;
      color: #0b5073; }
      @media print, screen and (min-width: 992px) {
        .biz_case .biz_case_txt h4 {
          width: 190px; } }
    @media print, screen and (min-width: 992px) {
      .biz_case .biz_case_txt p {
        width: calc(100% - 190px);
        border-left: #CCCCCC solid 1px;
        padding: 1em;
        padding-right: 0; } }
  @media print, screen and (min-width: 768px) {
    .biz_case .biz_case_img {
      display: flex;
      justify-content: center; } }
  .biz_case .biz_case_img li {
    margin-bottom: 20px; }
    @media print, screen and (min-width: 768px) {
      .biz_case .biz_case_img li {
        margin: 0 15px 0; } }

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

 company

--------------------------------------------------------------------------------------------------------- */
.company_partner ul {
  border-top: #CCCCCC solid 1px; }
  @media print, screen and (min-width: 768px) {
    .company_partner ul {
      display: flex;
      justify-content: flex-start;
      flex-wrap: wrap; } }
  .company_partner ul li {
    padding: 1em;
    border-bottom: #CCCCCC solid 1px; }
    @media print, screen and (min-width: 768px) {
      .company_partner ul li {
        width: calc(100% / 3 - 30px);
        width: calc(100% / 3); } }
    .company_partner ul li:nth-child(odd) {
      background: #F5F5F5; }

@media print, screen and (min-width: 768px) {
  .company_link ul {
    display: flex;
    justify-content: space-between; } }
.company_link ul li {
  text-align: center;
  margin-bottom: 20px; }
  .company_link ul li:last-child {
    margin-bottom: 0; }
  @media print, screen and (min-width: 768px) {
    .company_link ul li {
      width: 23%;
      margin-bottom: 0; } }
  .company_link ul li a {
    display: block; }
    .company_link ul li a:hover {
      opacity: 0.7; }

/* ---------------------------------------------------------------------------------------------------------
 contact
--------------------------------------------------------------------------------------------------------- */
.contact_tel ul {
  border: #0b5073 solid 2px; }
  @media print, screen and (min-width: 768px) {
    .contact_tel ul {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      width: 100%;
      margin-left: auto;
      margin-right: auto; } }
  @media print, screen and (min-width: 1200px) {
    .contact_tel ul {
      width: 80%; } }
  .contact_tel ul li {
    padding: .5em;
    width: 100%; }
    @media print, screen and (min-width: 768px) {
      .contact_tel ul li {
        padding: 1em;
        width: 50%; } }
  .contact_tel ul dl.contact_tel_tel {
    border-bottom: #ccc solid 1px; }
    @media print, screen and (min-width: 768px) {
      .contact_tel ul dl.contact_tel_tel {
        border-right: #ccc solid 1px;
        border-bottom: none; } }
  .contact_tel ul dl {
    padding: .5em;
    text-align: center; }
    .contact_tel ul dl dt {
      font-weight: bold;
      font-size: 1.8rem; }
    .contact_tel ul dl dd {
      color: #148fcc;
      font-size: 3rem;
      font-weight: bold; }
.contact_tel [data-action] {
  color: #148fcc; }

.pp {
  background: #eee;
  padding: 1.5em;
  margin-top: 3em; }
  @media print, screen and (min-width: 768px) {
    .pp {
      padding: 3em; } }
  .pp h4 {
    font-size: 2rem;
    border-bottom: #0b5073 solid 2px;
    margin-bottom: 1.5em; }

/* form
----------------------------------------------------------*/
.required, .any {
  display: inline-block;
  color: #fff;
  padding: 3px 5px;
  border-radius: 3px;
  line-height: 1;
  margin-right: 5px;
  font-size: 76%;
  font-weight: bold; }

.required {
  background: #e00c0c; }

.any {
  background: #999; }

input[type="checkbox"] {
  border: 1px solid #CCCCCC;
  margin-right: 5px; }

input[type="text"],
textarea {
  padding: 10px;
  outline: none;
  border-radius: 3px;
  border: 1px solid #CCCCCC;
  -webkit-transition: all .3s;
  transition: all .3s;
  font-size: 16px;
  font-size: 1.6rem;
  box-sizing: border-box; }
  input[type="text"]::placeholder,
  textarea::placeholder {
    color: #999; }
  input[type="text"]:-ms-input-placeholder,
  textarea:-ms-input-placeholder {
    color: #999; }
  input[type="text"]::-ms-input-placeholder,
  textarea::-ms-input-placeholder {
    color: #999; }

input[type="text"]:focus,
textarea:focus {
  box-shadow: 0 0 7px #1abc9c;
  border: 1px solid #1abc9c; }

input[type="text"] {
  width: 100%; }

input.w50[type="text"] {
  width: 100%; }

textarea {
  width: 100%;
  height: 10em; }

.select_bg {
  overflow: hidden;
  width: 100%;
  position: relative;
  border: #CCCCCC solid 1px;
  border-radius: 3px;
  padding: 10px; }
  .select_bg select {
    width: 100%;
    -webkit-appearance: none;
    appearance: none;
    box-shadow: none;
    background-image: none;
    background: transparent;
    outline: none;
    border: none;
    text-overflow: ellipsis; }
    .select_bg select::-ms-expand {
      display: none; }

.select_bg::before {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.8em;
  width: 0;
  height: 0;
  padding: 0;
  content: '';
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 6px solid #333333;
  pointer-events: none; }

.contact_form table ul {
  display: flex;
  flex-wrap: wrap; }

.contact_form table ul li {
  margin-right: 2em; }

.contact_form table table {
  width: 100%; }
  .contact_form table table th {
    background: transparent;
    padding: 5px 10px;
    border: 0;
    width: 20%;
    text-align: right; }
  .contact_form table table td {
    padding: 5px 10px;
    border: 0; }

@media screen and (max-width: 640px) {
  .contact_form table table th {
    padding: 5px 0 0;
    width: 100%;
    display: block;
    text-align: left; }
  .contact_form table table td {
    width: 100%;
    padding: 0;
    display: block; } }
.pp_check {
  padding: 1.5em 0;
  text-align: center; }

.contact_form .form_btn {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
  text-align: center; }

.contact_form .btn_back {
  margin-bottom: 20px; }
  @media print, screen and (min-width: 768px) {
    .contact_form .btn_back {
      margin-bottom: 0; } }

/* ---------------------------------------------------------------------------------------------------------
 footer
--------------------------------------------------------------------------------------------------------- */
.f_contact {
  background: url("../images/f_contact_bg.jpg") no-repeat center center/cover;
  padding-top: 50px;
  padding-bottom: 50px; }
  @media print, screen and (min-width: 992px) {
    .f_contact {
      padding-top: 100px;
      padding-bottom: 100px; } }
  .f_contact h3 {
    text-align: center;
    color: #fff;
    font-size: 4.2rem; }
    @media print, screen and (min-width: 992px) {
      .f_contact h3 {
        font-size: 7.2rem; } }
  .f_contact h3 + p {
    font-weight: bold;
    text-align: center;
    color: #fff;
    margin-bottom: 1.5em; }
  .f_contact ul {
    background: rgba(255, 255, 255, 0.8);
    padding: 1em 2em; }
    @media print, screen and (min-width: 992px) {
      .f_contact ul {
        display: flex;
        justify-content: space-between;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap; } }
    .f_contact ul li {
      text-align: center; }
      @media print, screen and (min-width: 992px) {
        .f_contact ul li {
          width: calc(100% / 3);
          padding: 2em 30px; } }
      .f_contact ul li:nth-of-type(2) {
        padding-top: 1em;
        padding-bottom: 1em; }
        @media print, screen and (min-width: 992px) {
          .f_contact ul li:nth-of-type(2):nth-of-type(2) {
            padding-top: 0;
            padding-bottom: 0;
            border-right: #333333 solid 1px;
            border-left: #333333 solid 1px; } }
    .f_contact ul .btn_contact {
      display: block;
      background: #148fcc;
      color: #fff;
      font-weight: bold;
      text-align: center;
      padding: 1em;
      position: relative; }
      .f_contact ul .btn_contact::before {
        content: '';
        background: url("../images/arrow.png");
        width: 17px;
        height: 15px;
        position: absolute;
        right: 20px;
        top: 50%;
        transform: translateY(-50%); }
      .f_contact ul .btn_contact span {
        position: relative;
        padding-left: 38px; }
        .f_contact ul .btn_contact span::before {
          content: '';
          background: url("../images/icon_mail_w.png");
          width: 28px;
          height: 19px;
          position: absolute;
          left: 0;
          top: 50%;
          transform: translateY(-50%); }
      .f_contact ul .btn_contact:hover {
        opacity: 0.7; }
    .f_contact ul [data-action],
    .f_contact ul .f_fax {
      font-family: "PT Sans", sans-serif;
      font-size: 3rem;
      font-weight: 700;
      color: #0b5073;
      padding-left: 34px;
      position: relative; }
      .f_contact ul [data-action]::before,
      .f_contact ul .f_fax::before {
        content: '';
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%); }
    .f_contact ul [data-action]::before {
      background: url("../images/icon_phone_b.png");
      width: 24px;
      height: 29px; }
    .f_contact ul .f_fax::before {
      background: url("../images/icon_fax_b.png");
      width: 26px;
      height: 26px; }

.f_info {
  background: #0b5073;
  color: #fff;
  padding-top: 50px;
  padding-bottom: 50px; }
  @media print, screen and (min-width: 992px) {
    .f_info {
      padding-top: 100px;
      padding-bottom: 100px; } }
  @media print, screen and (min-width: 1200px) {
    .f_info .f_info_box {
      display: flex;
      justify-content: space-between; } }
  .f_info [data-action] {
    color: #fff; }
  .f_info dl {
    text-align: center; }
    @media print, screen and (min-width: 1200px) {
      .f_info dl {
        text-align: left; } }
  .f_info dt {
    padding-bottom: 2em; }
  .f_info .sitemap {
    display: grid;
    -ms-grid-template-rows: 40px 40px 40px;
    grid-template-rows: 40px 40px 40px;
    -ms-grid-template-columns: 140px 1fr;
    grid-template-columns: 140px 1fr;
    grid-template-areas: "area01 area01" "area02 area03" "area04 area05"; }
    .f_info .sitemap li:nth-of-type(1) {
      grid-area: area01; }
    .f_info .sitemap li:nth-of-type(2) {
      grid-area: area02; }
    .f_info .sitemap li:nth-of-type(3) {
      grid-area: area03; }
    .f_info .sitemap li:nth-of-type(4) {
      grid-area: area04; }
    .f_info .sitemap li:nth-of-type(5) {
      grid-area: area05; }
    .f_info .sitemap li a {
      display: block;
      font-weight: bold;
      padding-left: 20px;
      color: #fff;
      position: relative; }
      .f_info .sitemap li a::before {
        content: '';
        background: #fff;
        width: 10px;
        height: 2px;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%); }
      .f_info .sitemap li a:hover {
        opacity: 0.7; }

.copyright {
  background: #333333;
  text-align: center;
  padding-top: .5em;
  padding-bottom: .5em; }
  .copyright small {
    font-size: 1.2rem;
    color: #fff; }

/* pagetop
----------------------------------------------------------*/
#pagetop {
  position: fixed;
  bottom: 40px;
  right: 20px;
  z-index: 1; }
