/*
Theme Name:株式会社ミツカル
Description: 株式会社ミツカル theme for WordPress
Author: yuki izawa
Version:1.0
*/


/* --------共通--------- */

html {
    font-size: 62.5%;
    box-sizing: border-box;
}
html {
  visibility: hidden;
}
html.wf-active {
  visibility: visible;
}

body {
    font-family: noto-sans-cjk-jp, sans-serif;
    font-weight: 500;
    font-style: normal;
    color: #231815;
    letter-spacing: 0.05em;
}
body {
    overflow-x: hidden;
}

ul {
    list-style: none;
}

img{
    max-width:100%;
    vertical-align:bottom;
}
p {
    font-size: 1.6rem;
    line-height: 30px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-weight: 500;
    font-style: normal;
}
a {
    font-size: 1.6rem;
    color: #231815;
    cursor: pointer;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-weight: 500;
    font-style: normal;
}

/* --------トップページ--------- */


header {
    position: absolute;
    z-index: 999999;
    width: 100%;
    margin: auto;
    top: 2rem;
}
.header_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 0 8rem;
    max-width: 1366px;
    margin: auto;
}
.header_left {
    display: flex;
    align-items: center;
}
.header_left h2 {
    font-size: 1.6rem;
    font-weight: 500;
}
.header_left h2 span {
    font-size: 1.3rem;
    font-weight: 500;
    color: #636464;
}
.header_left img {
    margin-right: 2rem;
}
.gnavi__lists {
    display: flex;
}
.gnavi__list {
    position: relative;
  
    margin-right: 3rem;
}
.gnavi__list:last-child {
    margin-right: 0;
}
.gnavi__list:nth-child(1) {
    margin-right: 4.5rem;
}
.gnavi__list:nth-child(2) {
    margin-right: 4.5rem;
}
.gnavi__list:hover::before {
    background-color: #0071BB;
}
.gnavi__list a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    color: #1b4059;
    padding-bottom: 2rem;
}

.gnavi_hover:hover {
    color: #e95513;
}
.gnavi_arrow {
    position: relative;
}
.gnavi_arrow::after {
    content: "";
    display: inline-block;
    vertical-align: middle;
    color: #17315e;
    line-height: 1;
    width: 0.8rem;
    height: 0.8rem;
    border: 0.1em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    box-sizing: border-box;
    transform: translateY(-25%) rotate(135deg);
    position: absolute;
    right: -15px;
}
.gnavi_arrow:hover::after {
    color: #e95513;
   
}
.gnavi__list:hover .dropdown__lists {
    display: block;/*Gナビメニューにホバーしたら表示*/   
}
.dropdown__list {
    background-color: #e95513;
    height: 60px;
    position: relative;
}
.dropdown__list:not(:first-child)::before{
    content: "";
    width: 100%;
    height: 1px;
    background-color: #fff;
    position: absolute;
    top: 0;
    left: 0;
}
.dropdown__list:hover {
    background-color: #e47646;
}
.dropdown__list a {
    display: flex;
    justify-content: left;
    align-items: center;
    color: #fff;
    text-decoration: none;
    position: relative;
    padding-left: 2rem;
}

.dropdown__lists {
    visibility: hidden;/*デフォルトでは非表示の状態にしておく*/
    opacity: 0;/*不透明度0*/
    width: 100%;
    position: absolute;
    top: 60px;
    left: 0;
}
.dropdown__lists {
    transition: all .3s;
}
.dropdown__lists {
    transform: scaleY(0);
    transform-origin: center top;
    width: 26.4rem;
    position: absolute;
    top: 40px;
    left: 0;
}
.gnavi__list:hover .dropdown__lists {
    visibility: visible;/*Gナビメニューにホバーしたら表示*/
    opacity: 1;/*不透明度1*/
    transform: scaleY(1);/*Gナビメニューにホバーしたら表示*/
}
.top_eye_inner {
    position: relative;
    margin-top: -5rem;
}
.eye_text_box {
    position: absolute;
    top: 17%;
    width: 100%;
}
.eye_text_box h2 {
    font-size: 4.2vw;
    line-height: 8vw;
    color: #17315e;
    font-weight: 500;
    max-width: 1366px;
    margin: auto;
    padding: 0 8rem;
}
.eye_text_center {
    font-family: ta-oonishi, sans-serif;
    font-weight: 300;
    font-style: normal;
    background-color: rgba(23, 49, 94, 0.1);
    padding: 2rem 1rem;
    margin-right: 1rem;
    font-size: 5.3vw;
    border: 1px solid rgba(23, 49, 94, 0.3);
    letter-spacing: -0.02em;
}
.top_eye_bottom_inner {
    max-width: 1366px;
    margin: auto;
    padding: 0 8rem;
    margin-top: -4.0vw;
    position: relative;
}
.top_eye_bottom {
    background-color: #17315e;
    color: #fff; 
    padding: 3.646vw 0;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    z-index: 5;
}
.top_eye_bottom::after {
    content: "M I T S U K A R U";
    color: #fff;
    font-size: 11.5vw;
    width: 100%;
    z-index: -10;
    font-family: futura-pt, sans-serif;
    font-weight: 400;
    font-style: normal;
    opacity: 0.05;
    letter-spacing: -15px;
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
.top_eye_bottom p {
    text-align: center;
    font-size: 1.145834vw;
    line-height: 4rem;
    padding: 0 2rem;
}
.top_service_inner {
    max-width: 1366px;
    margin: auto;
    margin-top: 12rem;
    padding: 0 8rem;
    padding-bottom: 8rem;
    margin-bottom: 12rem;
    position: relative;
}
.top_service_inner:before {
    content: "";
    background-image: url(image/top/img_34.png);
    position: absolute;
    height: 100%;
    width: 100%;
    background-repeat: no-repeat;
    z-index: -1;
    background-size: contain;
}

.top_service_inner:after {
    content: "";
    background-image: url(image/top/img_35.png);
    position: absolute;
    height: 100%;
    width: 100%;
    background-repeat: no-repeat;
    background-position: right;
    top: 0;
    right: 6%;
    z-index: 0;
    background-size: contain;
}
.top_service_inner h2 {
    font-size: 6.6rem;
    padding-left: 8rem;
    margin-bottom: 5.6rem;
    padding-top: 8rem;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #17315e;
    position: relative;
    z-index: 1;
}
.top_service_inner h2 span {
    color: #e89212;
}
/*　画像の拡大　*/

.zoomIn img{
	transform: scale(1);
	transition: .3s ease-in-out;
    height: auto;
    position: relative;
    margin-top: -1px;
}
.zoomIn {
	width:100%;
}
.zoomIn a:hover img{/*hoverした時の変化*/
	transform: scale(1.1);/*拡大の値を変更したい場合はこの数値を変更*/
    opacity: 0.7;
}

/*　画像のマスク　*/

.mask {
    display: block;
    line-height: 0;/*行の高さを0にする*/
    overflow: hidden;/*拡大してはみ出る要素を隠す*/
    position: relative;
}
.mask::before {
    content: "";
    background-color: #fff;
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
}
.top_service_box {
    background-color: #17315e;
    height: 16.8rem;
    width: 300%;
}

.fadeInRight {
    opacity: 0;
    transform: translateX(100px);
}
.fadeInUp {
    opacity: 0;
    transform: translateY(100px);
}
.fadeIn_phi {
    opacity: 0;
}
/* フェードインアップ　アイキャッチ用 */
.fadeInUp_eye_1 {
    opacity: 0;
    transform: translateY(100px);
}
.fadeInUp_eye_2 {
    opacity: 0;
    transform: translateY(100px);
}
.fadeInUp_eye_3 {
    opacity: 0;
    transform: translateY(100px);
}
.fadeIn_eye_1 {
    animation-name: fadeIn_eye;
    animation-duration: 1s;
    animation-delay: 0.5s;
    animation-fill-mode: forwards;
}
.fadeIn_eye_2 {
    animation-name: fadeIn_eye;
    animation-duration: 1s;
    animation-delay: 0.8s;
    animation-fill-mode: forwards;
}
.fadeIn_eye_3 {
    animation-name: fadeIn_eye;
    animation-duration: 1s;
    animation-delay: 1.1s;
    animation-fill-mode: forwards;
}

@keyframes fadeIn_eye {
    0% {
    }
    100% {
        opacity: 1;
        transform: translate(0);
    }
}


/* フェードインさせるクラス */
.fadeIn {
    animation-name: fadeIn;
    animation-duration: 1s;
    animation-fill-mode: forwards;
}
@keyframes fadeIn {
    0% {
    }
    100% {
        opacity: 1;
        transform: translate(0);
    }
}

/* フェードインさせるクラス */
.fadeIn_phi_2 {
    animation-name: fadeIn_phi;
    animation-duration: 2s;
    animation-delay: 1s;
    animation-fill-mode: forwards;
}
@keyframes fadeIn_phi {
    0% {
    }
    100% {
        opacity: 1;
    }
}

.top_service_box h3 {
    font-size: 3.2rem;
    color: #fff;
    font-weight: 500;
    padding: 2.4rem 8rem;
    letter-spacing: 0.15em;
    position: relative;
    z-index: 1;
    display: flex;
}
.top_service_box h3 span {
    font-size: 2.2rem;
    background-color: #fff;
    color: #17315e;
    margin-right: 2rem;
    letter-spacing: 0.15em;
    height: 3.6rem;
    display: inline-flex;
    width: 16.5rem;
    vertical-align: middle;
    align-items: center;
    justify-content: center;
}
.top_service_inner ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 0 8rem;
    margin-top: -8rem;
    margin-bottom: 5.6rem;
    position: relative;
    z-index: 10;
}
.top_service_inner ul li {
    width: 48.366%;
    margin-bottom: 4rem;
    position: relative;
   
}

