@charset "utf-8";
html{
  font-size: 100%;
  scroll-behavior: smooth;
}
body{
  font-family: "Yu Gothic Medium","游ゴシック Medium,YuGothic","游ゴシック体","ヒラギノ角ゴ Pro W3","sans-serif";
  line-height: 1.7;
  color: #432;
}
a{
  text-decoration: none;
}
img{
  max-width: 100;
}
.logo{
  width: 200px;
  height: 65px;
  margin-left: 10px;
  margin-top: 11px;
}
.logo2{
  width: 130px;
  height: 65px;
  text-align: left;
  margin-top: 11px;
}
.ka-to{
  width: 54px;
  margin-top: 5px;
}
.ka-to:hover{
  cursor: pointer;
  transform: scale(1.1, 1.1);
  transition: all 0.6s ease 0s;
}
.tyumon{
  width: 60px;
  margin-top: 5px;
}
.tyumon:hover{
  cursor: pointer;
  transform: scale(1.1, 1.1);
  transition: all 0.6s ease 0s;
}
.main-nav{
  display: flex;
  font-size: 1.25rem;
  text-transform: uppercase;
  margin-top: 15px;/*元数字34px*/
  list-style: none;
}
.main-nav li{
  margin-left:36px;
}
.main-nav a{
  color: #432;
  /*↓文字縁↓*/
  text-shadow :1px 1px 1px #ffffff,
                -1px 1px 1px #ffffff,
                 1px -1px 1px #ffffff,
                -1px -1px 1px #ffffff,
                 1px  0px 1px #ffffff,
                 0px  1px 1px #ffffff,
                 -1px  0px 1px #ffffff,
                 0px -1px 1px #ffffff;
  /*↑文字縁End↑*/
}
.main-nav a:hover{
  color:#FF007F;
}

.page-header{
  display: flex;
  justify-content: space-between;
}
.page-header-right{
  text-align: right;
}
.page-header-icon{
  display: flex;
  justify-content: flex-end;
  margin-bottom: -40px;
}
.page-header-icon img{
  height: 30px;
  padding: 0 20px 10px 15px;
}
.page-header-icon img:hover{
  filter:opacity(20%);
  transition: all 0.6s ease 0s;
}
.page-header-icon2{
  margin: 32px 0px 0 0 ;
  display: flex;
  justify-content: flex-end;
}

.wrapper{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 4%;
}
/*HOME------------------------------------*/
.home-content{
  text-align: center;
  margin-top: 10%;
}
.home-content p{
  font-size:1.125rem;
  margin: 10px 0 42px;
  /*↓文字縁↓*/
  text-shadow :1px 1px 1px #ffffff,
                -1px 1px 1px #ffffff,
                 1px -1px 1px #ffffff,
                -1px -1px 1px #ffffff,
                 1px  0px 1px #ffffff,
                 0px  1px 1px #ffffff,
                 -1px  0px 1px #ffffff,
                 0px -1px 1px #ffffff;
  /*↑文字縁End↑*/
}
/*見出し*/
.page-title{
  font-size:3rem;
  font-family: 'Philosopher',serif;
  text-transform: uppercase;
  font-weight: normal;
  line-height:3em;
  margin-top: 20px;
  font-weight:bold;
  color: #fff;
  text-shadow:0 0.05em 0.08em rgba(0,0,0,0.7);
}
.top-content h3{
  font-size:2rem;
  margin-top: -50px;
}
#home{
  min-height: 28vh;
  margin-bottom: 20px;
}
#home .page-title{
  text-transform: none;
}
#top{
  border-width: 5px;
  border-top-style: solid;
  border-color: #FF007F;
  height: 60px;
}
#top img{
  width: 100%;
}
/*メインエリアstart*/
.top-contents{
  display: flex;
  justify-content: space-between;
  margin-bottom:50px;
  padding-top: 0px;/*id=topの上から50px離す*/
}
article{
  width:100%;
}
article img{
  margin-bottom:20px;
  width:100%;/*本来無いのを書き込んだ*/
}
article p{
  margin-bottom: 1rem;
}
.post-info{
  padding-top: 10px;
  margin-bottom:22px;
}
.info{
  width: 100%;
}
.info-b{
  border-top: solid 1px #000;
}
.info-c{
  display: flex;
  justify-content: space-between;
  padding: 20px;
  color: #000;
}
.info-c:hover{
  filter: opacity(20%);
  transition: all 0.6s ease 0s;
}
.info-c h1{
  font-size: 1rem;
  font-weight: 100;
}
.info-c h2{
  font-size: 1.1rem;
}
.info-c img{
  width: 300px;
  margin-bottom: -10px;
}
.read-more{
  display: flex;
  justify-content: flex-end;
  margin: 0 15px 0 0;
}
.read-more a:hover{
  filter: opacity(20%);
  transition: all 0.6s ease 0s;
}
.read-more img{
  width: 100px;
}

