/*customcss*/
/*sub-head-共通*/
.sub-head {
    width: 100vw;
	margin: 5vh 0 0;
}
.sub-head h2 {
	margin: 0;
}
img.subhedimg {
    display: block;
    width: 100%;
}

/*bg*/
.gray-bg-wrapper {
	background-color: #efefef;
	padding: 4vh 0;
}

/*top*/
.int-top-cntn {
    width: 88vw;
    margin: 100px auto 0;
    max-width: 1400px;
}

h3.intprof-h-title {
    margin: 0;
    padding: 0 0 0 4vw;
    color: #fff;
	font-size: clamp(18px, 1.5vw, 26px);
    /*font-size: 1.5vw;*/
}




.intprofhed {
    width: 100%;
    background-color: #022c4f;
    border-top-left-radius: 30px;
    border-top-right-radius: 30px;
    padding: 4vw 0;
    position: relative;
    overflow: hidden;
}


#fpintroduction .intprofhed{
	    padding: 2vw 0;
}

span.intprof-h-title-backfont {
    font-size: 10vw;
	font-family: "Oswald", sans-serif;
	font-weight: 450;
    color: #fff;
    opacity: 0.1;
    position: absolute;
    top: 60%;
    left: -10px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.int-prof-main {
    background-color: #fff;
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
    padding: 3vw 4vw;
    display: flex;
/*    align-items: center;*/
    justify-content: center;
    gap: 3vw;
}

.intprof-main-left {
    display: block;
    width: 30vw;
	max-width: 500px;
	overflow: hidden;
	border-radius: 12px;
}
.intprof-main-left img{
    opacity: 1;
    transition: all .4s;
    max-width: 100%;
    height: auto;
    min-width: 100%;
	object-fit: cover;
	min-height: 100%;

}


.intprof-main-right {
    width: 40vw;
	display: flex;
    flex-direction: column;
    justify-content: flex-start;
}
dl.intprof-career {
    margin: 0;
}
.intprof-career dt {
    margin: 0;
	font-size: clamp(18px, 1.2vw, 20px);
    /*font-size: 1.2vw;*/
    /* font-weight: bold; */
}
.intprof-career dd {
	margin: 0;
	font-size: clamp(18px, 1vw, 18px);
	/*font-size: 1vw;*/
}
dl.intprof-name {
    margin: 0;
    display: flex;
    align-items: center;
	padding: 0 0 4vw;
}
.intprof-name dt {
    margin: 0;
	font-size: clamp(18px, 3vw, 50px);
    /*font-size: 3vw;*/
}
.intprof-name dd {
    margin: 0;
	font-size: clamp(18px, 1.2vw, 22px);
    /*font-size: 1.2vw;*/
    padding-left: 2vw;
}

p.p-qualif {
    margin: 0 0 0.5vw;
	font-size: clamp(18px, 1.2vw, 22px);
    /*font-size: 1.2vw;*/
    padding-left: 2vw;
	position: relative;
}
p.p-qualif::before {
	display: block;
	content: "";
	width: 5px;
	height: 2vw;
	max-height: 30px;
	background-color: #757575;
	border-radius: 50px;
	position: absolute;
	top: 50%;
    left: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

span.int-cp {
	font-size: clamp(18px, 1.3vw, 20px);
    /*font-size: 1.3vw;*/
}
.intprof-cp {
    padding-left: 2vw;
	position: relative;
	margin: 1vw 0;
}
.intprof-cp::before {
    display: block;
    content: "";
    width: 2vw;
    height: 2vw;
	max-width: 35px;
    background-image: url(http://fp-collab.com/new-site/wp-content/uploads/2025/08/icon-catchphrase.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    position: absolute;
    top: 50%;
    left: -10px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

ul.consultation-terms {
    display: flex;
    flex-wrap: wrap;
    gap: 1vw;
}
.consultation-terms li {
    list-style: none;
    width: 18%;
    background-color: #022c4f;
    color: #fff;
    text-align: center;
	font-size: clamp(16px, 0.9vw, 18px);
    /*font-size: 0.9vw;*/
	padding: 3px 5px;
    border-radius: 3px;
}

/*gs-contents*/
.int-gs-container {
    width: 88vw;
    margin: 4vw auto;
    max-width: 1400px;
}
.int-gs-main {
	background-color: #fff;
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
    padding: 3vw 4vw;
}
.intgsmain-box p {
	margin: 0;
	font-size: clamp(16px, 1vw, 20px);
}

/*intro-contact*/
.int-con-cntn {
    position: relative;
}
.int-con-cntn::after {
	display: block;
	content: "";
	width: 100vw;
	height: 1.5px;
	background-color: #000;
	position: absolute;
	top: 45%;
	left: 0;
}
.intcon-inner {
    width: 88vw;
    margin: 0 auto;
    max-width: 1400px;
    padding: 4vw 0;
    display: flex;
    align-items: flex-start;
	justify-content: space-between;
}
h3.int-c-h {
    margin: 0;
    font-size: clamp(18px, 2.6vw, 40px);
	/*position: relative;*/
}
/*h3.int-c-h::after {
	display: block;
	content: "";
	width: 5px;
	height: auto;
	background-color: #000;
	position: absolute;
	top: 0;
	left: 0;
}*/
dl.int-c-c {
    margin: 0;
    display: flex;
	align-items: center;
}
.int-c-c dt {
    margin: 0;
    width: clamp(5px, 3vw, 50px);
}
.int-c-c dt img {
	display: block;
	width: 100%;
}
.int-c-c dd {
	margin: 0;
	padding-left: 2vw;
}
.int-c-c dd {
	margin: 0;
	font-size: clamp(18px, 2vw, 30px);
	font-weight: bold;
}
p.int-c-text {
    font-size: clamp(18px, 1.2vw, 22px);
    padding: 0 2vw;
}
.int-c-dl-flex {
    display: flex;
    gap: 3vw;
    padding: 2vw 2vw;
	align-items: center;
}
.int-c-cntn {
    padding-left: clamp(10px, 8vw, 120px);
	position: relative;
}
.int-c-cntn::after {
	display: block;
	content: "";
	width: 5px;
	height: 100%;
	background-color: #000;
	position: absolute;
	top: 0;
	left: 0;
}



#fpintroduction .int-c-cntn a{
	color: #022c4f;
}


#fpintroduction .int-c-cntn a:hover{
	color: #000;
}

/*fplist-loop-contents*/

.fplist-loop-cntn {
  margin: clamp(50px, 12vh, 180px) 0;
}


ul.fplist-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: clamp(12px, 2vw, 32px);
  width: 88vw;
  margin: 0 auto;
  max-width: 1600px;
}

li.fplist-item {
  width: calc((100% - (clamp(12px, 2vw, 32px) * 3)) / 4);
  list-style: none;
}

.fpli_thumbnail{
	border-radius: 10px;
	overflow: hidden;
	background: #fff;
	transition: all .4s;
		display: flex;
}


.fpli_loop_inner {
    position: relative;
	overflow: hidden;

	
}

.fpli_loop_inner:hover .fpli_thumbnail{
	background: #022c4f;
}


.fpli_loop_inner .fpli_thumbnail img{
    opacity: 1;
    transition: all .4s;
    max-width: 100%;
    height: auto;
    min-width: 100%;
	object-fit: cover;
}

.fpli_loop_inner:hover .fpli_thumbnail img{
	opacity: 0.8;
}




.fpli_name {
  background-color: #fff;
  position: absolute;
  bottom: -1px;
  width: 68%; /* li.fplist-item に合わせる */
  border-top-right-radius: clamp(6px, 0.8vw, 12px);

}



dl.fpliname-dl {
  margin: clamp(0.5em, 1.2vw, 1.5em) 0 clamp(0.5em, 1.2vw, 1.5em) clamp(1vw, 1.2vw, 2vw);
  color: #000;
}

.fpliname-dl dt {
  font-size: clamp(14px, 1.5vw, 24px);
  color: #022c4f;
}

.fpliname-dl dd {
  margin: 0;
  padding: 0;
  font-size: clamp(12px, 1vw, 18px);
}

div#fpli_loop_bottom {
  margin-top: clamp(8px, 1vw, 16px);
  color: #000;	
   display: flex;
   flex-direction: column;
}

