/* ===============================
header
=============================== */
html{
	padding:0px;
	margin:0px;
   scroll-behavior: smooth;
    overflow-x:hidden;
}
body{
	font-family: "Noto Sans JP", sans-serif;
    padding:0px;
	margin:0px;
    overflow-x:hidden;
}
.site-header{
width:100%;
background:#f5f6f8;
}

.header-inner{
display:flex;
align-items:center;
justify-content:space-between;
height:auto;
}


/* ロゴ */

.header-logo{
width:300px;
display:flex;
align-items:center;
justify-content:center;
}

.header-logo img{
width:70px;
	display:block;
}


/* PCナビ */

.header-nav{
display:flex;
align-items:center;
gap:50px;
margin-left:auto;
padding-right:40px;
}

.nav-list{
display:flex;
gap:50px;
list-style:none;
margin:0;
padding:0;
}

.nav-list li a{
text-decoration:none;
color:#3b4560;
font-weight:700;
font-size:16px;
}
/* CTA */
.header-cta{
	margin-right:20px;
}
.header-contact{
background:#3b4560;
color:#fff;
padding:14px 28px;
border-radius:10px;
text-decoration:none;
font-weight:600;
display:flex;
align-items:center;
gap:10px;
transition:0.5s;
}
.header-contact:hover{
	background:#fff;
color:#3b4560;
}

/* ===============================
ハンバーガー
=============================== */

.hamburger{
display:none;
width:30px;
height:22px;
flex-direction:column;
justify-content:space-between;
cursor:pointer;
  z-index:201;
position: fixed;   /* ←これ追加 */
  top: 20px;         /* 好きな位置 */
  right: 70px;
  z-index: 9999;     /* 最前面 */
}

.hamburger span{
display:block;
height:3px;
background:#3b4560;
border-radius:2px;
}
.nav-list{
display:flex;
gap:50px;
list-style:none;
margin:0;
padding:0;
}

.nav-list li{
list-style:none;
}

.nav-list li a{
text-decoration:none;
color:#3b4560;
font-weight:600;
font-size:16px;
display:block;
}
/* ===============================
SPメニュー
=============================== */

.sp-menu{
position:fixed;
top:0;
right:-100%;
width:260px;
height:100vh;
background:#fff;
padding:80px 30px;
transition:0.4s;
z-index:100;
}

.sp-menu.active{
right:0;
}

.sp-nav{
list-style:none;
padding:0;
margin:0;
}

.sp-nav li{
margin-bottom:25px;
}

.sp-nav a{
text-decoration:none;
color:#3b4560;
font-weight:600;
font-size:18px;
}

.sp-contact{
display:inline-block;
margin-top:30px;
background:#3b4560;
color:#fff;
padding:12px 20px;
border-radius:8px;
text-decoration:none;
}
/* =========================
FV
========================= */

.fv{
  position: relative;
  overflow: hidden;
      height: 90vh;
}