.post-title{
  font-family: "Yu mincho","YuMincho","serif";
  font-size: 1.8rem;
  font-weight: bold;
}
.news{
  margin-top: 20px;
}
img {
  border-radius: 12px;
}
/*.post-title,
.post-cat{
  margin-left: 0px;元は120px
}*/
/*サイドバーstart*/
aside{
  width:17%;
  margin-top: 12px;
}
aside img:hover{
  filter: opacity(20%);
  transition: all 0.6s ease 0s;
}
.sub-title{
  font-size: :1.375rem;
  padding:0 8px 8px;
  border-bottom:2px #FF007F solid;
  font-weight: normal;
}
.sub-title1{
  margin-top: 50px;
}
aside p{
  padding: 12px 10px;
}
.sub-menu{
  margin-bottom: 35px;
  list-style: none;
}
.sub-menu li{
  border-bottom: 1px #ddd solid;
}
.sub-menu a{
  color: #432;
  padding:10px;
  display: block;
}
.sub-menu a:hover{
  color: #FF007F;
}
.side-img img{
  width: 100%;
}
/*追加*/
h3.sub-title a{
  color: #432;
}
h3.sub-title a:hover{
  color: #FF007F;
}
h4 {
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: 2rem; /* 必要に応じて調整可能 */
  font-weight: normal; /* 明朝らしさを出すため通常は太くしない */
}
/*サイドバーend*/
.crop-hero {
  width: 100%;
  max-width: 2048px;
  aspect-ratio: 4 / 1; /* 2048:512 = 4:1 */
  overflow: hidden;
  position: relative;
  margin-top:30px;
  margin-bottom:20px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.crop-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center; /* 中央トリミング */
  display: block;
}

/*tabke開始*/
.hyo{
  width: 100%;
  text-align: left;

}
.hyo th{
  width: 20%;
  padding-left: 10px;
}
.hyo td{
  width: 80%;
  padding-left: 10px;
}
.hyo td a{
  color: #000;
}
.hyo td a:hover{
  color: #0bd;
}
.comp-table table{
  border-collapse: collapse;
}
.comp-table table tr{
  border-bottom: solid 2px white;
}
.comp-table table th{
  position: relative;
  text-align: left;
  background-color: #1f3f95;
  color: white;
  font-weight: 400;
}
.comp-table table td{
  text-align: left;
  background-color: #eee;
  padding: 10px 0 10px 10px;
}
.hyo2{
  width: 100%;
  text-align: left;

}
.hyo2 th{
  width: 65%;
  padding-left: 10px;
}
.hyo2 td{
  width: 35%;
  padding-left: 10px;
}
.hyo22 table{
  border-collapse: collapse;
}

.hyo22 table tr{
  border-bottom: solid 1px #ddd;
}
.hyo22 table th{
  position: relative;
  text-align: left;
  background-color: #fff;
  color:#000;
  text-align: center;
  font-weight: 400;
  text-align: left;
}
.hyo22 table td{
  text-align: left;
  background-color: #fff;
  padding: 10px 10px;
}
.pad {
  height: 100px;
  margin-bottom: 4rem;
}
/*tabke終了*/
/*地図開始*/
.tizu{
  width: 100%;
  height: 600px;
}
/*地図終了*/
/*技術リスト開始*/
.gili li{
  list-style-type: none;
}
.gili h5{
  margin-bottom: 20px;
}
.gili img{
  margin-bottom: -15px;
}

.gili table {
  border-collapse: collapse;
  padding: 0;
  width: 100%;
  table-layout: fixed;
  color: #000;
}