.fpli-tel {
  padding-left: clamp(10px, 1vw, 24px);
  position: relative;
  margin: 0;
  color: #000;	
  margin-bottom: 4px;	
}

.fpli-tel::before {
  display: block;
  content: "";
  width: 4px;
  height: clamp(14px, 2.5vh, 24px);
  background-color: #757575;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
	    border-radius: 10px;
}

.fpli-mail {
  padding-left: clamp(10px, 1vw, 24px);
  position: relative;
  margin: clamp(6px, 0.6vw, 12px) 0 0;
  color: #000;	
}

.fpli-mail::before {
  display: block;
  content: "";
  width: 4px;
  height: clamp(14px, 2.5vh, 24px);
  background-color: #757575;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  border-radius: 10px;
}

.fpli-tug {
  margin-top: clamp(8px, 0.9vw, 16px);
}

ul.fpli-consultation-terms {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(8px, 1.2vw, 20px);
}

.fpli-consultation-terms li {
  list-style: none;
  width: clamp(70px, 4vw, 120px);
  text-align: center;
  padding: clamp(4px, 0.5vw, 10px) clamp(8px, 1vw, 16px);
  color: #fff;
  background-color: #022c4f;
  border-radius: clamp(4px, 0.4vw, 8px);
  font-size: clamp(12px, 0.8vw, 16px);
}


.fpli_thumbnail {
    width: clamp(200px, 100%, 350px);
}

/*fplist-search-cp*/

.fplist-cp {
    width: 60vw;
    margin: 6vw auto 0;
}
p.fpli-cp01 {
    font-size: 2vw;
    text-align: left;
	margin: 0;
}
p.fpli-cp02 {
    font-size: 2vw;
    text-align: right;
    position: relative;
    margin: 0.5vw 0 5vw;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 15px;
}
p.fpli-cp02::before {
    display: block;
    content: "";
    width: 8vw;
    height: 2px;
    background-color: #000;
/*    position: absolute;
    top: 50%;
    left: 18vw;
    transform: translateY(-50%);*/
}

/*fplist-search-bar*/
.fplist-search {
    /*position: relative;*/
}
.search-form {
    display: flex;
    justify-content: center;
	gap: 0.5vw;
}
button.search-button {
    width: clamp(24px, 3vw, 48px);
    background-color: inherit;
    border: none;
    /*position: absolute;
    top: 13px;*/
}
img.fpli-s-icon {
    display: block;
    width: 100%;
}
select#area {
	width: 20vw;
    padding: 0.5vw;
    /*margin: 1vw;*/
    border: solid 2px #022c4f;
    border-radius: 4px;
	font-size: clamp(14px, 1vw, 20px);
}
select#consultation, select#company{
	width: 20vw;
	padding: 0.5vw;
    /*margin: 1vw;*/
    border: solid 2px #022c4f;
    border-radius: 4px;
	font-size: clamp(14px, 1vw, 20px);
}
input#s {
	width: 20vw;
	padding: 0.5vw;
    /*margin: 1vw;*/
    border: solid 2px #022c4f;
    border-radius: 4px;
	font-size: clamp(14px, 1vw, 20px);
}



/*faq-contents*/

img.faqsubhedimg {
    display: flex;
    width: 100vw;
}

.faq-p-bg {
    margin-top: 5vw;
}