.top_service_inner ul li .top_service_bg {
    position: absolute;
    bottom: 0;
    width: 70%;
    background-color: #fff;
    padding: 1.5rem 2rem 0 0;
    border-radius: 0 3rem 0 0;
}
.top_service_inner ul li .top_service_bg .top_service_item {
    display: flex;
    align-items: center;
}
.top_service_inner ul li .top_service_bg .top_service_item .top_service_item_left {
    margin-right: 2rem;
}
.top_service_inner ul li .top_service_bg .top_service_item .top_service_item_right h4 {
    font-size: 2.5rem;
    font-weight: 500;
    letter-spacing: 0;
    color: #17315e;
}
.top_service_inner ul li .top_service_bg .top_service_item .top_service_item_right p {
    font-size: 1.2rem;
    color: #a8a8a7;
    font-family: poppins, sans-serif;
    font-weight: 300;
    font-style: normal;
}
.top_service_item_link {
    display: block;
    width: 1.8rem;
    height: 1.8rem;
    border: 1px solid #e0e0df;
    border-radius: 50%;
    box-sizing: border-box;
    margin-left: auto;
    position: relative;
    margin-top: -2rem;
    margin-bottom: 0.8rem;
}
.top_service_item_link::after {
    content: "→";
    position: absolute;
    font-size: 1.2rem;
    font-weight: bold;
    left: 2px;
    top: 1px;
}
.top_service_item_border {
    border-bottom: 2px solid #e0e0df;
    position: relative;
}
.top_service_item_border::after {
    content: '';
    position: absolute;
    width: 1.8rem;
    height: 2px;
    right: 0;
    background: #17315e;
}
.top_service_box:nth-of-type(2) {
    background-color: #e89212;
}
.top_service_box:nth-of-type(2) h3 span {
    color: #e89212;
}
.top_service_inner ul:nth-of-type(2) li .top_service_bg .top_service_item .top_service_item_right h4 {
    color: #e89212;
}
.top_service_inner ul:nth-of-type(2) .top_service_item_border::after {
    background: #e89212;
}
.top_service_inner ul:nth-of-type(2) .top_service_item_link::after {
    color: #e89212;
}
.top_service_box:nth-of-type(3) h3 {
    padding: 2.4rem 6rem;
}
.top_service_inner ul:nth-of-type(3) {
    padding: 0 6rem;
}
.top_service_inner ul:nth-of-type(3) li {
    width: 44.723%;
}
.top_service_box:nth-of-type(3) {
    position: relative;
}
.top_service_box:nth-of-type(3)::after {
    content: "";
    display: block;
    width: 1px;
    height: 20rem;
    background-color: #17315e;
    position: absolute;
    bottom: -97%;
    left: 16.6%;
}
.top_news_inner {
    background-color: #fdf7ee;
    padding: 8.8rem 8rem;
}
.top_news_box {
    max-width: 1366px;    
    margin: auto;
}
.top_news_box h2 {
    font-size: 6.6rem;
    margin-bottom: 5.6rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #17315e;
}
.top_news_box h2 span {
    color: #e89212;
}
.top_news_box ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.top_news_box ul li {
    width: 31%;
}
.top_news_box ul li p {
    font-size: 1.4rem;
    margin-top: 2.4rem;
    color: #7c7d7d;
    font-family: poppins, sans-serif;
    font-weight: 300;
    font-style: normal;
}
.top_news_box ul li h3 {
    font-size: 2rem;
    line-height: 2.8rem;
    font-weight: 500;
    margin-bottom: 5.6rem;
}
.top_news_box_link {
    font-size: 1.2rem;
    color: #17315e;
    font-family: poppins, sans-serif;
    font-weight: 300;
    font-style: normal;
}
.top_news_btn {
    display: flex;
    width: 30rem;
    margin: auto;
    margin-top: 5.6rem;
    background-color: #fff;
    border: 1px solid #17315e;
    border-radius: 3rem;
    height: 4.8rem;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    position: relative;
    top: 0;
    left: 0;
    overflow: hidden;
}
.top_news_btn span {
  color: #17315e;
  z-index: 1;
}
.top_news_btn:before {
  content: "";
  width: 0%;
  height: 100%;
  background: #17315e;
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.2s;
}
.top_news_btn:hover:before {
  width: 100%;
}
.top_news_btn:hover span {
  color: #fff;
}