.gili table tr {
  background-color: #fff;
  border-bottom: 1px solid #bbb;
}
.gili table thead{
  border-bottom: 2px solid #FF007F;
}
.gili table tr:last-child{
   border-bottom: none
}
.gili table th,
.gili table td {
  padding: 1em 10px 1em 1em;
  border-right: 1px solid #bbb;
}
.gili table th:last-child,
.gili table td:last-child{
    border: none;
}
.txt{
   text-align: center;
   font-size: 1em;
}
.price{
   text-align: left;
   font-size: .85em;
}

/*技術リスト終了*/
/*ボタンhover青*/
.container{
  width: 100%;
}
.btn-animation-02 {
  display: inline-block;
  width: 32%;
  text-align: center;
  background-color: #1f3f95;
  border: 2px solid #1f3f95;
  font-size: 16px;
  color: #1f3f95;
  text-decoration: none;
  font-weight: bold;
  padding: 10px 24px;
  border-radius: 4px;
  position: relative;
}

.btn-animation-02 span {
  position: relative;
  z-index: 1;
}

.btn-animation-02::before,
.btn-animation-02::after {
  content: "";
  display: block;
  background-color: #FFF;
  width: 50%;
  height: 100%;
  position: absolute;
  top: 0;
  transition: .2s;
}
.btn-animation-02::before {
  left: 0;
}
.btn-animation-02::after {
  right: 0;
}

.btn-animation-02:hover:before,
.btn-animation-02:hover:after {
  width: 0;
  background-color: #FFF;
}

.btn-animation-02:hover {
  color: #FFF;
}
/*ボタンhover青終了*/



/*8耐ページcss開始*/

.eight-hours-table-container {
  overflow-x: auto;
  margin: 30px 0;
}

.eight-hours-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Segoe UI', sans-serif;
  font-size: 0.95rem;
  background-color: #f9f9f9;
}

.eight-hours-table thead {
  background-color: #1f3f95;
  color: #fff;
}

.eight-hours-table th,
.eight-hours-table td {
  border: 1px solid #ccc;
  padding: 8px 12px;
  text-align: center;
}

.eight-hours-table tbody tr:nth-child(odd) {
  background-color: #f6faff;
}

.eight-hours-table tbody tr:nth-child(even) {
  background-color: #ffffff;
}

.eight-hours-table td:nth-child(1) {
  font-weight: bold;
  background-color: #edf4ff;
}
/*8耐ページ終了*/




/*メインエリアend*/

/*フッター*/
footer{
  background: #002D72;
  padding: 26px 0;
  margin-bottom: -30px;
}
.footer-nav{
  display: flex;
  justify-content: flex-end;
  text-transform: uppercase;
  list-style: none;
}
.footer-nav li{
  margin-left:36px;
}
.footer-nav p{
  color: #fff;
  font-size:0.875rem;
}
.footerlogo{
  margin-top: -8px;
  margin-right: -20px;
  width: 36px;
}
/*フッターEND*/

/*検索エンジンstart*/
dl.search1{
  margin-top: 22px;
	position:relative;
	background-color:#fff;
	border:1px solid #aaa;
	-webkit-border-radius:6px;
	-moz-border-radius:6px;
	-o-border-radius:6px;
	-ms-border-radius:6px;
	border-radius:6px;
}
dl.search1 dt{
	margin-right:40px;
	padding:8px 0 8px 8px;
}
dl.search1 dt input{
	width:100%;
	height:24px;
	line-height:24px;
	background:none;
	border:none;
}
dl.search1 dd{
	position:absolute;
	top:0;
	right:0;
}
dl.search1 dd button{
	display:block;
	padding:10px;
	background:none;
	border:none;
}
dl.search1 dd button span{
	display:block;
	width:20px;
	height:20px;
	background:url(../images/search2.png) no-repeat scroll 0 0;
}
.kensaku{
  margin-left: 10px;
  width: 950px;
}
/*検索エンジンend*/

.top-photo1{
  margin-top: -40px;
  margin-bottom: -20px;
}
/*見出しstart*/
.midasi h1 {
    padding: 0.25em 0.5em;/*上下 左右の余白*/
    color: #494949;/*文字色*/
    background: transparent;/*背景透明に*/
    border-left: solid 5px #FF007F;/*左線*/
    margin-bottom:20px;
  }