.faq-p-cntn-h {
    position: relative;
}


span.faqph-border {
    display: block;
    content: "";
    width: 100vw;
    height: 1px;
    background-color: #a3a3a3;
	position: relative;
	margin-bottom: 3vw;
}
span.faqph-border::before {
    display: block;
    content: "";
    width: 13vw;
    height: 5px;
    background-color: #022c4f;
    position: absolute;
    top: 50%;
    left: 15vw;
}

h4.qap-pageSubTitle2 {
    font-size: clamp(14px, 1.3vw, 20px);
    font-weight: lighter;
    margin: 1vw;
}
/*.pageSubTitle2 {
    font-size: 1.5vw;
    line-height: 1.7;
    font-weight: 400;
    font-style: normal;
    color: #4D4D4D;
    margin: 0;
}*/

h3.faqhp3 {
    padding-left: 10vw;
    font-size: clamp(22px, 1.55vw, 24px);
    line-height: 5;
    margin: 3vw 0;
}
span.faqp-backfont {
    font-size: 5vw;
    font-weight: bold;
    opacity: 0.1;
    position: absolute;
    top: 50%;
    left: 15vw;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
		font-family: "Oswald", sans-serif;
}


.admin span.faqp-backfont {
	    font-size: 2.55vw;
	
}
	
.faq-pp-tab {
    width: 95vw;
    margin: 0 auto;
	padding-bottom: 5vw;
}

.faqp-child.is-open {
    background-color: #022c4f;
/*	width: clamp(280px, 50vw, 800px);
*/    margin-left: auto;
    margin-right: auto;
}
p.faqtext {
    color: #fff;
   font-size: clamp(12px, 1vw, 18px);
}

/*
.bordertext {
    position: relative;
}
p.faqMessage {
    position: absolute;
    top: -8vw;
    left: 40vw;
    -ms-transform: translateX(-50%);
}*/


.qqbox > dl > dt {
    background-color: transparent;
    display: flex;
    align-items: center;
    padding: 10px 30px;
    position: relative;
    border-bottom: solid 2px #fff;
    margin: 0 auto;
}




/*company-contents*/

.coint-top-cntn {
    width: 88vw;
    margin: 5.5vw auto 6vw;
    max-width: 1400px;
}

.cointhed {
    width: 100%;
    background-color: #022c4f;
    border-top-left-radius: 30px;
    border-top-right-radius: 30px;
    padding: 2vw 0;
    position: relative;
    overflow: hidden;
}
h3.coint-h-title {
    margin: 0;
    padding: 0 0 0 4vw;
    color: #fff;
    font-size: clamp(18px, 1.5vw, 26px);
}

span.coint-h-title-backfont {
    font-size: 10vw;
    font-family: "Oswald", sans-serif;
    font-weight: 450;
    color: #fff;
    opacity: 0.1;
    position: absolute;
    top: 60%;
    left: -10px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}


.coint-main {
    border: solid 3px #000;
    box-sizing: border-box;
	padding: 4vw;
}

.coint-top {
    display: flex;.coint-top-left
    align-items: center;
    padding-bottom: 3vw;
    border-bottom: solid 1.5px #a3a3a3;
	gap: 2%;
}

.coint-top-left {
    aspect-ratio: 3 / 2;
    width: 30%;
    overflow: hidden;
    padding: 0.5vw;
    position: relative;
    border-radius: 3px;
    box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.5), inset 0px -3px 6px -2px rgba(0, 0, 0, 0.3);
    border: solid 1px #000;
}
.coint-top-left img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.coint-top-right {
    width: 68%;
	padding-left: 2vw;
}
h3.co-name {
    margin: clamp(16px, 3vw, 48px) 0 0.5vw;
    font-size: clamp(20px, 2.3vw, 30px);
}

