@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

/* RESET
----------------------------------------------------------------------------------------------------*/
a,body,dd,div,dl,dt,em,form,footer,header,h1,h2,h3,h4,h5,h6,html,i,iframe,img,label,legend,li,nav,ol,p,section,main,span,table,tbody,tfoot,thead,time,tr,th,td,ul,video{font-size:100%;font-weight:inherit;vertical-align:baseline;white-space:normal;margin:0;padding:0;border:0;outline:0;background:transparent;line-height:1.8;}footer,header,nav,section,main{display:block}ol,ul{list-style:none}table{border-collapse:collapse;border-spacing:0}


/* ----------------------------------------------

 * 設定をしなおす

---------------------------------------------- */
html {
    scroll-behavior: smooth;
	scroll-padding-top: 90px;
}

.visuallyhidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(0px 0px 99.9% 99.9%);
  clip-path: inset(0px 0px 99.9% 99.9%);
  border: 0;
}



body {
  margin: 0 auto;
  padding: 0;
  font-size: 14px;
  font-family: "Noto sans JP";
  letter-spacing: 1px;
  color: #172051;
  -webkit-text-size-adjust: 100%;
  background-color: #fff!important;
}
#main{
	letter-spacing: 2px;
}
	.tab{
		display: none;
	}
@media only screen and ( max-width : 768px ) {
  body {
	  line-height: 1.9;
	  font-size: 14px;
	letter-spacing: 0px;
	}
}

table {
  margin : 0;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
}

img {
  vertical-align: middle;
  border: none;
}



/* ----------------------------------------------

 * アンカータグの設定

---------------------------------------------- */
a {
  outline:none;
  color: #172051;
}

a:hover {
  text-decoration: none;
}


a,a:hover,a:hover img {
  -webkit-transition: 0.5s;
  -moz-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
  text-decoration: none;
}




/* ----------------------------------------------

 * 要素を左右中央寄せ

---------------------------------------------- */

.taC {
  text-align: center !important;
}

.taR {
  text-align: right !important;
}

.taL {
  text-align: left !important;
}
.fcb{
	color: #0070C3;
}


*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;*behavior:url(/scripts/boxsizing.htc)}.container{margin:0 auto}.clr:after,.col:after,.container:after,.group:after,.row:after{content:"";display:table;clear:both}.row{padding-bottom:0}.col{display:block;float:left;width:100%}@media (min-width:769px),print{.gutters .col{margin-left:2%}.gutters .col:first-child{margin-left:0}.gutters .colR:first-child{margin-right:0}}


img {
    width: 100%;
    height: auto;
}

.sp{
	display: none!important;
}
@media only screen and ( max-width : 768px ) {
  .sbox {
    margin-bottom: 20px;
  }
  .container {
    padding: 0 30px;
  }
  section {
  }
	.pc{
		display: none!important;
	}
	.sp{
		display: block!important;
	}
}

@media only screen and ( max-width : 835px ) {
  .container {
    padding: 0px;
  }
	#h_top {
	height: 100%;
    display: flex;
    padding: 5%;
    justify-content: space-between;
    align-items: center;
	}

}


@media print, screen and ( min-width : 769px ) {
  .sbox {
    margin-bottom: 25px;
  }

  section {
  }
}
@media (min-width: 769px) and (max-width: 1060px)

{
	.tab{
		display: block;
	}

}
@media (min-width: 852px) {
	.flow-br{
		display: block;
	}
}
@media (max-width: 851px) {
	.flow-br{
		display: none;
	}
}
@media print, screen and ( min-width : 836px ) {
  .container {
    margin: 0 4%;
  }
 }

/* ---------------------------------------------------------------------------------------------

　   フェードイン

--------------------------------------------------------------------------------------------- */

/* フェードインさせる要素 */
.block {
    opacity: 0; /* 最初は非表示にしておく */
    transition: all 2s; /* 動きを滑らかに */
	transform: translateY(20px);
}
/* フェードイン用のクラス */
.fadeIn {
    opacity: 1;
	transform: translateY(0);
}


/* ---------------------------------------------------------------------------------------------

　   HEADER

--------------------------------------------------------------------------------------------- */

#header {
	font-weight: bold;
  z-index: 99;
  width: 100%;
  background: #fff;
	position: fixed;
}

#header .container {
	height: 100%;
}

#gNav a:hover {
  color: #d5b200;
}

ul.kigyou li a:hover {
  color: #d5b200!important;
}

nav .sub-menu,.mean-container .mean-nav ul ul {
  background: #fff;
}
.h_nav {
    display: flex;
    align-items: center;
}
.header-btn {
	margin-right: 10px;
    background: #D5B200;
    padding: 8px 20px;
    border-radius: 50px;
	color: white;
	transition: background 0.3s ease;
}

.header-btn:hover {
  background: #172051;
}
.header-btn_sp{
	display: none;
}
.header-btn02 {
	border: 1px solid #172051;
    background: white;
    padding: 8px 20px;
    border-radius: 50px;
	color: #172051;
	transition: background 0.3s ease;
}

	.nav-sp{
		display: none;
	}


div#nav-content li {
    padding: 10px 0;
}

.nav-links {
    display: flex;
    gap: 5%;
    justify-content: center;
}
.h_logo a {
	display: block;
}

@media (min-width: 836px) and (max-width: 1155px) {
	.h_logo {
    width: 13%;
}
	#gNav li {
    margin-right: 12px!important;
}
	.header-btn {
    margin-right: 10px;
    padding: 8px;
	}
	.header-btn02 {
    padding: 8px;
	}

}

@media (min-width: 902px) and (max-width: 1155px) {
	.container {
    margin: 0 2%;
}
}
@media (min-width: 836px) and (max-width: 901px) {
	.container {
    margin: 0 1%;
	font-size: 0.9em;
}
}
@media only screen and ( max-width : 835px ) {
	body.home .h_logo{
	display: none;
}
	body.home a.header-btn_sp.js-btn-link{
	display: none;
}
	body.home #h_top {
    justify-content: flex-end;
}
  #header {
    /* padding: 0; */
    height: 60px;
	  /* position: fixed; */
  }
	.nav-sp{
		display: block;
	}
	.header-btn_sp {
	display: block;
    margin-right: 10px;
    background: #D5B200;
    padding: 5px 20px;
    border-radius: 50px;
    color: white;
    font-size: 0.9em;
}
	.nav-sp .header-btn {
    display: block;
    width: 100%;
    padding: 13px 20px;
    margin: 5% 0;
    text-align: center;
}
	.nav-sp .header-btn:hover {
    background: #D5B200;
}
		.nav-sp .header-btn02 {
    display: block;
    width: 100%;
    padding: 13px 20px;
    margin: 5% 0;
    text-align: center;
	background: white;
	color: #172051;
}
	.nav-links a {
    font-size: 12px;
    display: flex;
    padding: 5px 0;
	font-weight: normal;
}

  .h_logo {
    width: 40%;
    z-index: 10;
  }
	.h_logo img {
    vertical-align: inherit;
}

	.menu-name p {
    color: white;
    padding: 1em;
}
	.header-btn{
		display: none;
	}
	ul.sub-menu img {
    display: none;
}
	nav .sub-menu, .mean-container .mean-nav ul ul {
    background: #172051;
}
  #gNav .nav {
    overflow-y: auto;
    height: 100vh;
  }
  .mean-nav .container {
    padding: 0;
  }
  nav li .fa {
    display: none;
  }
}

@media print, screen and ( min-width : 836px ) {
  #header {
	/* position: fixed; */
    height: 80px;
  }


  #h_top {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  #gNav ul {
    position: relative;
    display: flex;
  }
  #gNav li {
    position: relative;
    margin-right: 25px;
  }

  #gNav li a {
    position: relative;
    display: block;
    text-align: center;
    line-height: 80px;
  }
	.menu-name {
	letter-spacing: 0;
    width: 16%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

	.menu-name a p {
    transition: color 0.3s ease;
}
	.menu-name a p:hover {
    color: #D5B200;
}

  #gNav .sub-menu {
	justify-content: space-evenly;
    padding: 20px;
    border-radius: 5px;
    visibility: hidden;
	opacity: 0;
    z-index: 1;
    position: absolute;
    top: 50px;
    left: 50%;
    margin-left: -320px;
    width: 650px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    transition: all .2s ease;
    align-items: center;
  }
  #gNav .sub-menu a {
    letter-spacing: 0;
    display: contents;
	line-height: 1em;
  }
  #gNav .sub-menu a:hover:after {
    content: none;
  }
  #gNav .sub-menu li {
    margin: 8px;

  }

  #gNav .sub-menu li:last-child {
    border-bottom: none;
  }
  #gNav ul > li:hover {
    -webkit-transition: all .5s;
    transition: all .5s;
  }
  #gNav ul > li:hover a,#gNav .current-menu-item a,#gNav .current-menu-parent a {
    color: #d5b200;
  }
  #gNav li:hover ul.sub-menu {
    top: 80px;
    visibility: visible;
    opacity: 1;
    z-index: 9999;
  }
  #gNav li ul li:after {
    content: none;
  }
 #gNav li:hover ul.sub-menu a {
    color: #111;
  }

  #gNav .contact_btn a:hover {
    color: #fff;
  }

}

/* ---------------------------------------------------------------------------------------------

　   パンクズリスト

--------------------------------------------------------------------------------------------- */

.breadcrumb-001 {
    display: flex;
    gap: 0 14px;
    list-style: none;
    padding: 0;
    font-size: .9em;
	margin: 4%;
	letter-spacing: 0;
}

.breadcrumb-001 li {
    display: flex;
    align-items: center;
}

.breadcrumb-001 li:not(:last-child)::after {
    display: inline-block;
    transform: rotate(45deg);
    width: .3em;
    height: .3em;
    margin-left: 10px;
    border-top: 1px solid #333333;
    border-right: 1px solid #333333;
    content: '';
}

.breadcrumb-001 a {
    color: #B4B4B4;
    text-decoration: underline;
}

.breadcrumb-001 a.current-page {
	color: #172051;
	text-decoration: none;
}
.aioseo-breadcrumb-separator {
	padding:0 10px;
}

@media only screen and ( max-width : 835px ) {


}


/* ---------------------------------------------------------------------------------------------

　   FOOTER

--------------------------------------------------------------------------------------------- */
#footer {
	background-color: #172051;
	color: white;
	letter-spacing: 2px;
}
#footer a {
	color: white;
}
#footer a:hover {
  color: #D5B200;
}
.footer-bg {
    padding: 5% 0 7% 0;
    margin: 0 4%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.footer-menu a {
    width: 100%;
    word-break: keep-all;
}
.footer-info {
	margin: 0px 4%;
    display: flex;
    border-top: 1px solid;
    justify-content: space-between;
}
.fotter-left {
    margin-top: 4%;
    width: 30%;
}
.footer-right{
	letter-spacing: 0;
	margin-top: 4%;
}
.fotter-left img {
    width: 74%;
}
.fotter-left p {
    font-size: 12px;
    margin-top: 8%;
}
.footer-menu {
    text-align: right;
    margin-bottom: 3%;
}
.footer-menu a {
    margin-left: 20px;
}
.footer-menu a:hover {
  color: #D5B200;
}
.footer-contact {
    text-align: right;
    margin-bottom: 10%;
}
.footer-contact a {
    margin-left: 25px;
}
.footer-txt {
    text-align: right;
    font-size: 12px;
    margin-bottom: 6%;
}
.footer-txt a {
    margin-left: 15px;
}
.footer-right p {
    text-align: right;
    font-size: 10px;
}
.btn-group {
    gap: 9%;
    flex-shrink: 0;
    width: 30%;
    display: flex;
    align-items: center;
}
.btn-group p {
    font-size: 16px;
    width: max-content;
}
.con-group p {
    margin-top: 6%;
    font-size: 16px;
}
.btn01 {
    width: 50%;
    gap: 15px;
    border-radius: 5px;
    padding: 15% 5%;
    background: #D5B200;
    color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform　0.3s ease;
}
#footer a:hover {
    color: #D5B200;
}
.btn01:hover {
    background: #fff;
}