/* 背景画像 */
.fv__bg{
  position: absolute;
  inset: 0;
  background-image: url('../images/fv.jpg');
  background-size: cover;
  background-position: center;
  z-index: 1;
}
/* フィルタ */
.fv__bg::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(34,44,79,0.7);
z-index:1;
}
/* 中身 */
.fv__inner{
  position: relative;
  z-index: 2;
  max-width: 1240px;
  height: 100%;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.fv__inner br{
	display:none;
}
.fv__content{
  width: 65%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-top:100px;
}

/* タイトル */
.fv__title{
  margin: 0;
  color: #fff;
  font-family:
    "Yu Mincho",
    "YuMincho",
    "Hiragino Mincho ProN",
    "Hiragino Mincho Pro",
    serif;
  font-size: 4.1rem;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.06em;
  white-space: nowrap;
}

/* サブコピー */
.fv__text{
  margin: 18px 0 0;
  color: #fff;
  font-family:
    "Yu Mincho",
    "YuMincho",
    "Hiragino Mincho ProN",
    "Hiragino Mincho Pro",
    serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.9;
  letter-spacing: 0.08em;
  white-space: nowrap;
}

/* 追従ボタン */
.floating-contact{
  position: fixed;
  right: 40px;
  bottom: 40px;
	z-index:9999;
  width: 250px;
  height: 74px;
  padding: 0 28px;
  background: #f7f5f2;
  color: #2f3c63;
  text-decoration: none;
  border-radius: 4px;
  box-shadow: 4px 4px 0 rgba(47, 60, 99, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transition:0.5s;
}

.floating-contact:hover{
    background: #2f3c63;
  color: #f7f5f2;
}

.floating-contact__text{
  font-family:
    "Yu Mincho",
    "YuMincho",
    "Hiragino Mincho ProN",
    "Hiragino Mincho Pro",
    serif;
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.06em;
}
.floating-contact__textbr{
	display:none;
}
.floating-contact__arrow{
  font-size: 1.5rem;
  line-height: 1;
}
/* =========================
concept section
========================= */

.concept{
background:#cfd7df;
padding:140px 0;
}

.concept__inner{
max-width:1100px;
margin:0 auto;
padding:0 40px;
}


/* 見出し */

.concept__title{
font-family:
"Yu Mincho",
"YuMincho",
"Hiragino Mincho ProN",
serif;

font-size:28px;
line-height:1.8;
letter-spacing:0.08em;
color:#2f3c63;

margin:0 0 60px 0;
}


/* リスト */

.concept__list{
list-style:none;
padding:0;
margin:0;
width:700px;
}

.concept__list p{
position:relative;
width:700px;
font-size:16px;
line-height:2.2;
letter-spacing:0.05em;
color:#2f3c63;
}
/* =========================
ABOUT
========================= */

.about{
background:#cfd7df;
padding:160px 0;
position:relative;
overflow:hidden;
}

.about__inner{
max-width:1200px;
margin:0 auto;
padding:0 40px;
position:relative;
}

/* 背景ABOUT文字 */

.about__bg{
position:absolute;

left:0;
top:-80px;

font-size:90px;
letter-spacing:0.08em;

color:#ffffff;
opacity:0.18;

z-index:0;

font-family:
"Yu Mincho",
"Hiragino Mincho ProN",
serif;
}

/* 見出し */

.about__head{
position:relative;
margin-bottom:100px;
}

.about__title{
position:relative;
z-index:2;

font-size:24px;
letter-spacing:0.15em;
color:#3b4560;

padding-bottom:12px;
border-bottom:1px solid #3b4560;
}
/* 背景ABOUT */


/* グリッド */

.about__grid{
display:grid;
grid-template-columns:1fr 520px;
gap:80px;
align-items:start;
}


/* キャッチ */

.about__catch{
font-size:36px;
margin-bottom:40px;

font-family:
"Yu Mincho",
"Hiragino Mincho ProN",
serif;

letter-spacing:0.08em;
color:#2f3c63;
}


/* 本文 */

.about__text p{
font-size:15px;
line-height:2;
letter-spacing:0.06em;
margin-bottom:30px;
color:#2f3c63;
}


/* =========================
右画像
========================= */

.about__visual{
position:relative;
height:520px;
}


/* 背景オブジェクト */

.about__bgbox{
position:absolute;
right:-60px;
bottom:-40px;
width:360px;
height:360px;
background:#9aa5ba;
z-index:1;
}


/* 画像 */

.about__img{
position:absolute;
z-index:2;
}

.about__img img{
width:100%;
display:block;
}


/* 上画像 */

.about__img--top{
top:0;
right:0;
width:250px;
}


/* 下画像 */

.about__img--bottom{
bottom:-60px;
right:250px;
width:300px;
}
/* =========================
PROFILE BANNER
========================= */

.profile-banner{
height:600px;

background-image:url("../images/profile-banner.png");
background-size:cover;
background-position:72% center;
background-repeat:no-repeat;
}

/* コンテナ */

.profile-banner__inner{
max-width:1200px;
height:100%;
margin:0 auto;
padding:0 40px 35px;

display:flex;
align-items:flex-end;
}

/* テキスト */

.profile-banner__text{
color:#ffffff;
margin-bottom:40px;
}

.profile-banner__company,
.profile-banner__name{
margin:0;
font-size:20px;
line-height:1.9;
letter-spacing:0.1em;
}

.profile-banner__name{
margin-top:4px;
}
/* =========================
COMPANY
========================= */

.company{
padding:120px 0 140px;
background:#c7d0d8;
}

/* コンテナ */

.company__inner{
max-width:1100px;
margin:0 auto;
padding:0 40px;
}

/* ========================
理念
======================== */

.company__title{
font-size:22px;
font-weight:500;
color:#2f3c63;

display:flex;
align-items:center;
gap:20px;

margin-bottom:40px;
}

.company__title::after{
content:"";
flex:1;
height:1px;
background:#2f3c63;
}

.company__text p{
font-size:14px;
line-height:2;
color:#2f3c63;

margin-bottom:22px;
}

/* ========================
会社概要
======================== */

.company__info{
margin-top:140px;
}

.company__info-title{
font-size:26px;
color:#2f3c63;

margin-bottom:40px;
}

/* テーブル */

.company__table{
border-top:1px dashed #7a8798;
max-width:720px;
}

.company__row{
display:grid;
grid-template-columns:140px 1fr;

padding:18px 0;
border-bottom:1px dashed #9aa6b6;
}

.company__row dt{
font-size:14px;
color:#2f3c63;
}

.company__row dd{
font-size:14px;
color:#2f3c63;
line-height:1.9;
}
/* =========================
THEORY
========================= */

.theory{
background:#3f4d73;
padding:140px 0;
}

/* コンテナ */

.theory__inner{
max-width:1100px;
margin:0 auto;
padding:0 40px;
}

/* ========================
タイトル
======================== */

.theory__head{
position:relative;
margin-bottom:60px;
}

.theory__title{
color:#ffffff;
font-size:24px;

display:flex;
align-items:center;
gap:20px;
}

.theory__title::after{
content:"";
flex:1;
height:1px;
background:#ffffff;
}

/* 背景HOW */

.theory__bg{
position:absolute;
left:0;
top:-80px;

font-size:100px;
color:#ffffff;
opacity:0.08;

letter-spacing:0.1em;
font-family:
"Yu Mincho",
"Hiragino Mincho ProN",
serif;
}


/* ========================
キャッチ
======================== */

.theory__lead{
color:#ffffff;
font-size:20px;
line-height:1.8;

margin-bottom:60px;
}

/* ========================
メイン画像
======================== */

.theory__main{
text-align:center;
margin-bottom:150px;
height:300px;
}

.theory__main img{
width:300px;
height:auto;
display:inline-block;
}

/* ========================
下画像
======================== */

.theory__grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:40px;

}
.theory__item{
	text-align:center;
	width:360px;
    height:300px;
	margin-bottom:100px;
}
.theory__item img{
width:300px;
height:auto;
display:block;
}
/* =========================
FEATURE
========================= */

.feature{
margin-top:120px;
}

/* 各ブロック */

.feature__item{
display:grid;
grid-template-columns:1fr 420px;
gap:30px;
align-items:center;

max-width:1100px;
margin:0 auto 120px;
}

/* テキスト */

.feature__num{
color:#ffffff;
font-size:16px;

border-bottom:1px solid #ffffff;
display:inline-block;

padding-bottom:6px;
margin-bottom:20px;
}

/* タイトル */

.feature__title{
color:#ffffff;
font-size:22px;
line-height:1.6;

margin-bottom:20px;
}

/* 説明 */

.feature__desc{
color:#ffffff;
font-size:14px;
line-height:2;
max-width:520px;
}

/* 画像 */

.feature__img img{
width:100%;
height:auto;
display:block;
}
/* ================================
提供価値
================================ */

.service-value{
background:#d7dee6;
padding:140px 0;
position:relative;
}

.service-value__inner{
width:1100px;
margin:0 auto;
position:relative;
}

/* タイトル */

.service-value__head{
position:relative;
margin-bottom:50px;
}

.service-value__title{
z-index:1;
font-size:26px;
font-weight:500;
letter-spacing:0.1em;
display:inline-block;
padding-right:30px;
position:relative;
}

.service-value__title::after{
content:"";
position:absolute;
left:120px;
top:50%;
width:900px;
height:1px;
background:#9da7b1;
transform:translateY(-50%);
}

/* 背景文字 */

.service-value__bg{
position:absolute;
left:0;
top:-60px;
font-size:80px;
letter-spacing:0.1em;
color:#c8d1da;
font-weight:500;
z-index:0;
font-family:
"Yu Mincho",
"Hiragino Mincho ProN",
serif;
}

/* 見出し */

.service-value__lead{
font-size:16px;
line-height:2;
color:#445068;
margin-bottom:60px;
}

/* ボックス */

.service-value__box{
background:#f2f2f2;
border:1px solid #6f7a87;
border-radius:14px;
padding:30px 40px;
width:900px;
margin:0 auto 70px;
}

/* リスト */

.service-value__list{
list-style:none;
padding:0;
margin:0;
}

.service-value__list li{
font-size:15px;
line-height:2;
margin-bottom:14px;
padding-left:32px;
position:relative;
color:#2f3a4a;
}

/* チェック */

.service-value__list li::before{
content:"✔";
position:absolute;
left:0;
top:2px;
font-size:14px;
color:#2f3a4a;
}

/* 下テキスト */

.service-value__bottom{
text-align:center;
font-size:16px;
line-height:2;
color:#445068;
}
/* ================================
サービス詳細
================================ */

.service-detail{
margin-top:120px;
}

/* 上レイアウト */

.service-detail__top{
display:flex;
align-items:flex-start;
gap:60px;
max-width:1000px;
margin:0 auto;
}

/* 画像 */

.service-detail__img{
width:440px;
}

.service-detail__img img{
width:100%;
display:block;
}

/* テキスト */

.service-detail__content{
flex:1;
}

/* タイトル */

.service-detail__title{
font-size:22px;
font-weight:500;
margin-bottom:20px;
padding-bottom:6px;
border-bottom:1px solid #2f3a4a;
display:inline-block;
}

/* 本文 */

.service-detail__text{
font-size:15px;
line-height:2;
color:#2f3a4a;
}

/* 下テキスト */

.service-detail__bottom{
margin-top:80px;
text-align:center;
font-size:15px;
line-height:2;
color:#2f3a4a;
}
/* ================================
サービスカテゴリ
================================ */

.service-tags{
margin-top:80px;
}

.service-tags__list{
display:flex;
flex-wrap:wrap;
gap:28px;
justify-content:center;
padding:0;
margin:0;
list-style:none;
}

/* ボタン */

.service-tags__item{
background:#384261;
color:#fff;
padding:18px 18px;
border-radius:14px;
font-size:15px;
line-height:1.6;
text-align:center;
min-width:100px;
font-weight:500;
}
/* ================================
お悩みセクション
================================ */

.service-problem{
margin-top:120px;
text-align:center;
}

/* タイトル */

.service-problem__title{
font-size:20px;
color:#2f3a4a;
display:inline-block;
position:relative;
padding-bottom:12px;
}

.service-problem__title::after{
content:"";
position:absolute;
left:0;
right:0;
bottom:0;
margin:auto;
width:180px;
height:1px;
background:#2f3a4a;
}

/* ▼装飾 */

.service-problem__title::before{
content:"";
position:absolute;
bottom:-8px;
left:50%;
transform:translateX(-50%);
width:12px;
height:12px;
background:#d7dee6;
border-left:1px solid #2f3a4a;
border-bottom:1px solid #2f3a4a;
transform:translateX(-50%) rotate(-45deg);
}

/* カード */

.service-problem__cards{
display:flex;
gap:40px;
justify-content:center;
margin-top:60px;
}

/* 個別カード */

.service-problem__card{
background:#f3f3f3;
padding:20px;
border-radius:16px;
width:300px;
box-shadow:0 6px 12px rgba(0,0,0,0.15);
}

/* 画像 */

.service-problem__img{
width:100%;
height:180px;
border-radius:12px;
overflow:hidden;
margin-bottom:14px;

}

.service-problem__img img{
width:100%;
height:100%;
object-fit:cover;
display:block;
}

/* テキスト */

.service-problem__text{
font-size:14px;
line-height:1.8;
color:#2f3a4a;
text-align:left;
}

/* 下矢印 */

.service-problem__arrow{
margin-top:40px;
}

.service-problem__arrow span{
display:block;
width:18px;
height:18px;
border-bottom:4px solid #2f3a4a;
border-right:4px solid #2f3a4a;
transform:rotate(45deg);
margin:6px auto;
animation: arrowFade 2s infinite;
}
@keyframes arrowFade{

0%{
opacity:0.2;
transform:rotate(45deg) translateY(0);
}

50%{
opacity:1;
transform:rotate(45deg) translateY(0);
}

100%{
opacity:0.2;
transform:rotate(45deg) translateY();
}
}
/* ================================
解決セクション
================================ */

.service-solution{
margin-top:120px;
text-align:center;
}

/* リスト */

.service-solution__list{
display:flex;
flex-direction:column;
gap:36px;
align-items:center;
}

/* 各カード */

.service-solution__item{
display:flex;
align-items:center;
gap:30px;
background:linear-gradient(90deg,#4b5575,#6a7393);
color:#fff;
padding:28px 40px;
border-radius:12px;
width:900px;
}

/* 番号 */

.service-solution__num{
font-size:64px;
font-weight:300;
opacity:0.9;
}

/* 縦ライン */

.service-solution__num::after{
content:"";
display:inline-block;
width:1px;
height:60px;
background:#fff;
margin-left:20px;
vertical-align:middle;
}

/* テキスト */

.service-solution__text{
font-size:14px;
line-height:1.8;
text-align:left;
max-width:650px;
}

/* 説明 */

.service-solution__desc{
margin-top:60px;
font-size:14px;
line-height:2;
color:#2f3a4a;
}

/* CTA */
.service-solution__cta{
margin-top:40px;
margin-bottom:60px;
 text-align:center;
}

.service-solution__btn{
display:inline-flex;
align-items:center;
gap:10px;
background:#2f3553;
color:#fff;
padding:14px 30px;
border-radius:6px;
text-decoration:none;
font-size:14px;
transition:0.5s;
}

.service-solution__btn:hover{
background:#fff;
color:#2f3553;
}
/* ===============================
ダークサービスセクション
=============================== */

.service-dark__inner{
max-width:1100px;
margin:auto;
padding:0 20px;
}

/* 行 */

.service-dark__row {
  width: 100%;
  max-width: 1500px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 100px;
  margin-bottom:100px;
}

.service-dark__content {
  width: 46%;
  color: #07194a;
}
.service-dark__row--reverse {
  flex-direction: row-reverse;
}
.service-dark__title {
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0.18em;
  line-height: 1.4;
  margin: 0 0 20px;
}

.service-dark__meta {
  font-family: "Noto Serif JP", serif;
  font-size:20px;
  letter-spacing: 0.16em;
  line-height: 1.8;
  margin: 0 0 20px;
}

.service-dark__text p {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(15px, 1.25vw, 22px);
  letter-spacing: 0.16em;
  line-height: 2.1;
  margin: 0;
}

.service-dark__target {
  margin-top: 50px;
}

.service-dark__target-title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 28px;
  margin-bottom: 30px;
}

.service-dark__target-title span {
  display: block;
  width: 150px;
  height: 1px;
  background: #07194a;
}

.service-dark__target-title p {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(16px, 1.4vw, 24px);
  letter-spacing: 0.18em;
  margin: 0;
  white-space: nowrap;
}

.service-dark__target-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 70px;
  row-gap: 18px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.service-dark__target-list li {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(14px, 1.1vw, 20px);
  letter-spacing: 0.12em;
  line-height: 1.7;
}

.service-dark__target-list li::before {
  content: "・";
  margin-right: 4px;
}

.service-dark__image {
  width: 40%;
}

.service-dark__image img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}
/* =========================
Instagram Section
========================= */