p.co-sug {
    margin: 0;
    position: relative;
    font-size: clamp(14px, 1.3vw, 19px);
    padding-left: clamp(20px, 3vw, 30px);
}
p.co-sug::before {
	display: block;
    content: "";
    width: clamp(20px, 2.2vw, 30px);
    height: clamp(20px, 2.2vw, 30px);
    max-width: 35px;
    background-image: url(http://fp-collab.com/new-site/wp-content/uploads/2025/08/icon-suggest.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    position: absolute;
    top: 50%;
    left: -10px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

dl.co-address {
    margin: 0;
	font-size: clamp(14px, 1.2vw, 18px);
	padding-bottom: clamp(0.5px, 0.5vw, 3.5px);
}
.co-address dt {
	margin: 0;
}
.co-address dd {
	margin: 0;
}

dl.co-time {
    margin: 0;
    display: flex;
	font-size: clamp(14px, 1.2vw, 18px);
	padding-bottom: clamp(0.5px, 0.5vw, 3.5px);
}
.co-time dt {
	margin: 0;
	min-width: 100px;
}
.co-time dd {
	margin: 0;
	padding-left: 20px;
}

dl.co-hp {
    margin: 0;
    display: flex;
	font-size: clamp(14px, 1.2vw, 18px);
	flex-wrap: wrap;
}
.co-hp dt {
	margin: 0;
	min-width: 100px;
}
.co-hp dd {
	margin: 0;
	padding-left: 20px;
	color:#000;
}
.co-hp dd a{
	color:#000;	
}

.coint-top-contactbox {
    width: 23vw;
}
dl.coint-topc-dl {
    margin: 0;
    display: flex;
    justify-content: center;
    background-color: #e1e8ee;
    padding:10px 15px;
    margin-bottom: 1vw;
    border-radius: 5px;
    align-items: center;
}

.coint-top-contactinner a dl.coint-topc-dl{
	    transition: all .4s;
}

.coint-top-contactinner a:hover dl.coint-topc-dl {
	background-color: #b2c1cf;
}

.coint-topc-dl dt {
	margin: 0;
	width: clamp(24px, 3vw, 40px);
}
img.coint-c-icon {
    display: block;
    width: 100%;
}
.coint-topc-dl dd {
	margin: 0;
	padding-left: clamp(12px, 1vw, 20px);
}
.coint-topc-dl dd p {
	text-decoration: none;
	font-size: clamp(12px, 1vw, 15px);
	color: #022c4f;
	font-weight: bold;
}



.coint-bottom {
    margin: 2.5vw 0 0;
}
dl.co-b1 {
    margin: 0;
    display: flex;
    justify-content: space-between;
	margin-bottom: 25px;
}
.co-b1 dt {
    margin: 0;
    width: 10%;
    font-size: clamp(14px, 1.3vw, 19px);
    position: relative;
}
.co-b1 dt::after {
    display: block;
    content: "";
    width: 5px;
    height: 1.5vw;
    background-color: #022c4f;
    position: absolute;
    top: 1.5vh;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.co-b1 dd {
	margin: 0;
	width: 86%;
}

dl.co-b2 {
	margin: 15px 0 25px;
    display: flex;
    justify-content: space-between;
	
}
.co-b2 dt {
    margin: 0;
    width: 10%;
    font-size: clamp(14px, 1.3vw, 19px);
    position: relative;
}
.co-b2 dt::after {
    display: block;
    content: "";
    width: 5px;
    height: 1.5vw;
    background-color: #022c4f;
    position: absolute;
    top: 1.5vh;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.co-b2 dd {
	margin: 0;
	width: 86%;
}

ul.cob2-ul {
    display: flex;
	justify-content: space-between;
}
li.cob2-li {
    list-style: none;
    width: 30%;
}
li.cob2-li img {
	display: block;
	width: 100%;
}


.comap {
    margin: 2.5vw 0 0;
}
.comap iframe {
	width: 100% !important;
	height: 20vw;
}
.comap p {
	margin: 0;
}


.coint-contact {
    margin: 0;
}
.coint-c-bg {
    background-color: #022c4f;
    display: flex;
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
	padding: 1vw 0;
	position: relative;
}
.coint-c-bg::after {
	display: block;
	content: "";
	width: 2px;
	height: 6vw;
	background-color: #fff;
	position: absolute;
	top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

p.coint-c-text {
    margin: 0;
	color: #fff;
	text-align: center;
	padding-bottom: 0.8vw;
}
dl.coint-c-dl {
    margin: 0;
	color: #fff;
}
dl.coint-c-dl {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2vw;
}
.coint-c-dl dt {
	display: block;
	width: clamp(24px, 5vw, 48px);
}
img.coint-c-icon-bright {
	filter: brightness(100);
}
.coint-c-dl dd {
	margin: 0;
	font-size: clamp(14px, 1.3vw, 24px);
	font-weight: bold;
}
.coint-c-dl dd a {
	text-decoration: none;
	color: #fff;
}
dd.coint-cotel-space {
    letter-spacing: 0.3vw;
}
.coint-telbox {
    width: 50%;
	padding: 2vw;
}
.coint-mailbox {
    width: 50%;
	padding: 2vw;
}



/*co-loop*/
.co-loop-inner {
    border-top: solid 0.5vw #022c4f;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
}
.co-loop-top {
    padding-bottom: 2vw;
    padding: 2vw 1.5vw 2vw;
    border: solid 2px #022c4f;
	background: #fff;
}

.co-loop-top:hover{
	background: #e8e8eb;
}

.co-loop-flex {
    width: 88vw;
    max-width: 1600px;
    margin: 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	 gap: 2vh;
}
.co-loop-container {
	width: 48%
}
.co-loop-top-right {
    padding-left: 1vw;
	color:#000;
}



p.co-loop-sug {
    font-size: clamp(14px, 1.3vw, 16px);;
}
h3.co-name.co-loop-name {
    font-size: clamp(20px, 2.3vw, 22px);
    margin: 1rem 0 0;
}
dl.co-loop-address, dl.co-loop-time, dl.co-loop-hp{
    font-size: clamp(14px, 1vw, 16px);
}

.co-loop-time dd {
	padding-left: 1vw;
}

.co-loop-hp dd {
	padding-left: 1vw;
}

.co-loop-c-bg {
    border-bottom-left-radius: 15px;
    border-bottom-right-radius: 15px;
}
.co-loop-telbox {
    padding: 0.5vw 2vw;
}
.co-loop-mailbox {
    padding: 0.5vw 2vw;
}
p.co-loop-c-text {
    font-size: 0.8vw;
}
.co-loop-c-dl dt {
	width: clamp(24px, 2vw, 40px);
}
.co-loop-c-dl dd {
	font-size: clamp(14px, 1.2vw, 20px);
}
dd.co-loop-cotel-space {
    letter-spacing: 0;
}

.companylist-archive-wrapper .coint-c-bg{
	padding:0;
}

.companylist-archive-wrapper .co-loop-telbox {
    padding: 1.5vw 2vw;
}

.companylist-archive-wrapper .co-loop-mailbox {
    padding: 1.5vw 2vw;
}


/*service-page*/

.svp-cate-container {
    margin: 13vw 0 0;
}

.svp-title {
	width: 88vw;
	max-width: 1800px;
	margin: 0 auto;
	position: relative;
}
span.svp-backfont {
    font-size: 12vw;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    color: #005faf;
    opacity: 0.1;
    position: absolute;
    top: -12.5vw;
    /* right: 1vw; */
    left: 0;
	z-index: -1;
}

.svp-cate-inner {
    width: 88vw;
    margin: 0 auto;
    max-width: 1400px;
}

.svp-cate-inner-bg {
    width: 100%;
    background-color: #022c4f;
    border-radius: 30px;
}
.svp-cate-inner-box {
    padding: 3vw;
}

dl.svp-cate-title {
    color: #fff;
    margin: 0 auto;
    width: 90%;
    padding-bottom: 2vw;
}
.svp-cate-title h3 {
	margin: 0;
	font-size: clamp(18px, 1.5vw, 25px);
}
.svp-cate-title dt {
	margin: 0;
}
.svp-cate-title dd {
	margin: 0;
}

.svp-cate-imgbox {
    width: 100%;
    /*background-color: #fff;
    padding: 5vw 0;
    border-radius: 30px;*/
}
.svp-cate-imgbox img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
}
p.svp-cate-text {
    margin: 0;
    color: #fff;
    width: 100%;
    font-size: clamp(16px, 1.1vw, 18px);
}
.svp-cate-inner-flex {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 3vw;
    width: 90%;
    margin: 0 auto;
}
.svp-cate-left {
    width: 25%;
}
.svp-cate-right {
    width: 75%;
}

.svp-btnbox {
    width: 90%;
    margin: 2.5vw auto 0;
    display: grid;
    justify-content: space-between;
    gap: 2vw;
    flex-wrap: wrap;
    grid-template-columns: 1fr 1fr;
}

.svp-btn {
	position: relative;
}
.dli-caret-circle-fill-right-white-svp {
	display: inline-block;
    vertical-align: middle;
    color: #fff;
    line-height: 1;
    position: relative;
    width: 1.2vw;
    height: 1.2vw;
    border: 0.075em solid currentColor;
    background: currentColor;
    border-radius: 100%;
    box-sizing: content-box;
	transition: all 1s ease-out;
}
.dli-caret-circle-fill-right-white-svp::before {
    content: '';
    color: #007ce3;
    width: 0;
    height: 0;
    border-style: solid;
    border-color: transparent;
    border-width: 0.4vw 0.6vw;
    border-left-color: currentColor;
    border-right: 0;
    transform: translateX(15%);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
	transition: all 1s ease-out;
}

.svpbtnbox {
    position: absolute;
    top: 50%;
    right: 2vw;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.svp-btn-bg {
    position: relative;
    width: 100%;
    background-color: #007ce3;
    border-radius: 50px;
	  transition: all 1s ease-out;
}





.svp-btn-inner {
    padding: 25px 30px;
}
p.svp-btn-title {
    margin: 0;
	font-weight: bold;
	font-size: clamp(16px, 1.2vw, 20px);
	color: #fff;
	  transition: all 1s ease-out;
}

/*bg-grey*/
.svp-cate-inner-bg-grey {
    width: 100%;
    background-color: #e1e8ee;
    border-radius: 30px;
}
dl.svp-cate-title-grey {
    color: #022c4f;
    margin: 0 auto;
    width: 90%;
    padding-bottom: 2vw;
}
.svp-cate-title-grey h3 {
	margin: 0;
	font-size: clamp(18px, 1.5vw, 25px);
}
.svp-cate-title-grey dt {
	margin: 0;
}
.svp-cate-title-grey dd {
	margin: 0;
	font-weight: bold;
}

p.svp-cate-text-grey {
    margin: 0;
    color: #022c4f;
    width: 100%;
    font-size: clamp(16px, 1.1vw, 18px);
	font-weight: bold;
}


.svp-btn-bg:hover{
	background: #fff;
}

.svp-btn-bg:hover p.svp-btn-title {
	color: #007ce3;
}

.svp-btn-bg:hover .dli-caret-circle-fill-right-white-svp{
	color: #007ce3;
}

.svp-btn-bg:hover .dli-caret-circle-fill-right-white-svp::before {
		color: #fff;
}



.svp-cate-inner:first-child {
  margin-top: 6vw;
}

.svp-cate-inner:last-child {
  margin-bottom: 6vw;
}
.svp-cate-inner:nth-child(n+2):nth-child(-n+7) {
  margin: 4vw auto; /* 2〜7番目まで */
}




/*contact*/


.contantp-bg {
    padding: 3vw 0;
    background-color: #e1e8ee;
}

h3.cnthh3 {
    color: #022c4f;
	margin: 0 0 3vw;
	position: relative;
	z-index: 10;
}
span.cnthbf {
    color: #fff;
	opacity: 0.5;
	/*z-index: -1;*/
}


/*feedin-contact用追記*/
/*li.feedin2 {
  opacity: 0;
  transform: translateX(-50px);
  transition: all 1s ease-out;
}

.feedin2.active {
  opacity: 1;
  transform: translateX(0);
}*/
/* 初期：透明＆左ズレ（フェードイン用） */
.contact-tab-list li.feedin3 {
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity 1s ease, transform 1s ease;
}

/* フェードイン中 */
.contact-tab-list li.feedin3.active, .search-tab-list li.feedin3.active {
  opacity: 1;
  transform: translateX(0);
}

/* フェードイン後は常時表示モード（既定0.5） */
.contact-tab-list li.feedin3.faded, .search-tab-list li.feedin3.faded {
  opacity: 0.5;
  transform: none;
}

/* 選択中タブだけ濃く（1.0） */
.contact-tab-list li.feedin3.faded.selected, .search-tab-list li.feedin3.faded.selected {
  opacity: 1;
}


li.feedin3 {
	/*opacity: 0;*/
    width: 25vw;
    /*margin-left: -2vw;*/
    list-style: none;
    background-color: #fff;
    padding: clamp(30px, 4vw, 70px);;
	border-radius: 15px;
	cursor: pointer;
}
li.feedin3 img {
    display: block;
    width: 10vw;
    margin: 0 auto;
}
.contact-tab-panel{
	opacity: 0;
	transition: opacity 0.5s ease;
}
.contact-tab-panel.fade-in, .search-tab-panel.fade-in {
	opacity: 1;
}





/*
.contact-tab-panel {
  opacity: 0.5;
  transition: opacity 0.5s ease;
}

.contact-tab-panel.active {
  opacity: 1;
}
*/





/*panel*/
.cntp-tub-flex ul {
    width: 88vw;
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    gap: 3vw;
}
/*.cntp-from-menu {
    padding: 4vw;
}*/
.cntp-tub-flex {
    background-color: #e1e8ee;
}

.cntp-btn-bg {
    background-color: #022c4f;
    border-radius: 30px;
}
.cntp-btn-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
p.cntp-btn-title {
    padding-left: clamp(10px, 2vw, 25px);
	color: #fff;
    font-weight: bold;
	/*font-size: clamp(16px, 0.8vw, 18px);*/
}
.cntpbtnbox {
    padding-right: clamp(10px, 2vw, 25px);
}


/*tab*/
.contact-tab-panels {
    width: 88vw;
    margin: 0 auto;
    max-width: 1400px;
}

/*form*/
div#form-box {
    padding-bottom: 8vw;
}

div#form {
    background-color: #fff;
    /* border: solid 1.5px #000; */
    border-radius: 15px;
    margin-top: 2vw;
	padding-bottom: 2vw;
}
.form-inner {
    padding: 3vw 10vw 1vw;
}
dl.f-dl {
    display: flex;
	align-items: center;
}
dt.f-dt {
    font-size: clamp(14px, 1.2vw, 18px);
	width: 17%;
}
dt.f-dt p {
	margin: 0;
}
dd.f-dd {
    width: 83%;
}

input.wpcf7-form-control.wpcf7-text {
    font-size: clamp(14px, 1vw, 18px);
    text-align: unset;
    padding: 8px 5px;
    width: 100%;
	border-radius: 5px;
	border: solid 1px #898989;
}
textarea.wpcf7-form-control.wpcf7-textarea {
    font-size: clamp(14px, 1vw, 16px);
    text-align: unset;
    padding: 8px 5px;
    width: 100%;
	border: solid 1px #898989;
    border-radius: 8px;
}



.form_purapori {
    display: flex;
    justify-content: center;
}
.form_purapori a {
	text-decoration: none;
	color: #022c4f;
}

.form-btn {
    width: 10vw;
    margin: 0 auto;
}
.form-btn p {
	margin-bottom: 0;
}
input.wpcf7-form-control.wpcf7-submit.has-spinner {
    width: 100%;
    padding: 1vw;
    border: none;
    background-color: #022c4f;
    color: #fff;
    font-weight: bold;
    border-radius: 5px;
	font-size: 18px;
}

input.wpcf7-form-control.wpcf7-submit:hover{
	background-color:#001f39;
}



/*news-p*/
.news-right.newsp {
    margin: 5vw auto 5vw;
}


.single-news{
	width: 88vw;
    margin: 0 auto 5vw;
    max-width: 1400px;
}


.search-results ul.result-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)); /* prevents overflow */
  gap: 2.1875vw;
  max-width: 100%; /* keeps it within container */
  padding-left: 0;
  margin-bottom: 2.1875vw;
}