.midasi-margin-top{
  margin-top: 50px;
}
.midasi1 h1 {
    color: #FF007F;/*文字色*/
    margin-top: 25px;
    margin-bottom: 10px;
  }
.midasi1 h3{
  margin-top: 20px;
  margin-bottom: 20px;
}
.midasi2{
  margin-top: 20px;
}
.midasi2 :hover{
  filter : opacity(20%);
  transition: all 0.6s ease 0s;
}
.aisatu h2 {
  padding: 0.25em 0.5em 0.25em 0;/*上下 左右の余白*/
  color: #494949;/*文字色*/
  border-top: solid 1px #a9a9a9;
  border-bottom: solid 1px #a9a9a9;
  margin-bottom:20px;
}
.aisatu-p p{
  font-size: 5rem;
}
/*見出しend*/
/*メインメニュー画像STRAT*/
.flex{
  display: flex;
  justify-content: flex-start;
}
.flex-i{
  padding: 10px;
  width: 25%;
}
.flex-i:hover{
  filter : opacity(20%);
  transition: all 0.6s ease 0s;
}
.flex-i3{
  padding: 10px;
  width: 25%;
}
.flex-i3:hover{
  filter : opacity(20%);
  transition: all 0.6s ease 0s;
}
.flex-i3 img{
  aspect-ratio: 16 / 9;
}

.logo-box {
  width: 100%;
  aspect-ratio: 4 / 3;
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}

.logo-box img {
  max-width: 90%;
  max-height: 90%;
  object-fit: contain;
}

.flex-i p{
  color: #000;
  font-size: 1.1rem;
  margin-top: -15px;
  font-weight: bold;
  display: flex;
  justify-content: center;
}
.flex-i2{
  width: 100%;
}
.flex-i2:hover{
  filter : opacity(20%);
  transition: all 0.6s ease 0s;
}
.flex-i2 p{
  color: #000;
  font-size: 1.1rem;
  font-weight: bold;
  margin-top: -10px;
  display: flex;
  justify-content: right;
}
.o-flex-i{
  padding: 10px;
  width: 17%;
}
.o-flex-i:hover{
  filter : opacity(20%);
  transition: all 0.6s ease 0s;
}
.o-flex-i p{
  color: #000;
  font-size: 1.1rem;
  margin-top: -15px;
  font-weight: bold;
  display: flex;
  justify-content: center;
}
.o-flex-i2{
  padding: 10px;
  width: 17%;
}
.o-flex-i2 p{
  color: #000;
  font-size: 1.1rem;
  margin-top: -15px;
  font-weight: bold;
  display: flex;
  justify-content: center;
}
 .takemi{
   text-align: right;
   font-size: 0.8rem;
   margin-top: -15px;
 }
.img-border-radius img{
  border-radius: 15px;
}
.img-padding{
  padding: 25px 0;
}
.gura h1{
  color: #FF007F;
  font-size: 1rem;
  margin-bottom: 15px;
}
.ga1 img{
  border-radius: 15px;
}
/*メインメニュー画像END*/


/*ドロップダウンメニュー*/
.gnav-background{
  background: #F2F2F2;
}
.gnav-wrapper {
 width: 100%;
 margin: 0 auto;
 margin-top: 32px;
 background: #F2F2F2;
 position: relative;
 z-index: 2;
}
.gnav {
 display: flex;
 justify-content: space-between;
}
.gnav li {
 list-style-type: none;
 padding: 12px;/*元12px*/
 text-align: center;
 transition: all .3s ease-in-out;
}

.gnav a{
 font-family: "serif";
 color: #000;
}
.yajirusi2{
  background-image: url(../images/yajirusi1.png);
  background-repeat: no-repeat;
  background-size: 15px;
  background-position: 85px 6px;
}
.yajirusi0{
  background-image: url(../images/yajirusi1.png);
  background-repeat: no-repeat;
  background-size: 15px;
  background-position: 70px 6px;
}
.yajirusi1{
  background-image: url(../images/yajirusi1.png);
  background-repeat: no-repeat;
  background-size: 15px;
  background-position: 102px 6px;
}

.gnav img:hover {
  cursor: pointer;
  transform: scale(1.1, 1.1);
  transition: all 0.6s ease 0s;
}

.gnav > li:hover .megamenu {
 max-height: 9999px;
 opacity: 1;
 padding: 30px 0;
 color:#FFF;
}