.instagram-section{

padding:120px 0;
background:#d8e0e6;

}

.instagram-inner{

max-width:1100px;
margin:auto;

}

/* 説明テキスト */

.instagram-lead{

font-size:15px;
line-height:1.8;
margin-bottom:60px;

}

/* grid */

.instagram-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:30px;

}

/* card */

.instagram-card{

display:block;
overflow:hidden;

}

/* image */

.instagram-card img{

width:100%;
height:420px;
object-fit:cover;
display:block;
transition:0.3s;

}

/* hover */

.instagram-card:hover img{

transform:scale(1.05);

}

/* button */

.instagram-btn-wrap{

text-align:right;
margin-top:40px;

}

.instagram-btn{

border:1px solid #2e3556;
padding:12px 24px;
text-decoration:none;
color:#2e3556;
display:inline-block;
transition:0.5s;

}
.instagram-btn:hover{
	background:#2e3556;
	color:#fff;
}
/* =========================
BLOG
========================= */

.blog-section{

background:#d8e0e6;
padding:120px 0;

}

.blog-inner{
overflow:hidden;   /* ←これが超重要 */
padding-bottom:20px;
max-width:1100px;
margin:auto;

}

/* タイトル */

.blog-head{

display:flex;
align-items:center;
margin-bottom:60px;

}