.btn01:hover svg {
  fill: #fff;
}

.btn01:hover svg circle , .btn01:hover svg path{
	stroke: #D5B200;
}
.btn02 {
    width: 50%;
    border: 1px solid;
    gap: 15px;
    border-radius: 5px;
    padding: 15% 5%;
    background: none;
    color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform　0.3s ease;
}
.btn02:hover {
    background: #fff;
}
a.btn02:hover {
    color: #172051!important;
}
.btn01:hover svg {
  fill: #fff;
}

.btn02:hover svg circle , .btn02:hover svg path{
	stroke: #172051;
}
.btn-group img {
    width: 30%;
	transition: transform　0.3s ease;
}
#footer a:hover {
    color: #D5B200;
}

#footer h2 {
    font-family: "Montserrat";
    font-size: 76px;
    line-height: 1em;
    font-weight: 500!important;
    letter-spacing: 2px;
}
#footer .ttl-img {
    display: flex;
    align-items: center;
    gap: 5px;
}
#footer .ttl-img h3{
	font-size: 18px;
	font-weight: normal;
}
#footer .ttl-img img {
    width: 20px;
}
@media (min-width: 769px) and (max-width: 1170px) {
	.footer-txt {
    text-align: end;
    gap: 10px;
    display: flex;
    font-size: 12px;
    margin-bottom: 7%;
    flex-direction: column;
    align-items: flex-end;
}
	.footer-bg {
    padding: 5% 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
}
@media (min-width: 481px) and (max-width: 768px){
	.footer-bg {
    padding: 0% 0;
    margin: 0 7%;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-direction: column;
}
	 #footer {
    padding: 15% 0 10px 0;
  }
	.fotter-left {
    margin: 10% 2%;
    width: 96%;
}
		.footer-txt {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(3, 1fr);
    gap: 10px;
    text-align: left;
    font-size: 12px;
    margin-bottom: 10%;
}
}
@media only screen and ( max-width : 768px ) {

	#footer .ttl-img img {
    width: 17px;
}
	#footer h2 {
    font-size: 46px;
    margin: 0% 0%;
}
	#footer .sec-ttl {
    margin: 0%;
}
  .f_logo {
    padding: 0 20px;
    text-align: center;
  }
  .f_logo p {
    text-align: center;
  }
  .f_logo img {
    margin-bottom: 20px;
    width: 150px;
  }
	.btn-group {
    gap: 5%;
    flex-shrink: 0;
    width: 100%;
    display: flex;
    align-items: center;
}

	.footer-bg {
    padding: 15% 0;
	margin: 0 7%;
}
	.btn01,.btn02 {
    width: 100%;
	}
	#footer.con-group p {
    margin: 7% 0 0 0;
    font-size: 16px;
}
	.footer-info {
    margin: 0px 5%;
    display: flex;
    border-top: 1px solid;
    justify-content: space-between;
    flex-direction: column;
}

.footer-menu {
    text-align: left;
    margin-bottom: 3%;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    /*grid-template-rows: repeat(2, 1fr);*/
    gap: 10px;
}
	.footer-menu a {
    margin-left: 0;
}
	.footer-contact {
    text-align: left;
    margin: 10px 0 10% 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
	.footer-contact a {
    margin-left: 0px;
}

.footer-txt a {
    margin-right: 10%;
	margin-left: 0;
}
	.footer-txt {
    display: flex;

	}
	footer-right p {
    text-align: center;
    font-size: 10px;
}

	#footer .con-group p {
	letter-spacing: 0;
    margin: 8% 0 12% 0;
    font-size: 16px;
}
	.fotter-left img {
    width: 100%;
}

	.fotter-left img {
    width: 73%;
}
	.fotter-left {
    margin: 15% 0% 5%;
    width: 100%;
}
	.footer-right p {
    text-align: right;
    font-size: 10px;
    letter-spacing: 0px;
}
	.footer-right {
    margin: 5% 0;
}
}
@media only screen and ( max-width : 480px ) {
	.footer-bg {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: column;
}
	#footer {
    padding: 0;
  }
#footer .ttl-img h3{
	font-size: 16px;
	font-weight: normal;
}

}

@media print, screen and ( min-width : 769px ) {
  #footer {
    padding: 30px 0;
  }
  .f_logo {
  }

  .f_logo img {
    margin-bottom: 20px;
    width: 200px;
  }
  .f_logo {
  }
  .copy {
  }
}

/* ---------------------------------------------------------------------------------------------

　   page-top

--------------------------------------------------------------------------------------------- */
.page-top {
    position: fixed;
    bottom: 143px;
    right: 15px;
    z-index: 9;
    transition: opacity 0.3s ease-in-out;
	 display: none;/* 初期状態で非表示 */
}
.page-top a img {
  transition: transform 0.3s ease; /* ホバー時のアニメーション効果を追加 */
}

.page-top :hover {
  transform: translateY(-20px); /* ホバー時に少し上に移動 */
}


@media only screen and ( max-width : 768px ) {
.page-top {
    position: fixed;
    bottom: 80px;
    right: 0px;
    z-index: 9;
    padding: 10px 8px;
    transition: opacity 0.3s ease-in-out;
}
	}



/* ---------------------------------------------------------------------------------------------

　   scroll

--------------------------------------------------------------------------------------------- */

.scrolldown {
  position: absolute;
  bottom: 40px;
  right: 40px;
  padding: 15px;
　opacity: 1; /* 初期状態では表示されるように設定 */
  transition: opacity 0.3s ease; /* アニメーションを追加 */
}

.scrolldown span {
  font-family: "Noto sans JP";
  position: absolute;
  right: 45px;
  top: -30px;
  color: #fff;
  font-size: 12px;
  letter-spacing: 0.0em;
}

.scrolldown:before {
  content: "";
  position: absolute;
  bottom: 0; /* 下端からスタート */
  left: -3px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #fff;
  animation: circlemove 1.6s ease-in-out infinite, cirlemovehide 1.6s ease-out infinite;
}

@keyframes circlemove {
  0% { bottom: 80px; } /* 下端でスタート */
  100% { bottom: 0px; } /* 上端で停止 */
}

@keyframes cirlemovehide {
  0% { opacity: 0 }
  50% { opacity: 1; }
  80% { opacity: 0.9; }
  100% { opacity: 0; }
}

.scrolldown:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 1px;
  height: 80px;
  background: #fff;
}
@media print, screen and ( min-width : 769px ) {

	.scrolldown.hide {
  opacity: 0; /* スクロールで非表示にするための設定 */
}
}
@media only screen and ( max-width : 768px ) {


	.scrolldown {
    position: absolute;
    bottom: 120px;
    right: 10px;
    padding: 8px;
    opacity: 1;
    transition: opacity 0.3s ease;
}
	.scrolldown span{
		right: 33px;

}
	}



/* ---------------------------------------------------------------------------------------------

　   ロゴループ

--------------------------------------------------------------------------------------------- */
/*
右から左へ
----------------------------*/
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

/*
IE11対策
----------------------------*/
_:-ms-lang(x)::-ms-backdrop,
.d-demo {
  display: -ms-grid;
  overflow: hidden;
}
/*----------------------------*/

.d-demo__wrap {
  display: flex;
  overflow: hidden;
}

.d-demo__list {
  display: flex;
  list-style: none;
}

.d-demo__list--left.infinity-scroll {
    animation: infinity-scroll-left 95s infinite linear 0.5s both;
}

.d-demo__item {
  margin: 0 40px;
}
.d-demo__item > img{
   width: auto;
    height: 40px;
}



/* ---------------------------------------------------------------------------------------------

　   ボタン

--------------------------------------------------------------------------------------------- */
.hover_btn:hover {
    color: white;
    background: #D5B200;
}
.hover_btn:hover img {
    content: url(../img/arrow-white.svg);
}
.hover_btn2:hover {
    color: white;
    background: #D5B200;
}
.hover_btn2:hover img {
    content: url(../img/arrow-down-white.png);
}
.hover_btn3:hover {
    color: white;
    background: #D5B200!important;
}
.hover_btn4:hover {
    color: white;
    background: #172051!important;
}

/* ---------------------------------------------------------------------------------------------

　   #sec01,sec02

--------------------------------------------------------------------------------------------- */
h1 {
    padding-top: 40px;
}
.d-demo {
    margin-top: 1%;
}
#sec01 .sec-ttl {
    margin: 13% 0;
}

.big-ttl{
	padding: 6% 0 6% 10%;
	max-width: 1300px;
}
.big-ttl p {
    font-weight: lighter;
    margin-top: 2%;
    letter-spacing: 0px;
}
.btn {
	color: white;
	background: #172051;
display: flex;
    width: 320px;
    padding: 22px 32px;
    text-align: center;
    border-radius: 50px;
    align-items: center;
    justify-content: space-between;
	transition: background 0.3s, color 0.3s;
}
.btn img {
    width: 13%;
}

h2 {
    font-size: 56px;
    font-weight: bold;
    line-height: 1em;
    margin: 10px 0 30px 0;
}
h3 {
    font-size: 16px;
    font-family: "Montserrat";
    font-weight: 800;
	letter-spacing:0;
}

.ttl-img {
    font-weight: bold;
}


p.aimlogo {
    width: 50%;
	margin:30px 0;
}

.overlay-img {
  width: 52%;
    position: absolute;
    bottom: -15%;
    left: -15%;
}

#sec02 {
    background-image: url("../img/blue_bg.png");
    background-size: cover;
    background-position: top;
    background-repeat: no-repeat;
	padding-bottom: 16%;
}
.sec02_margin {
    margin: 0% 4%;
}
.sec02_wrapper {
    margin: auto;
    max-width: 1200px;
}

p.sec02_wrapper_text {
	padding-top: 8%;
	margin: 3% 0;
    text-align: center;
    font-weight: bold;
    font-size: 22px;
}
span.sec02_wrapper_bigtext {
    font-size: 45px;
}
.sec02_wrapper_problem {
    display: grid;
    grid-template-columns: 23% 23% 23% 23%;
    gap: 2.6%;
}


.sec02_wrapper_problem_item_ttl{
	width: 23%;
    margin: auto;
    display: block;
}

.sec02_wrapper_problem_item_bg {
	height: 300px;
    background: white;
    padding: 8%;
    border-radius: 10px;
    margin-top: -12%;
	box-shadow: 0px 0px 16px 0px rgba(191, 191, 191, 0.25);
}

.sec02_wrapper_problem_item_illust{
	width: 50%;
    margin: auto;
    display: block;
    margin-top: 12%;
    margin-bottom: 10%;
}

.sec02_wrapper_problem_item_text {
	letter-spacing: 0;
	font-size: 16px;
    display: flex;
    font-weight: bold;
    align-items: flex-start;
}

.sec02_wrapper_problem_item_text img {
    width: 7%;
}

.sec02_wrapper_problem_item_text p {
    margin: 0% 0 1% 5%;
}
.sec02_wrapper_solution {
    display: grid;
    grid-template-columns: 23% 23% 23% 23%;
    gap: 2.6%;
}
.sec02_wrapper_solution_item_bg{
	position: relative;
}
.sec02_wrapper_solution_item_picture{
    box-shadow: 0px 0px 16px 0px rgba(191, 191, 191, 0.25);
}
.sec02_wrapper_solution_item_ttl{
	width: 23%;
    margin: auto;
    display: block;
}
.sec02_wrapper_solution_item_ttl {
  position: absolute; /* 絶対的な配置を指定 */
  top: -18%; /* 上端に配置 */
  left: 38%; /* 左端に配置 */
}
.sec02_wrapper_solution_item_bigttl{
	font-size: 25px;
	font-weight: bold;
	line-height: 1.4;
	margin: 7% 0;
	text-align: center;
	height: 4.2em;
}
.sec02_wrapper_arrow{
	margin: 3% 0 4% 0;
}