.top_sns_inner {
    max-width: 1366px;
    margin: auto;
    padding: 12rem 8rem;
}
.top_sns_inner h2 {
    font-size: 6.6rem;
    margin-bottom: 5.6rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #17315e;
}
.top_sns_inner h2 span {
    color: #e89212;
}
.top_sns_inner ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.top_sns_inner ul li {
    width: 49%;
}
.top_sns_inner ul li a :hover {
    opacity: 0.7;
}
.top_sns_inner ul li h3 {
    text-align: center;
    font-size: 2.4rem;
    font-weight: 500;
    margin-top: 2.4rem;
}
.top_company_bg {
    background-color: #17315e;
    padding: 8.8rem 8rem;
}
.top_company_inner {
    max-width: 1366px;
    margin: auto;
}
.top_company_inner h2 {
    font-size: 6.6rem;
    margin-bottom: 5.6rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #fff;
}
.top_company_inner h2 span {
    color: #e89212;
}
.top_company_inner ul {
    display: flex;
    /*justify-content: space-between;*/
    justify-content: center;
    flex-wrap: wrap;
    padding: 0 8rem;
}
.top_company_inner ul li {
    width: 48.366%;
    position: relative;
}
.top_company_inner ul li .top_service_bg {
    position: absolute;
    bottom: 0;
    width: 70%;
    background-color: #17315e;
    padding: 1.5rem 2rem 0 0;
    border-radius: 0 3rem 0 0;
}
.top_company_inner ul li .top_service_bg .top_service_item {
    display: flex;
    align-items: center;
}
.top_company_inner ul li .top_service_bg .top_service_item .top_service_item_left {
    margin-right: 2rem;
}
.top_company_inner ul li .top_service_bg .top_service_item .top_service_item_right h4 {
    font-size: 2.5rem;
    font-weight: 500;
    letter-spacing: 0;
    color: #fff;
}
.top_company_inner ul li .top_service_bg .top_service_item .top_service_item_right p {
    font-size: 1.2rem;
    color: #a8a8a7;
    font-family: poppins, sans-serif;
    font-weight: 300;
    font-style: normal;
}
.top_company_inner .top_service_item_border {
    border-bottom: 2px solid #3a5076;
    position: relative;
}
.top_company_inner .top_service_item_border::after {
    background: #fff;
}
.top_company_inner .top_service_item_link::after {
    color: #fff;
}
.top_company_inner .top_service_item_link {
    border: 1px solid #3a5076;
}
.top_contact_bg {
    background-color: #f3f5f7;
    padding: 8.8rem 8rem;
}
.top_contact_inner {
    text-align: center;
}
.top_contact_inner h2 {
    font-size: 6.6rem;
    margin-bottom: 5.8rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #17315e;
}
.top_contact_inner h2 span {
    color: #e89212;
}
.top_contact_inner p {
    font-size: 2rem;
}
.top_contact_inner a {
    display: flex;
    width: 32rem;
    margin: auto;
    margin-top: 5.8rem;
    background-color: #fff;
    border: 1px solid #17315e;
    border-radius: 3rem;
    height: 5.6rem;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    position: relative;
    top: 0;
    left: 0;
    overflow: hidden;
}
.top_contact_inner a span {
  color: #17315e;
  z-index: 1;
}
.top_contact_inner a:before {
  content: "";
  width: 0%;
  height: 100%;
  background: #17315e;
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.2s;
}
.top_contact_inner a:hover:before {
  width: 100%;
}
.top_contact_inner a:hover span {
  color: #fff;
}
.footer_inner {
   max-width: 1366px;
    margin: auto;
    padding: 0 8rem;
    padding-top: 12rem;
}
.footer_box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 2.4rem;
}
.footer_box_left {
    display: flex;
    align-items: center;
}
.footer_box_left img {
    margin-right: 3rem;
}
.footer_box_right ul {
    display: flex;
    align-items: center;
}
.footer_box_right ul li p {
    color: #17315e;
    font-family: futura-pt, sans-serif;
    font-weight: 500;
}
.footer_box_right ul li {
    margin-right: 2rem;
}
.footer_box_right ul li:last-child {
    margin-right: 0;
}
.footer_list {
    border-top: 1px solid #17315e;
    padding-top: 1.8rem;
    margin-bottom: 2.4rem;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.footer_list li {
    width: 18%;
}

.footer_list li p {
    display: flex;
    font-size: 1.2rem;
    color: #516486;
}
.footer_list li h2 {
    font-size: 1.5rem;
    font-weight: 500;
    border-bottom: 1px solid #17315e;
    padding-bottom: 1.8rem;
    margin-bottom: 2.4rem;
}
.footer_list li a {
    display: block;
    font-size: 1.4rem;
}
.footer_list li a:hover {
    color: #e95513;
}


.footer_list li a span {
    color: #516486;
    font-size: 1.2rem;
}
.footer_bottom {
    border-top: 1px solid #17315e;
}
.footer_bottom_box {
    max-width: 1200px;
    margin: auto;
    padding: 2.4rem 8rem;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.footer_bottom_box_left p a {
    font-size: 1.4rem;
}
.footer_bottom_box_left p a:hover {
    color: #e95513;
}


.footer_bottom_box_right p {
    font-size: 1.4rem;
}
.pc_none {
    display: none;
}

.gnavi__list_acc label {
    display: flex;
    line-height: 1;
    color :#fff;
    cursor :pointer;
    height: 60px;
    justify-content: left;
    align-items: center;
    text-decoration: none;
    position: relative;
    padding-left: 2rem;
    font-size: 1.6rem;
    
}
.gnavi__list_acc label:after {
    content:"";
  display:block;
  width:8px;
  height:8px;
  border-top: #fff 2px solid;
  border-right: #fff 2px solid;
  -webkit-transform: rotate(135deg);
  -ms-transform: rotate(135deg);
  transform: rotate(135deg);
  position:absolute;
  right: 5%;
  top: 0;
  bottom: 15%;
  margin: auto;
}
input[type=checkbox]:checked + label:after{
  content:"";
  display:block;
  width:8px;
  height:8px;
  border-top: #fff 2px solid;
  border-right: #fff 2px solid;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  position:absolute;
  right: 5%;
  top: 7%;
  bottom: 0;
  margin: auto;
}
#js-header.m_fixed {
	left: 0;
    right: 0;
    position: fixed;
    top: 0px;
    background-color: #fff;
    z-index: 100;
    padding: 1.5rem 0;
    border-bottom: 1px solid #c1c1c1;
    animation-name:fadeInAnime_header;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes fadeInAnime_header {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.gnavi__list_acc label:hover {
    background-color: #e47646;
    
}
.gnavi__list_acc .dropdown__list:not(:first-child)::before {
    top: -1px;
}

.gnavi__list_acc .dropdown__list {
    background-color: #e95513;
    height: auto;
    
    position: relative;
}
.acc_header a {
    font-size: 1.5rem;
    padding-left: 4rem;
}
.acc_header a:hover {
    background-color: #e47646;
}


#links01 li {
    height: 0;
    overflow: hidden;
    transition: all .3s;
  
}
#links02 li {
    height: 0;
    overflow: hidden;
    transition: all .3s;
  
}
#links03 li {
    height: 0;
    overflow: hidden;
    transition: all .3s;
  
}