.blog-title{
font-family:
"Yu Mincho",
"Hiragino Mincho ProN",
serif;
font-size:26px;
margin-right:30px;

}

.blog-head::after{

content:"";
flex:1;
height:1px;
background:#2e3556;

}

/* grid */

.blog-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:40px;

}
.blog-grid-home{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:40px;

}
/* card */

.blog-card{

text-decoration:none;
color:#000;

}

/* image */

.blog-thumb img{

width:100%;
height:200px;
object-fit:cover;
display:block;

}

/* text */

.blog-text{

margin-top:12px;
font-size:14px;
line-height:1.6;

}

/* more button */

.blog-more-wrap{
text-align:right;
margin-top:60px;

}

.blog-more{
font-family:
"Yu Mincho",
"Hiragino Mincho ProN",
serif;
background:#eee;
padding:12px 26px;
border-radius:12px;
text-decoration:none;
color:#000;
transition:0.5s;

}
.blog-more:hover{
	background:#2e3556;
	color:#fff;
}
/* ======================
CONTACT
====================== */
.cf7-privacy{
  margin-top:60px;
  padding:40px;
  background:#f7f7f7;
  border:1px solid #ddd;
  height:100px;
  overflow-y:scroll;
}

.cf7-privacy h3{
  font-size:18px;
  margin:0 0 30px;
  color:#07194a;
}

.cf7-privacy h4{
  font-size:14px;
  margin:40px 0 16px;
  color:#07194a;
}

.cf7-privacy p,
.cf7-privacy li{
  font-size:12px;
  line-height:2;
  color:#333;
}

.cf7-privacy ul{
  padding-left:20px;
}
.cf7-check{
  margin-top:30px;
}

.cf7-check .wpcf7-list-item{
  margin:0;
}

.cf7-check label{
  display:flex;
  align-items:flex-start;
  gap:16px;

  cursor:pointer;
}

.cf7-check input[type="checkbox"]{
  width:22px;
  height:22px;
  margin-top:2px;
  accent-color:#07194a;
  cursor:pointer;
}

.cf7-check span{
  font-size:16px;
  line-height:1.8;
  color:#222;
}


.contact-page{

background:#d8e0e6;
padding:120px 0;

}

.contact-inner{

max-width:700px;
margin:auto;

}

/* タイトル */

.contact-head{

position:relative;
margin-bottom:30px;

}

.contact-title{
position:relative; 
font-size:26px;
color:#2e3556;
z-index:1;
}

.contact-head{
position:relative;
margin-bottom:30px;
}

/* 背景文字 */
.contact-bg{
z-index:0;
position:absolute;
left:0;
top:-40px;

font-size:80px;
font-weight:700;

color:#cfd7df;



}