.search-results ul.result-list li.fplist-item{
        width: 100%;
}
	
.search-results ul.result-list .fpli_thumbnail {
    width:100%;
}
.search-results .co-loop-inner{
	border-top:none; 
}


.search-results .container, .container{
	width: 95%;
    margin: 0 auto;
    max-width: 1600px;
}





.search-results ul.result-list .coint-top{
	flex-direction: column;
	padding: 0;
	border: none;
	color: #000;
	border-radius: 10px;
	padding-bottom: 8px;
}

.search-results ul.result-list .coint-top .coint-top-img{
/*    max-width: 100%;*/
}

.search-results ul.result-list .coint-top .coint-top-text{
	width: 94%;
	padding: 0 3%;
}


.search-results ul.result-list .coint-top .coint-top-img{
	border-radius: 10px;
	overflow: hidden;
	background: #fff;
	transition: all .4s;
	display: flex;
}


.search-results ul.result-list .coint-top:hover .coint-top-img{
	background: #022c4f;
}


.search-results ul.result-list .coint-top .coint-top-img img{
	opacity: 1;
	transition: all .4s;
}

.search-results ul.result-list .coint-top:hover .coint-top-img img{
	opacity: 0.8;
}






.search-results{
		padding: 80px 0;
}



.pagination{
	display: flex;
    justify-content: center;
	margin-top: 30px;
}