.megamenu {
 background: rgba(255,255,255,0.8);
 max-height: 0;
 opacity: 0;
 overflow: hidden;
 width: 100%;
 position: absolute;
 top: 55px;
 left: 0;
 transition: all .2s ease-in;
 z-index: 999;

}
.megamenu a{
  color:#000;
  font-size: 1rem;
}
.megamenu a:hover{
  color:#FF007F;
}
.megamenu-inner {
 display: flex;
 flex-wrap: wrap;
}

.megamenu-inner li {
 width: calc( (100% / 3) );
 padding: 0;
}

.megamenu-inner a {
 border-left: none;
}

.megamenu-inner-img {
 margin: 50px 0 10px;
}

.megamenu-inner-img img{
 border-radius: 15px;
}

.megamenu-inner-text img {
 margin: 0 5px 0 0;
}

/*プロフィール用CSSコード　開始*/
/* ベース */
.profile-section {
  background: linear-gradient(to bottom, #ffffff, #e0ecff);
  padding: 20px 20px;
  font-family: 'Segoe UI', 'Hiragino Kaku Gothic ProN', sans-serif;
  color: #333;
}

/* コンテナと見出し */
.profile-container {
  max-width: 1100px;
  margin: 0 auto;
}

.profile-title {
  font-size: 2.5rem;
  text-align: center;
  color: #1f3f95;
  font-weight: bold;
  margin-bottom: 10px;
}

.profile-subtitle {
  text-align: center;
  color: #555;
  font-size: 1.2rem;
  margin-bottom: 40px;
}

/* グリッドレイアウト */
.profile-grid {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

@media (min-width: 768px) {
  .profile-grid {
    flex-direction: row;
    align-items: flex-start;
  }
}

/* プロフィール写真 */
.profile-image-wrapper {
  flex: 1;
  border: 4px solid #cfe2ff;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.profile-image{
  width: 100%;
  height: auto;
  display: block;
  margin-bottom:-10px;
}

/* プロフィール情報 */
.profile-info-box {
  flex: 1;
  background-color: #fff;
  border-left: 6px solid #3381ff;
  padding: 20px 25px;
  border-radius: 10px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.05);
}

.info-heading {
  font-size: 1.5rem;
  color: #1a5bd8;
  margin-bottom: 15px;
}

.profile-list {
  list-style: none;
  padding: 0;
  line-height: 1.8;
}

/* 戦績エリア */
.profile-results {
  margin-top: 60px;
}

.results-heading {
  font-size: 2rem;
  color: #1a5bd8;
  margin-bottom: 20px;
  border-bottom: 2px solid #3381ff;
  display: inline-block;
}

.results-box {
  background-color: #fff;
  padding: 25px;
  border-radius: 10px;
  border: 1px solid #ddd;
  box-shadow: 0 4px 10px rgba(0,0,0,0.03);
}

.results-list {
  list-style: none;
  padding: 0;
  line-height: 1.8;
}

.results-list ul {
  padding-left: 1.5em;
  list-style-type: disc;
  margin-bottom:20px;
}


/*プロフィール用CSSコード　終了*/


/*会社情報とお問い合わせだけjustify-content:centerにしたかったので下記のコードを追加　開始*/

.megamenu-inner1 {
 display: flex;
 flex-wrap: wrap;
 justify-content: left;
}

.megamenu-inner1 li {
 width: calc( (100% / 3) );
 padding: 0;
}

.megamenu-inner1 a {
 border-left: none;

}

.megamenu-inner1-img {
 margin: 50px 50px;
}

.megamenu-inner1-img img{
 border-radius: 15px;
 max-width: 150px;
}

.megamenu-inner1-text img {
 margin: 0 5px 0 0;
}
/*会社情報とお問い合わせだけjustify-content:centerにしたかったので下記のコードを追加　終了*/

/*ドロップダウンメニューend*/

/*スライドショースタート*/
#suraido{
  text-align: center;
  margin-top: 25px;
  margin-bottom: -30px;
  width: 100%;
  height: 100%;
}
/*スライドショーEND*/
#movie {
  margin-top: 25px;
  width: 100%;
  overflow: hidden;
  position: relative;
  text-align: center; /* 念のためセンター寄せ */
}