#functions_sec03_02_pc .slick-slide img{
	box-shadow: none;
}


@media (min-width: 769px) and (max-width: 895px) {
		.sec02_wrapper_solution_item_bigttl {
			    font-size: 20px;
	}
}
@media (min-width: 769px) and (max-width: 1170px) {

}
@media (min-width: 481px) and (max-width: 768px) {
		.btn {
    margin: 0% auto;
    width: 40%;
    padding: 14px;
}
	section#sec02 .btn {
    margin: 13% auto;
}
		.big-ttl img {
    width: 85%;
}

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

  #main {
	  padding-top: 60px;
  }
#sec02 {
    background-image: url("../img/blue_bg_sp.png");
	background-size: cover;
	padding-bottom: 10%;
}
}
@media only screen and ( max-width : 760px ){
h1 {
     padding-top: 0px;
}

	h2 {
	letter-spacing: 0;
    font-size: 42px;
    font-weight: bold!important;
	line-height: 1.3!important;
}
	.sec02_margin {
    margin: 0% 8%;
}
  .big-ttl {
    padding: 10% 5%;
    max-width: 768px;
}
	.d-demo {
    margin-top: 7%;
    margin-bottom: 4%;

}
.d-demo__item {
    margin: 0 20px;
}
	.d-demo__item > img {
    width: auto;
    height: 30px;
}
	p.sec02_wrapper_text{
		font-size: 18px;
		padding-top: 26%;
    margin: 0% 0;
	}
span.sec02_wrapper_bigtext {
    font-size: 32px;
    line-height: 1.6;
}
	.sec02_wrapper_problem {
    display: flex;
    flex-direction: column;
}
	.sec02_wrapper_problem_item_ttl {
    width: 19%;
    margin: auto;
    display: block;
}
	.sec02_wrapper_problem_item {
    margin-top: 6%;
}
	.sec02_wrapper_problem_item_bg {
    display: flex;
    height: 145px;
    background: white;
    padding: 4% 3% 0%;
    border-radius: 10px;
    margin-top: -9%;
    box-shadow: 0px 0px 16px 0px rgba(191, 191, 191, 0.25);
    align-items: center;
}
	.sec02_wrapper_problem_item_text p {
    font-size: 14px;
}
	.sec02_wrapper_solution_item_bigttl {
		margin: 6% 0 5% 0;
		height: auto;
	}
	.sec02_wrapper_problem_item_illust {
    width: 22%;
    margin: auto;
    display: block;
    margin-top: 0%;
    margin-bottom: 2%;
}
	.sec02_wrapper_problem_item_texts {
    width: 67%;
}
	.sec02_wrapper_problem_item_bg03{
		height: 170px;
	}
	#sec02 .sec-ttl {
    margin: 9% 7%;
}
	.sec02_wrapper_solution {
    display: flex;
    flex-direction: column;
}
	.sec02_wrapper_solution_item_ttl {
    position: absolute;
    top: -18%;
    left: 41%;
}
	.sec02_wrapper_solution_item {
    padding-bottom: 20%;
}
	.sec02_wrapper_solution_item_ttl {
    width: 19%;
    margin: auto;
    display: block;
}
	.sec02_wrapper_arrow_sp{
		margin: 10% 0 17% 0;
	}
	.ttl-img {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 5px;
}

	.overlay-img {
    width: 65%;
    position: absolute;
    bottom: -40%;
    left: -11%;
}


	.big-ttl p {
    font-weight: lighter;
    margin-top: 2%;
    font-size: 8px;
}
	.txt-info {
    font-size: 14px;
    margin: 0%;
}


	h3{
		font-size: 16px;
	}

	.sec02-pc{
		display: none;
	}
}
@media (min-width: 761px) and (max-width: 768px) {
h1 {
     padding-top: 0px;
}

	h2 {
	letter-spacing: 0;
    font-size: 42px;
    font-weight: bold!important;
	line-height: 1.3!important;
}
	.sec02_margin {
    margin: 0% 8%;
}
  .big-ttl {
    padding: 10% 5%;
    max-width: 768px;
}
	.d-demo {
    margin-top: 7%;
    margin-bottom: 4%;

}
.d-demo__item {
    margin: 0 20px;
}
	.d-demo__item > img {
    width: auto;
    height: 30px;
}
	p.sec02_wrapper_text{
		font-size: 18px;
		padding-top: 26%;
    margin: 0% 0;
	}
span.sec02_wrapper_bigtext {
    font-size: 32px;
    line-height: 1.6;
}
	.sec02_wrapper_problem {
    display: flex;
    flex-direction: column;
}
	.sec02_wrapper_problem_item_ttl {
    width: 15%;
    margin: auto;
    display: block;
}
	.sec02_wrapper_problem_item {
    margin-top: 6%;
}
	.sec02_wrapper_problem_item_bg {
    display: flex;
    height: 220px;
    background: white;
    padding: 7% 3% 0%;
    border-radius: 10px;
    margin-top: -9%;
    box-shadow: 0px 0px 16px 0px rgba(191, 191, 191, 0.25);
    align-items: center;
}
	.sec02_wrapper_problem_item_text p {
    font-size: 14px;
}
	.sec02_wrapper_problem_item_text p {
    margin: 1% 0 0% 5%;
}
	.sec02_wrapper_solution_item_bigttl {
		margin: 6% 0 5% 0;
		height: auto;
	}
	.sec02_wrapper_problem_item_illust {
    width: 22%;
    margin: auto;
    display: block;
    margin-top: 0%;
    margin-bottom: 2%;
}
	.sec02_wrapper_problem_item_texts {
    width: 67%;
}
	.sec02_wrapper_problem_item_bg03{
		height: 190px;
	}
	#sec02 .sec-ttl {
    margin: 9% 7%;
}
	.sec02_wrapper_solution {
    display: flex;
    flex-direction: column;
}
	.sec02_wrapper_solution_item_ttl {
    position: absolute;
    top: -12%;
    left: 43%;
}
	.sec02_wrapper_solution_item {
    padding-bottom: 20%;
}
	.sec02_wrapper_solution_item_ttl {
    width: 15%;
    margin: auto;
    display: block;
}
	.sec02_wrapper_arrow_sp{
		margin: 10% 0 17% 0;
	}
	.ttl-img {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 5px;
}

	.overlay-img {
    width: 65%;
    position: absolute;
    bottom: -40%;
    left: -11%;
}


	.big-ttl p {
    font-weight: lighter;
    margin-top: 2%;
    font-size: 8px;
}
	.txt-info {
    font-size: 14px;
    margin: 0%;
}


	h3{
		font-size: 16px;
	}

	.sec02-pc{
		display: none;
	}
}

@media only screen and ( max-width : 480px ) {
	.btn {
    margin: 15% auto;
    width: 70%;
    padding: 3px 14px;
}

	.big-ttl img {
    width: 90%;
}


}
@media (min-width: 836px) and (max-width: 1250px) {
	#main {
	padding-top: 80px;
	}

}
@media print, screen and ( min-width : 1251px ) {

}
@media only screen and ( max-width : 760px ) {
	.function_wrapper_imgtext_area_img_sp{
	display: block!important;
	position: relative;
    width: 110%;
    height: 250px;
	}
}
@media (min-width: 761px) and (max-width: 768px) {
	.function_wrapper_imgtext_area_img_sp{
		width: 85%;
		height: 430px;
		display: block!important;
	position: relative;
	}
}

/* ---------------------------------------------------------------------------------------------

　   #sec03

--------------------------------------------------------------------------------------------- */
#sec03 {

}
#sec03 h2{
	margin: 1% 0 3% 0;
}
.sec03_bg{
	 margin-top: -8%;
    line-height: 0;
    background: transparent;
}
.btn_white {
	background: white;
display: flex;
    width: 330px;
    font-weight: bold;
    border: 1px solid #172051;
    padding: 25px;
    text-align: center;
    border-radius: 50px;
    align-items: center;
    justify-content: space-between;
	transition: background 0.3s, color 0.3s;
}
.btn_white img {
    width: 13%;
}
#sec03 .btn_white{
	margin: 3% auto 0 auto;
}

.function_wrapper {
	color: white;
    background: #172051;
	padding: 7% 0;
	margin-top: -1px;
}
p.function_wrapper_text {
	margin: 0 4%;
	font-size: 16px;
    text-align: center;
	font-weight: bold;
}

#sec03 .sec-ttl{
	text-align: center;
}
.function_wrapper_imgtext_area_texts {
    display: grid;
    grid-template-columns: 48% 48%;
    gap: 4%;
    width: 100%;
    margin: 7% 3% 5% 1%;
}
.function_wrapper_imgtext_area_img02,.function_wrapper_imgtext_area_img03, .function_wrapper_imgtext_area_img04, .function_wrapper_imgtext_area_img05, .function_wrapper_imgtext_area_img06 {
    display: none; /* 両方の画像を初期状態では非表示 */
}

.function_wrapper_imgtext_area_text01,.function_wrapper_imgtext_area_text02, .function_wrapper_imgtext_area_text03, .function_wrapper_imgtext_area_text04, .function_wrapper_imgtext_area_text05, .function_wrapper_imgtext_area_text06 {
    background: white;
    color: #172051;
    display: inline-block;
	border-radius: 10px;
	padding: 4% 7% 7% 7%;
	line-height: 1.7;
	font-weight: bold;
	transition: transform 0.3s ease;
}
.function_wrapper_imgtext_area_text01:hover,
.function_wrapper_imgtext_area_text02:hover,
.function_wrapper_imgtext_area_text03:hover,
.function_wrapper_imgtext_area_text04:hover,
.function_wrapper_imgtext_area_text05:hover,
.function_wrapper_imgtext_area_text06:hover {
    transform: translateY(-5px);
}

.function_wrapper_imgtext_area_text01_ttl img,.function_wrapper_imgtext_area_text02_ttl img, .function_wrapper_imgtext_area_text03_ttl img, .function_wrapper_imgtext_area_text04_ttl img, .function_wrapper_imgtext_area_text05_ttl img,.function_wrapper_imgtext_area_text06_ttl img   {
    width: 10%;
    margin-right: 4%;
}

.function_wrapper_imgtext_area_text01_ttl,.function_wrapper_imgtext_area_text02_ttl, .function_wrapper_imgtext_area_text03_ttl, .function_wrapper_imgtext_area_text04_ttl, .function_wrapper_imgtext_area_text05_ttl, .function_wrapper_imgtext_area_text06_ttl {
    display: flex;
    font-size: 21px;
    font-weight: bold;
    align-items: center;
	padding-bottom: 1%;
    margin-bottom: 3%;
    border-bottom: 1px solid #E4E4E4;
}
img.function_wrapper_imgtext_area_img01,img.function_wrapper_imgtext_area_img02, img.function_wrapper_imgtext_area_img03, img.function_wrapper_imgtext_area_img04, img.function_wrapper_imgtext_area_img05, img.function_wrapper_imgtext_area_img06 {
    width: 52%;
    margin-left: -10%;
    margin-bottom: 6%;
}
.function_wrapper_imgtext_area {
    display: flex;
    align-items: flex-end;
}
.function_wrapper_imgtext_area_img_sp{
	display: none;
}
@media only screen and ( max-width : 768px ) {
	#sec03 h3{
		display: block;
    margin: auto;
	}

	.function_wrapper_imgtext_area {
    display: flex;
    flex-direction: column;
    align-items: center;
}
	img.function_wrapper_imgtext_area_img01, img.function_wrapper_imgtext_area_img02, img.function_wrapper_imgtext_area_img03, img.function_wrapper_imgtext_area_img04, img.function_wrapper_imgtext_area_img05, img.function_wrapper_imgtext_area_img06 {
    width: 100%;
    margin-bottom: 2%;
}
	.function_wrapper_imgtext_area_text01, .function_wrapper_imgtext_area_text02, .function_wrapper_imgtext_area_text03, .function_wrapper_imgtext_area_text04, .function_wrapper_imgtext_area_text05, .function_wrapper_imgtext_area_text06 {
    background: white;
    color: #172051;
    display: inline-block;
    border-radius: 10px;
    padding: 4% 5% 7% 5%;
    margin-bottom: 5%;
}

	.function_wrapper_imgtext_area_img_sp li{
		list-style: none;
        width: 100%;
        height: 100%;
	}
	.function_wrapper_imgtext_area_img_sp img{
          position: absolute;
          left: 0;
          top: 0;
          width: 100%;
   }
	#sec03 .btn_white {
    margin: 0%;
    width: 100%;
	margin-top: 5%;
	padding: 23px 32px;
}
	p.function_wrapper_text {
    text-align: start;
    margin: 7% 0 20% 0;
}
	#sec03 h2 {
    margin: 0% 0 5% 0;
}
.function_wrapper_imgtext_area_texts {
    display: flex;
    width: 100%;
    margin: 5%;
    flex-direction: column;
	padding: 0 3%;
}
	.function_wrapper {
    color: white;
    background: #172051;
    padding: 25% 5%;
}
	.function_sec03_wrapper_items_item_imgtxt .btn {
    margin-top: 10%;
    width: 100%;
    padding: 15px 20px;
}
}



