/*
Theme Name: Miraiz Partners
Description: Miraiz Partners original theme
Version: 1.0
*/
/* ---------------------------------
   共通
--------------------------------- */
*, *::before, *::after {box-sizing:border-box;}
html {margin:0; padding:0;}
body {
margin: 0; color: #222; line-height: 1.7; background: #fff;
font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "Meiryo", sans-serif;
}
img {max-width:100%; height:auto; vertical-align:bottom;}
a {color:inherit; text-decoration:none;}
.container {
width: min(1120px, calc(100% - 40px));
margin: 0 auto;
}

/* コンテンツ幅 */
.content-container {
width: min(960px, calc(100% - 40px));
margin: 0 auto;
}

/* front-page */
.fv {
position: relative;
overflow: hidden;
min-height: 700px;
display: flex;
align-items: center;
color: #fff;
}
.fv-bg {
position: absolute;
inset: 0;
z-index: 0;
}
.fv-bg img {
width: 100%;
height: 100%;
object-fit: cover;
}
.fv-overlay {
position: absolute;
inset: 0;
z-index: 1;
background: linear-gradient(
90deg,
rgba(0, 59, 130, 0.82) 0%,
rgba(0, 89, 170, 0.62) 42%,
rgba(0, 89, 170, 0.18) 70%,
rgba(0, 89, 170, 0.05) 100%
);
}
.fv-inner {
position: relative;
z-index: 2;
width: 100%;
}
.fv-content {
max-width: 960px;
padding: 150px 0 50px;
margin:0 auto;
}
.fv-lead {
margin: 0 0 18px;
font-size: 1rem;
font-weight: 700;
letter-spacing: 0.06em;
}
.fv-title {
margin: 0 0 60px;
font-size: clamp(2.2rem, 4.5vw, 4.0rem);
line-height: 1.5;
font-weight: 700;
letter-spacing: 0.02em;
}
.fv-text {
max-width: 720px;
margin: 0 0 60px;
font-size: 1.0625rem;
}
.fv-buttons{
display:flex;
flex-wrap:wrap;
gap:16px;
margin:60px 0;
}
.btn {
display: inline-flex;
justify-content: center;
align-items: center;
min-width: 240px;
min-height: 58px;
padding: 14px 24px;
border-radius: 8px;
font-weight: 700;
transition: 0.3s ease;
}
.btn-primary {
background: #0b4ea2;
color: #fff;
}
.btn-secondary {
border: 1px solid #fff;
color: #fff;
background: rgba(255, 255, 255, 0.08);
}
.points{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:32px;
margin-top:40px;
}
.point li{
position:relative;
padding-left:20px;
margin-bottom:8px;
line-height:1.6;
font-size:0.95rem;
}
.point li::before{
content:"";
position:absolute;
left:0;
top:0.6em;
width:6px;
height:6px;
background:#0b4ea2;
border-radius:50%;
}
.point{
background:#fff;
padding:32px 28px;
border-radius:12px;
box-shadow:0 12px 30px rgba(0,0,0,0.08);
display:flex;
flex-direction:column;
}
.point img{width:55%; display:block; margin:0 auto 30px auto;}
.points ul{
list-style:none;
padding:0;
margin:16px 0;
}
.point h3{
margin:0 0 16px;
font-size:1.25rem;
font-weight:700;
color:#0b4ea2;
line-height:1.4;
}
.point p{
margin:0;
font-size:0.85rem;
line-height:1.7;
color:#333;
}
.appeal {margin-top:90px;}
.top-intro {
padding: 80px 0;
}
.section-head {
margin-bottom: 24px;
}
.section-subtitle {
margin: 0 0 8px;
color: #0b4ea2;
font-weight: 700;
}
.section-title {
margin:0 0 15px 0;
font-size: clamp(1.75rem, 3vw, 2.5rem);
line-height: 1.4;
}
.top-intro-text p {
margin: 0;
font-size: 1rem;
}
.top-problems{
padding:80px 0;
background:#f7f8fb;
}
.problems-layout{
display:grid;
grid-template-columns:280px 1fr;
gap:40px;
align-items:center;
margin-top:40px;
}
.problems-image{
text-align:center;
}
.problems-image img{
max-width:100%;
height:auto;
display:block;
margin:0 auto;
}
.problems-list{
display:flex;
flex-direction:column;
gap:20px;
}
.problem-item{
background:#fff;
border:1px solid #d7dcef;
border-left:6px solid #4d5bd1;
border-radius:8px;
padding:24px 28px;
box-shadow:0 8px 24px rgba(0,0,0,0.04);
}
.problem-item p{
margin:0;
font-size:1.1rem;
font-weight:700;
line-height:1.6;
color:#222;
}
.top-solution{
padding:80px 0;
background:#fff;
text-align:center;
}
.solution-title{
margin:0 0 20px;
font-size:clamp(1.8rem,3vw,2.6rem);
font-weight:700;
color:#0b4ea2;
}
.solution-text{
margin:0 auto 60px;
max-width:720px;
line-height:1.8;
font-size:1rem;
}
.solution-results{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:40px;
}
.result-item{
display:flex;
flex-direction:column;
align-items:center;
}
.result-number{
font-size:3rem;
font-weight:700;
color:#222;
margin-bottom:10px;
}
.result-label{
margin:0 0 6px;
font-weight:700;
}
.result-note{
margin:0;
font-size:0.9rem;
color:#555;
}
/* front-page 【SP】*/
@media screen and (max-width:767px){
	.fv{min-height:640px;	}
	.fv-bg img{
	height:100%;
	object-fit:cover;
	object-position:68% center;
	transform:scale(1.12);
	transform-origin:68% 25%;
	}
	.fv-content{padding:130px 10px 40px;}
	.fv-title{
	font-size:1.9rem;
	line-height:1.45;
	margin-bottom:36px;
	}
	.fv-text{font-size:0.95rem; margin-bottom:32px;}
	.fv-buttons{margin:32px 0 0;}
	.btn {width:100%; min-width:0;}
	.top-intro {padding:56px 0;}
	.points{grid-template-columns:1fr; gap:20px;}
	.point img {width:35%; margin-bottom:15px;}
	.top-problems{padding:56px 0;}
	.problems-layout{
	grid-template-columns:1fr;
	gap:24px;
	}
	.problems-image img{
	max-width:220px;
	}
	.problem-item{
	padding:18px 20px;
	}
	.problem-item p{
	font-size:1rem;
	}
	.solution-results{
	grid-template-columns:1fr;
	gap:30px;
	}

	.result-number{
	font-size:2.4rem;
	}
	.footer-inner {
	flex-direction: column;
	gap: 24px;
	padding: 48px 0 32px;
	}
	.footer-menu {
	justify-content: flex-start;
	gap: 12px 18px;
	}
}