.gnavi__list_acc input {
    display: none;
}

.menu ul {
    margin: 0;
    padding: 0;
    background :#f4f4f4;
    list-style: none;
}

.menu li {
    height: 0;
    overflow: hidden;
}

#menu_bar01:checked ~ #links01 li,
#menu_bar02:checked ~ #links02 li,
#menu_bar03:checked ~ #links03 li{
    height:4rem;
    opacity: 1;
    transition: all .3s;
}
.header_right_sp {
    display: none;
}
#js-header_sp {
    display: none;
}
.footer_sp {
    display: none;
}

.top_company_inner .mask::before {
    display: none;
}
.top_eye_inner img {
    width: 100%;
} 



/* --------調整--------- */

@media screen and (max-width: 1600px) {
    .eye_text_box {
    top: 25%;
}

}

@media screen and (max-width: 1366px)   {
    .top_service_inner ul li .top_service_bg .top_service_item .top_service_item_right h4 {
    font-size: 1.829623vw;
}
.top_company_inner ul li .top_service_bg .top_service_item .top_service_item_right h4 {
    font-size: 1.829623vw;
}
.top_service_inner ul li .top_service_bg .top_service_item .top_service_item_right p {
    font-size: 0.87822vw;
}
.footer_list li h2 {
    font-size: 1.1vw;
}
.footer_list li a {
    font-size: 1vw;
}
.footer_list li {
    width: 19%;
}
.header_left h2 {
    font-size: 1rem;
}
.header_left h2 span {
    font-size: 0.6rem;
}
.gnavi__list:nth-child(1) {
    margin-right: 2.5rem;
}
.gnavi__list:nth-child(2) {
    margin-right: 2.5rem;
}
.gnavi__list {
    margin-right: 2rem;
}
.eye_text_box {
    top: 25%;
}

.phi_box_flex_right ul li .phi_box_left p {
    font-size: 1.4637vw;
}
.phi_box_flex_right ul li .phi_box_right p {
    font-size: 1.31733vw;
}

}

@media screen and (max-width: 1200px) {
    .eye_text_box {
        top: 30%;
    }
}

/* --------沿革--------- */

.under_eye_inner {
    margin-top: 9rem;
    position: relative;
}
.under_eye_inner img {
    width: 100%;
    height: 368px;
    object-fit: cover;
}
.under_eye_text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
.under_eye_text h2 {
    color: #fff;
    font-size: 4.8rem;
    font-weight: 500;
    letter-spacing: 0.05em;
}
.history_inner {
    max-width: 1000px;
    margin: auto;
    padding: 0 8rem;
}
.history_bg {
    background-color: #f3f5f7;
    padding: 8.8rem 0;
}
.history_inner h2 {
    font-size: 2.8rem;
    color: #1a3261;
    font-weight: 500;
}
.history_inner h3 {
    font-size: 1.6rem;
    color: #969696;
    font-weight: 500;
    margin-top: 0.8rem;
    margin-bottom: 5.6rem;
    letter-spacing: 0.15em;
}
.history_box dl {
    display: flex;
    margin-bottom: 7.2rem;
}
.history_box dl dt {
    font-size: 2rem;
    color: #1a3261;
    width: 21.6rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    position: relative;
}
.history_box dl dt::after {
    content: "";
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    background-color: #1a3261;
    border-radius: 50%;
    right: -3.7%;
    z-index: 10;
}
.history_box dl:nth-of-type(even) dt::after {
    background-color: #5f6f90;
}

.history_box dl dd {
    font-size: 1.8rem;
    color: #313232;
    width: 80%;
}
.history_box dl:nth-of-type(even) dt {
    color: #5f6f90;
}
.history_box dl:nth-of-type(even) dd .his_left p {
    color: #5f6f90;
}
.history_box {
    position: relative;
}
.history_box::after {
    content: "";
    position: absolute;
    background-color: #c1c1c1;
    width: 1px;
    height: 100%;
    top: 0;
    left: 21.2rem;
}

.history_box dl dd ul li {
    display: flex;
    margin-bottom: 4rem;
}
.his_left p {
    font-size: 2rem;
    color: #1a3261;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
}
.his_right p {
    font-size: 1.8rem;
    letter-spacing: 0;
}
.history_box dl:nth-of-type(1) dt {
    border-top: 1px solid #c1c1c1;
    padding-top: 4rem;
}
.history_box dl:nth-of-type(1) dd {
    padding-top: 4rem;
}

.his_left {
    padding: 0 5rem;
    margin-top: -3px;
}
.his_right {
    margin-top: -6px;
}

.history_box dl:last-child {
    margin-bottom: 0;
}



/* --------会社概要--------- */

.com_box dl dt::after {
    display: none;
}
.com_box dl dd ul li {
    display: block;
    margin-bottom: 0;
}
.com_box dl dd ul {
    padding-left: 5.5rem;
}

.com_box .his_right p {
    font-size: 2rem;
    letter-spacing: 0.05em;
}
.com_box .his_right p span {
    font-size: 1.6rem;
}
.com_box dl:nth-of-type(even) dt {
    color: #1a3261;
}
.com_box .his_right iframe {
    margin-top: 3.2rem;
}
.com_box dl:last-of-type {
    margin-bottom: 0;
}


/* -------メッセージ---------- */