/* ---------------------------------------------------------------------------------------------

　   #sec04

--------------------------------------------------------------------------------------------- */
#sec04 {

}
.sec04_wrapper{
	margin: 7% 0 7% 7%;
}
.sec04_wrapper .sec-ttl p {
	font-size: 16px;
    font-weight: bold;
}
.sec04_margin {
    max-width: 1200px;
    margin: auto;
}
.sec04_wrapper_prize {
    margin: 0 16%;
}
p.sec04_wrapper_prize_text {
    margin: 1% 0 0 0;
    display: flex;
    font-size: 10px;
	etter-spacing: 0;
    color: #9D9D9D;
    justify-content: space-evenly;
}
#sec04 .slider01-img {
    box-shadow: none;
	transition: color 0.3s ease;
}
.slider01-img:hover :not(span) {
  color: #d5b200; /* ホバー時の文字色 */
}


.slider01 img {
  transition: filter 0.3s ease; /* 変化の速度を設定 */
}

.slider01 img:hover {
  filter: brightness(110%); /* ホバー時に明るさを110%に設定 */
}
.sec04_wrapper .slider01-img img {
    background: white;
    object-fit: contain;
    padding: 15%;
}
p.case-ttl {
    font-size: 16px;
    font-weight: bold;
    margin: 5% 0% 3% 0
}

p.case-com {
    font-size: 12px;
}

#sec04 .btn {
    margin-left: auto;
    margin-right: 8%;
	padding: 23px 28px;
	width: 330px;
}

@media only screen and ( max-width : 768px ) {

	.sec04_wrapper {
    margin: 25% 0;
}

	#sec04 h2{
		text-align: center;
		margin-bottom: 8%;
		margin-top: 0;
	}
	#sec04 h3{
		display: block;
		margin: auto;
	}
	#sec04 .slider01 .slick-list {
    margin: 12px 0 40px 7%;
}
	p.sec04_wrapper_prize_text {
    margin: 3% 0 0 0;
	}
	.sec04_wrapper_prize {
    margin: 0 6%;
}
	#sec04 p.case-ttl {
    font-size: 16px;
    font-weight: bold;
		margin: 3% 0 1% 0;
	}

	.sec04_wrapper .slider01-img img{
		padding: 18%;
	}
.sec04_wrapper .slide-arrow,.sec06_wrapper .slide-arrow,.sec07 .slide-arrow{
  margin-left: 7% !important;
}

#sec04 .btn {
	margin: 29% auto 17%;
    width: 85%;
    padding: 22px 32px;
    margin-bottom: 130px;
}
	#sec04 .sec-ttl{
		margin: 5% 8% 12% 8%;
	}
	}



/* ---------------------------------------------------------------------------------------------

　   #sec05

--------------------------------------------------------------------------------------------- */

#sec05 {
    position: relative;
	padding-bottom: 12%;
}
.sec05_bg {
	background-image: url("../img/blue_flow_bg.png");
    z-index: -1;
    height: 100%;
    width: 100%;
    left: 0;
    top: 0;
    position: absolute;
    background-position: top left;
    background-size: 100%;
    background-repeat: no-repeat;
}
.sec05_margin{
	margin: 0% 5%;
}
.sec05_wrapper{
	margin: auto;
    max-width: 1200px;
	padding: 0 18% 12% 18%;
}
#sec05 .sec-ttl{
	margin-top: 29%;
	text-align: center;
	margin-bottom: 5%;
}
p.sec05_wrapper_flow_step_text {
    color: #d5b201;
    line-height: 1em;
    display: flex;
    flex-direction: column;
    font-size: 38px;
    font-weight: 600;
    letter-spacing: 1px;
    font-family: "Montserrat";
    margin: 10% 0;
    width: 50%;
    align-items: center;
}
.sec05_wrapper_flow {
    display: grid;
    grid-template-columns: 20% 75%;
    gap: 5%;
}
.sec05_wrapper_flow_step_bg{
	position: relative;
    width: 100%;
    background-image: url(../img/flow_bg.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
p.sec05_wrapper_flow_step_text.sec05_border {
    font-family: 'Noto Sans JP';
    font-weight: 100;
	font-size: 30px;
}
.sec05_wrapper_flow_step {
    position: absolute;
    top: 11%;
    left: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.sec05_wrapper_flow_text {
    padding: 5% 3%;
    margin: 10px 0;
	font-weight: 500;
}
.sec05_wrapper_flow_texts {
    padding: 19% 0;
}

span.sec05_wrapper_flow_step_text_small {
    text-align: center;
    font-weight: bold;
    font-size: 14px;
    letter-spacing: 1px;
    font-family: "Montserrat";
}
p.sec05_wrapper_flow_text_ttl {
    font-size: 2.3em;
    font-weight: bold;
}
p.sec05_wrapper_flow_step_text.sec05_border.sp {
    text-align-last: center;
}
@media (min-width: 1700px) {
.sec05_border {
    margin: 6% 0!important;
}
	.sec05_wrapper_flow_text {
    padding: 5% 3%;
    margin: 10px 0;
    letter-spacing: 0;
}
	.sec05_wrapper_flow_step {
    top: 12%;
	}
	p.sec05_wrapper_flow_step_text.sec05_border {
    font-size: 53px;
}
	.sec05_wrapper {
    margin: auto;
    max-width: 1200px;
    padding: 0 14% 12% 14%;
}
	}
@media (min-width: 1190px) and (max-width: 1699px) {
.sec05_wrapper_flow {
    display: grid;
    grid-template-columns: 20% 75%;
    gap: 5%;
}
.sec05_wrapper_flow_step_bg{
	position: relative;
    width: 100%;
    background-image: url(../img/flow_bg.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.sec05_wrapper_flow_step {
    position: absolute;
    top: 8%;
    left: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.sec05_wrapper_flow_text {
    padding: 6% 0%;
    margin: 0px 0;
}
.sec05_wrapper_flow_texts {
    padding: 10% 0;
}
p.sec05_wrapper_flow_step_text {
	color: #d5b201;
    line-height: 1em;
    display: flex;
    flex-direction: column;
    font-size: 38px;
    font-weight: 600;
    letter-spacing: 1px;
    font-family: "Montserrat";
    margin: 10% 0;
    width: 50%;
    align-items: center;
}
span.sec05_wrapper_flow_step_text_small {
    text-align: center;
    font-weight: bold;
    font-size: 14px;
    letter-spacing: 1px;
    font-family: "Montserrat";
}
p.sec05_wrapper_flow_text_ttl {
    font-size: 26px;
    font-weight: bold;
}
}

@media (min-width: 852px) and (max-width: 1189px) {
	.sec05_wrapper_flow_texts {
    padding: 12% 0;
}
	.sec05_wrapper_flow_text {
    padding: 5% 3% 3% 3%;
    margin: 13px 0;
	letter-spacing: 0;
}
	p.sec05_wrapper_flow_step_text {
    color: #d5b201;
    line-height: 1em;
    display: flex;
    flex-direction: column;
    font-size: 38px;
    font-weight: 600;
    letter-spacing: 1px;
    font-family: "Montserrat";
    margin: 9% 0;
    width: 50%;
    align-items: center;
}
	.sec05_border {
    margin: 5% 0!important;
}
	.sec05_wrapper_flow_step {
    position: absolute;
    top: 8%;
    left: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
	p.sec05_wrapper_flow_step_text.sec05_border {
    font-family: 'Noto Sans JP';
    font-weight: 100;
    font-size: 55px;
}
	#sec05 {
		padding-bottom: 41%;
	}
.sec05_bg {
	background-image: url("../img/blue_flow_bg_sp.png");
    z-index: -1;
    height: 100%;
    width: 100%;
    left: 0;
    top: 0;
    position: absolute;
    background-position: top left;
    background-size: 100%;
    background-repeat: no-repeat;
}
}
@media (min-width: 769px) and (max-width: 851px) {

	.sec05_wrapper_flow_step_bg{
	position: relative;
    width: 100%;
    background-image: url(../img/flow_bg_sp.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
	.sec05_wrapper {
    margin: auto;
    max-width: 1200px;
    padding: 0 15% 12% 15%;
}
	p.sec05_wrapper_flow_step_text{
		font-size: 2.6em;
		margin: 8% 0;
	}
	.sec05_border {
    margin: 17% 0!important;
    font-size: 3.3em!important;
    font-weight: lighter!important;
    font-family: 'Noto Sans JP'!important;
}
	p.sec05_wrapper_flow_text_ttl{
		font-size: 2em;
	}
	.sec05_wrapper_flow_step {
    top: 6%!important;
}
	.sec05_wrapper_flow_texts {
    padding: 11% 0;
}
	.sec05_wrapper_flow_text {
    padding: 6% 3%;
    margin: 10px 0;
}
}

@media (min-width: 569px) and (max-width: 768px) {
	.sec05_wrapper_flow_step {
    top: 10%;
	}
	p.sec05_wrapper_flow_step_text.sec05_border.sp {
    width: 10%;
		margin: 0;
}
	p.sec05_wrapper_flow_step_text {
    font-size: 38px;
    margin: 9% 0;
}
	.sec05_border {
    font-weight: lighter!important;
    font-family: 'Noto Sans JP'!important;
}
	.sec05_wrapper_flow_texts {
    padding: 18% 0;
}
	.sec05_wrapper_flow_text {
    padding: 6% 3%;
    margin: 10px 0;
}
	.sec05_wrapper_flow_text p.sec05_wrapper_flow_text_ttl {
    font-size: 2em!important;
}
		.sec05_margin {
    margin: 0% 9%;
}
		#sec05 .sec-ttl{
		margin-top: 47%;
	}
		#sec05 h3{
		display: block;
		margin: auto;
	}
		.sec05_wrapper {
    padding: 0;
}
	#sec05 {
		padding-bottom: 41%;
	}
		.sec05_bg {
    background-image: url("../img/blue_flow_bg_sp.png");
}
		span.sec05_wrapper_flow_step_text_small {
    font-size: 12px;
}
		.sec05_wrapper_flow {
    display: grid;
    grid-template-columns: 22% 71%;
    gap: 7%;
}
}

@media (min-width: 490px) and (max-width: 568px) {
	.sec05_border {
    margin: 15% 5% 17% 5%!important;
    font-weight: lighter!important;
    font-family: 'Noto Sans JP'!important;
}
	.sec05_wrapper_flow_step {
    top: 7%;
	}

	p.sec05_wrapper_flow_step_text{
	    font-size: 27px;
    margin: 0% 0;
	}
	.sec05_wrapper_flow_texts {
    padding: 20% 0;
}
	p.sec05_wrapper_flow_text_ttl {
    font-size: 1.7em;
    font-weight: bold;
}
	p.sec05_wrapper_flow_step_text.sec05_border img {
    width: 32% !important;
}
		.sec05_margin {
    margin: 0% 9%;
}
		#sec05 .sec-ttl{
		margin-top: 47%;
	}
		#sec05 h3{
		display: block;
		margin: auto;
	}
		.sec05_wrapper {
    padding: 0;
}
	#sec05 {
		padding-bottom: 41%;
	}
		.sec05_bg {
    background-image: url("../img/blue_flow_bg_sp.png");
}

		span.sec05_wrapper_flow_step_text_small {
    font-size: 12px;
}
		.sec05_wrapper_flow {
    display: grid;
    grid-template-columns: 22% 71%;
    gap: 7%;
}
}

@media (min-width: 400px) and (max-width: 489px){
	p.sec05_wrapper_flow_step_text.sec05_border img{
		width: 45% !important;
	}
	.sec05_wrapper_flow_texts {
    padding: 17% 0;
}
		p.sec05_wrapper_flow_step_text {
    font-size: 27px;
	font-weight: 600;
			margin: 0;
	}
	p.sec05_wrapper_flow_text_ttl {
    font-size: 1.6em;
}
	#sec05 {
		padding-bottom: 41%;
	}
		.sec05_bg {
    background-image: url("../img/blue_flow_bg_sp.png");
	
}
	.sec05_wrapper_flow_step_bg{
	position: relative;
    width: 100%;
    background-image: url(../img/flow_bg_sp.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
	.sec05_wrapper_flow_step {
    top: 7%;
	}

	.sec05_border {
    margin: 0% 5% 5% 5%!important;
    font-weight: lighter!important;
    font-family: 'Noto Sans JP'!important;
    font-size: 2.7em!important;
}
	#sec05 .sec-ttl{
		margin-top: 74%;
	}

	p.sec05_wrapper_flow_text_ttl {
    font-size: 22px;
    letter-spacing: 0;
	padding-bottom: 10px;
}
	.sec05_wrapper_flow_text {
    letter-spacing: 0;
		line-height: 1.3;
		padding: 6% 3%;
    margin: 10px 0;
}
	.sec05_wrapper_flow_text p {
    line-height: 1.5;
}
		.sec05_margin {
    margin: 0% 9%;
}
		#sec05 h3{
		display: block;
		margin: auto;
	}
		.sec05_wrapper {
    padding: 0;
}
		span.sec05_wrapper_flow_step_text_small {
    font-size: 12px;
}
		.sec05_wrapper_flow {
    display: grid;
    grid-template-columns: 22% 71%;
    gap: 7%;
}
}
@media (max-width: 399px){
		p.sec05_wrapper_flow_step_text {
    font-size: 27px;
	margin: 0;
		font-weight: 600;
}
		p.sec05_wrapper_flow_step_text.sec05_border img {
    width: 50%!important;
}
		.sec05_wrapper_flow_texts {
    padding: 20% 0;
}

	p.sec05_wrapper_flow_text_ttl {
    font-size: 1.6em;
}
	#sec05 {
		padding-bottom: 41%;
	}
		.sec05_bg {
    background-image: url("../img/blue_flow_bg_sp.png");
}
	.sec05_wrapper_flow_step_bg{
	position: relative;
    width: 100%;
    background-image: url(../img/flow_bg_sp.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
	.sec05_wrapper_flow_step {
    top: 7%;
	}

	.sec05_border {
    margin: 0% 5% 5% 5%!important;
    font-weight: lighter!important;
    font-family: 'Noto Sans JP'!important;
    font-size: 2.7em!important;
}
	.sec05_margin {
    margin: 0% 9%;
}
	#sec05 .sec-ttl{
		margin-top: 69%;
	}
	p.sec05_wrapper_flow_text_ttl {
    font-size: 22px;
    letter-spacing: 0;
	padding-bottom: 10px;
}
	.sec05_wrapper_flow_text {
    letter-spacing: 0;
		line-height: 1.3;
		padding: 6% 3%;
    margin: 10px 0;
}
	.sec05_wrapper_flow_text p {
    line-height: 1.5;
}
		#sec05 h3{
		display: block;
		margin: auto;
	}
		.sec05_wrapper {
    padding: 0;
}
		span.sec05_wrapper_flow_step_text_small {
    font-size: 12px;
}
		.sec05_wrapper_flow {
    display: grid;
    grid-template-columns: 22% 71%;
    gap: 7%;
}
}