/* * * * * 
 Header 
* * * * */
.site-header{
position:absolute;
top:0;
left:0;
width:100%;
z-index:100;
padding:20px 0;
background:rgba(255,255,255,0.65);
backdrop-filter:blur(6px);
color:#0b4ea2;
}
.header-inner{
display:flex;
align-items:center;
justify-content:space-between;
gap:24px;
}
.site-logo img{
height:48px;
width:auto;
display:block;
}
.global-nav{
margin-left:auto;
}
.global-menu,
.footer-menu{
display:flex;
align-items:center;
gap:28px;
margin:0;
padding:0;
list-style:none;
}
.global-menu li a,
.footer-menu li a{
display:inline-block;
}
.global-menu li a{
font-weight:500;
color:#0b4ea2;
}
.global-menu li a:hover{
opacity:0.7;
}
.menu-toggle{
display:none;
}
/* =========================
PC：グローバルナビ 子メニュー
========================= */
.global-nav li {position:relative;}
.global-nav .sub-menu {
	display:none;
	position:absolute;
	top:100%;
	left:0;
	min-width:260px;
	padding:10px 10px 0 10px;
	margin:0;
	list-style:none;
	background:#fff;
	border-radius:14px;
	box-shadow:0 12px 32px rgba(0,0,0,0.12);
	z-index:100;
}
.global-nav li:hover > .sub-menu {display:block;}
.global-nav .sub-menu li {
	width:100%; margin:0; padding:0; list-style:none; border-bottom: 1px solid #dcdcdc;
}
.global-nav .sub-menu li:last-child {border-bottom:none;}
.global-nav .sub-menu li::before {display:none; content:none;}
.global-nav .sub-menu a {
	display:block;
	padding:10px 18px;
	font-size:0.9rem;
	line-height:1.2;
	color:#0b4ea2;
	text-decoration:none;
	white-space:nowrap;
	transition:background 0.25s ease, color 0.25s ease;
}
.global-nav .sub-menu a:hover {background:#f5f7fa; color:#0b4ea2;}

/* SP Header */
@media screen and (max-width:767px){
	.site-header{padding:14px 0;}
	.header-inner{
	position:relative;
	flex-wrap:nowrap;
	gap:12px;
	}
	.site-logo{width:auto;flex:1;}
	.site-logo img{height:42px;}
	.menu-toggle{
		display:flex;
		flex-direction:column;
		justify-content:center;
		align-items:center;
		gap:6px;
		width:44px;
		height:44px;
		padding:0;
		border:none;
		background:transparent;
		cursor:pointer;
		z-index:102;
	}
	.menu-toggle span{
		display:block;
		width:28px;
		height:2px;
		background:#0b4ea2;
		transition:0.3s;
	}
	.global-nav{
		display:none;
		position:absolute;
		top:calc(100% + 14px);
		left:0;
		right:0;
		width:100%;
		margin-left:0;
		background:#fff;
		border-radius:12px;
		box-shadow:0 12px 30px rgba(0,0,0,0.12);
		overflow:hidden;
		z-index:101;
	}
	.global-nav.is-open{display:block;}
	.global-menu{
	display:flex;
	flex-direction:column;
	align-items:stretch;
	gap:0;
	width:100%;
	}
	.global-menu li{border-bottom:1px solid #e5eaf0;}
	.global-menu li:last-child{border-bottom:none;}
	.global-menu li a{
	display:block;
	padding:14px 18px;
	font-weight:700;
	color:#0b4ea2;
	}
	.menu-toggle.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
	.menu-toggle.is-open span:nth-child(2){opacity:0;}
	.menu-toggle.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}
	
	/* サブメニュー */
	.global-nav .sub-menu {
		display:block;
		position:static;
		min-width:100%;
		background:none;
		border-radius:0;
		box-shadow:none;
		opacity:1;
		padding:0px;
		margin:-15px 0 15px 5px;
		visibility:visible;
		transform:none;
		line-height:1.0;
	}
	/* 子メニューli */
	.global-nav .sub-menu li {margin:0 0 5px 0; padding:0; border:none;}
	/* 子メニューリンク */
	.global-nav .sub-menu a {
		display:block;
		font-size:0.85rem;
		line-height:1.5;
		color:#0b4ea2;
		border:none;
		background:none;
		padding:0px 18px;
	}
	.global-nav .sub-menu li::before {display:none; content:none;}
	.global-nav .sub-menu a {display:flex; align-items:center; gap:10px;}
	.global-nav .sub-menu a::before {
		content:"";
		display:inline-block;
		width:6px;
		height:6px;
		border-top:2px solid #0b4ea2;
		border-right:2px solid #0b4ea2;
		transform:rotate(45deg);
		flex-shrink:0;
	}
	/* 親メニューとの余白 */
	.global-nav .menu-item-has-children > a {margin-bottom:6px;}
	
}

/* =========================
   Header CTA
========================= */
.header-cta{
display:flex;
align-items:center;
gap:16px;
margin-left:24px;
}
.header-contact-btn{
display:inline-flex;
align-items:center;
justify-content:center;
min-height:48px;
padding:0 26px;
border-radius:999px;
background:#0b4ea2;
color:#fff;
font-size:14px;
font-weight:700;
letter-spacing:0.04em;
transition:0.3s;
box-shadow:0 10px 24px rgba(11,78,162,0.18);
}
.header-contact-btn:hover{
transform:translateY(-2px);
background:#083a7a;
box-shadow:0 14px 30px rgba(11,78,162,0.24);
}

/* =========================
   SP
========================= */
@media screen and (max-width:767px){
.header-inner{
align-items:center;
}
.header-cta{
margin-left:auto;
gap:10px;
}
.header-contact-btn{
min-height:40px;
padding:0 16px;
font-size:12px;
white-space:nowrap;
}

}

/* =========================
Privacy
========================= */
.privacy-section {
max-width:900px;
margin:0 auto;
padding:70px 0;
}
.privacy-section p {
font-size:1.0rem;
line-height:2;
margin-bottom:22px;
}
.entry-content .privacy-section h2 {
font-size:1.35rem;
line-height:1.5;
color:#0b4ea2;
margin:42px 0 16px;
padding-bottom:10px;
border-bottom:1px solid #d9e2dc;
}
.privacy-section ul {margin:0 0 28px; padding-left:22px;}
.privacy-section li {font-size:1.0rem; line-height:1.9; margin-bottom:8px;}
/* SP */
@media screen and (max-width:767px) {
	.entry-content .privacy-section {padding:0;}
	.entry-content .privacy-section p {font-size:1.0rem; line-height:1.9; margin-bottom:18px;}
	.entry-content .privacy-section h2 {
	font-size:1.35rem;
	margin:34px 0 14px;
	padding-bottom:8px;
	}
	.entry-content .privacy-section ul {padding-left:20px; margin-bottom:24px;}
	.entry-content .privacy-section ul li {font-size:1.0rem; line-height:1.8;}
}

/* =========================
   Top Cycle
========================= */
.top-cycle {
padding:80px 0;
background:#f7f9fb;
}
.cycle-wrap {
position:relative;
width:min(680px, 100%);
height:560px;
margin:50px auto 0;
}
.cycle-center {
position:absolute;
top:50%;
left:50%;
transform:translate(-50%, -50%);
width:140px;
height:140px;
border-radius:50%;
background:#fff;
border:3px solid #0b4ea2;
display:flex;
align-items:center;
justify-content:center;
box-shadow:0 10px 30px rgba(15, 31, 51, 0.08);
z-index:2;
}
.cycle-center p {
margin:0;
color:#0b4ea2;
font-size:24px;
font-weight:700;
line-height:1.4;
text-align:center;
}
.cycle-item {
position:absolute;
width:180px;
min-height:120px;
padding:25px 18px;
background:#fff;
border:2px solid #d8e2ec;
border-radius:22px;
box-shadow:0 10px 30px rgba(15, 31, 51, 0.08);
text-align:center;
}
.cycle-item span {
display:inline-flex;
align-items:center;
justify-content:center;
width:32px;
height:32px;
margin-bottom:8px;
border-radius:50%;
background:#0b4ea2;
color:#fff;
font-size:14px;
font-weight:700;
}
.cycle-item h3 {
margin:0 0 8px;
font-size:20px;
font-weight:700;
color:#0f1f33;
}
.entry-content .cycle-item p {
margin:0;
font-size:14px;
line-height:1.7;
color:#4f5f70;
}
.cycle-item-01 {top:0; left:50%; transform:translateX(-50%); border-color:#00a6df;}
.cycle-item-02 {top:80px; right:0; border-color:#14b882;}
.cycle-item-03 {bottom:80px; right:0; border-color:#f58220;}
.cycle-item-04 {bottom:0; left:50%; transform:translateX(-50%); border-color:#8b5cf6;}
.cycle-item-05 {bottom:80px; left:0; border-color:#3b82f6;}
.cycle-item-06 {top:80px; left:0; border-color:#64748b;}
.cycle-wrap::before {
content:"";
position:absolute;
top:50%;
left:50%;
transform:translate(-50%, -50%);
width:430px;
height:430px;
border:2px dashed #c8d3df;
border-radius:50%;
z-index:0;
}
.cycle-item {z-index:1;}
.cycle-detail-section {padding:80px 0;background:#fff;}
.cycle-detail-list {
display:grid;
grid-template-columns:repeat(2, 1fr);
gap:30px;
margin-top:50px;
}
.cycle-detail-card {
background:#f8f9fb;
padding:36px 32px;
border-radius:18px;
border:1px solid #dbe3ec;
box-shadow:0 10px 24px rgba(15,31,51,0.05);
}
.cycle-detail-card h3 {
margin:0 0 18px;
font-size:24px;
line-height:1.5;
color:#0f1f33;
}
.cycle-detail-card p {
margin:0;
font-size:15px;
line-height:1.9;
color:#4f5f70;
}
.cycle-detail-card .service-label {
margin:0 0 14px;
font-size:12px;
font-weight:700;
letter-spacing:0.08em;
color:#0b4ea2;
text-transform:uppercase;
}
/* =========================
   Mobile
========================= */
@media screen and (max-width:767px) {
.top-cycle {padding:60px 0;}
.cycle-wrap {
width:100%;
height:auto;
margin:35px auto 0;
display:flex;
flex-direction:column;
gap:16px;
}
.cycle-wrap::before {display:none;}
.cycle-center {
position:relative;
top:auto;
left:auto;
transform:none;
width:100%;
height:auto;
min-height:auto;
padding:18px;
border-radius:18px;
order:0;
}
.cycle-center p {font-size:22px; line-height:1.4;}
.cycle-item {
position:relative;
top:auto;
right:auto;
bottom:auto;
left:auto;
transform:none;
width:100%;
min-height:auto;
padding:18px 18px 18px 72px;
text-align:left;
border-radius:18px;
}
.cycle-item span {
position:absolute;
top:18px;
left:20px;
margin:0;
}
.cycle-item h3 {font-size:18px; margin:0 0 6px;}
.cycle-item p {font-size:14px;}
.cycle-item::after {
content:"";
position:absolute;
left:35px;
bottom:-18px;
width:2px;
height:18px;
background:#c8d3df;
}
.cycle-item:last-child::after {display:none;}
.cycle-detail-section {padding:60px 0;}
.cycle-detail-list {
grid-template-columns:1fr;
gap:20px;
margin-top:35px;
}
.cycle-detail-card {padding:26px 22px; border-radius:16px;}
.cycle-detail-card h3 {font-size:20px; margin-bottom:14px;}
.cycle-detail-card p {font-size:14px; line-height:1.8;}

}

/* =========================
   Country Section
========================= */
.country-section {
padding:80px 0;
background:#f7f9fb;
}

.country-card-list {
display:grid;
grid-template-columns:repeat(3, 1fr);
gap:30px;
margin-top:50px;
}

.country-card {
background:#fff;
padding:36px 30px;
border-radius:18px;
border:1px solid #dbe3ec;
box-shadow:0 10px 24px rgba(15,31,51,0.05);
display:flex;
flex-direction:column;
}

.country-card-main {
border:2px solid #0b4ea2;
}

.country-card .service-label {
margin:0 0 14px;
font-size:12px;
font-weight:700;
letter-spacing:0.08em;
color:#0b4ea2;
text-transform:uppercase;
}

.country-card h3 {
margin:0 0 18px;
font-size:24px;
line-height:1.4;
color:#0f1f33;
}

.country-card p {
margin:0 0 20px;
font-size:15px;
line-height:1.9;
color:#4f5f70;
}

.country-card ul {
list-style:none;
padding:0;
margin:0 0 24px;
}

.country-card li {
position:relative;
padding-left:18px;
margin-bottom:10px;
font-size:14px;
line-height:1.7;
color:#333;
}

.country-card li::before {
content:"";
position:absolute;
top:11px;
left:0;
width:6px;
height:6px;
border-radius:50%;
background:#0b4ea2;
}

.country-job {
margin-top:auto;
padding-top:20px;
border-top:1px solid #dbe3ec;
font-size:13px;
font-weight:700;
color:#0b4ea2;
line-height:1.8;
}

/* =========================
   Mobile
========================= */
@media screen and (max-width:767px) {

.country-section {
padding:60px 0;
}
.country-card-list {
grid-template-columns:1fr;
gap:20px;
margin-top:35px;
}
.country-card {
padding:28px 22px;
border-radius:16px;
}
.country-card h3 {
font-size:21px;
margin-bottom:14px;
}
.country-card p {
font-size:14px;
line-height:1.8;
}
.country-card li {
font-size:14px;
}
.country-job {
padding-top:18px;
font-size:13px;
}

}

/* 固定ページ */
.page-hero{
padding:140px 0 40px;
background:#f7f8fb;
}
.page-title{
position:relative;
margin:0;
padding-left:24px;
font-size:clamp(2rem,4vw,3rem);
font-weight:700;
line-height:1.3;
color:#0b4ea2;
}
.page-title::before{
content:"";
position:absolute;
top:0.15em;
left:0;
width:8px;
height:1.1em;
background:
linear-gradient(
to bottom,
#0b4ea2 0%,
#0b4ea2 50%,
#c6291f 50%,
#c6291f 100%
);
}
.page-content{
background: #f7f9fb;
padding:60px 0 100px;
}
.entry-content{
font-size:1rem;
line-height:1.9;
color:#222;
}
.entry-content h2{
margin:0 0 24px;
font-size:1.75rem;
line-height:1.4;
color:#0b4ea2;
}
.entry-content p {margin:0 0 24px;}
.entry-content ul{
margin:0 0 24px;
padding-left:1.2em;
}
.entry-content li {margin-bottom:10px;}

/* サービス一覧 */
.entry-content .service-section {
padding:80px 40px;
background:#f8f9fb;
}
.entry-content .service-intro {
max-width:1000px;
margin:0 auto 60px;
text-align:center;
}
.entry-content .service-intro h2 {
font-size:30px;
margin:0 0 20px;
color:#0b4ea2;
}
.entry-content .service-intro p {
font-size:1.0rem;
line-height:1.9;
color:#333;
margin:0;
}
.entry-content .service-main {
display:flex;
gap:30px;
max-width:1200px;
margin:0 auto;
align-items:stretch;
}
.entry-content .service-card {
flex:1;
background:#fff;
padding:35px 30px;
border-radius:12px;
box-shadow:0 8px 20px rgba(0,0,0,0.06);
}
.entry-content .service-card-main {
border:3px solid #0b4ea2;
}
.entry-content .service-label {
font-size:12px;
letter-spacing:1px;
color:#0b4ea2;
margin:0 0 12px;
font-weight:bold;
}
.entry-content .service-card h3 {
font-size:20px;
margin:0 0 15px;
color:#111;
}
.entry-content .service-card p {
font-size:14px;
line-height:1.8;
margin:0 0 20px;
color:#444;
}
.entry-content .service-card ul {
margin:0;
padding-left:20px;
}
.entry-content .service-card li {
font-size:14px;
margin-bottom:8px;
color:#555;
}
.entry-content .service-note {
max-width:900px;
margin:50px auto 0;
text-align:center;
}
.entry-content .service-note p {
line-height:1.8;
color:#333;
margin:0;
}
.service-related {margin-top:40px;}
.service-related h3 {font-size:1.5rem; color:#0b4ea2; margin-bottom:14px;}
.service-related > p {
font-size:1.0rem;
line-height:1.9;
margin-bottom:24px;
}
.service-related-list {
margin:0;
padding-left:20px;
}
.service-related-list li {
margin-bottom:12px;
}
.service-related-list li:last-child {
margin-bottom:0;
}
.service-related-list a {
font-size:1.0rem;
line-height:1.8;
color:#0b4ea2;
text-decoration:none;
transition:0.2s ease;
}
.service-related-list a:hover {
text-decoration:underline;
opacity:0.8;
}


/* サービス【SP】 */
@media screen and (max-width:767px) {
	.entry-content .service-section {padding:50px 0;}
	.entry-content .service-intro {margin-bottom:28px;}
	.entry-content .service-intro p {font-size:1.0rem; line-height:1.9;}
	.entry-content .service-main {
		display:grid;
		grid-template-columns:1fr;
		gap:20px;
	}
	.entry-content .service-card {padding:30px 20px; border-radius:16px;}
	.entry-content .service-label {margin-bottom:10px; letter-spacing:0.08em;}
	.entry-content .service-card h3 {
		font-size:1.35rem;
		line-height:1.5;
		margin-bottom:16px;
	}
	.entry-content .service-card p {font-size:1.0rem;line-height:1.9;}
	.entry-content .service-card ul {margin-top:18px; padding-left:18px;}
	.entry-content .service-card li {
		font-size:1.0rem;
		line-height:1.9;
		margin-bottom:0px;
	}
	.entry-content .service-note {
	margin-top:28px;
	padding:22px 20px;
	}
	.entry-content .service-note p {font-size:1.0rem;}
}

/* ---------------------------------
問い合わせ
--------------------------------- */
.contact-form-section {
max-width:800px;
margin:0 auto;
padding:60px 20px;
}
.contact-form-section .wpcf7-form {width:100%;}
.contact-title {
font-size:28px;
text-align:center;
margin-bottom:20px;
color:#0b4ea2;
}
.contact-lead {
text-align:center;
font-size:14px;
line-height:1.8;
margin-bottom:20px;
color:#333;
}
.contact-note {
text-align:center;
font-size:12px;
color:#777;
margin-bottom:30px;
}
.form-item{margin:45px 0px 15px 0px;}
.form-label {
font-size:14px;
font-weight:bold;
margin-bottom:8px;
color:#111;
}
.wpcf7-form-control {
width:100%;
font-size:14px;
padding:12px 14px;
border:1px solid #dcdcdc;
border-radius:6px;
box-sizing:border-box;
background:#fff;
transition:0.2s;
}
.wpcf7-form-control:focus {
border-color:#0b4ea2;
outline:none;
box-shadow:0 0 0 2px rgba(11,78,162,0.1);
}
/* select専用 */
select.wpcf7-form-control {
appearance:none;
background-image:url("data:image/svg+xml;utf8,<svg fill='%23666' height='20' viewBox='0 0 20 20' width='20' xmlns='http://www.w3.org/2000/svg'><path d='M5 7l5 5 5-5z'/></svg>");
background-repeat:no-repeat;
background-position:right 12px center;
background-size:16px;
}
/* ラジオ */
.wpcf7-form-control.wpcf7-radio {
display:flex;
gap:20px;
padding:0;
border:none;
}
.wpcf7-radio label {
display:flex;
align-items:center;
font-size:14px;
gap:6px;
}
/* textarea */
textarea.wpcf7-form-control {
min-height:140px;
resize:vertical;
}
/* 送信ボタン */
.form-submit {
text-align:center;
margin-top:40px;
}
.wpcf7-submit {
background:#0b4ea2;
color:#fff;
font-size:16px;
padding:14px 40px;
border:none;
border-radius:6px;
cursor:pointer;
transition:0.3s;
}
.wpcf7-submit:hover {background:#083a7a;}

/* サービス【SP】 */
@media screen and (max-width:767px) {
	.contact-form-section {padding:0px;}
	.entry-content p {margin-bottom:15px;}
}


/* 強み */
.strength-section {
padding:80px 40px;
background:#fff;
}
.strength-intro {
max-width:1000px;
margin:0 auto 60px;
text-align:center;
}
.strength-intro h2 {
font-size:30px;
margin-bottom:20px;
color:#0b4ea2;
}
.strength-intro p {
font-size:15px;
line-height:1.9;
color:#333;
}
.strength-list {
display:grid;
grid-template-columns:repeat(3, 1fr);
gap:30px;
max-width:1200px;
margin:0 auto;
}
.strength-card {
position:relative;
background:#f8f9fb;
padding:36px 30px 34px;
border-radius:12px;
border:1px solid #e5eaf0;
box-shadow:0 8px 20px rgba(0,0,0,0.04);
}
.strength-number {
display:inline-block;
font-size:30px;
font-weight:bold;
letter-spacing:1px;
color:#0b4ea2;
margin-bottom:14px;
}
.strength-card h3 {
font-size:20px;
line-height:1.5;
margin-bottom:14px;
color:#111;
}
.strength-card p {
font-size:14px;
line-height:1.8;
color:#444;
margin:0;
}
/* 強み【SP】 */
@media screen and (max-width:767px) {
	.strength-section {padding:50px 15px;}
	.strength-intro {margin-bottom:28px;}
	.strength-intro p {font-size:1.0rem;line-height:1.9;}
	.strength-list {
	display:grid;
	grid-template-columns:1fr;
	gap:20px;
	}
	.strength-card {padding:24px 20px;}
	.strength-number {font-size:1.8rem; margin-top:5px; margin-bottom:0px; line-height:1;}
	.strength-card h3 {font-size:1.35rem;}
	.strength-card p {font-size:1.0rem;}
}

/* 導入実績 */
.intro {margin:0;}
.case-heading {
margin: 0 0 28px;
font-size: 1.9rem;
line-height: 1.4;
color: #0b4ea2;
}
.case-list {
display: grid;
grid-template-columns: 1fr;
gap: 28px;
margin: 0 0 70px;
}
.case-item {
padding: 32px 36px;
border: 1px solid #d8dce3;
border-radius: 12px;
background: #fff;
box-shadow: 0 10px 28px rgba(0,0,0,0.05);
}
.case-title {
margin: 0 0 24px;
font-size: 1.35rem;
line-height: 1.5;
font-weight: 700;
}
.case-category {
display: inline-block;
margin-right: 14px;
padding: 5px 14px;
border-radius: 999px;
background: #0b4ea2;
color: #fff;
font-size: 0.9rem;
font-weight: 700;
vertical-align: middle;
}
.case-body dl {
display: grid;
grid-template-columns: 110px 1fr;
gap: 14px 20px;
margin: 0;
}
.case-body dt {
margin: 0;
font-weight: 700;
color: #0b4ea2;
}
.case-body dd {margin:0; line-height:1.8;}
.country-list {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 20px;
}
.country-item {
padding: 24px 22px;
border-top: 5px solid #0b4ea2;
background: #f5f8fc;
}
.country-name {
margin: 0 0 10px;
font-size: 1.15rem;
color: #0b4ea2;
}
.country-feature {
margin: 0;
line-height: 1.8;
font-size: 0.95rem;
}

/* =========================
導入事例 【SP】
========================= */
@media screen and (max-width:767px) {
	.case-body dl {
		display:grid;
		grid-template-columns:5em 1fr;
		gap:12px 16px;
	}
	.country-list {
		display:grid;
		grid-template-columns:1fr;
		gap:18px;
	}
	.entry-content .case-body {font-size:0.95rem;}
	.case-item {padding:20px;}
	.country-item {padding:20px 0px; border-top: 3px solid #0b4ea2;}
	.entry-content .country-item .country-feature {margin-bottom:0;}
	.country-name {font-size:1.35rem; margin-bottom:10px;}
	.country-feature {font-size:1.0rem; line-height:1.8;}
	.case-detail {display:block; margin-top:15px;}
}

/* 会社概要 */
.company-profile {padding:0;}
.company-table{
	border-top:1px solid #d9e2dc;
	border-left:1px solid #d9e2dc;
}
.company-row {display:grid; grid-template-columns:220px 1fr;}
.company-head{
padding:24px 28px;
background:#0b4ea2;
color:#fff;
font-weight:700;
border-right:1px solid #d9e2dc;
border-bottom:1px solid #d9e2dc;
}
.company-data{
padding:24px 28px;
background:#fff;
border-right:1px solid #d9e2dc;
border-bottom:1px solid #d9e2dc;
line-height:1.9;
}
.company-data a{
color:#0b4ea2;
text-decoration:underline;
word-break:break-all;
}

/* 料金 */
.price-table {
width: 100%;
border-collapse: collapse;
margin: 30px 0;
font-size: 1.0rem;
}
.price-table th,
.price-table td {
border: 1px solid #d8dce3;
padding: 16px 18px;
text-align: left;
vertical-align: top;
}
.price-table th {
background: #0b4ea2;
color: #fff;
font-weight: 600;
}
.price-table td span {display:inline-block; margin-left:5px; font-size:0.85rem; font-weight:400;}
.price-table td:first-child {
font-weight: 600;
color: #0b4ea2;
white-space: nowrap;
}
.price-table td:nth-child(2) {font-weight:700; white-space:nowrap;}
.price-table tbody tr:nth-child(even) {background:#f5f8fc;}
.price-summary {margin: 40px 0;}
.price-summary h3 {
font-size: 2.2rem;
margin-bottom: 15px;
color: #0b4ea2;
}
.price-summary p {
margin-bottom: 10px;
line-height: 1.8;
}
.monthly-support {
margin: 40px 0;
padding: 25px;
border: 1px solid #d8dce3;
background: #f5f8fc;
}
.monthly-support h3 {
font-size: 2.2rem;
margin-bottom: 15px;
color: #0b4ea2;
}
.monthly-support-price {font-weight: 700;}
.monthly-support p {
margin-bottom: 15px;
line-height: 1.8;
}
.monthly-support ul {
padding-left: 20px;
}
.monthly-support li {
margin-bottom: 8px;
list-style: disc;
}

/* 料金 【SP】 */
@media screen and (max-width: 767px) {
	.price-table {font-size:1.0rem; margin-top:0px;}
	.price-table th,
	.price-table td {
	padding:12px 10px; vertical-align:middle;
	}
	.price-table td span {margin-left:0px;}
	.price-table td:first-child,
	.price-table td:nth-child(2) {
	white-space: normal;
	}
}


/* Footer */
.site-footer {background: #0b4ea2; color: #fff;}
.footer-inner {padding:60px 0;}
.footer-logo a {
display: inline-block;
margin-bottom: 16px;
font-size: 1.375rem;
font-weight: 700;
}
.footer-text {
margin: 0;
color: rgba(255, 255, 255, 0.8);
}
.footer-nav {
display: flex;
align-items: flex-start;
}
.footer-menu {
flex-wrap: wrap;
justify-content: flex-end;
gap: 16px 24px;
}
.copyright {
margin:30px 0 0 0; font-size: 0.875rem; text-align:center;
color: rgba(255, 255, 255, 0.7);
}

/* SP */
@media screen and (max-width: 767px) {
/* 会社概要 */
	.company-row {grid-template-columns:1fr;}
	.company-head ,.company-data {padding:18px 20px;}
	.company-head {border-right:none;}
	.page-hero {padding:110px 0 32px;}
	.page-content {padding:40px 0 72px;}
}