.contact-head::after{

content:"";
display:block;
height:1px;
background:#2e3556;
margin-top:10px;

}

/* 説明 */

.contact-lead{

font-size:14px;
line-height:1.8;
margin-bottom:60px;

}

/* フォーム */

.cf7-wrap{

max-width:650px;
margin:auto;

}

.cf7-item{

margin-bottom:30px;

}

.cf7-item label{

display:block;
margin-bottom:6px;
font-size:14px;

}

/* 必須 */

.required{

background:#2e3556;
color:#fff;

font-size:11px;

padding:2px 6px;

margin-left:6px;

}

/* input */

.cf7-wrap input,
.cf7-wrap select,
.cf7-wrap textarea{

width:100%;

padding:12px;

border:1px solid #8a94a3;

background:#eee;

box-sizing:border-box;

}

/* textarea */

.cf7-wrap textarea{

height:180px;

}

/* プライバシー */

.cf7-privacy{

border:1px solid #8a94a3;

padding:20px;

margin-top:30px;

}

/* 送信 */

.cf7-submit{

text-align:center;
margin-top:40px;

}

.cf7-submit input{

background:#2e3556;

color:#fff;

border:none;

padding:14px 40px;

cursor:pointer;

font-size:14px;

}
/* ======================
BLOG LIST
====================== */

.blog-archive{
background:#d8e0e6;
padding:120px 0;
}

.blog-inner{
max-width:1100px;
margin:auto;
}

/* タイトル */

.blog-head{
position:relative;
margin-bottom:60px;
}

.blog-title{
font-size:26px;
color:#2e3556;
position:relative;
z-index:2;
}

.blog-bg{
position:absolute;
left:0;
top:-20px;
font-size:70px;
color:#cfd7df;
z-index:0;
}

/* 線 */
.blog-head::after{
content:"";
display:block;
height:1px;
background:#2e3556;
margin-top:10px;
}

/* グリッド */

.blog-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:60px 40px;
}

/* カード */

.blog-card{
text-decoration:none;
color:#333;
}

/* 画像 */

.blog-thumb img{
width:100%;
height:180px;
object-fit:cover;
}

/* カテゴリ */

.blog-cat{
font-size:12px;
color:#2e3556;
margin-top:10px;
}

/* タイトル */

.blog-card-title{
font-size:16px;
margin-top:6px;
}

/* テキスト */

.blog-text{
font-size:13px;
margin-top:6px;
line-height:1.6;
}
/* ======================
SINGLE PAGE
====================== */

.single-page{
background:#d8e0e6;
padding:120px 0;
}

.single-inner{
max-width:800px;
margin:auto;
}

/* タイトル */
.single-title{
font-size:26px;
color:#2e3556;
}

/* 日付 */
.single-date{
font-size:12px;
margin-top:6px;
}

/* 線 */
.single-line{
height:1px;
background:#999;
margin:10px 0 30px;
}

/* 画像 */
.single-thumb img{
width:100%;
height:auto;
}

/* 本文 */
.single-content{
margin-top:40px;
line-height:1.8;
font-size:14px;
}

/* ボタンエリア */
.single-bottom{
margin-top:60px;
text-align:center;
}

/* 一覧 */
.back-btn{
display:inline-block;
padding:10px 30px;
border:1px solid #2e3556;
color:#2e3556;
text-decoration:none;
margin-bottom:30px;
transition:0.5s;
}
.back-btn:hover{
	color:#fff;
	background:#2e3556
}
/* 前後 */
.post-nav{
display:flex;
justify-content:space-between;
margin-top:20px;
}

.post-nav a{
color:#2e3556;
text-decoration:none;
font-size:14px;
}






/* =========================
footer
========================= */

/* 全体 */
.site-footer{
  color:#2f3c63;
}


/* =========================
CTAエリア
========================= */
.footer-cta{
  background:#1f294d;
  padding:50px 20px 50px;
  position:relative;
  overflow:hidden;
  font-family:
"Yu Mincho",
"YuMincho",
"Hiragino Mincho ProN",
"Hiragino Mincho Pro",
"Times New Roman",
serif;
}

/* うっすらノイズ感を出す */
.footer-cta::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:0.10;
  pointer-events:none;
  background-image:
    radial-gradient(rgba(255,255,255,0.35) 0.8px, transparent 0.8px);
  background-size:6px 6px;
}

.footer-cta__inner{
  max-width:900px;
  margin:0 auto;
  text-align:center;
  position:relative;
  z-index:1;
}

.footer-cta__title-en{
  margin:0;
  color:#ece7df;
  font-family:
"Yu Mincho",
"YuMincho",
"Hiragino Mincho ProN",
"Hiragino Mincho Pro",
"Times New Roman",
serif;
  font-size:35px;
  font-weight:600;
  line-height:1;
  letter-spacing:0.08em;
}

.footer-cta__title-ja{
  margin:14px 0 0;
  color:#ece7df;
  font-size:20px;
  font-weight:500;
  letter-spacing:0.08em;
}

.footer-cta__text{
  margin:30px 0 0;
  color:#ece7df;
  font-size:15px;
  line-height:2.0;
  letter-spacing:0.06em;
}

.footer-cta__btn{
  width:200px;
  min-height:60px;
  margin:30px auto 0;
  background:#f6f4f1;
  border-radius:8px;
  text-decoration:none;
  color:#2f3c63;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-size:16px;
  font-weight:600;
  letter-spacing:0.06em;
  transition:0.5s;
}

.footer-cta__btn:hover{
background:#2f3c63;
color:#f6f4f1;
}

.footer-cta__btn-icon{
  font-size:18px;
  line-height:1;
}


/* =========================
フッター本体
========================= */
.footer-main{
  background:#dbe3ea;
  padding:78px 20px 88px;
}

.footer-main__inner{
  max-width:1140px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:80px;
}


/* 左 */
.footer-info{
  width:340px;
}

.footer-logo{
  width:80px;
  border:1px solid #6d7694;
  background:#f4f4f4;
  display:flex;
  align-items:center;
  justify-content:center;
}

