/* ===== Company page ===== */
.gnav a.is-active{color:var(--navy);font-weight:700}

/* ===== ごあいさつ hero ===== */
.chero{position:relative;overflow:hidden;background:#fff}
.chero__bg{
  position:absolute;left:0;top:0;bottom:0;width:60%;z-index:0;pointer-events:none;
  background:url("../assets/img/cc-bg-blueprint.png") left top/cover no-repeat;opacity:.5;
}
.chero__media{
  position:absolute;top:0;right:0;bottom:0;width:47%;z-index:1;overflow:hidden;
  background:linear-gradient(150deg,#7ba1d8 0%,#4470ac 52%,#2a5088 100%);
}
.chero__media::after{
  content:"";position:absolute;inset:0;
  background:url("../assets/img/cc-scaffold.png") right bottom/auto 118% no-repeat;
  opacity:.18;mix-blend-mode:screen;
}
.chero__ceo{
  position:absolute;bottom:0;right:220px;height:78%;width:auto;max-width:none;
  object-fit:contain;object-position:bottom;z-index:1;
}
.chero__badges{position:absolute;top:16%;right:26px;z-index:2;display:flex;flex-direction:column;gap:18px}
.cbadge{background:#fff;border-radius:12px;box-shadow:0 12px 30px rgba(12,35,80,.22);padding:16px 22px}
.cbadge img{display:block;height:56px;width:auto}

.chero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:66px 28px 74px}
.chero__body{width:53%;max-width:640px}
.chero__chip{
  display:inline-block;background:var(--navy);color:#fff;
  font-size:15px;font-weight:700;padding:8px 20px;border-radius:6px;letter-spacing:.5px;
}
.chero__title{margin-top:26px;font-size:48px;font-weight:900;color:var(--navy);letter-spacing:2px;line-height:1.3}
.chero__lead{margin-top:26px;font-size:16px;line-height:2;color:var(--text);font-weight:500}
.chero__sign{margin-top:26px;font-family:'Yuji Syuku',serif;font-weight:400;font-size:38px;color:#16294e;letter-spacing:10px}

/* ===== 会社概要 ===== */
.cprofile{background:#f6f8fc;padding:74px 0 80px}
.cprofile__inner{max-width:1160px;margin:0 auto;padding:0 28px}
.cprofile__title{display:flex;align-items:center;justify-content:center;gap:16px;font-size:32px;font-weight:900;color:var(--navy);letter-spacing:2px}
.cprofile__hic{display:inline-flex;width:34px;height:34px}
.cprofile__hic svg{width:100%;height:100%;fill:var(--navy)}
.cdash{width:44px;height:2px;background:#2b5bb5}
.cprofile__table{
  margin-top:40px;background:#fff;border:1px solid #dde4ef;border-radius:8px;overflow:hidden;
  display:grid;grid-template-columns:auto 1fr auto 1fr;
}
.cprofile__label,.cprofile__val{padding:22px 26px;display:flex;align-items:center;font-size:16px}
.cprofile__label{gap:12px;background:#f7f9fc;font-weight:700;color:var(--navy);white-space:nowrap}
.cprofile__label svg{width:22px;height:22px;fill:var(--navy);flex-shrink:0}
.cprofile__val{color:#3a4863;line-height:1.6}
.cprofile__label--r{border-left:1px solid #e7ecf4}
/* row separators (rows 2 and 3) */
.cprofile__table>div:nth-child(n+5){border-top:1px solid #e7ecf4}
.cprofile__note{text-align:center;margin-top:24px;font-size:14px;color:#7c879b}

/* ===== CTA band ===== */
.ccta{position:relative;overflow:hidden;background:linear-gradient(180deg,#eef3fa,#e4ecf6)}
.ccta__bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.22;
  background:url("../assets/img/cc-scaffold.png") right center/auto 150% no-repeat;
}
.ccta__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:40px 40px;display:flex;align-items:center;gap:36px}
.ccta__laptop{width:270px;flex-shrink:0;display:block}
.ccta__laptop img{width:100%;height:auto;display:block}
.ccta__text{flex:1;min-width:0}
.ccta__title{font-size:30px;font-weight:900;color:var(--navy);letter-spacing:1px}
.ccta__lead{margin-top:14px;font-size:16px;line-height:1.8;color:var(--text);font-weight:500}
.ccta__btn{
  flex-shrink:0;display:inline-flex;align-items:center;gap:18px;
  background:var(--navy);color:#fff;height:74px;padding:0 44px;border-radius:8px;
  font-size:21px;font-weight:700;transition:opacity .2s;box-shadow:0 14px 30px rgba(12,35,80,.24);
}
.ccta__btn .arr{font-style:normal;font-size:22px}
.ccta__btn:hover{opacity:.92}

/* ===== responsive ===== */
@media (max-width:1100px){
  .chero__title{font-size:40px}
  .chero__media{width:44%}
  .ccta__laptop{width:220px}
}
@media (max-width:900px){
  .chero__media{position:relative;width:100%;height:400px}
  .chero__ceo{right:16%;height:92%}
  .chero__badges{top:auto;bottom:20px;right:16px;flex-direction:row}
  .cbadge img{height:42px}
  .chero__inner{padding:36px 28px 44px}
  .chero__body{width:100%;max-width:none}
  .chero__bg{width:100%}
  .cprofile__table{grid-template-columns:auto 1fr}
  .cprofile__label--r{border-left:none}
  .cprofile__table>div:nth-child(n+3){border-top:1px solid #e7ecf4}
  .ccta__inner{flex-wrap:wrap;justify-content:center;text-align:center;gap:20px}
  .ccta__laptop{width:200px}
  .ccta__text{flex-basis:100%}
  .ccta__btn{width:100%;justify-content:center}
}
@media (max-width:768px){
  .chero__title{font-size:32px}
  .chero__media{height:320px}
  .chero__chip{font-size:13px;padding:7px 14px}
  .chero__lead{font-size:15px}
  .chero__lead br{display:none}
  .cprofile__title{font-size:24px}
  .cdash{width:26px}
  .cprofile__label,.cprofile__val{padding:16px 16px;font-size:15px}
  .cprofile__label{gap:8px}
  .ccta__title{font-size:24px}
  .ccta__lead br{display:none}
}
@media (max-width:480px){
  .chero__media{height:270px}
  .cprofile__table{grid-template-columns:1fr}
  .cprofile__label{border-top:1px solid #e7ecf4}
  .cprofile__table>div:nth-child(1){border-top:none}
  .cprofile__label--r{border-top:1px solid #e7ecf4}
}

/* ===== Footer (shared with service page) ===== */
.sfooter{background:var(--navy);color:#fff}
.sfooter__inner{max-width:var(--maxw);margin:0 auto;padding:70px 28px 46px;display:grid;grid-template-columns:1.2fr 1fr;gap:48px}
.sfooter__logo{display:flex;align-items:center;gap:16px}
.sfooter__logo img{width:auto;height:104px;object-fit:contain}
.sfooter__name{font-size:23px;font-weight:800;letter-spacing:.5px}
.sfooter__tag{margin-top:22px;font-size:15px;line-height:1.9;color:rgba(255,255,255,.8)}
.sfooter__btn{display:inline-flex;align-items:center;gap:12px;margin-top:28px;background:#fff;color:var(--navy);height:56px;padding:0 32px;border-radius:8px;font-size:17px;font-weight:700;transition:opacity .2s}
.sfooter__btn .arr{font-style:normal;font-size:20px}
.sfooter__btn:hover{opacity:.9}
.sfooter__info{list-style:none;display:flex;flex-direction:column;gap:20px;padding-top:8px}
.sfooter__info li{display:flex;align-items:center;gap:16px;font-size:15px;color:rgba(255,255,255,.9)}
.sfooter__info svg{width:24px;height:24px;fill:#fff;flex-shrink:0;opacity:.95}
.sfooter__info a{color:rgba(255,255,255,.9);transition:opacity .2s}
.sfooter__info a:hover{opacity:.7}
.sfooter__bottom{border-top:1px solid rgba(255,255,255,.16);max-width:var(--maxw);margin:0 auto;padding:26px 28px 40px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.sfooter__nav{display:flex;flex-wrap:wrap;gap:8px 22px}
.sfooter__nav a{font-size:14px;color:rgba(255,255,255,.82);transition:opacity .2s}
.sfooter__nav a:hover{opacity:.6}
.sfooter__copy{font-size:13px;color:rgba(255,255,255,.6)}
@media (max-width:980px){.sfooter__inner{grid-template-columns:1fr;gap:34px}}
@media (max-width:768px){
  .sfooter__inner{padding:52px 22px 36px}
  .sfooter__name{font-size:19px}
  .sfooter__logo img{height:84px}
  .sfooter__bottom{padding:22px 22px 34px;flex-direction:column;align-items:flex-start;gap:16px}
}
@media (max-width:480px){.sfooter__info li{font-size:14px;gap:12px}}

/* Google map link in profile table */
.cprofile__map{color:inherit}
.cprofile__map-ic{color:#2b5bb5;font-weight:700}
.cprofile__map:hover .cprofile__map-ic{text-decoration:underline}