.pagination .nav-links a {
	margin: 1rem .6rem;
}
.pagination .nav-links a.page-numbers {
	color: #022c4f;
}
.pagination .nav-links a.page-numbers:hover {
	color: #383838;
}
.pagination .nav-links .page-numbers.current,
.pagination .nav-links .page-numbers.dots {
	color: #e0e0e0;
}
.pagination .nav-links a.next,
.pagination .nav-links a.prev {
	display: inline-block;
	padding: .2rem .8rem;
	background-color: #022c4f;
	color: #fff;
	-webkit-border-radius: 9999px;
	border-radius: 9999px;
}
.pagination .nav-links a.next:hover,
.pagination .nav-links a.prev:hover {
	box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
	color: #fff;
}

.search-results ul.result-list .coint-top .coint-top-img img{
	max-width: 100%;
	border-radius: 10px;
	display: block;
    height: auto;
}

/***************************************************************/

/* ADMIN CSS*/

/*********************************************************************/

body.admin{
	background-color:#f6f6f6;
}

.admin ul#hb-menu{
	background-color:#fff;
	
}

.admin ul#hb-menu li a {
    color: #022c4f;
}

.admin ul#hb-menu li a:after{
	background-color: #022c4f;
}


.admin .mypagebox{
    display: flex;
    width: auto;
    margin-left: 0;
    justify-content: center;
    gap: 10px;
    align-items: center;
    background-color: #fff;
    border-radius: 100px;
    padding: 0 1.5vh 0 2.5vh;
}