/* ---------------------------------------------------------------------------------------------

　   #sec06

--------------------------------------------------------------------------------------------- */
#sec06 {
	background: transparent;
}
.sec06_bg{
	background-image: url("../img/round_bg.png");
    background-size: cover;
	color: white;
	margin-top: -12%;
}
.sec06_margin{
	margin: 0% 0 7% 7%;
}
.sec06_wrapper {
    padding-top: 8%;
	padding-bottom: 2%;
}
.sec06_wrapper .sec-ttl p {
    font-size: 16px;
    font-weight: bold;
	letter-spacing: 0;
}

.sec06_wrapper.slider01-img img {
    padding: 10px;
    background: white;
}
.sec06_wrapper p.case-ttl {
    font-size: 16px;
    font-weight: bold;
    margin: 0;
}

#sec06 .btn_white {
    margin: 2% 8% 5% auto;
}
p.news-day {
    margin: 6% 0 0 0;
	font-size: 12px;
}

span.news-tag {
	display: inline-flex;
    margin: 10px 10px 0 0;
    background: white;
    padding: 5px 5px;
    color: #172051;
	font-size: 12px;
}
span.news-tag:hover {
  /* ホバー時のスタイル */
  color: #172051; /* ホバー時の文字色 */
}
.slider01-img img{
	padding: 10px;
	background: white;
}
@media only screen and ( max-width : 768px ) {
#sec06 {
    margin: 0% 0 5% 0%;

}
	.sec06_wrapper {
    padding-top: 33%;
	}
	.sec06_bg{
	background-image:url(../img/round_bg_sp.png);
	margin-top: -24%;
	}
	#sec06 h2{
		text-align: center;
		margin-bottom: 5%;
	}
	#sec06 h3{
		display: block;
		margin: auto;
	}
	#sec06 .sec-ttl {
    margin: 5% 7%;
}

	#sec06 .slider02 .slick-list {
    margin: 10px 0 40px 0;
}
	.sec06_margin {
    margin: 0%;
}
	#sec06 .btn_white {
    margin: 28% auto 17%;
    width: 85%;
}

	}
@media only screen and ( max-width : 480px ){
		#sec06 .btn {
  margin-top: 120px;
}
	.btn_white{
		padding: 22px 32px;
	}
}


/* ---------------------------------------------------------------------------------------------

　   #sec07

--------------------------------------------------------------------------------------------- */
#sec07 {
    margin: 7% 0 7% 7%;
}
sec07 .slider01-img img {
    padding: 22px 10px;
    background: white;
}

#sec07 .btn {
    margin-left: auto;
    margin-right: 8%;
	width: 330px;
    padding: 23px 28px;
}
#sec07 .slider01-img img{
	padding: 22px 10px;
	background: white;
}
#sec07 .sec-ttl p {
    font-size: 16px;
    font-weight: bold;
}
#sec07 .slick-list {
    margin: 40px 0 9% 0;
    font-family: 'Noto Sans JP';
}

@media only screen and ( max-width : 768px ) {
#sec07 {
    margin: 0% 0px 20% 0%;
}
	#sec07 .sec-ttl {
    margin: 20% 7% 10% 7%;
}

	#sec06 .slider02 .slick-list {
    margin: 12% 0 40px 7%;
}

	#sec07 h2{
		text-align: center;
		margin-bottom: 5%;
	}
	#sec07 h3{
		display: block;
		margin: auto;
	}
	#sec07 .btn{
		margin: 25% auto;
		width: 85%;
    padding: 22px 32px;

	}
	#sec07 .slider03 .slick-list {
    margin-left: 7%;
}
	}
@media only screen and ( max-width : 480px ){
		#sec06 .btn {
  margin-top: 120px;
}
}




/* ---------------------------------------------------------------------------------------------

　   機能一覧

--------------------------------------------------------------------------------------------- */

#functions_sec01 {
    padding-top: 80px;
    margin: 0 5%;
}

#functions_sec01 .ttl-img {
    margin-top: 30%;
}
#functions_sec01 .breadcrumb-001{
	margin: 5% 0%;
}


.functions_sec01_mv {
    display: flex;
    margin: 3% auto 0 auto;
    max-width: 1200px;
    justify-content: space-between;
}

.functions_sec01_mv img {
    width: 76%;
}

a.functions_sec02_btn {
    height: 60px;
    line-height: 1.4;
    background: #172051;
    color: white;
    display: flex;
    width: 16%;
    border-radius: 90px;
    padding: 1% 2%;
    align-items: center;
    justify-content: space-around;
}

a.functions_sec02_btn img {
    width: 13%;
    height: auto;
    margin-left: 10px;
}
a.functions_sec02_btn.sp {
    display: none;
}
#functions_sec02 {
    margin: 0 4%;
}

.functions_sec02_wrapper {
    display: flex;
    max-width: 1200px;
    margin: auto;
    justify-content: space-between;
    padding: 6% 0 3% 0;
}
.functions_bg{
	background-image: url(../img/functions_bg.png);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
	padding-bottom: 22%;
}

.function_sec03_wrapper {
    margin: 0% 11%;
}

.function_sec03_wrapper_items {
    max-width: 1200px;
    margin: auto;
}

.function_sec03_wrapper_items_ttl {
    display: flex;
    font-size: 34px;
    font-weight: bold;
    align-items: center;
	padding: 7% 0 2% 0;
}

.function_sec03_wrapper_items_ttl img {
    width: 4%;
    margin-right: 2%;
}
.function_sec03_wrapper_items_item {
    display: flex;
    justify-content: space-between;
}
.function_sec03_wrapper_items_item.sp {
    display: none;
}
.function_sec03_wrapper_items_item_imgtxt {
    width: 47%;
}

p.function_sec03_wrapper_items_item_imgtxt_txt {
    font-size: 21px;
    font-weight: bold;
    margin: 2% 0px;
}

.function_sec03_wrapper_items_item_imgtxt ul {
    list-style: disc;
    margin-left: 20px;
	font-weight: bold;
}
.function_sec03_wrapper_items_item_imgtxt .btn {
	margin-top: 10%;
	width: 320px;
    padding: 22px 32px;
}

.functions_sec04_bg {
	margin-top: -9%;
	background-image: url(../img/round_bg.png);
    background-size: cover;
}

.functions_sec04_margin {
    margin: 0% 11%;
	padding: 7% 0 12% 0;
}

.functions_sec04_wrapper {
    max-width: 1200px;
    margin: auto;
}
.functions_sec04_wrapper_item ul {
    list-style: disc;
    margin-left: 20px;
	font-weight: bold;
}
.functions_sec04_wrapper_item ul li:first-child {
    padding-bottom: 15px;
}

p.functions_sec04_wrapper_ttl {
	    padding: 23px 0;
	color: white;
    font-size: 34px;
    font-weight: bold;
	line-height: 1.5;
}
p.functions_sec04_wrapper_item_ttl {
    font-weight: bold;
    font-size: 21px;
	letter-spacing: 0;
    line-height: 1.6;
	margin-bottom: 5%;
}
p.functions_sec04_wrapper_item_ttl span {
    display: block;
    color: #d5b201;
	font-weight: bold;
    font-size: 16px;
    font-family: "Montserrat";
}
.functions_sec04_wrapper_item {
	letter-spacing: 0;
    background: white;
    padding: 9% 5%;
    border-radius: 10px;
	margin-bottom: 4%;
}
.functions_sec04_wrapper_items {
    grid-template-columns: 48% 48%;
    display: grid;
    gap: 4%;
}
#functions_sec05 .sec-ttl p {
	font-weight: bold;
}
#functions_sec05 .btn {
    margin-left: auto;
    margin-right: 15%;
}
#functions_sec05 .slider01-img img {
    background: white;
    object-fit: contain;
    padding: 15%;
}

	a.btn.sp{
	display: none;
	}

	.functions_sec05_wrapper{
		margin: 7% 0 7% 7%;
	}