.phi_inner {
    max-width: 1000px;
    margin: auto;
    padding: 0 8rem;
    margin-top: 8.8rem;
    margin-bottom: 8.8rem;
}
.phi_box_flex {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.phi_box_flex_left {
    width: 16%;
}
.phi_box_flex_right {
    width: 84%;
}
.phi_box_flex_left h2 {
    font-size: 2.8rem;
    color: #1a3261;
    font-weight: 500;
}
.phi_box_flex_left h3 {
    font-size: 1.6rem;
    color: #969696;
    font-weight: 500;
    margin-top: 0.8rem;
    margin-bottom: 5.6rem;
    letter-spacing: 0.15em;
}
.phi_box_flex_right ul li {
    position: relative;
}
.phi_box_flex_right ul li::after {
    position: absolute;
    content: "";
    height: 12.8rem;
    width: 1px;
    top: 21%;
    right: 44%;
    background-color: #485b81;
}
.phi_box_flex_right ul li:nth-child(2)::after {
    background-color: #f29600;
}

.phi_box_flex_right ul li:nth-child(2) {
    margin-top: -7px;
    margin-left: -3px;
}
.phi_box_flex_right ul li:nth-child(3) {
    margin-top: -7px;
}

.phi_box_flex_right ul li .phi_box_left {
    position: absolute;
    top: 43%;
    left: 28%;
}
.phi_box_flex_right ul li:nth-child(2) .phi_box_left {
    top: 36%;
}
.phi_box_flex_right ul li .phi_box_left p {
    font-size: 2rem;
    color: #1a3261;
    font-weight: 600;
}
.phi_box_flex_right ul li:nth-child(2) .phi_box_left p {
    color: #f29600;
}
.phi_box_flex_right ul li:nth-child(2) .phi_box_right {
    top: 36%;
    right: 12%;
}

.phi_box_flex_right ul li .phi_box_right {
    position: absolute;
    top: 43%;
    right: 6%;
}
.phi_box_flex_right ul li:nth-child(3) .phi_box_right {
    top: 19%;
    right: 14.5%;
}
.phi_box_flex_right ul li .phi_box_right p {
    font-size: 1.8rem;
    line-height: 2.8rem;
}
.message_bg {
    background-color: #f3f5f7;
    padding: 8.8rem 0 6.4rem 0;
}
.message_inner h2 {
    font-size: 2.8rem;
    color: #1a3261;
    font-weight: 500;
    max-width: 1000px;
    margin: auto;
}
.message_inner h3 {
    font-size: 1.6rem;
    color: #969696;
    font-weight: 500;
    max-width: 1000px;
    margin: auto;
    margin-top: 0.8rem;
    margin-bottom: 4rem;
    letter-spacing: 0.15em;
}
.message_box {
    position: relative;
}
.message_box_left {
    margin-right: auto;
    width: 100%;
    margin-left: -25%;
  
}
.message_box_left img {
    object-fit: cover;
    height: 797px;
    width: 100%;
}
.message_box_right {
    background-color: rgba(255, 255, 255, 0.9);
    padding: 5rem;
    position: absolute;
    top: 4.8rem;
    right: 0;
    width: 47vw;
}
.message_box_right p span {
    font-size: 2rem;
}
.message_box_right p {
    line-height: 2.6rem;
    width: 39vw;
    font-size: 0.833334vw;
}

@media screen and (max-width: 1366px)   {

.phi_box_flex_right ul li .phi_box_left p {
    font-size: 1.4637vw;
}
.phi_box_flex_right ul li .phi_box_right p {
    font-size: 1.31733vw;
    line-height: 2vw;
}

}

@media screen and (max-width: 1100px)   {

.phi_box_flex_right ul li::after {
    height: 10.8rem;
    top: 24%;
}

}

/* --------スマホ対応--------- */
@media screen and (max-width: 980px)   {

.sp_none {
    display: none;
}
.pc_none {
    display:block;
}


.top_eye_bottom_inner {
    max-width: 1200px;
    margin: auto;
    padding: 0 1.8rem;
    margin-top: -5rem;
    position: relative;
}
.top_eye_bottom {
    background-color: #17315e;
        color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        position: relative;
        z-index: 10;
        padding: 3.6rem 0;
        height: auto;
}
.top_eye_bottom p {
    text-align: left;
    font-size: 1.6rem;
    line-height: 4rem;
    padding: 0 2rem;
}
.top_eye_bottom p br {
    display: none;
}
.top_eye_bottom::after {
    content: "M I T S U K A R U";
    position: absolute;
    top: 5%;
    color: #FFF;
    font-size: 13rem;
    width: 100%;
    z-index: -10;
    font-family: futura-pt, sans-serif;
    font-weight: 400;
    font-style: normal;
    opacity: 0.05;
    letter-spacing: -15px;
    text-align: center;
    left: -10px;
    -webkit-transform: unset;
    -ms-transform: unset;
}
.top_service_inner {
    max-width: 1200px;
    margin: auto;
    margin-top: 7.2rem;
    padding: 0 1.8rem;
    padding-bottom: 8rem;
    margin-bottom: 0;
    position: relative;
    overflow: hidden;
}
.top_service_inner h2 {
    font-size: 4.2rem;
    padding-left: 0rem;
    margin-bottom: 3.2rem;
    padding-top: 7.2rem;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #17315e;
    text-align: center;
}
.top_service_box {
    background-color: #17315e;
    height: 12.5rem;
}
.top_service_inner ul {
    display: block;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 0 3rem 0 2.4rem;
    margin-top: -56px;
    margin-bottom: 7.2rem;
    position: relative;
    z-index: 10;
}
.top_service_inner ul li {
    width: auto;
    margin-bottom: 1.6rem;
    position: relative;
}
.top_service_box h3 {
    font-size: 2rem;
    color: #fff;
    font-weight: 500;
    padding: 24px 0 24px 24px;
    letter-spacing: 0.15em;
    display: flex;
    
}
.top_service_box h3 span {
    font-size: 1.4rem;
        background-color: #fff;
        color: #17315e;
        margin-right: 1rem;
        letter-spacing: 0.15em;
        height: 2.2rem;
        display: inline-flex;
        width: 11rem;
        vertical-align: middle;
        align-items: center;
        justify-content: center;
}
    .top_service_inner ul li .top_service_bg .top_service_item .top_service_item_right h4 {
        font-size: 1.8rem;
        letter-spacing: -1px;
    }
.top_service_inner ul li .top_service_bg .top_service_item .top_service_item_right p {
        font-size: 0.83rem;
        letter-spacing: 0;
        margin-top: -0.5rem;
    }
    .top_service_inner ul li .top_service_bg .top_service_item .top_service_item_left {
    margin-right: 1rem;
        width: 12%;
}
.top_service_inner ul li .top_service_bg {
    position: absolute;
        bottom: 0;
        width: 23.6rem;
        background-color: #fff;
        padding: 0rem 2rem 0 0;
        border-radius: 0 2rem 0 0;
        height: 3rem;
        padding-top: 1rem;
        padding-bottom: 1rem;
}
.top_service_inner ul li .top_service_bg .top_service_item {
    display: flex;
    align-items: flex-start;
}
.top_service_item_link {
    display: block;
    width: 1.8rem;
    height: 1.8rem;
    border: 1px solid #e0e0df;
    border-radius: 50%;
    box-sizing: border-box;
    margin-left: auto;
    position: relative;
    margin-top: -3rem;
    margin-bottom: 0.8rem;
}
.top_service_inner .top_service_item_border::after {
    right: -12px;
}
.top_service_inner .top_service_item_border {
    width: 22.4rem;
}
.top_service_inner ul:nth-of-type(3) {
    padding: 0 3rem 0 2.4rem;
}
.top_service_inner ul:nth-of-type(3) li {
    width: auto;
}
.top_news_inner {
    background-color: #fdf7ee;
    padding: 7.2rem 1.8rem;
}
.top_news_box ul li {
    width: auto;
}
.top_news_box h2 {
    font-size: 4.2rem;
    margin-bottom: 3.2rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #17315e;
}
.top_news_box ul li p {
    font-size: 1rem;
    margin-top: 1.6rem;
    color: #7c7d7d;
    font-family: poppins, sans-serif;
    font-weight: 300;
    font-style: normal;
}
.top_news_box ul li h3 {
    font-size: 1.4rem;
    line-height: 2rem;
    font-weight: 500;
    margin-bottom: 3.2rem;
}
.top_news_btn {
    display: flex;
    width: 24.8rem;
    margin: auto;
    margin-top: 4rem;
    background-color: #fff;
    border: 1px solid #17315e;
    border-radius: 3rem;
    height: 4rem;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    position: relative;
    top: 0;
    left: 0;
    overflow: hidden;
}
.top_news_box_link {
    font-size: 1rem;
    color: #17315e;
    font-family: poppins, sans-serif;
    font-weight: 300;
    font-style: normal;
    display: block;
    margin-bottom: 1rem;
}
.top_sns_inner {
    max-width: 1200px;
    margin: auto;
    padding: 7.2rem 3.6rem;
}
.top_sns_inner h2 {
    font-size: 4.2rem;
    margin-bottom: 3.2rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #17315e;
}
.top_sns_inner ul {
    display: block;
    justify-content: space-between;
    flex-wrap: wrap;
}
.top_sns_inner ul li {
    width: auto;
    margin-bottom: 3.2rem;
}
.top_sns_inner ul li h3 {
    text-align: center;
    font-size: 1.5rem;
    font-weight: 500;
    margin-top: 1.2rem;
}
.top_company_bg {
    background-color: #17315e;
    padding: 7.2rem 3.6rem;
}
.top_company_inner h2 {
    font-size: 4.2rem;
    margin-bottom: 3.2rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #fff;
}

.top_company_inner ul {
    display: block;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 0 0rem;
}
.top_company_inner ul li {
    width: auto;
    position: relative;
    margin-bottom: 1.8rem;
}
.top_company_inner ul li .top_service_bg .top_service_item .top_service_item_right h4 {
        font-size: 1.8rem;
    }
.top_company_inner ul li .top_service_bg .top_service_item .top_service_item_right p {
    font-size: 0.85rem;
    color: #a8a8a7;
    font-family: poppins, sans-serif;
    font-weight: 300;
    font-style: normal;
}
.top_company_inner ul li .top_service_bg .top_service_item .top_service_item_left {
    margin-right: 1rem;
    width: 14%;
}
.top_company_inner ul li .top_service_bg .top_service_item {
    display: flex;
    align-items: flex-start;
}
.top_company_inner ul li .top_service_bg {
    position: absolute;
    bottom: 0;
    width: 75%;
    background-color: #17315e;
    padding: 1.5rem 2rem 0 0;
    border-radius: 0 3rem 0 0;
}
.top_contact_bg {
    background-color: #f3f5f7;
    padding: 7.2rem 3.6rem;
}
.top_contact_inner h2 {
    font-size: 4.2rem;
    margin-bottom: 3.2rem;
    text-align: center;
    font-family: poppins, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #17315e;
}
.top_contact_inner p {
    font-size: 1.5rem;
}
.top_contact_inner a {
    display: flex;
    width: 32rem;
    margin: auto;
    margin-top: 5.8rem;
    background-color: #fff;
    border: 1px solid #17315e;
    border-radius: 3rem;
    height: 5.6rem;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    position: relative;
    top: 0;
    left: 0;
    overflow: hidden;
}
.header_left h2 {
    display: none;
}
.header_right_pc {
    display: none;
}
.header_right_sp {
    display: block;
}
.header_left img {
    margin-right: 0rem;
}

.eye_text_box h2 {
    font-size: 4rem;
    line-height: 7rem;
    color: #17315e;
    font-weight: 500;
    max-width: 1366px;
    margin: auto;
    padding: 0 1.8rem;
}
.eye_text_box {
    position: absolute;
    top: 11%;
    width: 100%;
}
.eye_text_center {
    padding: 1rem 0.3rem;
    margin-right: 1rem;
    font-size: 5rem;
    letter-spacing: -0.07em;
}

.menu-btn {
    position: absolute;
        top: 0;
        right: 2.8rem;
        display: flex;
        height: 24px;
        width: 32px;
        justify-content: center;
        align-items: center;
        z-index: 90;
}
.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
    content: '';
        display: block;
        height: 3px;
        width: 32px;
        border-radius: 3px;
        background-color: #3d3a39;
        position: absolute;
}
.menu-btn span:before {
    bottom: 10px;
}
.menu-btn span:after {
    top: 10px;
}
#menu-btn-check:checked ~ .menu-btn span {
    background-color: rgba(255, 255, 255, 0);/*メニューオープン時は真ん中の線を透明にする*/
}
#menu-btn-check:checked ~ .menu-btn span::before {
    bottom: 0;
    transform: rotate(45deg);
    background-color: #fff;
    height: 1px;
    width: 26px;
}
#menu-btn-check:checked ~ .menu-btn span::after {
    top: 1px;
    transform: rotate(-45deg);
    background-color: #fff;
    height: 1px;
    width: 26px;
}