.admin .mypagebox a{
 color:#022c4f;
 display:flex;
 margin-left:0;
 align-items:center;
 width:auto;
 padding:1.5vh 0;
}


.admin .mypagebox a img.icon-mypage{
	max-width: 25px;
	
}

.admin .um-121.um{
	  max-width:100%;
	  margin-top: 20px;
          padding:10px;
}


.admin .um-profile-photo {
    float: none;
    position: relative;
    width: 100%;
    margin: 0;
}

.admin .um-header{
	width:60%;
	margin:0 auto;	
}

.admin .um-profile-photo a.um-profile-photo-img{
	left:50%;
	transform: translateX(-50%);	
}

.admin .um-121.um .um-profile-meta {
    padding-left: 0;
    padding-right: 0;
    text-align: center;
}

.admin .um-name {
    float: none;
    margin-right: 0;
    margin-top: 100px;
}

.admin .ft-left {
    width: 100%;
    display: flex;
    justify-content: center;
}

.admin .ft-left-inner {
     width: 100%;
	    margin: auto;
    justify-content: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.admin img.ft-logo {
    display: flex;
    width: 5vw;
    padding-bottom: 2vh;
    justify-content: center;
}

.admin ul.ft-nav {
    display: flex;
    width: auto;
}

.admin .ft-bg {
    background-color: #022c4f;
    padding: 30px 0px;
}

.admin .um-login.um-logout, .admin .um-120.um, .user_regiter{
	background-color:#fff;
	  border-radius: 8px;
  box-shadow: 1px 2px 8px rgba(0, 0, 0, 0.65);
  margin: 6rem auto 8.1rem auto;
  
}

 .user_regiter{
	width:900px;
	text-align:center;	 
}

.admin .um-120.um{
    padding: 30px;
}

.admin .um-misc-ul{
	  padding: 10px 10px 25px;
}

.admin .um-misc-ul, .admin .um-misc-ul li {
     font-size: 16px;
    text-align: center;
    list-style: none;
	display: flex;
    flex-direction: column;
}

.admin .um-misc-ul li a{
    padding: 10px;
	list-style:none;
	color: #022c4f;
	position:relative;
}

.admin .um-misc-ul li a{
	color:#000;	
}



.admin .um-misc-ul li a:before{
	width:100%;
	height:1px;
	position:absolute;
	left:0;
	bottom:0;
	content:"";
	background:#CCC;	
}

.admin .um-misc-ul li a:after{
	width:0%;
	height:1px;
	position:absolute;
	left:0;
	bottom:0;
	content:"";
	background:#022c4f;	
	transition: all .4s;
}

.admin .um-misc-ul li a:hover:after{
	width:100%;
}


.admin .um:not(.um-admin){
 margin: 6rem auto 8.1rem auto!important;	
}

.admin .um .um-form{
    padding:0 15px;
}

.admin .um .um-form input[type=text], .admin .um .um-form input[type=password]{
	border-radius:9999px;
	border: 1px solid #022c4f !important;
}
.admin .um .um-form input[type=text]:focus, .admin .um .um-form input[type=password]:focus{
	border: 1px solid #999 !important;
}

.admin .um-button{
	border-radius:9999px !important;
	
}


.admin .um a.um-button, .admin .um a.um-button.um-disabled:active, .admin .um a.um-button.um-disabled:focus, .admin .um a.um-button.um-disabled:hover, .admin .um input[type=submit].um-button, .admin .um input[type=submit].um-button:focus{
	background-color:#022c4f;
}

.admin .um .um-button.um-alt, .admin .um input[type=submit].um-button.um-alt {
    background: #eee;
}

.admin .login_header{
	display:flex;
	width:100%;
	background:#fff;
	padding: 10px 0;
		
}


.admin .login_header a {
    display: block;
    width: 5vw;
    /* padding: 0 0 0 4vw; */
    min-width: 90px;
}

.admin .container{
	max-width:900px;
	margin:0 auto;	
        width:100%;
}

.user_regiter h3{
 text-align:center;
 font-size:22px;
 padding-bottom:25px;	
}

.user_regiter {
    text-align: center;
    max-width: 900px;
	    padding:10px 20px;
}

.admin .regiter_fp span.faqph-border{
    width: 100%;
}

.admin .regiter_fp{
		background-color:#fff;
	  border-radius: 8px;
	  padding:20px;
	  margin-bottom: 80px;
}

body.admin .wpuf-form-add.wpuf-style ul.wpuf-form .wpuf-fields input[type=text]{
	padding: 8px 10px;
	border-radius:9999px;
}

body.admin .wpuf-form-add.wpuf-style ul.wpuf-form .wpuf-fields textarea {
    border-radius: 10px;
}

.wpuf-submit{
    display: flex;
    justify-content: center;
	gap:15px;
	align-items:center;
}

.admin .wpuf-form-add.wpuf-style ul.wpuf-form .wpuf-submit input[type=submit]{
	background-color: #022c4f;
    border: navajowhite;
    padding: 10px 25px;
    border-radius: 9999px;	
}

.admin .wpuf-form-add.wpuf-style ul.wpuf-form .wpuf-submit .btn{
	margin-left: 0.5rem;
    background-color: #c9c9c9;
    border: none;
    padding: 10px 25px;
    border-radius: 9999px;
    display: flex;
    align-items: center;
	color:#022c4f;
}


 .fplist_reg{
    display: flex;
    list-style: none;
	padding:0 5px;
	gap:2px;
margin-top:20px;
}
 .fplist_reg li{
    display: flex;
    padding: 0;
	
 }

 .fplist_reg li a.active{
    padding: 10px 25px;
    background-color: #022c4f;
    color: #fff;
    border-radius: 10px 10px 0 0;
 }
  .fplist_reg li a{
     padding: 10px 25px;
    background-color: #fff;
    color: #022c4f;
    border-radius: 10px 10px 0 0;
  }



.fpab-mission {
    width: 88vw;
    margin: 0 auto;
    max-width: 1400px;
    background-color: #022c4f;
    border-radius: 0px 30px 30px 0px;
    overflow: hidden;
}


.fpab-m-flex{
	display: flex;
	
}

.fpab-m-left, .fpab-m-right{
	width: 50%;
}

.fpab-m-left{
	display: flex;
}

.fpab-m-right .fpab-m-inner{
    padding:3vw 35px;
	color:#fff;
}


.fpab-m-titlebox{
	display: flex;
	align-items: flex-end;
	margin-bottom: 40px;
}

.fpab-m-titlebox .fpab-title{
    color: #fff;
    font-size: 44px;
    font-weight: 400;
    font-family: "Oswald", sans-serif;
    margin: 0;
	line-height: 1;
}




.fpab-m-titlebox dd span{ 
    color: #fff;
    font-size: 18px;
    margin: 0;
    display: flex;
    padding-right: 20px;
    align-items: center;
	font-weight: 600;
}


.fpab-m-titlebox dd span::before{
    width: 2px;
    height: 26px;
    content: "";
    background: #fff;
    display: block;
    margin-right: 20px;
    border-radius: 2px;
}



.fpabm-r-text{
	font-size:18px;
}

.fpabm-ul{
	margin-left:10px;
}
  
.fpabm-li{
	margin-bottom: 10px;	
	
}
.fpabm-li-border{

	border-bottom: 1px solid #fff;
}



.fpab-value {
    width: 88vw;
    margin: 10vh auto;
    max-width: 1400px;
}

.fpab-v-titlebox{
	display: flex;
	align-items: flex-end;
	margin-bottom: 40px;
}

.fpab-v-titlebox .fpab-title {
    color: #022c4f;
    font-size: 44px;
    font-weight: 400;
    font-family: "Oswald", sans-serif;
    margin: 0;
	line-height: 1;
}



.fpab-v-titlebox dd span{ 
    color: #022c4f;
    font-size: 18px;
    margin: 0;
    display: flex;
    padding-right: 20px;
    align-items: center;
	font-weight: 600;
}


.fpab-v-titlebox dd span::before{
    width: 2px;
    height: 26px;
    content: "";
    background: #022c4f;
    display: block;
    margin-right: 20px;
    border-radius: 2px;
}


.fpab-f-item-dl{
	display: flex;
	align-items: flex-end;
	margin-bottom: 20px;
	gap: 25px;
}

.fpab-f-item-dl dt {
    color: #022c4f;
    font-size: 36px;
    font-weight: 400;
    font-family: "Oswald", sans-serif;
    margin: 0;
	line-height: 1;
}



.fpab-f-item-dl dd{ 
    color: #022c4f;
    font-size: 16px;
    margin: 0;
    display: flex;
    padding-right: 20px;
    align-items: center;
	font-weight: 600;	
}





.fpab-v-flex{
	display:grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 5vw;
}


.fpab-v-li{
	background-color:#022c4f;
	display: flex; 
	flex-direction: column;
	padding: 10px;
	border-radius: 15px;
	align-items: center;
}



.fpab-v-li h5{
background: #fff;
    width: 90%;
    color: #022c4f;
    padding: 5%;
    border-radius: 10px 10px 0 0;
    margin: 0;
    display: block;
    text-align: center;
    font-size: 16px;
}

.fpab-v-li .img_box{
	width: 40%;
	margin: 30px 0;
}


.fpab-v-li p{
	margin: 0 10px 5px;
	color: #fff;
}

.admin .fplibs-cntn{
padding:15px;
}


  .admin .file-selector{
	  	margin-left: 0.5rem;
    background-color: #c9c9c9;
    border: none;
    padding: 10px 25px;
    border-radius: 5px;
    align-items: center;
	color:#022c4f;
	margin:0 0 10px;
}




.fpab-flow{
	padding: 10vh 0;
	background: #c9d8e6;
}


.fpab-f-bg {
    width: 80vw;
    margin: 0 auto;
    max-width: 1200px;
}

.fpabf-item-flex{
	background-color:#fff;
	width: 100%;
	margin-bottom: 40px;
}

.fpabf-item-inner{
    display: flex;
    justify-content: space-between;
    padding: 25px;
	
}

.fpabf-item-text{
	width: 58%;
	font-size: 16px;
	color: #022c4f;
}


.fpabf-item-inner .img-box{
	width: 35%;
}


.about_the{
	    width: 80vw;
    margin: 10vh auto;
    max-width: 1200px;
}


.airitcbox {
    width: 100%;
    padding-top: 50px;
}

.airitcbox dl {
    display: flex;
    border-bottom: 1px solid #f1f1f1;
    padding: 15px 0px 15px;
    margin: 0;
}

.airitcbox dt {
    width: 10%;
    margin: 0;
}

.airitcbox dd {
    margin: 0;
    padding-left: 15px;
}

.telmailairitc a {
    text-decoration: none;
    color: #022c4f;
    font-weight: bold;
}


.privacy h2, .privacy h3, .privacy h4{
	color: #022c4f;
	    margin-bottom: 0;
}
.privacy p{
	margin-top: 0;
	margin-bottom: 16px;
}


.privacy{
	padding-bottom: 50px;
}




.notfound_ttl {
    font-size: 100px;
    font-weight: 700;
    letter-spacing: 6px;
    line-height: 1;
	margin: 60px 0 0;

}


    .notfound_txt {
        text-align: center;
    margin-top: 41px;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 2;
		
}


.notfound{
	display: flex;
	flex-direction: column;
	padding-bottom: 40px;
	    align-items: center;
}