.footer-logo img{
  max-width:100%;
  max-height:100%;
  display:block;
}

.footer-info__text{
  margin:28px 0 0;
  color:#2f3c63;
  font-size:16px;
  line-height:2;
  letter-spacing:0.06em;
}

.footer-sns{
  margin-top:48px;
  display:flex;
  align-items:center;
  gap:14px;
}

.footer-sns__link{
  display:inline-flex;
  width:40px;
  height:40px;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}

.footer-sns__link img{
  width:40px;
  height:40px;
  display:block;
}


/* 右 */
.footer-nav-area{
  width:500px;
  padding-top:4px;
}

.footer-nav{
  display:grid;
  grid-template-columns:1fr 1fr;
  column-gap:40px;
}

.footer-nav__list{
  margin:0;
  padding:0;
  list-style:none;
}
.footer-nav__list br{
	display:none;
}
.footer-nav__list li + li{
  margin-top:38px;
}

.footer-nav__list a{
  text-decoration:none;
  color:#2f3c63;
  font-size:18px;
  font-weight:600;
  letter-spacing:0.06em;
  transition:opacity .3s ease;
}

.footer-nav__list a:hover{
  opacity:.7;
}

.footer-nav-area__btn{
  width:204px;
  height:56px;
  margin-top:54px;
  background:#25345e;
  color:#fff;
  text-decoration:none;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:600;
  letter-spacing:0.06em;
  transition:0.5s;
}

.footer-nav-area__btn:hover{
  background:#fff;
  color:#25345e;
}
.tokutei-fv {
  padding: 180px 20px 100px;
  background: #f7f7f7;
  text-align: center;
}

.tokutei-fv-inner {
  max-width: 1000px;
  margin: 0 auto;
}

.tokutei-fv-sub {
  font-size: 14px;
  letter-spacing: 0.15em;
  color: #888;
  margin-bottom: 16px;
}

.tokutei-fv-title {
  font-size: 42px;
  font-weight: 700;
  line-height: 1.4;
  color: #111;
}

/* ========================================
   CONTENT
======================================== */

.tokutei-content {
  padding: 100px 20px 120px;
}

.tokutei-content-inner {
  max-width: 1000px;
  margin: 0 auto;
}

/* ========================================
   SECTION
======================================== */

.tokutei-section {
  padding: 40px 0;
  border-bottom: 1px solid #e5e5e5;
}

.tokutei-section:first-child {
  border-top: 1px solid #e5e5e5;
}

.tokutei-section h2 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 20px;
  color: #111;
}

.tokutei-section p {
  font-size: 16px;
  line-height: 2;
  color: #444;
}

.tokutei-section ul {
  margin-top: 12px;
  padding-left: 1.2em;
}

.tokutei-section li {
  font-size: 16px;
  line-height: 2;
  color: #444;
}

/* ========================================
   LINK
======================================== */

.tokutei-section a {
  color: #111;
  text-decoration: underline;
  transition: opacity 0.3s;
}

.tokutei-section a:hover {
  opacity: 0.6;
}

