@charset "UTF-8";
/* font */
/* color */
/* ===========================================
デスクトップ系 769 - 1024
=========================================== */
/* ===========================================
タブレット系 1024
=========================================== */
@media screen and (max-width: 1150px) {
  body {
    width: 100%;
    min-width: auto; }
  .navbar-nav {
    margin-left: 30px; }
  .navbar-inverse .navbar-nav > li > a {
    font-size: 16px; }
  .navbar-inverse .navbar-nav > li > a {
    padding: 12px 12px; }
  .concept-image-box .image {
    width: 480px;
    margin-left: 8%; }
  .concept-image-box .info {
    margin-left: 37%; }
  .footer-list li a {
    font-size: 12px; }
  .social ul {
    margin: 0;
    margin-bottom: 0px;
    padding: 0;
    font-size: 12px; } }

@media screen and (max-width: 1000px) {
  .navbar-inverse .navbar-nav > li > a {
    padding: 10px 8px; }
  .navbar-right .open .time,
  .navbar-right .open span {
    font-size: 13px; } }

@media screen and (max-width: 950px) {
  .navbar-inverse .navbar-nav > li > a {
    font-size: 14px; }
  .navbar-inverse .navbar-collapse, .navbar-inverse .navbar-form {
    float: right; }
  .navbar-nav {
    float: right;
    margin-left: 5px; }
  .navbar-nav > li > a {
    padding: 10px 14px; } }

