@charset "UTF-8";

/*----------------------------------------
企業情報カテゴリページは以下を挿入
----------------------------------------*/ 
/*下層ヘッダー背景グラデ*/
.pages_head { background: #013396;
background: linear-gradient(90deg,rgba(1, 51, 150, 1) 0%, rgba(1, 104, 150, 1) 73%); }

/*サイドメニュー色変*/
.side_nav .side_nav_box { background: #005496; }
.side_nav a { color: #fff; }
.side_nav a:hover { color: #fff; background: #03477d; }
.side_nav a.is-active { color: #005496; background: #d7ebeb; font-weight: 700; font-weight: 700; }

/*----------------------------------------
END 企業情報カテゴリページは以下を共通で挿入 END
----------------------------------------*/ 


:root {
  --blue:#013396; --cyan:#01c6ca; --grad:linear-gradient(90deg,#0a55a5 0%,#0a55a5 35%,#2e7abf 55%,#62c2a1 100%); --grad-card:linear-gradient(90deg,#0b56a6 0%,#104aa2 30%,#1960b6 55%,#3aa8a4 80%,#9ad9a9 100%);
}

.pages_head { margin-bottom: 0;}
section h2 { font-family: var(--font-Mincho-B1); font-weight: 600; color: var(--blue-color); font-size: clamp(14px , 5vw, 30px); margin-bottom: clamp(15px , 5vw, 30px); }
section h2::before { content: attr(data-en); font-family: var(--font-Mincho-B1); font-weight: 600; color: var(--blue-color); font-size: clamp(20px , 5vw, 70px); display: block; }

.intro { position: relative; background-image: url("../img/philosophy/intro_bg.jpg"); background-repeat: no-repeat; background-size: cover; background-position: center bottom; padding: clamp(70px,8vw,180px) 0 clamp(100px,12vw,240px); color: #fff; overflow: hidden; margin-bottom: clamp(60px , 5vw , 120px); }
.intro::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgb(0 134 208 / 48%) 0%, rgb(156 191 221 / 34%) 45%, rgb(0 33 96 / 26%) 100%); pointer-events: none; }
.intro [data-size="w1300"] { margin-left: clamp(5%,6vw,8%); margin-right: auto; position: relative; z-index: 1; }
.intro > [data-size="w1300"] { margin: 0 auto; }
@media (min-width: 981px){
/*  .intro h2,.intro .intro_txt { margin-left: clamp(5%, 6vw, 8%); }*/
  .intro h2 { display: inline-block; }
}
.intro h2 { font-family: var(--font-Mincho-B1); font-weight: 800; line-height: 1.15; letter-spacing: .04em; margin: 0 0 clamp(24px,4vw,40px); font-size: clamp(36px,8vw,70px); color: #fff; }
.intro .intro_txt { max-width: 52rem; font-weight: 500; font-size: clamp(13px,1.6vw,18px); line-height: 2; letter-spacing: .05em; color: #fff; text-shadow: 0 1px 6px rgba(0,0,0,.18); }
.intro .txtbox { font-weight: 500; font-size: clamp(13px,1.6vw,18px); line-height: 2; letter-spacing: .05em; color: #fff; background: #01339678; padding: 35px 50px; box-sizing: border-box; margin-top: clamp(35px,5vw,45px); max-width: 28rem; display: inline-block; }

.message-body { display: flex; align-items: flex-start; gap: clamp(24px,4vw,48px); width: 85%; margin: 0 auto; }
.ceo-image { flex: 0 0 clamp(200px,35%,360px); }
.ceo-image img { display: block; width: 100%; height: auto; }
.message-text { flex: 1; }
.message-text p.ttl { line-height: 1.4; font-family: var(--font-Mincho); font-size: clamp( 14px , 6.5vw , 34px); font-weight: 600; color: var(--blue-color); margin-bottom: 10px; }
.message-text p.txt { line-height: 1.8; }
.message-text p.name { text-align: right; font-family: var(--font-Mincho); font-weight: 700; font-size: clamp(15px, 4vw, 22px); margin-top: clamp(15px, 2vw, 30px); }
.message-text p.name span { display: block; font-size: clamp(12px, 1.5vw, 16px); }


.grid-cards { display: grid; grid-template-columns: repeat(3, minmax(260px, 1fr)); gap: clamp(10px, 3vw, 20px); margin: 130px auto 80px; }
.gcard { position: relative; display: flex; align-items: center; justify-content: space-between; gap: clamp(12px, 3vw, 24px); padding: 23px 30px; color: #fff; text-decoration: none; background: linear-gradient(90deg, #013396 65%, #1960B6 79%, #1e8cb0 87%, #81e56a 100%); background-size: 250% 100%; background-position: 100% 50%; border-radius: 2px; transition: background-position .8s ease, transform .15s ease, box-shadow .4s ease; box-shadow: 0 6px 14px rgba(0,0,0,.08); }
.gcard__label { font-family: var(--font-Mincho-B1, serif); font-weight: 700; font-size: clamp(13px, 2.2vw, 20px); line-height: 1.3; letter-spacing: .05em; }
.gcard__icon { flex-shrink: 0; width: clamp(20px, 4vw, 30px); height: clamp(20px, 4vw, 30px); border-radius: 50%; display: inline-grid; place-items: center; background: #fff; color: #89BC75; transition: background .4s ease, color .4s ease, opacity .4s ease; }
.gcard__icon svg { width: 15px; height: 15px; }

@media (hover: hover) and (pointer: fine) {
  .intro { background-attachment: fixed; }
  .gcard:hover { background-position: 0% 50%; box-shadow: 0 10px 18px rgba(0,0,0,.12); }
  .gcard:hover .gcard__icon { background: rgba(255,255,255,.5); color: var(--blue-color); opacity: .8; }
}

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

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

@media only screen and (max-width: 980px){
    .grid-cards { grid-template-columns: repeat(2, 1fr); }
}

@media only screen and (max-width: 600px){
  .intro { padding: 70px 0 120px; }
  .intro .txtbox { padding: 25px 30px; }
  .message-body { flex-direction: column; gap: 20px; width: 100%;s }
  .ceo-image { flex: none; width: 60%; max-width: 100%; margin: 0 auto; }
  .gcard__icon svg { width: 12px; height: 12px; } 
  .grid-cards { grid-template-columns: 1fr; margin: 80px auto 60px; }
  .gcard { padding: 15px 20px; }
}