#menu-btn-check {
    display: none;
}

.gnavi__wrap {
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 100%;/*leftの値を変更してメニューを画面外へ*/
    z-index: 80;
    background-color: #e95513;
    transition: all 0.5s;/*アニメーション設定*/
}
#menu-btn-check:checked ~ .gnavi__wrap {
    left: 15%;
}
#menu-btn-check:checked ~ html {
    overflow: hidden;
}

#menu-btn-check:checked ~ .hamburger-demo-cover {
    position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 0;
	background: rgba(3,3,3,.5);
	display: block;
    overflow: hidden;
}

.gnavi__lists {
    display: block;
    height: 100%;
    overflow-y: scroll;
}

.gnavi__list a {
    display: grid;
        justify-content: left;
        align-items: center;
        height: 6rem;
        color: #fff;
       
        padding-bottom: 0rem;
        vertical-align: middle;
        padding-left: 2rem;
        font-size: 1.5rem;
}
#js-header {
    display: none;
}
#js-header_sp {
    display: block;
}
input[type=checkbox]:checked + label:after {
    display: none;
}

.gnavi__list_menu {
    height: 5rem;
    display: flex;
    align-items: center;
    font-size: 1.7rem;
    color: #ffff;
    letter-spacing: 0.2em;
    padding-left: 2rem;
    border-bottom: 1px solid #fff;
    font-family: poppins, sans-serif;
    font-weight: 400;
}
.gnavi__list:nth-child(1) {
        margin-right: 0;
    }
.gnavi__list:nth-child(2) {
        margin-right: auto;
        border-bottom: 1px solid #fff;
    }
.gnavi_hover:hover {
    color: #fff;
}
.dropdown__lists {
    transform: scaleY(0);
    transform-origin: unset;
  
    width: 100%;
    position: unset;
    top: 40px;
    left: 0;
}


.gnavi__list:active .dropdown__lists {
    display: block;/*Gナビメニューにホバーしたら表示*/
}

.gnavi__list:active .dropdown__lists {
    visibility: visible;/*Gナビメニューにホバーしたら表示*/
    opacity: 1;/*不透明度1*/
}
.gnavi__list:active .dropdown__lists {
    transform: scaleY(1);/*Gナビメニューにホバーしたら表示*/
}
#menu_bar04:checked ~ #links04 li,
#menu_bar05:checked ~ #links05 li,
#menu_bar06:checked ~ #links06 li{
    height:4rem;
    opacity: 1;
    overflow:auto;
}

#menu_bar08:checked ~ #links08 {
    height: auto;
    opacity: 1;
    overflow:auto;
   
}