/* ===========================================
タブレット系 749 - 768
=========================================== */
@media screen and (max-width: 768px) {
  body {
    min-width: 100%; }
  #page-heading .page-heading-title {
    font-size: 30px; }
  .button {
    margin-top: 18px; }
  /* title */
  .top-title {
    font-size: 24px;
    margin-bottom: 75px; }
    .top-title span {
      font-size: 14px;
      margin-top: 10px; }
  section {
    padding: 65px 0; }
  .top-news {
    padding-bottom: 60px; }
  .top-news-box-wrap {
    margin-bottom: 0px; }
  .archive .col3-box {
    padding-top: 45px; }
  .slideShow {
    width: 100%; }
  .navbar {
    padding-bottom: 15px; }
  .nav > li > a:hover {
    color: #222;
    text-shadow: 2px 1px 1px #fff;
    background: #eee; }
  .navbar-header {
    margin-bottom: 0;
    height: 46px; }
  .navbar-brand {
    padding: 0 0 0 10px; }
  .logo img {
    width: 220px;
    margin-top: 10px;
    margin-left: -4px; }
  .navbar-right {
    position: absolute;
    top: 6px;
    right: 64px;
    margin: 0;
    display: none; }
  .navbar-right .tel,
  .navbar-right .open {
    font-size: 9px;
    letter-spacing: 1px; }
  .navbar-right .tel {
    margin-bottom: -2px; }
  .navbar-right .tel a {
    font-size: 13px;
    letter-spacing: 1px; }
  .navbar-right-info p {
    font-size: 12px;
    line-height: 20px; }
  .navbar-right .open .time {
    font-size: 13px; }
  .navbar-right .open span {
    font-size: 14px; }
  .navbar-right .open .m-l {
    margin-left: 2px; }
  .navbar-right .open .last {
    font-size: 12px; }
  /*モバイルナビ*/
  /* MENU */
  .hamburger-menu-wrapper {
    padding: 1px 11px 0px;
    display: inline-block;
    position: absolute;
    right: 0;
    z-index: 100000; }
  .hamburger-menu-wrapper.bounce-effect {
    background: rgba(109, 109, 109, 0.15);
    padding-bottom: 7px; }
  .menu-overlay {
    -webkit-transition: margin 100ms cubic-bezier(0.17, 0.04, 0.03, 0.94);
    -o-transition: margin 100ms cubic-bezier(0.17, 0.04, 0.03, 0.94);
    transition: margin 100ms cubic-bezier(0.17, 0.04, 0.03, 0.94);
    display: none;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    background: rgba(255, 255, 255, 0.97);
    z-index: 1111;
    height: 1000px; }
  .menu {
    position: relative;
    text-align: center; }
  .hamburger-menu {
    border: 0;
    margin: 0 auto;
    display: block;
    position: relative;
    overflow: hidden;
    padding: 0;
    width: 42px;
    height: 32px;
    font-size: 0;
    text-indent: -9999px;
    cursor: pointer;
    z-index: 9999;
    cursor: pointer;
    background: transparent;
    top: 4px; }
  .menu-list {
    display: none;
    position: absolute;
    top: calc(100% + 90px);
    width: 100%;
    text-align: center;
    z-index: 9999;
    list-style: none;
    padding: 0; }
  .menu-list li {
    width: 100%;
    padding: 0;
    text-transform: uppercase; }
  .menu-list li:first-child a {
    margin-top: 0px; }
  .menu-list li:last-child {
    width: 100%;
    clear: both; }
  .menu-list li:last-child a {
    font-size: 24px; }
    .menu-list li:last-child a p {
      font-size: 12px;
      margin-bottom: 0; }
    .menu-list li:last-child a .fa {
      font-size: 24px; }
  .menu-list a {
    color: #163e86;
    text-decoration: none;
    font-size: 18px;
    display: inline-block;
    margin: 12px 0;
    letter-spacing: 2px;
    font-weight: bold; }
  .menu-list a .small {
    font-size: 11px;
    display: block;
    letter-spacing: 2px; }
  .menu-list a br {
    display: none; }
  .menu-list a:hover {
    color: #0c3071; }
  .hamburger-menu:focus {
    outline: none; }
  .hamburger-menu span {
    display: block;
    position: absolute;
    top: 17px;
    left: 5px;
    right: 5px;
    height: 2px;
    background: #333; }
  .hamburger-menu span:before, .hamburger-menu span:after {
    position: absolute;
    display: block;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #333;
    content: ""; }
  .hamburger-menu span:before {
    top: -9px; }
  .hamburger-menu span:after {
    bottom: -9px; }
  .hamburger-menu span:before, .hamburger-menu span:after {
    -webkit-transition-duration: 0.1s, 0.1s;
    -o-transition-duration: 0.1s, 0.1s;
    transition-duration: 0.1s, 0.1s;
    -webkit-transition-delay: 0.1s, 0s;
    -o-transition-delay: 0.1s, 0s;
    transition-delay: 0.1s, 0s; }
  .hamburger-menu span:before {
    -webkit-transition-property: top, -webkit-transform;
    transition-property: top, -webkit-transform;
    -o-transition-property: top, transform;
    transition-property: top, transform;
    transition-property: top, transform, -webkit-transform; }
  .hamburger-menu span::after {
    -webkit-transition-property: bottom, -webkit-transform;
    transition-property: bottom, -webkit-transform;
    -o-transition-property: bottom, transform;
    transition-property: bottom, transform;
    transition-property: bottom, transform, -webkit-transform; }
  .hamburger-menu.active span {
    background: none; }
  .hamburger-menu.active span:before {
    top: 0;
    -webkit-transform: rotate(225deg);
    -ms-transform: rotate(225deg);
    transform: rotate(225deg); }
  .hamburger-menu.active span:after {
    bottom: 0;
    -webkit-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    transform: rotate(135deg); }
  .hamburger-menu.active span:before,
  .hamburger-menu.active span:after {
    -webkit-transition-delay: 0.1s, 0.1s;
    -o-transition-delay: 0.1s, 0.1s;
    transition-delay: 0.1s, 0.1s; }
  @-webkit-keyframes bounce {
    0% {
      -webkit-transform: rotate(0);
      transform: rotate(0); }
    45% {
      -webkit-transform: rotate(15deg);
      transform: rotate(15deg); }
    90% {
      -webkit-transform: rotate(-7deg);
      transform: rotate(-7deg); }
    100% {
      -webkit-transform: rotate(0);
      transform: rotate(0); } }
  @keyframes bounce {
    0% {
      -webkit-transform: rotate(0);
      transform: rotate(0); }
    45% {
      -webkit-transform: rotate(15deg);
      transform: rotate(15deg); }
    90% {
      -webkit-transform: rotate(-7deg);
      transform: rotate(-7deg); }
    100% {
      -webkit-transform: rotate(0);
      transform: rotate(0); } }
  .sp-nav-txt {
    color: #333;
    font-size: 11px;
    position: relative;
    top: 2px;
    letter-spacing: 0.8px; }
  /* slider evolution*/
  .slider-logo {
    width: 300px !important; }
  /* bx-slider */
  .bx-wrapper {
    margin-top: 60px !important; }
  .bx-wrapper .bx-pager,
  .bx-wrapper .bx-controls-auto {
    bottom: -32px !important; }
  #first-view {
    display: block; }
    #first-view .first-view-title span {
      display: block;
      font-size: 26px;
      margin-bottom: 24px;
      letter-spacing: 12px;
      line-height: 42px; }
    #first-view .txt {
      line-height: 28px; }
    #first-view .btn-list li a {
      font-size: 13px;
      padding: 10px 0;
      margin: 32px auto 0;
      letter-spacing: 1px;
      width: 160px;
      height: 42px; }
  /*top-promo*/
  #top-promo {
    text-align: center; }
    #top-promo .flex {
      display: block; }
      #top-promo .flex .info {
        font-size: 18px;
        margin-bottom: 14px; }
  /*top-concept*/
  #top-concept .overlay {
    padding: 66px 0; }
  .concept-box {
    padding: 0; }
    .concept-box .catch {
      font-size: 22px;
      line-height: 40px;
      margin-bottom: 48px; }
    .concept-box .catch span {
      font-size: 22px;
      margin-top: 18px; }
    .concept-box .sub-title {
      font-size: 16px;
      font-weight: bold; }
    .concept-box .txt {
      font-size: 14px; }
    .concept-box .list {
      display: block; }
      .concept-box .list li {
        width: 100%;
        margin: 0 auto 42px; }
        .concept-box .list li:last-child {
          margin-bottom: 0; }
  /*top-service*/
  .top-service .list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    .top-service .list li {
      width: 100%;
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      padding: 0 8px;
      -ms-flex-negative: 0;
      flex-shrink: 0; }
      .top-service .list li:not(:last-child) {
        margin-bottom: 45px; }
      .top-service .list li i {
        font-size: 60px;
        margin-bottom: 16px; }
      .top-service .list li h3 {
        font-size: 20px;
        color: #163e86; }
  /*top-partner*/
  .top-partner .overlay {
    padding: 60px 0 20px; }
  .top-partner .list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
    .top-partner .list li {
      width: 50%;
      margin-bottom: 32px; }
      .top-partner .list li h3 span {
        font-size: 12px; }
  /*top-area*/
  .top-area .flex {
    display: block; }
    .top-area .flex .box {
      display: block;
      margin-right: 0;
      width: 100%; }
      .top-area .flex .box h3 {
        text-align: center; }
      .top-area .flex .box ul {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin-bottom: 45px; }
  /*top-time*/
  .top-time .flex .box {
    margin-right: 38px; }
    .top-time .flex .box h3 {
      font-size: 20px; }
  .top-time .txt001 {
    font-size: 18px;
    display: block; }
  .top-contact .overlay {
    padding: 60px 0; }
  .col3-box-wrap {
    display: block; }
  .col3-box-wrap .col3-box {
    width: 100%;
    margin-bottom: 0; }
  .col3-box-wrap .col3-box-image .image-inner {
    width: 95%;
    height: 16rem; }
  .col3-box-wrap .col3-box-image .image-inner .title {
    font-size: 22px; }
  .col3-box-wrap .col3-box-image .image-inner .txt {
    font-size: 18px;
    line-height: 28px; }
  /*セクション背景*/
  .section-bg {
    padding: 80px 0 60px;
    line-height: 30px; }
  .section-bg-title {
    line-height: 30px; }
  /*col2*/
  .col2-box {
    overflow: hidden;
    margin-bottom: 40px; }
  .col2-box .column-box {
    width: 100%;
    float: none;
    margin-right: 0;
    margin-bottom: 26px;
    padding-bottom: 4px; }
  .col2-box .column-box .news-info {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    float: left;
    width: 74%;
    padding-left: 22px; }
  .col2-box .entry-content {
    font-size: 14px; }
  /*col3*/
  .col3-box .column-box {
    width: 100%;
    float: none;
    margin-right: 0; }
  .col3-box .column-box .news-info .title {
    font-size: 16px; }
  .col3-box .column-box .entry-content {
    font-size: 14px; }
  /*col4*/
  .col4-box .column-box {
    width: 48%;
    float: left;
    margin-right: 4%;
    margin-bottom: 24px;
    padding-bottom: 0; }
  .col4-box .column-box:nth-child(4n) {
    margin-right: auto; }
  .col4-box .column-box:nth-child(2n) {
    margin-right: 0; }
  .col4-box .column-box .thumb .title {
    position: absolute;
    bottom: 0;
    background: rgba(51, 51, 51, 0.72);
    width: 100%;
    margin-bottom: 0;
    color: #fff;
    padding: 4px 4px;
    text-align: center;
    font-size: 14px;
    line-height: 14px; }
  /*top-col-3-box*/
  .top-col-3-box {
    float: none;
    width: 100%; }
  .bg-scale .inner {
    z-index: 1;
    position: relative;
    width: 80%;
    margin: 0 auto;
    padding: 40px 0; }
  .bg-scale .inner,
  .top-col-3-box:last-child .bg-scale .inner {
    z-index: 1;
    position: relative;
    width: 80%;
    padding: 32px 32ps 27px; }
  .bg-scale .overlay {
    padding: 8px 0; }
  .bg-scale .title {
    margin-bottom: 0;
    letter-spacing: 6px; }
  .bg-scale .title span {
    letter-spacing: 2px; }
  /* top-contact */
  .top-contact .top-contact-btn-list {
    width: 100%;
    max-width: 560px;
    margin: 40px auto 0;
    list-style: none;
    overflow: hidden;
    padding: 0;
    display: block; }
  .top-contact-btn-list li {
    width: 100%;
    max-width: 320px;
    margin: 0 auto 18px;
    float: none;
    padding: auto 5px;
    text-align: center; }
  .top-contact-btn-list a {
    text-align: center;
    padding-left: 0; }
  .top-contact .txt {
    margin-bottom: 0px;
    line-height: 27px; }
  /* footer */
  .footerwidget:first-child,
  .footerwidget:nth-child(2),
  .footerwidget:nth-child(3),
  .footerwidget:nth-child(4) {
    width: 100%;
    text-align: center; }
  footer {
    text-align: center; }
  footer h3 {
    font-size: 25px;
    margin-bottom: 18px;
    padding-bottom: 10px; }
  .footer-logo {
    width: 240px;
    margin: 0 auto 20px;
    position: relative;
    left: -14px; }
  .footer-txt {
    text-align: center;
    line-height: 20px;
    padding: 0 !important;
    position: static; }
  .footer-title {
    margin-top: 38px;
    padding-bottom: 11px; }
  .footerwidget:nth-child(2) {
    display: none; }
  .footerwidget:nth-child(3) {
    margin-bottom: 32px; }
  .footerwidget:nth-child(4) img {
    width: 200px; }
  .footer-add li {
    display: block;
    line-height: 24px; }
  .footer-add .footer-tel a {
    display: block;
    background: none;
    font-family: serif;
    width: 100%;
    letter-spacing: 3px;
    font-size: 18px;
    margin-bottom: 10px; }
  .footer-nav {
    display: none; }
  #copyrights {
    margin-top: 0px; }
  #copyrights .footer-policy {
    float: none;
    margin-bottom: 12px;
    position: static;
    display: block;
    text-align: center; }
  #copy {
    font-size: 10px;
    text-align: center;
    padding: 24px 0 13px; }
  #copy a {
    font-size: 10px; } }