@media only screen and ( max-width : 768px ) {
	#functions_sec02 {
    margin: 0 7%;
}
	#functions_sec01 {
    padding-top: 0px;
	}

	#functions_sec01 .ttl-img {
    margin-top: 0%;
}
	.functions_sec01_mv {
    display: flex;
    margin: auto;
    max-width: 1200px;
    flex-direction: column;
}
	.functions_sec01_mv img {
    width: 100%;
}
	.functions_sec02_wrapper {
    display: grid;
    grid-template-columns: 49% 49%;
    gap: 2%;
    max-width: 1200px;
    margin: auto;
    justify-content: space-between;
    padding: 20% 0 3% 0;
}
	p.functions_sec04_wrapper_ttl{
		font-size: 25px;
		text-align: center;
		margin-bottom: 9%;
	}
	a.functions_sec02_btn {
    height: 58px;
    margin-bottom: 3%;
    line-height: 1.4;
    background: #172051;
    color: white;
    display: flex;
    width: 100%;
    border-radius: 90px;
    padding: 5% 10%;
    align-items: center;
    justify-content: space-between;
}

	a.functions_sec02_btn.sp {
    display: block;
}
	a.functions_sec02_btn.pc{
		display: none;
	}
	p.functions_sec04_wrapper_item_ttl{
		margin-bottom: 10%;
	}
	.function_sec03_wrapper_items_item_imgtxt {
    width: 100%;
}
	.function_sec03_wrapper_items_item.sp {
    display: block;
}
	.function_sec03_wrapper_items_item {
    display: flex;
    flex-direction: column;
}
	.function_sec03_wrapper {
    margin: 0% 7%;
}
	.function_sec03_wrapper_items_ttl img {
    width: 9%;
    margin-right: 2%;
}
	p.function_sec03_wrapper_items_item_imgtxt_txt {
    line-height: 1.5;
		font-size: 18px;
}
	.function_sec03_wrapper_items_item_imgtxt ul {
    margin-bottom: 15%;
}
	.function_sec03_wrapper_items_ttl{
		padding: 15% 0 5% 0;
		font-size: 25px;
	}
	.functions_sec04_margin {
    margin: 0% 7%;
	padding: 30% 0 20% 0;
	}
	.functions_sec04_wrapper_items {
    display: flex;
    flex-direction: column;
}
	.functions_sec04_wrapper_item {
    margin-bottom: 8%;
	padding: 12% 8%;
}

	.functions_sec05_wrapper .sec-ttl {
    margin: 5% 8% 12% 8%;
	font-weight: bold;
    font-size: 16px;
}
	#functions_sec05 {
		margin: 25% 0;
	}
		.functions_sec05_wrapper {
		margin: 0;
	}
	.functions_sec05_wrapper h2 {
		text-align: center;
		margin-top: 0;
	}
	.functions_sec05_wrapper h3 {
		display: block;
		margin: auto;
	}
	#functions_sec05 .slider04 .slick-list {
    margin: 12px 0 40px 7%;
}
	#functions_sec05 a.btn.pc{
		display: none;
	}
	#functions_sec05 .btn {
    margin: 29% auto 17%;
    width: 85%;
    padding: 22px 32px;
    margin-bottom: 97px;
}
	#functions_sec05 a.btn.sp{
	display: flex;
	margin: 25% 0% 30% 5%;
    width: 90%;
    padding: 15px 20px;
	}

	.functions_sec04_bg {
	background-image: url(../img/round_bg_sp.png);
    background-size: cover;
	margin-top: -25%;
}
	#ai_sec04 a.btn.pc {
    display: none;
}

#ai_sec04 a.btn.sp {
    display: flex;
    margin: 25% 0% 30% 5%;
    width: 90%;
    padding: 15px 20px;
}
	.functions_bg {
    background-image: none;
		padding-bottom: 0%;
}
	section#functions_sec03 {
		background-image: url(../img/functions_bg_sp.png);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
	padding: 20% 0 30% 0;
	}
}


/* ---------------------------------------------------------------------------------------------

　   ai機能

--------------------------------------------------------------------------------------------- */

#ai_sec01 {
    padding-top: 80px;
    margin: 0 4%;
}

#ai_sec01 h2{
	margin: 15px 0 30px 0;
}
#ai_sec01 .breadcrumb-001{
	margin: 3% 0% 5% 0%;
}

.ai_sec01_mv {
    display: flex;
    margin: auto;
    max-width: 1200px;
    justify-content: space-between;
	font-weight: bold;
}
.ai_sec01_mv p {
	font-size: 16px;
    letter-spacing: 0;
}
.ai_sec01_mv img {
    width: 48%;
    height: max-content;
}
p.ai_sec01_ttl {
    font-size: 32px;
    line-height: 1.5;
    margin: 14% 0 3% 0;
}

.ai_sec01_mv h3{
	font-family: "Noto sans JP";
	font-size: 18px;
}
.ai_bg{
	margin-top: -2%;
    background-image: url(../img/blue_bg.png);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
}
.ai_sec02_wrapper_items {
    max-width: 1200px;
    margin: auto;
}

.ai_sec02_wrapper_items_ttl {
    display: flex;
    font-size: 21px;
    font-weight: bold;
    align-items: center;
	margin: 2% 0;
}

.ai_sec02_wrapper_items_ttl img {
    width: 8%;
    margin-right: 3%;
}
.ai_sec02_wrapper_items_item {
    grid-template-columns: 48% 48%;
    display: grid;
    gap: 4%;
}

.ai_sec02_wrapper_items_item_imgtxt ul {
    list-style: disc;
    margin-left: 20px;
    font-weight: bold;
}

p.ai_sec02_wrapper_items_item_imgtxt_txt {
    padding-top: 14%;
    font-size: 34px;
    font-weight: bold;
    margin-bottom: 2%;
}
.ai_sec02_wrapper_items_item_imgtxt {
    margin-bottom: 9%;
}
#ai_sec02 {
    padding-top: 80px;
    margin: 0 11%;
	padding-bottom: 27%;
}

#ai_sec02 .ttl-img {
    margin-top: 30%;
}
#ai_sec02 .breadcrumb-001{
	margin: 5% 0%;
}


.ai_sec02_mv {
    display: flex;
    margin: auto;
    max-width: 1200px;
    justify-content: space-between;
}

.ai_sec02 img {
    width: 70%;
}

#ai_sec03 {
    background: transparent;
}

.ai_sec03_bg{
	margin-top: -20%;
	background-image: url(../img/round_bg.png);
    background-size: cover;
}

.ai_sec03_margin {
    margin: 0% 11%;
}

.ai_sec03_wrapper {
    max-width: 1200px;
    margin: auto;
}
.ai_sec03_wrapper_item ul {
    list-style: disc;
    margin-left: 20px;
}
p.ai_sec03_wrapper_ttl {
	padding: 16% 0 0% 0;
    color: white;
    font-size: 34px;
    font-weight: bold;
}
p.ai_sec03_wrapper_item_ttl {
    font-weight: bold;
    font-size: 1.4em;
    line-height: 1.6;
	margin-bottom: 3%;
}
p.ai_sec03_wrapper_item_ttl span {
	padding: 0%;
    display: block;
    color: #d5b201;
    font-size: 16px;
    font-family: "Montserrat";
	letter-spacing: 0;
}
.ai_sec03_wrapper_item {
    color: white;
    border-radius: 10px;
    margin-bottom: 4%;
}

.ai_sec03_wrapper_items {
    grid-template-columns: 30% 30% 30%;
    display: grid;
    gap: 5%;
	padding: 4% 0 0 0;
}
.text_wrapper {
	margin-top: -1px;
    background: #172051;
	padding-bottom: 11%;
}
.read-more-1 {
    position: relative;
}

.read-more-1 .ai_sec03_wrapper {
    position: relative;
    max-height: 310px; /* 開く前に見せたい高さを指定 */
    margin-bottom: 0;
    overflow: hidden;
    transition: max-height 1s;
}

.read-more-1:has(:checked) .ai_sec03_wrapper {
    max-height: 180vh;
}

.read-more-1 .ai_sec03_wrapper::after {
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 140px;
    background:linear-gradient(180deg, hsla(0, 0%, 100%, 0) 0, hsl(230.69deg 55.77% 20.39% / 80%) 60%, #172051);
    content: '';
}

.read-more-1:has(:checked) .ai_sec03_wrapper::after {
    content: none;
}

.read-more-1 label {
    display: flex;
    align-items: center;
    gap: 0 4px;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    color: #ffffff;
    font-size: 16px;
	font-weight: bold;
	z-index: 10;
	justify-content: center;
}



.read-more-1:has(:checked) label {
    display: none;
}

.read-more-1 input {
    display: none;
}

.read-more-1 label img {
    width: 14%;
    margin-left: 5%;
}
.read-more-1 label img:hover {
	content: url("../img/read_more_arrow02.png");
	transition: all 0.3s ease;
}
#ai_sec04 .sec-ttl p {
    font-weight: bold;
}
#ai_sec04 .btn {
    margin-left: auto;
    margin-right: 15%;
}

.ai_sec04_wrapper{
	margin: 8% 0 7% 7%;
}
.ai_sec04_wrapper .slider01-img img {
    background: white;
    object-fit: contain;
    padding: 15%;
}

@media only screen and ( max-width : 768px ) {
	#ai_sec02 {
    padding-top: 80px;
    margin: 0 8%;
    padding-bottom: 46%;
}
	p.ai_sec02_wrapper_items_item_imgtxt_txt {
    padding-top: 10%;
	margin-bottom: 6%;
    text-align: center;
}
	p.ai_sec03_wrapper_item_ttl{
		margin-top: 1%;
	}
	#ai_sec04 {
    margin: 25% 0;
}
	.ai_sec01_mv h3 {
    font-size: 14px;
}
	#ai_sec01 h2 {
    margin: 5px 0 30px 0;
}
	#ai_sec04 .slider05 .slick-list {
    margin: 12px 0 40px 7%;
}

	#ai_sec04 .btn {
    margin: 29% auto 17%;
    width: 85%;
    padding: 22px 32px;
    margin-bottom: 97px;
}
	.slider05 .slide-arrow {
    margin-left: 7%!important;
}
	.ai_sec04_wrapper{
		margin: 0;
	}
	.ai_sec04_wrapper .sec-ttl {
    margin: 5% 8% 12% 8%;
    font-weight: bold;
    font-size: 16px;
}
	.ai_sec04_wrapper .slider04 .slick-list {
    margin: 12px 0 40px 7%;
}
	.ai_sec04_wrapper h2 {
    text-align: center;
    margin-top: 0;
}
	.ai_sec04_wrapper h3 {
    display: block;
    margin: auto;
}
	.ai_sec03_margin {
    margin: 0% 10%;
}
	.read-more-1 .ai_sec03_wrapper {
    max-height: 350px;
	}
	.read-more-1 .ai_sec03_wrapper::after{
		background: linear-gradient(180deg, hsla(0, 0%, 100%, 0) 0, hsl(230.69deg 55.77% 20.39% / 80%) 30%, #172051);
	}
	.ai_sec01_mv {
    display: flex;
    margin: auto;
    max-width: 1200px;
    justify-content: space-between;
    font-weight: bold;
    flex-direction: column;
}
	.ai_sec01_mv img {
    width: 100%;
    height: max-content;
}
	#ai_sec01 {
    padding-top: 0px;
	margin: 0 5%;
	}
	p.ai_sec01_ttl {
    font-weight: bold;
    font-size: 21px !important;
    line-height: 1.5;
    margin: 7% 0 7% 0;
}
	#ai_sec01 p{
		font-weight: bold;
		font-size: 16px;
	}

	.ai_sec02_wrapper_items_item {
    display: flex;
    flex-direction: column;
}
	.ai_sec02_wrapper_items_ttl img {
    width: 12%;
    margin-right: 6%;
}
	.ai_sec02_wrapper_items_item_imgtxt {
    margin-bottom: 10%;
}
	.ai_sec03_bg{
	margin-top: -30%;
	background-image: url(../img/round_bg_sp.png);
    background-size: cover;
}
	.ai_sec03_wrapper_items {
    display: flex;
    padding: 2% 0;
    flex-direction: column;
}
	p.ai_sec03_wrapper_ttl {
    padding: 45% 0 11% 0;
    color: white;
    font-size: 1.6em;
    text-align: center;
    font-weight: bold;
}
	.ai_sec03_wrapper_item {
    color: white;
    border-radius: 10px;
    margin-bottom: 15%;
}
	.read-more-1 label {
    bottom: 55%;
}
	.read-more-1 .ai_sec03_wrapper::after {
    height: 550px;
}
	.read-more-1:has(:checked) .ai_sec03_wrapper {
    max-height: 1200vh;
}
	.ai_bg{
	margin-top: 4%;
    background-image: url(../img/blue_bg_sp.png);
    background-size: cover;
	padding-bottom: 20%;
}
}