.label_7 {
    position: relative;
    
}
.label_7::after {
        content: "";
        display: inline-block;
        vertical-align: middle;
        color: #fff;
        line-height: 1;
        width: 1.3rem;
        height: 1.3rem;
        border: 0.1em solid currentColor;
        border-left: 0;
        border-bottom: 0;
        box-sizing: border-box;
        transform: translateY(-25%) rotate(135deg);
        position: absolute;
        right: 25%;
}


.label_8 {
    position: relative;
}
.gnavi__list_acc label:after {
    content: "";
    display: block;
    width: 1.3rem;
    height: 1.3rem;
    border-top: #fff 1px solid;
    border-right: #fff 1px solid;
    -webkit-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    transform: rotate(135deg);
    position: absolute;
    right: 25%;
    top: 0;
    bottom: 15%;
    margin: auto;
}
#menu_bar08:checked ~ #links08::after {
        content: "";
        display: inline-block;
        vertical-align: middle;
        color: #fff;
        line-height: 1;
        width: 1.3rem;
        height: 1.3rem;
        border: 0.1em solid currentColor;
        border-left: 0;
        border-bottom: 0;
        box-sizing: border-box;
        -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
        position: absolute;
        right: 25%;
        top: 25px;
}











#menu_bar07 {
    display: none;
}
.label_7 {
    height: 6rem;
    display: flex;
    align-items: center;
    padding-left: 2rem;
    color: #fff;
    transition: all .3s;
}
.label_8 {
    height: 6rem!important;
    display: flex;
    align-items: center;
    padding-left: 2rem!important;
    color: #fff;
    
}

#links04 li {
    height: 0;
    overflow: hidden;
    /*transition: all .3s;*/
  
}
#links05 li {
    height: 0;
    overflow: hidden;
    /*transition: all .3s;*/
   
}
#links06 li {
    height: 0;
    overflow: hidden;
    /*transition: all .3s;*/
    
}

#menu_bar07:checked ~ #links07 {
    height: auto;
    overflow: auto;
    
}

#links07 {
    height: 0;
    overflow: hidden;
  
}

#menu_bar07:checked ~ #links07::after {
        content: "";
        display: inline-block;
        vertical-align: middle;
        color: #fff;
        line-height: 1;
        width: 1.3rem;
        height: 1.3rem;
        border: 0.1em solid currentColor;
        border-left: 0;
        border-bottom: 0;
        box-sizing: border-box;
        -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
        position: absolute;
        right: 25%;
        top: 25px;
}




#links08 {
    height: 0;
    overflow: hidden;
}


.dropdown__lists {
    opacity: 1;
    transform: unset;
    visibility: visible;
}

.gnavi__list:hover .dropdown__lists {
    transform: unset;
}
.gnavi__list:hover .dropdown__lists {
    visibility: unset;
    opacity: unset;
}
.gnavi__list:hover .dropdown__lists {
    display: unset;
}
.gnavi__lists .gnavi__list {
    border-bottom: 1px solid #fff;
    font-size: 1.5rem;
   
    
}
.gnavi__list_menu {
    font-size: 1.7rem!important;
}
.dropdown__list:not(:first-child)::before {
    display: none;
}
.dropdown__list a {
    padding-left: 4rem;
    height: 4rem;
}
.dropdown__list {
    height: 4rem;
}
.gnavi_arrow:hover::after {
    color: #fff;
}
.gnavi_arrow::after {
    content: "";
    display: inline-block;
    vertical-align: middle;
    color: #fff;
    line-height: 1;
    width: 1.3rem;
        height: 1.3rem;
    border: 0.1em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    box-sizing: border-box;
    transform: translateY(-25%) rotate(135deg);
    position: absolute;
    right: 25%;
}
    .gnavi__list {
        margin-right: auto;
    }
    
    
.footer_pc {
    display: none;
}
.footer_sp {
    display: block;
}


/*ベース*/
.toggle {
	display: none;
}
.Label {/*タイトル*/
	padding: 2.4rem 1.8rem 2.4rem 1.8rem;
        display: block;
        color: #17315e;
        font-size: 1.5rem;
        border-top: 1px solid #17315e;
}
.Label_1 {
    border-top:unset;
}
.Label::before{		/*タイトル横の矢印*/
	content: "";
        width: 8px;
        height: 8px;
        border-top: 1px solid #17315e;
        border-right: 1px solid #17315e;
        -webkit-transform: rotate(45deg);
        position: absolute;
        top: calc(50% - 7px);
        right: 20px;
        transform: rotate(135deg);
}
.Label,
.content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	
}
.content {		/*本文*/
	height: 0;
	padding:0 20px;
	overflow: hidden;
}
.toggle:checked + .Label + .content {	/*開閉時*/
	height: auto;
	
}
.toggle:checked + .Label::before {
	transform: rotate(-45deg) !important;
}

.footer_inner_sp {
    margin-top: 6rem;
}
.footer_box_sp {
    border-bottom: 1px solid #17315e;
    padding-bottom: 2.4rem;
   
    text-align: center;
}
.footer_box_sp p {
    font-size: 1.5rem;
    margin-top: 1.6rem;
}
.accordion {
    padding: 0 1.8rem;
}
.content p {
    font-size: 1.4rem;
    color: #516486;
    margin-bottom: 2rem;
}
.content p a {
    font-size: 1.4rem;
}
.content p a:hover {
    color: #e95513;
}
.footer_bottom_sp p a:hover {
    color: #e95513;
}
.footer_inner_sp ul li {
    display: flex;
    border-top: 1px solid #17315e;
    padding: 1.5rem 1.8rem 1.5rem 1.8rem;
    align-items: center;
}
.footer_inner_sp ul li:last-child {
    padding: 2.4rem 1.8rem 2.4rem 1.8rem;
}
.footer_inner_sp ul li:last-child a {
    color: #17315e;
}
.footer_inner_sp ul li p {
    font-size: 1.5rem;
    margin-right: 3rem;
    color: #17315e;
}
.footer_inner_sp ul li:nth-child(1) div {
    display: flex;
    align-items: center;
    width: 40%;
}
.footer_inner_sp ul li:nth-child(1) div a:nth-of-type(2) {
    margin: 0 2rem;
}

.footer_bottom_sp {
    border-top: 1px solid #17315e;
    padding-top: 2.4rem;
}
.footer_bottom_sp p:nth-of-type(1) {
    text-align: center;
    font-size: 1.3rem;
    padding-bottom: 2.4rem;
}
.footer_bottom_sp p:nth-of-type(2) {
    text-align: center;
    font-size: 1rem;
    padding-bottom: 2.4rem;
    color: #636464;
}