/* ===============================
レスポンシブ
=============================== */
@media (max-width: 1300px) {

  .fv__title{
    font-size: 50px;
    line-height: 1.2;
  }
.fv__text{

  font-size: 20px;
}
}
@media (max-width:768px){

.header-nav{
display:none;
}

.hamburger{
display:flex;
z-index:201;
}

.header-logo{
width:200px;
}
	.header-logo img{
		width:70px;
	}
/* ========================
CTAエリア
======================== */

.footer-cta{
padding:60px 20px 70px;
}

.footer-cta__title-en{
font-size:36px;
letter-spacing:0.08em;
}

.footer-cta__title-ja{
font-size:16px;
margin-top:8px;
}

.footer-cta__text{
font-size:14px;
line-height:1.8;
margin-top:30px;
}

.footer-cta__btn{
width:200px;
height:56px;
font-size:16px;
margin-top:35px;
}


/* ========================
フッター本体
======================== */

.footer-main{
padding:50px 20px;
}

.footer-main__inner{
flex-direction:column;
gap:40px;
}


/* 左エリア */

.footer-info{
width:100%;
}

.footer-logo{
width:50px;
}

.footer-info__text{
font-size:14px;
margin-top:20px;
}

.footer-sns{
margin-top:25px;
}


/* 右エリア */

.footer-nav{
grid-template-columns:1fr 1fr;
column-gap:30px;
}

.footer-nav__list li + li{
margin-top:20px;
}

.footer-nav__list a{
font-size:15px;
}

.footer-nav-area__btn{
width:180px;
height:48px;
font-size:15px;
margin-top:30px;
}
	.floating-contact{
right:20px;
bottom:20px;
width:200px;
height:56px;
font-size:14px;
}
	/* ========================
ABOUTセクション
======================== */

.about{
padding:100px 0;
}

/* 見出しエリア */

.about__head{
margin-bottom:60px;
}

/* 思想と立場 */

.about__title{
font-size:18px;
}

/* 背景ABOUT */

.about__bg{
font-size:80px;
top:-40px;
left:0;
opacity:0.15;
}


/* ========================
レイアウト
======================== */

.about__grid{
grid-template-columns:1fr;
gap:60px;
}


/* キャッチコピー */

.about__catch{
font-size:20px;
line-height:1.6;
margin-bottom:30px;
}


/* 本文 */

.about__text p{
font-size:14px;
line-height:1.9;
}


/* ========================
画像エリア
======================== */

.about__visual{
height:auto;
}

/* 上画像 */

.about__img--top{
position:relative;
width:100%;
top:auto;
right:auto;
margin-bottom:20px;
}

/* 下画像 */

.about__img--bottom{
position:relative;
width:80%;
left:0;
bottom:auto;
}

/* 背景オブジェクト */

.about__bgbox{
width:200px;
height:200px;
right:-20px;
bottom:-20px;
}
	.profile-banner{
height:320px;

background-position:70% center;
}

/* コンテナ */

.profile-banner__inner{
padding:0 20px 24px;
}

/* テキスト */

.profile-banner__company,
.profile-banner__name{
font-size:13px;
line-height:1.8;
}
	/* =========================
COMPANY
========================= */

.company{
padding:80px 0;
}

.company__inner{
padding:0 20px;
}


/* 理念タイトル */

.company__title{
font-size:18px;
gap:14px;
margin-bottom:28px;
}

.company__title::after{
height:1px;
}


/* 理念テキスト */

.company__text p{
font-size:13px;
line-height:1.9;
margin-bottom:18px;
}


/* =========================
会社概要
========================= */

.company__info{
margin-top:80px;
}

.company__info-title{
font-size:20px;
margin-bottom:30px;
}


/* テーブル */

.company__table{
max-width:100%;
}

.company__row{
grid-template-columns:100px 1fr;
padding:14px 0;
}

.company__row dt{
font-size:12px;
}

.company__row dd{
font-size:12px;
line-height:1.8;
}
	/* =========================
THEORY
========================= */

.theory{
padding:90px 0;
}

.theory__inner{
padding:0 20px;
}

/* タイトル */

.theory__title{
font-size:18px;
gap:14px;
}

/* 背景HOW */

.theory__bg{
font-size:70px;
top:-20px;
}

/* キャッチ */

.theory__lead{
font-size:16px;
line-height:1.8;
margin-bottom:40px;
}

/* メイン画像 */

.theory__main{
margin-bottom:40px;
}

.theory__main img{
width:100%;
max-width:340px;
}

/* 下画像 */

.theory__grid{
display:none;
}
	.service-value{
padding:80px 20px;
}

.service-value__inner{
width:100%;
}

/* 背景SERVICE */

.service-value__bg{
font-size:64px;
top:-30px;
}

/* タイトル */

.service-value__title{
font-size:20px;
padding-right:0;
}

/* 横ライン消す */

.service-value__title::after{
display:none;
}

/* 見出し */

.service-value__lead{
font-size:14px;
line-height:1.9;
margin-bottom:40px;
}

/* ボックス */

.service-value__box{
width:90%;
padding:22px 20px;
margin:0 auto 40px;
border-radius:10px;
}

/* リスト */

.service-value__list li{
font-size:14px;
line-height:1.8;
padding-left:26px;
}

/* チェック */

.service-value__list li::before{
font-size:12px;
top:3px;
}

/* 下テキスト */

.service-value__bottom{
font-size:14px;
line-height:1.9;
}
	.service-detail{
margin-top:80px;
}

.service-detail__top{
flex-direction:column;
gap:30px;
}

.service-detail__img{
width:100%;
}

.service-detail__title{
font-size:18px;
}

.service-detail__text{
font-size:14px;
line-height:1.9;
}

.service-detail__bottom{
margin-top:40px;
font-size:14px;
text-align:left;
}
	.service-tags{
margin-top:60px;
}

.service-tags__list{
display:grid;
grid-template-columns:1fr 1fr;
gap:16px;
}

.service-tags__item{
font-size:14px;
padding:16px 14px;
border-radius:10px;
}
.service-problem{

margin-top:80px;

}

.service-problem__cards{

flex-direction:column;

gap:26px;

align-items:center;

}

.service-problem__card{

width:90%;

}

.service-problem__img{

height:160px;

}
.service-solution{

margin-top:80px;

}

.service-solution__item{

flex-direction:column;

align-items:flex-start;

width:90%;

gap:14px;

padding:20px;

}

.service-solution__num{

font-size:40px;

}

.service-solution__num::after{

display:none;

}

.service-solution__text{

font-size:14px;

}
	.service-dark{
padding:80px 0;
}

.service-dark__row{
flex-direction:column;
gap:30px;
margin-bottom:70px;
}

.service-dark__row--reverse{
flex-direction:column;
}

.service-dark__image{
width:100%;
height:220px;
}

.service-dark__title{
font-size:22px;
}

.service-dark__text p{
font-size:14px;
}
	.instagram-grid{

grid-template-columns:repeat(2,1fr);
gap:20px;

}

.instagram-card img{

height:240px;

}

.instagram-btn-wrap{

text-align:center;

}
	.blog-grid{
    display:flex;
    overflow-x:auto;
    gap:16px;
    padding-left:20px;   /* ←左右均等にしないのがコツ */
}
  .blog-card{
    flex: 0 0 70%;              /* ← カード幅（ここ調整） */
	scroll-snap-align: start;
  }
	.blog-grid-home{
		grid-template-columns:repeat(2,1fr);
gap:40px;
	}
  /* スクロールバー消す（任意） */
  .blog-grid::-webkit-scrollbar{
    display:none;
  }

.blog-thumb img{

height:160px;

}

.blog-more-wrap{

text-align:center;

}
	/* 全体余白 */
.contact-page{
  padding:80px 0;
}

/* 横余白 */
.contact-inner{
  padding:0 20px;
}

/* タイトル周り */
.contact-head{
  margin-bottom:20px;
}

/* 背景CONTACT */
.contact-bg{
  font-size:48px;
  top:-20px;
}

/* 見出し */
.contact-title{
  font-size:20px;
}

/* 線 */
.contact-head::after{
  margin-top:8px;
}

/* 説明文 */
.contact-lead{
  font-size:13px;
  line-height:1.7;
  margin-bottom:40px;
}

/* フォーム全体 */
.cf7-wrap{
  width:100%;
}

/* 各項目 */
.cf7-item{
  margin-bottom:24px;
}

/* ラベル */
.cf7-item label{
  font-size:13px;
}

/* 必須 */
.required{
  font-size:10px;
  padding:2px 5px;
}

/* 入力欄 */
.cf7-wrap input,
.cf7-wrap select,
.cf7-wrap textarea{
  padding:10px;
  font-size:14px;
}

/* テキストエリア */
.cf7-wrap textarea{
  height:140px;
}

/* プライバシー */
.cf7-privacy{
  padding:16px;
  font-size:12px;
}

/* 送信ボタン */
.cf7-submit input{
  width:100%;
  padding:14px;
  font-size:14px;
}
	
.blog-inner{
padding:20px 20px;
}

.blog-bg{
font-size:60px;
top:-20px;
}

.blog-grid{
grid-template-columns:2 1fr;
gap:30px;
}

.blog-thumb img{
height:160px;
}
	 .single-inner{
padding:0 20px;
}

.single-title{
font-size:20px;
}

.single-content{
font-size:13px;
}

.post-nav{
flex-direction:column;
gap:10px;
text-align:center;
}
/* タイトル */
.fv__title{
  font-size:2rem;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.06em;
  white-space: nowrap;
}

/* サブコピー */
.fv__text{
  margin: 18px 0 0;
  color: #fff;
  font-family:
    "Yu Mincho",
    "YuMincho",
    "Hiragino Mincho ProN",
    "Hiragino Mincho Pro",
    serif;
  font-size: 0.9rem;
  font-weight: 400;
  line-height: 1.9;
  letter-spacing: 0.08em;
  white-space: nowrap;
}
	/* 中身 */
.fv__inner{
  max-width: 700px;
  height: 100%;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  justify-content:center;
}
.fv__inner br{
	display:block;
}
	
.concept__title{
font-size:20px;
line-height:1.8;
letter-spacing:0.08em;
color:#2f3c63;
margin:0 0 0px 0;
}
	.concept__list{
		width:500px;
	}
	.concept__list p{
		font-size:12px;
		width:300px;
	}
.concept__list li{
font-size:14px;
}
	.concept{
		padding-top:60px;
		padding-bottom:60px;
	}
	
  .feature{
    margin-top:80px;
  }

  .feature__item{
    display:block;
    padding:0 20px;
    margin-bottom:80px;
  }

  /* 画像 */
  .feature__img{
    margin-bottom:20px;
  }

  /* テキスト */
  .feature__num{
    font-size:14px;
  }

  .feature__title{
    font-size:18px;
    line-height:1.6;
  }

  .feature__desc{
    font-size:13px;
    line-height:1.8;
  }
	.blog-section{
background:#d8e0e6;
padding:60px 0;
padding-top:0px;

}
	/* 追従ボタン */
.floating-contact{
  position: fixed;
  right: 20px;
  bottom: 40px;
	z-index:9999;
  width: 150px;
  height: 50px;
  padding: 0 10px;
}

	.floating-contact__text br{
		display:block;
	}
.floating-contact__text{
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.floating-contact__arrow{
  font-size: 1.0rem;
  line-height: 1;
}
	.header-cta{
		display:none;
	}
.hamburger span{
  transition: all 0.3s ease;
  transform-origin: center;
}

/* 上 */
.hamburger.active span:nth-child(1){
  transform: translateY(9px) rotate(45deg);
}

/* 真ん中 */
.hamburger.active span:nth-child(2){
  opacity: 0;
}

/* 下 */
.hamburger.active span:nth-child(3){
  transform: translateY(-9px) rotate(-45deg);
}
	.instagram-section{

padding:80px 0;

background:#d8e0e6;

}
	
.instagram-inner{

max-width:300px;
margin:auto;

}

.instagram-lead{

font-size:12px;
line-height:1.8;
margin-bottom:60px;

}
	.service-dark__inner{
  padding:0 20px;
}

/* 行 */
.service-dark__row{
  flex-direction:column;
  gap:40px;
  margin-bottom:80px;
}

/* reverse解除 */
.service-dark__row--reverse{
  flex-direction:column;
}

/* テキスト */
.service-dark__content{
  width:100%;
  margin-top:50px;
}

.service-dark__title{
  font-size:26px;
  letter-spacing:0.12em;
  line-height:1.5;
  margin-bottom:16px;
}

.service-dark__meta{
  font-size:16px;
  letter-spacing:0.08em;
  line-height:1.8;
  margin-bottom:20px;
}

.service-dark__text p{
  font-size:15px;
  line-height:2;
  letter-spacing:0.08em;
}

/* brをSPで自然改行に */
.service-dark__text br{
  display:none;
}

/* 対象 */
.service-dark__target{
  margin-top:40px;
}

.service-dark__target-title{
  gap:14px;
  margin-bottom:24px;
}

.service-dark__target-title span{
  width:60px;
}

.service-dark__target-title p{
  font-size:15px;
  letter-spacing:0.12em;
}

/* リスト */
.service-dark__target-list{
  grid-template-columns:1fr;
  row-gap:12px;
  column-gap:0;
}

.service-dark__target-list li{
  font-size:14px;
  line-height:1.8;
  letter-spacing:0.08em;
}

/* 画像 */
.service-dark__image{
  width:100%;
}

.service-dark__image img{
  aspect-ratio:1 / 1;
  border-radius:4px;

}

/* CTA */
.service-solution__cta{
  margin-top:20px;
  text-align:center;
}

.service-solution__btn{
  width:100%;
  max-width:320px;
  justify-content:center;
  margin-top:50px;
}
.footer-nav__list br{
	display:block;
}
}









/* =========================
   Scroll Fade In
========================= */
/* ===== Scroll Fade In ===== */
.js-fade {
  opacity: 0;
  transform: translateY(10px); /* 保険の微移動（不要なら消してOK） */
  transition: opacity 0.8s ease, transform 0.8s ease;
  will-change: opacity, transform;
}

/* 左から */
.js-fade-left {
  transform: translateX(-40px);
}

/* 右から */
.js-fade-right {
  transform: translateX(40px);
}

/* 表示時 */
.js-fade.is-show {
  opacity: 1;
  transform: translateX(0);
}

/* もし上下の微移動も残したいなら、表示時にこうする
.js-fade.is-show {
  opacity: 1;
  transform: translate(0, 0);
}
*/


/* “遅らせたい要素”用（任意） */
.js-fade.delay-1 { transition-delay: 0.12s; }
.js-fade.delay-2 { transition-delay: 0.24s; }
.js-fade.delay-3 { transition-delay: 0.36s; }
/* WP管理バーをCSS影響から守る */