#responsive-video {
  width: 100%; /* あなたの動画の実サイズに合わせる */
  height: auto;
  max-width: 100%;
  position: relative;
}
/*他ページ開始*/
.o-topg img{
  text-align: center;
  margin-top: 25px;
  margin-bottom: 20px;
  width: 100%;
}
.o-flex{
  display: flex;
  justify-content: space-between;
  width: 50%;
}
.o-flex img{
  padding: 0 10px 0 10px;
}
.o-flex3{
  display: flex;
  justify-content: space-between;
  width: 33.3%;
  margin-top: 15px;
}

.san img{
  width: 100%;
  margin-bottom: 25px;
}
.san img:hover{
  filter:opacity(20%);
  transition: all 0.6s ease 0s;
}
/*他ページ終了*/

/*　ハンバーガーボタン　*/
/*メモ　801px以上の時の表示*/
@media screen and (min-width:801px){
  .global-nav{
  	display: none;
  }
  .global-nav-toggle {
  	display: none;
  }
}

/*------------------------レスポンシブstrat-------------------------*/
@media (max-width:800px){
  #top{
    height: 48px;
  }
  #top header{
    margin-top: -5px;
    border: none;
    position: fixed;
    z-index :1;
    width: 100%;
    background-color: #f2f2f2;
  }
  #top img{
    margin: 16px 0 0 -5px;
    height: 42px;
    width: 85px;
  }
  .page-header-right{
    display: none;
  }
  .global-nav-button{
    margin-top: 3px;
  }
  #drmenu{
    display: none;
  }
  .bxslider img{
    min-height: 600px;
    width: 100%;
    object-fit: cover;
  }
  article{
    width: 100%;
  }
  aside{
    display: none;
  }
  .midasi h1{
    font-size: 1.2rem;
  }
  .info-c{
    display: flex;
    flex-direction: column;
  }
  .info-c img{
    width: 100%;
  }
  .flex{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
  }
  .flex-i{
    width: 50%;
  }
  .flex-i3{
    width: 50%;
  }
  .o-flex-i{
    width: 33%;
  }
  .o-flex-i2{
    width: 33%;
  }
  .hyo th{
    width: 35%;
    padding-left: 10px;
  }
  .hyo td{
    width: 65%;
    padding-left: 10px;
  }
  .o-flex3{
    display: flex;
    flex-direction: column;
    width: 100%;
  }
/**ハンバーガーメニュー↓**/
/** グローバルナビリスト (1階層目) */
.global-nav-item-list {
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 100%;
    margin: auto;
    overflow: auto;
    z-index: 100;
    background: rgba(255, 255, 255, 0.95);
    transition: 0.2s all;
}
.global-nav.open .global-nav-item-list {
    left: 0;
}
/** グローバルナビ項目 (1階層目, 2階層目) のリンク */

.global-nav-item a {
    display: flex;
    align-items: center;
    box-sizing: border-box;
    position: relative;
    width: 100%;
    padding: 15px 30px;
    font-size: 18px;
    font-family: 'M PLUS Rounded 1c', sans-serif;
    color: #4f4f4f;
    text-decoration: none;
    transform: rotate(0.05deg);
    transition: 0.2s all;
}
.global-nav-item a:hover {
    background: hsl(200, 100%, 97%);
}
.global-nav-item > a::before,
.global-nav-sub-item-list.open a::before {
    box-sizing: border-box;
    content: "";
    display: block;
    margin-right: 10px;
    width: 10px;
    height: 10px;
    border: solid #FF007F;
    border-width: 0 3px 3px 0;
    transform-origin: center;
    transform: translateX(-25%) rotate(-45deg);
    transition: 0.2s all;
}
.global-nav-item > a.open::before {
    transform: translate(-25%, -2.5px) rotate(45deg);
}
.global-nav-sub-item a {
    padding-left: 45px;
}
/** グローバルナビリスト (2階層目) */
.global-nav-sub-item-list:not(.open),
.global-nav-sub-item-list:not(.open) * {
    overflow: hidden;
    opacity: 0;
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 0;
    border-top-width: 0;
    border-bottom-width: 0;
    color: transparent;
    line-height: 0;
    transition: 0.2s margin, 0.2s padding, 0.2s border-width, 0.2s line-height, 0.2s opacity;
}
.global-nav-sub-item-list.open,
.global-nav-sub-item-list.open * {
    transition: 0.2s margin, 0.2s padding, 0.2s border-width, 0.2s line-height, 0.2s opacity;
}