/* ---------------------------------------------------------------------------------------------

　   ニュース

--------------------------------------------------------------------------------------------- */
#article {
    margin: auto;
    max-width: 1300px;
    padding-bottom: 9%;
}
.pt_5{
	padding-top: 5%;
}
.news_wrapper{
	position: relative;
}
.news_wrapper #article {
    margin-top: 11%;
}
.news_wrapper_bg{
	z-index: -1;
    height: 100%;
    width: 100%;
    left: 0;
    top: 0;
    position: absolute;
    background-image: url(../img/blue_bg.png);
    background-position: 0 300px;
    background-size: 100%;
    background-repeat: no-repeat;
}
.search {
	font-family: 'Noto Sans JP';
	margin: 10% 0 8% 0;
    gap: 20px;
    display: grid;
}
.news_wrapper_sec-ttl .sec-ttl {
    margin: 5%;
}
.news-kiji {
	font-family: 'Noto Sans JP';
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    /* grid-template-rows: repeat(2, 1fr); */
    gap: 25px;
	max-width: 1200px;
    margin: auto 11%;
}
.news-kiji .slider01-img {
	margin: 0;
}
.news-kiji p.case-ttl {
    margin: 1% 0% 2% 0;
}
.news-kiji img {

}
.news-kiji .slider01-img img{
	border-radius: 0px;
	    box-shadow: 4px 4px 10px 2px rgba(191, 191, 191, 0.25);

}


.search-c span {
    border: 1px solid #172051;
    padding: 5px 15px;
	margin: 0 3px;
}
.search-c span:hover {
  background: #172051; /* ホバー時の背景色 */
  color: #ffffff; /* ホバー時の文字色（白） */
}
.color-white {
	color:#fff;
}
.search01 {
display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    position: relative;
}
.archives-title {
    width: 11%;
    min-width: 110px;
	padding: 7px 0px;
	margin:0;
}
.archives-ul {
position: relative;
    display: flex;
    width: auto;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
}
.archives-ul li {
    position: relative;
    width: auto;
margin:5px 5px;
	display: flex;
}
.archives-ul li a {
border: 1px solid #172051;
padding: 7px 13px;
    text-align: center;
    font-size: 14px;
    line-height: 1;
	transition: all 0.3s ease;
}
.archives-ul li a:hover,
.archives-ul li a.current {
	background: #172051;
   color: #ffffff;
	transition: all 0.3s ease;
}

.search02 {
    display: grid;
    grid-template-columns: 12% 88%;
}
.archives-articles {
	position: relative;
    display: flex;
    width: 100%;
    height: auto;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: flex-start;
    justify-content: center;
    align-items: flex-start;
    margin-bottom: 60px;
	    transition: all 0.3s ease;
}
.archives-articles.slick-slide {
	margin:0 20px 0 0;
}


.archives-articles-link {
position: relative;
    display: flex;
    width: 100%;
    height: auto;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: flex-start;
    justify-content: center;
    align-items: flex-start;
	    transition: all 0.3s ease;
}

.archives-articles-link img {
	    padding: 10px;
    background: white;
	width:100%;
  aspect-ratio: 64 / 39;
  object-fit: contain;
	box-shadow: 4px 4px 10px 2px rgba(191, 191, 191, 0.25);
	    transition: all 0.3s ease;
}
.archives-articles-date {
    width: 100%;
    margin-top: 20px;
    font-size: 14px;
    line-height: 1;
    font-weight: 500;
    text-align: left;
	    transition: all 0.3s ease;
}
.archives-articles-title {
    width: 100%;
    font-size: 16px;
    font-weight: 900;
    line-height: 1.7;
    margin-top: 15px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    font-feature-settings: "palt";
    letter-spacing: 0.01em;
	    transition: all 0.3s ease;
}
.archives-articles-tag {
font-size: 12px;
    background: #f0f0f0;
    padding: 5px 10px;
    margin-right: auto;
    margin-top: 20px;
    font-weight: 900;
	    transition: all 0.3s ease;
}
.archives-articles-link:hover .archives-articles-date,
.archives-articles-link:hover .archives-articles-title,
.archives-articles-link:hover .archives-articles-tag {
color: #d5b200;
}

.wp-pagenavi {/* 全体 */
    margin: 6% 0 0 0;
    font-size: 14px;
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    letter-spacing: 0;
}
.wp-pagenavi a {/* フォント色 */
    color: #4a4a4a;
	transition: all 0.3s ease;
}
.pages {/* 左の表記 */
    margin-right: 20px;
}
.wp-pagenavi .current,
.wp-pagenavi a.page {/* ボタン */
    margin: 0 6px 6px 0;
    display: inline-block;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    line-height: 40px;
    text-align: center;
}
.wp-pagenavi .current {/* カレント数字 */
    border: solid 1px #172051;
    background: #172051;
    color: #fff;
}
.wp-pagenavi a.page:hover {/* マウスオーバー */
	border: solid 1px #172051;
    background: #172051;
    color: #fff;
}
.wp-pagenavi .first,
.wp-pagenavi .extend {/* ... */
    margin-right: 10px;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {/* 記号の削除 */
    margin: 0 6px 6px 0;
    display: inline-block;
    border: solid 1px #172051;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    line-height: 40px;
    text-align: center;
	transition: all 0.3s ease;
}
.wp-pagenavi .previouspostslink:hover,
.wp-pagenavi .nextpostslink:hover {
border: solid 1px #172051;
background: #172051;
color: #fff;
}
.article-thumbnail-wrap {
position: relative;
    width: 100%;
    height: auto;
    margin: 20px auto;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: center;
    align-items: center;
}
.article-thumbnail-wrap img {
    width: auto;
    height: auto;
    max-width: 100%;
}

.article-content-wrap {
    position: relative;
    width: 100%;
    height: auto;
}
.article-content-wrap img {
    width: auto;
    height: auto;
    max-width: 100%;
}
.article-content-wrap img.alignnone {
	text-align:center;
}
.kiji a {
    color: #d5b201;
	word-break: break-all;
}
.sec_article_fv {
	display: flex;
	align-items: center;
}
.sec_article_fv img {
    width: 50%;
    margin-right: 5%;
}

.kiji h2 {
    font-size: 2em;
    font-weight: bold;
    line-height: 1.7;
}

span.kiji-tag {
    font-size: 12px;
    background: #f0f0f0;
    padding: 5px 10px;
}

.kiji h3 {
    line-height: 1.6;
    font-size: 26px;
    margin: 20px 0;
}
.kiji p {
    margin: 20px 0;
}
span.yellow-url a {
    color: #D5B200;
    text-decoration: underline;
}

.kiji table {
  margin: 0;
width: 100%;
}
.tbl-r02 th {
	vertical-align: middle;
  text-align: center;
    background: #F0F0F0;
    border: solid 1px #172051;
    padding: 20px;
}
table.tbl-r02 td {
	vertical-align: middle;
    padding: 20px;
	background: white;
}
table.tbl-r02 tr {
    border: solid 1px #172051;
}
figure.wp-block-table tr td {
    background: #FFFFFF; /* すべての td の背景色を白に設定 */
}
figure.wp-block-table tr td:first-child {
    background: #F0F0F0;
	text-align: center;
}
.wp-block-table td, .wp-block-table th {
    border: solid 1px #172051;
    padding: 20px!important;
}
.more-btn {
	display: block;
	color: #172051;
    margin: 4% auto;
    text-align: center;
    border: 1px solid #172051;
    padding: 10px;
    border-radius: 5px;
    width: 35%;
}
a.more-btn {
    color: #172051;
}
.more-btn:hover{
	background-color: #172051; /* ホバー時の背景色 */
	color: white;
	transition: background 0.3s ease;
}
.download {
    display: flex;
    align-items: center;
	margin: 4% 0;
}

.download-btn {
    background: #172051;
    color: white;
    padding: 10px;
    width: fit-content;
    border-radius: 5px;
	margin-left: 10px;
}
.download-btn:hover {
  background-color: #D5B200; /* ホバー時の背景色 */
  transition: background 0.3s ease;
}
.has-luminous-vivid-orange-background-color {
	background-color: transparent;
    color: #172051;
    margin: 4% auto;
    text-align: center;
    padding: 10px 50px;
    border-radius: 5px;
    width: 30%;
}
.has-luminous-vivid-orange-background-color:hover {
  background-color: #172051; /* ホバー時の背景色 */
color: white;
  transition: background 0.3s ease;
}
.news-btn {
	color: #172051;
	margin: 7% 0 0 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
}
.news-btn img {
    width: 4%;
    margin: 0 20px 0 0;
}
.breadcrumb-002 {
    display: flex;
    gap: 0 22px;
    list-style: none;
    padding-top: 100px;
    font-size: .9em;
    margin: 0% 5% 5% 5%;
}
.breadcrumb-002 span:not(:last-child)::after {
    display: inline-block;
    width: 0.3em;
    height: 0.3em;
    margin-left: 10px;
    content: '>';
    margin-right: 22px;
}
.breadcrumb-002 a {
    color: #B4B4B4;
    text-decoration: underline;
}
.breadcrumb-002 a.current-page {
    color: #172051;
    text-decoration: none;
}
table.tbl-r02 img {
    width: 25%;
    margin: 0;
}
.wp-block-buttons.is-content-justification-center.is-layout-flex.wp-container-core-buttons-layout-1.wp-block-buttons-is-layout-flex {
    display: block;
}
.wp-block-buttons.is-content-justification-center.is-layout-flex.wp-container-core-buttons-layout-2.wp-block-buttons-is-layout-flex {
    display: block;
}
.wp-block-buttons>.wp-block-button {
    display: block!important;
}
.wp-block-button {
    margin-top: 5% !important;
}
h2.has-medium-font-size.wp-block-heading {
    line-height: 1.6;
    font-size: 26px!important;
    font-weight: normal!important;
    margin: 20px 0;
}
h2.has-text-align-center {
}

h2.wp-block-heading {
    font-weight: normal;
}


.wp-block-button__link {
	display: block!important;
    background-color: transparent!important;
    text-align: center;
    padding: 10px 50px;
    width: 100%;
}

.wp-block-file__button {
    background: #172051!important;
    padding: 10px;
	color: #FFFFFF!important;
    width: fit-content;
    border-radius: 5px;
}
div#ez-toc-container ul.ez-toc-list a{
	color: #172051!important;
    text-decoration: underline;
    padding: 5px 0;
}
mark.has-inline-color.has-white-color {
    color: #172051;
}
mark.has-inline-color.has-white-color:hover {
    color: #FFFFFF!important;
}
.kiji {
    font-family: 'Noto Sans JP';
}
p.ez-toc-title {
    color: #172051!important;
}
@media only screen and ( max-width : 480px ) {
	.wp-block-button {
    margin-top: 10% !important;
}
	.news_wrapper_bg{
		background: none;
	}
	.news-kiji{
		display: block;
		margin: 0;
	}
.news-kiji p.case-ttl {
    margin: 1% 0% 3% 0;
}

	h2.has-medium-font-size.wp-block-heading{
		font-size: 20px!important;
	}

	.kiji h2 {
	font-size: 20px;
	margin: 10px 0;
	}
	#article {
    padding: 23% 8%;
    margin: -7% 0 0 0;
}
	#article .slider01-img {
    max-width: 100%;
    margin: 11% 0 0 0;
}
	p.case-ttl {
    font-size: 16px;
    font-weight: bold;
    margin: 3% 0 1% 0;;
}
	.news_wrapper {
		background: none;
	}

	section#article{
	background-image: url(../img/functions_bg_sp.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: top;
	}
	.wp-pagenavi {
    margin: 48% 0 6% 0;
	}
}
@media only screen and ( max-width : 900px ) {

.archives-title {
    width: 100%;
    min-width: 130px;
    margin-bottom: 10px;
}
.search01 {
flex-wrap: wrap;
}
.archives-ul li {
    position: relative;
    width: auto;
    margin: 0 12px 12px 0;
    display: flex;
}
.archives-ul li a {
    border: 1px solid #172051;
    padding: 8px 14px;
    text-align: center;
    font-size: 14px;
    line-height: 1;
    min-width: 70px;
}
	.search-c span {
    margin: 0 10px 0 0;
}
	.search-sp {
    display: flex;
    margin: 10px 0;
}
	.search{
		margin: 10% 0 10% 0;
	}
.breadcrumb-002 {
    margin: 3% 10% 10% 10%;
}
	.breadcrumb-002{
		display: block;
	}

	p.kiji-day {
    margin: 0px;
}
	.kiji h3 {
    line-height: 1.6;
    font-size: 20px;
    margin: 20px 0;
}
	.tbl-r02 th{
		border-bottom: solid 1px #172051;
		border-top: none;
    border-right: none;
    border-left: none;
	}
	.download {
    margin: 10% 0;
}
	.has-luminous-vivid-orange-background-color {
    width: 100%;
}
	.news-btn img {
    width: 10%;
    margin: 0 10px 0 0;
}
	.news-btn {
    margin: 30% 0 0 0;
}
	  .last td:last-child {
    border-bottom: solid 1px #ccc;
    width: 100%;
  }
  .tbl-r02 {
    width: 80%;
  }
  .tbl-r02 th,
  .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 100%;
  }
	table.tbl-r02 img {
    width: 45%;
    margin: 0 auto;
    display: block;
}
	.wp-block-gallery.has-nested-images figure.wp-block-image:not(#individual-image){
		width: 100%!important;
	}
			.more-btn{
		width: 100%;
	}
	figure.wp-block-table tr {
    display: flex;
    flex-direction: column;
}
	.wp-block-button__link{
		width: 100%;
	}
}
@media only screen and ( min-width : 901px ) {
	.search01-sp , .search02-sp {
		display: none;
	}
}
.wp-pagenavi .previouspostslink, .wp-pagenavi .nextpostslink {
    display: flex;
    text-align: center;
    flex-direction: column;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.previouspostslink img,
.nextpostslink img {
	transition:all .3s ease;
	padding: 8px;
}

.previouspostslink:hover img,
.nextpostslink:hover img{
filter:invert(0%) sepia(0%) saturate(0%) hue-rotate(331deg) brightness(300%) contrast(200%)
}
.nextpostslink:hover img {
  content: url("../img/slider-next-arrow.svg"); /* 画像のパスを変更 */
}

.previouspostslink:hover img {
  content: url("../img/slider-prev-arrow.svg"); /* 画像のパスを変更 */
}




/* ---------------------------------------------------------------------------------------------

　   導入事例　記事

--------------------------------------------------------------------------------------------- */

.news_wrapper_sec-ttl .sec-ttl p{
	font-size: 16px;
    font-weight: bold;
}
.news_wrapper_sec-ttl .sec-ttl h2 {
	margin: 13px 0 32px 0;
}
.news_wrapper_sec-ttl .sec-ttl {
    margin: 4% 4% 5% 4%;
}
.lower__article {
    margin: 0 8%;
	padding-bottom: 10%;
}
body.post-type-archive-case section#article .slider01-img img {
    background: white;
    object-fit: contain;
    padding: 15%;
}
section.lower {
	max-width: 1200px;
    padding-top: 80px;
    margin: auto;
}