#menu_bar04:checked ~ #links04::after {
        content: "";
        display: inline-block;
        vertical-align: middle;
        color: #fff;
        line-height: 1;
        width: 1.3rem;
        height: 1.3rem;
        border: 0.1em solid currentColor;
        border-left: 0;
        border-bottom: 0;
        box-sizing: border-box;
        -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        transform: rotate(-45deg);
        position: absolute;
        right: 25%;
        top: 25px;
}
#menu_bar05:checked ~ #links05::after {
        content: "";
        display: inline-block;
        vertical-align: middle;
        color: #fff;
        line-height: 1;
        width: 1.3rem;
        height: 1.3rem;
        border: 0.1em solid currentColor;
        border-left: 0;
        border-bottom: 0;
        box-sizing: border-box;
        -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        transform: rotate(-45deg);
        position: absolute;
        right: 25%;
        top: 25px;
}
#menu_bar06:checked ~ #links06::after {
        content: "";
        display: inline-block;
        vertical-align: middle;
        color: #fff;
        line-height: 1;
        width: 1.3rem;
        height: 1.3rem;
        border: 0.1em solid currentColor;
        border-left: 0;
        border-bottom: 0;
        box-sizing: border-box;
        -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        transform: rotate(-45deg);
        position: absolute;
        right: 25%;
        top: 25px;
}






.gnavi__list_acc label {
    display: flex;
    line-height: 1;
    color: #fff;
    cursor: pointer;
    height: 5rem;
    justify-content: left;
    align-items: center;
    text-decoration: none;
    position: relative;
    padding-left: 4rem;
    font-size: 1.5rem;
}
.gnavi_arrow:hover::after {

    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.acc_header li a {
    padding-left: 6rem;
}


#links07 li a {
    padding-left: 4rem;
        height: 4rem;
}
#menu-btn-check:checked ~ .menu-btn {
       position: fixed;
        top: 1rem;
        right: 2.5rem;
    }
#js-header_sp.m_fixed {
    left: 0;
    right: 0;
    position: fixed;
    top: 0px;
    background-color: #fff;
    z-index: 100;
    padding: 1.5rem 0;
    border-bottom: 1px solid #c1c1c1;
    animation-name: fadeInAnime_header;
    animation-duration: 1s;
    animation-fill-mode: forwards;
    opacity: 0;
}
.header_inner {
    margin-top: -1rem;
}
.m_fixed .menu-btn {
    top: 2rem;
}
.header_left {
    width: 40%;
}
.footer_box_sp img {
    width: 38%;
}
.top_service_inner:before {
    background-size: auto;
}

.top_service_inner:after {
    background-size: auto;
}
.top_service_box:nth-of-type(3)::after {
    display: none;
}
.top_eye_inner {
    position: relative;
    margin-top: 0;
}
.header_inner {
    padding: 0 2rem;
}

/* --------沿革--------- */

.under_eye_inner {
    margin-top: 7rem;
}
.under_eye_inner img {
    height: 37.5rem;
}
.under_eye_text h2 {
    font-size: 4rem;
}
.under_eye_text {
    width: 100%;
    text-align: center;
}
.history_bg {
    padding: 7.2rem 0;
}
.history_inner {
    padding: 0 1.8rem;
    overflow: hidden;
}
.history_inner h2 {
    font-size: 2.2rem;
}
.history_inner h3 {
    margin-bottom: 4rem;
}
.history_box dl:nth-of-type(1) dt {
    padding-top: 3.2rem;
}
.history_box dl dt {
    font-size: 1.4rem;
    width: 8rem;
    text-align: left;
}
.history_box dl dt::after {
    width: 1.2rem;
    height: 1.2rem;
    right: -5.7px;
}
.his_left p {
    font-size: 1.4rem;
    white-space: nowrap;
}
.his_right p {
    font-size: 1.4rem;
    letter-spacing: 0;
    line-height: 2.2rem;
}
.history_box dl:nth-of-type(1) dd {
    padding-top: 3.2rem;
}
.history_box dl {
    margin-bottom: 4rem;
}
.his_left {
    padding: 0 2rem;
    margin-top: -6px;
}
.history_box::after {
    left: 78px;
}
.his_right {
    margin-top: -5px;
}



/* --------会社概要--------- */

.com_inner h3 {
    font-size: 1.2rem;
}
.com_box dl dt {
    width: 9.6rem;
}

.com_box::after {
    left: 89px;
}
.com_box .his_right p {
    font-size: 1.4rem;
    letter-spacing: 0;
}
.com_box dl dd ul {
    padding-left: 3rem;
}

.com_box .his_right p span {
    font-size: 1.3rem;
}
.com_box .his_right iframe {
    margin-top: 2rem;
    height: 10.9rem;
}
.com_box dl dt {
    font-family:unset;
    font-weight: bold;
}


/* -------メッセージ---------- */


.phi_inner {
    padding: 0 1.8rem;
    margin-top: 7.2rem;
    margin-bottom: 7.2rem;
    overflow: hidden;
}
.message_inner {
    overflow: hidden;
}
.phi_box_flex {
    display: block;
}
.phi_box_flex_left {
    width: auto;
}
.phi_box_flex_left h2 {
    font-size: 2.2rem;
}
.phi_box_flex_left h3 {
    font-size: 1.2rem;
    margin-bottom: 4rem;
}
.phi_box_flex_right {
    width: auto;
}
.phi_box_flex_right ul li::after {
    display: none;
}
.phi_box_flex_right ul li .phi_box_left p {
    font-size: 1.4rem;
    white-space: nowrap;
    
}
.phi_box_flex_right ul li .phi_box_right p {
    font-size: 1.4rem;
    line-height: 2.2rem;
    white-space: nowrap;
}
.phi_box_flex_right ul li .phi_box_right {
    position: absolute;
        top: 9.2rem;
        right: unset;
        left: 11rem;
}
.phi_box_flex_right ul li .phi_box_left {
    position: absolute;
        top: 7rem;
        left: 11rem;
}
.phi_box_flex_right ul li:nth-child(2) {
    margin-top: 0px;
    margin-left: 0px;
}
.phi_box_flex_right ul li:nth-child(2) .phi_box_left {
    top: 39%;
}
.phi_box_flex_right ul li:nth-child(2) .phi_box_right {
    top: 53%;
    right: 22%;
}
.phi_box_flex_right ul li:nth-child(3) {
    margin-top: 0px;
}
.phi_box_flex_right ul li:nth-child(3) .phi_box_right {
    top: 41%;
    right: 26.5%;
}
.phi_box_flex_right ul li:nth-child(3) .phi_box_left {
    top: 30%;
    left: 11rem;
}
.message_bg {
    padding: 7.2rem 0 7.2rem 0;
}
.message_inner h2 {
    font-size: 2.2rem;
    padding: 0 1.8rem;
}
.message_inner h3 {
    font-size: 1.2rem;
    padding: 0 1.8rem;
}
.message_box_left img {
    object-fit: cover;
    height: auto;
    width: 100%;
}
.message_box_left {
    margin-right: auto;
    width: 100%;
    margin-left: auto;
}
.message_box {
    position: relative;
    padding: 0 1.8rem;
    
}
.message_box_right {
    background-color: rgba(255, 255, 255, 0.9);
    padding: 2.4rem;
    position: unset;
    top: unset;
    right: unset;
    width: auto;
    box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.2);
}
.message_box_right p {
    line-height: 2rem;
    width: auto;
    font-size: 1.3rem;
}
.message_box_right p span {
    font-size: 1.7rem;
}
.message_box_right_sp {
    padding: 0 1.8rem;
    margin-top: -8rem;
    z-index: 10;
    position: relative;
    padding-bottom: 1rem;
}












}