.global-nav-button {
    box-sizing: border-box;
    position: fixed;
    cursor: pointer;
    z-index: 9999;
    top   : 3px;
    right: 5px;
}

.openbtn{
  position: relative;
  width: 70px;/*50*/
  height: 70px;/*50*/
  border-radius: 5px;
  cursor: pointer;
}

.openbtn span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 2px;
    border-radius: 5px;
  background: #555;
    width: 45%;
  }

.openbtn span:nth-of-type(1) {
  top:13px;
}

.openbtn span:nth-of-type(2) {
  top:23px;/*19*/
}

.openbtn span:nth-of-type(3) {
  top:33px;/*25*/
}

.openbtn span:nth-of-type(3)::after {
  content:"Menu";
  position: absolute;
  top:8px;/*5*/
  left:1px;/*-2*/
  color: #555;
  font-size: 0.6rem;
  text-transform: uppercase;
}

.openbtn.active span:nth-of-type(1) {
    top: 14px;
    left: 14px;/*18*/
    transform: translateY(6px) rotate(-45deg);
    width: 45%;/*30*/
}

.openbtn.active span:nth-of-type(2) {
  opacity: 0;
}

.openbtn.active span:nth-of-type(3){
    top: 26px;
    left: 14px;/*18*/
    transform: translateY(-6px) rotate(45deg);
    width: 45%;/*30*/
}

.openbtn.active span:nth-of-type(3)::after {
  content:"Close";
    transform: translateY(0) rotate(-45deg);
  top:12px;/*5*/
  left:17px;/*4*/
}
/**ハンバーガーメニュー↑**/
/*他ページ開始*/
.o-topg img{
  min-height: 200px;
  width: 100%;
  object-fit: cover;
}
.btn-animation-02 {
  width: 100%;
}
/*他ページ終了*/
.news{
  margin-top: 40px;
}
}
/*レスポンシブEND*/


/* Timeline style */
.timeline-container {
  margin-top: 40px;
  border-left: 4px solid #1f3f95;
  padding-left: 20px;
}

.timeline-year {
  margin-bottom: 40px;
}

.timeline-year h3 {
  font-size: 1.8rem;
  color: #FF007F;
  border-bottom: 1px solid #FF007F;
  padding-bottom: 5px;
  margin-bottom: 15px;
}

.timeline-year ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.timeline-year li {
  margin-bottom: 10px;
  padding-left: 10px;
  position: relative;
}

.timeline-year li::before {
  content: '';
  position: absolute;
  left: -22px;
  top: 7px;
  width: 12px;
  height: 12px;
  background-color: #FF007F;
  border-radius: 50%;
}

.timeline-year .date {
  display: inline-block;
  min-width: 110px;
  color: #666;
  font-weight: bold;
  margin-right: 10px;
}

.timeline-year a {
  color: #000;
  text-decoration: none;
}

.timeline-year a:hover {
  color: #FF007F;
  text-decoration: underline;
}


/* Timeline style - Teamカラー調整済み */
.timeline-container {
  margin-top: 40px;
  border-left: 4px solid #1f3f95;
  padding-left: 20px;
}

.timeline-year {
  margin-bottom: 40px;
}

.timeline-year h3 {
  font-size: 1.8rem;
  color: #1f3f95;
  border-bottom: 1px solid #3381ff;
  padding-bottom: 5px;
  margin-bottom: 15px;
}

.timeline-year ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.timeline-year li {
  margin-bottom: 10px;
  padding-left: 10px;
  position: relative;
}

.timeline-year li::before {
  content: '';
  position: absolute;
  left: -22px;
  top: 7px;
  width: 12px;
  height: 12px;
  background-color: #3381ff;
  border-radius: 50%;
}

.timeline-year .date {
  display: inline-block;
  min-width: 110px;
  color: #494949;
  font-weight: bold;
  margin-right: 10px;
}

.timeline-year a {
  color: #1f3f95;
  text-decoration: none;
  font-weight: bold;
}

.timeline-year a:hover {
  color: #FF007F;
  text-decoration: underline;
}