.breadcolumn {
    margin-bottom: 5%;
	padding-top: 40px;
}

.breadcolumn__list {
    display: inline-block;
}

.breadcolumn__list:after {
    content: ">";
    margin: 0 10px;
}
.breadcolumn .breadcolumn__list:nth-of-type(3):after {
    display: none;
}

.lower__article_ttl {
    grid-template-columns: 48% 48%;
    gap: 4%;
    display: grid;
    align-items: center;
}

p.lower__column__list__logo {
    padding: 20%;
    border-radius: 10px;
    border: 1px solid #cccccc;
	background: white;
}
.lower__article_ttl .title {
    font-size: 2.3em;
    font-weight: bold;
}
.lead_area {
    grid-template-columns: 48% 48%;
    gap: 4%;
    display: grid;
    align-items: start;
	padding-bottom: 10%;
}
#ez-toc-container {
    border: none!important;
    border-radius: 10px!important;
    margin: 15% 0 5% 0!important;
    padding: 3% 5%!important;
    box-shadow: 0px 0px 16px 0px rgba(191, 191, 191, 0.25)!important;
}

section.lower h1, section.lower h2 {
    font-size: 34px!important;
	text-align: left;
	margin-bottom: 3%;
	font-weight: bold;
	padding-top: 60px;
}
.lower__article a {
    color: #d5b201;
}
section.lower p {
    margin: 2% 0;
	font-size: 16px;
}
section.lower .btn{
	gap: 7%;
    margin: 6% auto 0% auto;
    display: flex;
    color: white;
    background: #172051;
    width: 330px;
    padding: 16px 32px;
    text-align: center;
    border-radius: 50px;
    align-items: center;
    justify-content: flex-start;
    transition: background 0.3s, color 0.3s;
}
section.lower .btn p {
	font-size: 14px!important;
	width: auto;
}

.ez-toc-title-container p{
	color: #d5b201!important;
}
div#ez-toc-container nav {
    border-top: 1px solid #d5b201;
    margin-top: 1%;
    padding-top: 1%;
}
.ez-toc-counter nav ul li a::before {
    content: " ・ "!important;
}
.lower__article_imgtxt {
    gap: 20%;
    display: grid;
}
@media only screen and ( max-width : 768px ) {
	p.lower__column__list__logo {
    margin-top: 0 !important;
}
		.news_wrapper .ttl-img {
    margin-bottom: 0px;
}
.news_wrapper_sec-ttl .sec-ttl h2 {
    margin: -5px 0 20px 0;
}
	.news_wrapper_sec-ttl .sec-ttl{
		margin: 5%;
	}
	section.lower .btn{
    margin: 41% auto 0% auto;
	width: 100%;
		gap: 6%;
		padding: 11px 32px;
}
	section.lower .btn img {
    width: 15%;
}
	section.lower {
    padding: 50px 5% 23% 5%;
}
	.lower__article{
		margin: 0 3%;
	}
	.lower__article .eyecatch {
    margin: 7% 0 26% 0;
    padding: 22px 10px;
    background: white;
    box-shadow: 4px 4px 10px 2px rgb(191 191 191 / 49%);
}
	.lower__article_ttl {
    display: flex;
    align-items: center;
    margin-bottom: 10%;
    flex-direction: column;
}
	.lower__article_ttl .title {
    font-size: 1.5em;
}
	section.lower h1, section.lower h2 {
		margin-top: 10%;
		font-size: 23px !important;
	}
	section.lower p {
    margin: 5% 0 4% 0;
	width: 100%;
}
	.breadcolumn {
    margin-top: 5%;
		padding-top: 0;
}
	.lower__article_imgtxt {
    gap: 7%;
	}
	div#ez-toc-container nav {
    border-top: 1px solid #d5b201;
    margin-top: 2%;
    padding-top: 5%;
}
	#ez-toc-container {
    padding: 10% 5%!important;
		margin: 28% 0 20% 0!important;
}
	.lead_area {
    display: flex;
    align-items: start;
    margin-bottom: 10%;
    flex-direction: column;
	padding-bottom: 0;
}
}







/* ---------------------------------------------------------------------------------------------

　   お役立ち情報　記事

--------------------------------------------------------------------------------------------- */

.post-type-archive-useful-materials .news-kiji p.case-ttl {
    margin: 3% 0% 2% 0;
}
.post-type-archive-useful-materials .news-kiji .slider01-img {
    margin: 6% 0 5% 0;
}
.post-type-archive-useful-materials .slider01-img img {
    padding: 22px 10px;
    background: white;
}
.title {
    font-size: 2.3em;
    font-weight: bold;
    margin: 5% 0;
}


.wp-block-button.is-style-fill {
	max-width: fit-content;
    color: #fff;
    background-color: #d5b201 !important;
    border-radius: 9999px;
    box-shadow: none;
    cursor: pointer;
    display: inline-block;
    text-align: center;
    text-decoration: none;
    word-break: keep-all;
    box-sizing: content-box;
}
.wp-block-button.is-style-fill a {
    color: white;
}
.wp-block-button.is-style-outline {
    text-align: center;
    margin: 5% auto;
    color: #172051;
    background: white;
    border-radius: 9999px;
    box-shadow: 0px 0px 16px 0px rgb(191 191 191 / 40%);
    display: table;
    word-break: keep-all;
}
a.has-luminous-vivid-orange-background-color {
    max-width: fit-content;
    color: #fff;
    background-color: #d5b201 !important;
    border-radius: 9999px;
    box-shadow: none;
    cursor: pointer;
    display: inline-block;
    font-size: 1.125em;
    padding: 12px 20px !important;
    text-align: center;
    text-decoration: none;
    word-break: keep-all;
    box-sizing: content-box;
}
a.article-download-btn {
    padding: 15px 20px;
    text-align: center;
    margin: 5% auto;
    color: #172051;
    border: 1px solid #172051;
    background: #ffffff!important;
    border-radius: 9999px;
    box-shadow: 0px 0px 16px 0px rgb(191 191 191 / 40%);
    display: table;
    word-break: keep-all;
}
.has-background {
    padding: 3% 5%!important;
    box-shadow: 0px 0px 16px 0px rgb(191 191 191 / 44%);
    background: white!important;
    display: block;
    text-align: start!important;
    margin: auto!important;
    border-radius: 16px;
}
.article-background {
	padding: 3% 5%;
    background: white;
    border-radius: 16px;
	border: 1px solid #d5b201;
}
.lower_bg {
	position: relative;
}
.lower_bg2 {
	z-index: -1;
    height: 100%;
    width: 100%;
    left: 0;
    top: 120px;
    position: absolute;
    background-image: url(../img/article_bg.png);
    background-position: top left;
    background-size: 100%;
    background-repeat: no-repeat;
}
mark.has-inline-color {
    color: #172051 !important;
    font-weight: bold;
}
.wp-block-media-text {
	margin: 5% 0;
}

@media only screen and ( max-width : 768px ) {
	.post-type-archive-useful-materials #article .slider01-img {
    max-width: 100%;
    margin: 8% 0 0 0;
}
	a.article-download-btn{
		width: 223px;
    font-weight: bold;
    padding: 10px 20px;
	}
.title {
    line-height: 1.5;
    font-size: 1.5em;
    font-weight: bold;
    margin: 5% 0;
}
	.has-background {
    padding: 10% 5%!important;
    margin: 3% auto 20% auto!important;
}
	.lower_bg {
	position: relative;
}
	.lower_bg2 {
	z-index: -1;
    height: 100%;
    width: 100%;
    left: 0;
    top: 120px;
    position: absolute;
    background-image: url(../img/article_bg_sp.png);
    background-position: top left;
    background-size: 100%;
    background-repeat: no-repeat;
}
	.eyecatch {
    margin: 10% 0 30% 0;
}
	}