/* CSS Document */


body {
	margin-top:-24px;}
@media (min-width: 1301px) {
}

@media (min-width: 1201px) {

.cd-menu ul.menu a {
	color: #fff;
}
.cd-menu ul.menu li:after {
	border-bottom: 1px solid #fff;
}
.cd-menu ul.menu li:hover:after {
	border-bottom: 1px solid #fff;
}
/* スクロール後 */
header.scrolled {
	background: #111c43;
}

.top .col-60 { width:70%;padding-right: 0%;padding-left: 0%;}
.top .col-40 { width:30%;padding-right: 0%;padding-left: 0%;}

.vew {
	padding-left: 100px;
}

}
@media (max-width: 1200px) {
   .header-inner {
   }
.hamburger span{
    background-color: #999;
}
   .header-info {
	/*background-color: #000227;*/
	background-color: transparent;
	}
.cd-menu ul.menu a {
	color: #000 !important;
}
.cd-menu ul.menu .menu_contact {color:#fff !important;
}
/* スクロール後 */
header.scrolled {
	background: #000227;
}
}

header {
	background: transparent;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.0);
}

.cd-menu ul.menu a {
	color: #fff;
}
.cd-menu ul.menu li:after {
	border-bottom: 1px solid #fff;
}
.cd-menu ul.menu li:hover:after {
	border-bottom: 1px solid #fff;
}

/* スクロール後 */
header.scrolled {
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}
.top {
	background: url(../images/bg07.avif) bottom center / cover;
	/*height:110vh;*/
	height:auto;
	padding-top:120px;
	position:relative;
}
.h1test { position:fixed; z-index:1; color:#f00; top:100px;writing-mode: vertical-rl; font-size:24px;}
.top .inner {
	max-width: 1300px;
	padding-bottom:100px;
}

.top .h1sub { font-size:24px; text-align:center; color:#fff; margin-bottom:10px;}
.top h1 {
	font-size: 60px;
	font-weight: 900;
	text-align: center;
	color: #fff;
	line-height: 1.2em;
	margin-bottom: 0.5em;
}
.top h1 span {font-size: 80px; color:#f00;}
.top .msg { font-size:16px; margin-bottom:20px; text-align:center;}
.top ul.ulmerit {
	display: flex;
	justify-content: center;
	margin-bottom:5%;
}
.top ul.ulmerit li {
	margin-right: 15px;
	margin-left: 15px;
}

/* Slider control */
.sliderArea {
	max-width: 100%;
	margin: 0 auto;
	padding: 0;
}
.sliderArea.w300 {
	max-width: 300px;
}
.sliderArea .slick-slide {
	margin: 0 5px;
}
.sliderArea .slick-slide img {
	width: 100%;
	height: auto;
}
.sliderArea .slick-prev, .slick-next {
	z-index: 1;
}
.sliderArea .slick-prev:before,.sliderArea .slick-next:before {
	color: #fff !important;
}
.sliderArea .slick-slide {
/*	transition: all ease-in-out .3s;*/
	opacity: .2;
}
.sliderArea .slick-active {
	opacity: 1;
}
.sliderArea .slick-current {
	opacity: 1;
}
.sliderArea .thumb {
	margin: 20px 0 0;
}
.sliderArea .thumb .slick-slide {
	cursor: pointer;
}
.sliderArea .thumb .slick-slide:hover {
	opacity: .7;
}
/* Slider contents */
.section {
	margin: 0 auto;
	padding: 0px 30px;
}
.slider div {
	position:relative;
}
.slider div p {
	position: absolute;
	bottom: 0;
	width: 100%;
	color: #fff;
	text-align: center;
	background-color: rgba(0,102,204,0.5);
	display: inline-block;
	margin-bottom: 0px;
	padding-top: 1%;
	padding-bottom: 1%;
}

ul.userlogo {
	max-width: 1000px;
	margin-right: auto;
	margin-left: auto;
	display: flex;
	flex-wrap: wrap;
	align-content: center;
}
ul.userlogo li {
	width: 21%;
	margin-right: 2%;
	margin-bottom: 2%;
	margin-left: 2%;
	text-align: center;
	padding: 5px 20px;
	background-color: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
	}
ul.userlogo li img {
	max-height: 60px;
}

/* section */
.sec01 {
	padding-top:100px;
	padding-bottom:100px;
}
.sec02 {
	padding-top:100px;
	padding-bottom:100px;
	background-image: linear-gradient(0deg, rgba(234, 241, 250, 1) 10%, rgba(234, 241, 250, 0) 30% 70%, rgba(234, 241, 250, 1) 90%);
}
.sec03 {
	padding-top:100px;
	padding-bottom:100px;
	background-color: rgba(0, 109, 204, 0.3);
}
.sec04 {
	padding-top:100px;
	padding-bottom:100px;
}
.sec05 {
	padding-top:100px;
	padding-bottom:100px;
	background-color: rgba(0, 0, 0,0.1);
}

.sec06 {
	padding-top:100px;
	padding-bottom:100px;
	background-image: linear-gradient(0deg, rgba(0, 109, 204, 0.2) 10%, rgba(0, 109, 204, 0) 30% 70%, rgba(0, 109, 204, 0.3) 90%);
}
.sec06::after {
	background-image: url("../images/bg03.svg");
	background-repeat: repeat-y;
	background-size: 100% auto;
	background-position: top center;
}

.sec07 {
	padding-top:100px;
	padding-bottom:100px;
	/*background-image: url("../images/back01.svg");*/
	background-image: url("../images/worries_bg_pc.png.webp");
	background-repeat: repeat-y;
	background-size: 100% auto;
	background-position: top center;
}
.sec08 {
	padding-top: 100px;
	padding-bottom: 100px;
	background: url(../images/bg08.svg) center center / cover;
}
.sec09 {
	padding-top:100px;
	padding-bottom:100px;
	background-image: url("../images/bg09-l.svg"), url("../images/bg09-r.svg");
	background-repeat: repeat-y,repeat-y;
	background-size: 20% auto,20% auto;
	background-position: top left,top right;
	background-color:#ebfafd;
}

.content_box {
	background-color: #FFF;
	padding: 3%;
	border-radius: 10px;
	border: 1px solid #069;
}

/*--------  title box --*/
.title_box01 {
	background: url(../images/title_box_bg01.png) bottom center / cover;
	background-color: #036;
	color:#fff;
	padding:3%;
}

.title_box02 {
	background: url(../images/title_box_bg03.png) center center / cover;
	background-color: #091a43;
	color:#fff;
	padding:3%;
	border-radius:10px;
}

.title_box03 {
	background-color: rgba(255,255,255,0.5);
	padding: 3%;
	border-radius: 10px;
	border: 2px solid rgba(255,255,255,0.8);
}
/* ------------------------------- ギャラリー（スライダー）  -- */

.autoplay {
	display: flex;
	justify-content: space-around;
	margin-right: 30px;
	margin-left: 30px;
}
.autoplay .gallery {
  /*width: 360px;*/
  height: 280px;
  padding: 10px;
  border: 1px solid #ccc;
  border-radius:10px;
  display: flex;
  align-items: center;     /* 上下中央 */
  justify-content: center; /* 左右中央 */
  background-color: #fff;
  padding-bottom:24px;
}

.autoplay .gallery > * {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.autoplay .gallery img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
}
.autoplay .gallery p {
	/*	margin-top:-138px;*/
	display:block;
	bottom: -10px;
	width: auto;
	text-align: center;
	background-color: #fff;
	z-index: 1;
	height: 24px;
}
.autoplay .slick-prev:before,.autoplay .slick-next:before {
	color: #006dcc !important;
}
.autoplay .slick-slide {
	margin: 0 5px;
}

.dots-box {
    position: relative;
    text-align: center;
    margin: 10px 0;
}

.dots-box .dots-wrap {
    display: flex;
    justify-content: center;
}

.dots-box .dots-wrap li {
    width: auto;
    height: auto;
    margin: 0 3px;
}

.dots-box .dots-wrap li button {
    padding: 0;
    color: transparent;
    outline: none;
    width: 10px;
    border: unset;
    height: 10px;
    display: block;
    background: #ccc;
    cursor: pointer;
    border-radius: 50%;
}
.dots-box .dots-wrap li button:hover,
.dots-box .dots-wrap .slick-active button {
    background: #006dcc;
}

.youtube-box {
  width: 100%;
  aspect-ratio: 16 / 8.6;
  margin-bottom:10%;
}
.youtube-box iframe {
  width: 100%;
  height: 100%;
}



/*-------------------------------------　機能　--*/
/* 他社AIとの比較 */
.hikaku {
	background-color: #fff;
	box-shadow: 0px 0px 20px -6px rgba(0,0,0,0.8);
	border-radius: 10px;
	width:46%;
	padding: 5%;
	margin-left:2%;
	margin-right:2%;

}

.hikaku dl {
	font-size:14px;
}
.hikaku dl dt {
	font-weight: normal;
	width:30%;
	float: left;
}
.hikaku dl dd {
	padding-left: 32%;
	border-bottom: 1px double #ccc;
	margin-bottom:1em;
	padding-bottom:1em;
}


.system {
	position: relative;
}

.system .system01 {
	position: absolute;
	top: 18%;
	left: 50%;
    transform: translateX(-50%);
	width: 50%;
	text-align: left;
	font-size: 12px;
	padding: 8px;
	border: 3px solid #CCC;
	border-radius:5px;
	background-color: #fff;
}
.system .system02 {
	position: absolute;
	top: 67.5%;
	left: 0%;
	width: 48%;
	text-align: left;
	font-size: 12px;
	padding: 5px;
	border: 3px solid #CCC;
	border-radius:5px;
	background-color: #fff;
}
.system .system03 {
	position: absolute;
	top: 67.5%;
	right: 0%;
	width: 48%;
	text-align: left;
	font-size: 12px;
	padding: 5px;
	border: 3px solid #CCC;
	border-radius:5px;
	background-color: #fff;
}
.example img {
}

/*---------------------------------------  流れ ---*/
.cp_step {
	max-width: 1200px;
	margin-right: auto;
	margin-left: auto;
	padding-left:15px;
	padding-right:15px;
	margin-bottom:100px;
}
.cp_stepflow {
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 1em;
	padding: 0;
	width:100%;
	z-index:1;
}

/* Step番号の円 */
.cp_stepflow .step-header {
	width: 80px;
	height: 80px;
	background: #006dcc;
	border: 1px solid #ccc;
	border-radius: 50%;
	color: #CCCCCC;
	font-weight: normal;
	font-size: 14px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: -40px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}
.cp_stepflow .step-header span {
	font-family: serif;
	font-size: 30px;
	font-weight: bold;
	color: #fff;
}
.cp_stepflow > li {
	position: relative;
	display: block;
	background-color: #fff;
	width: auto;
	width: calc(25% - 10px);
	border: 1px solid #CCC;
	border-radius: 10px;
	margin-top: 0;
	margin-right: 5px;
	margin-top: 40px;
	margin-left: 5px;
	padding-top: 30px;
	padding-right: 20px;
	padding-bottom: 10px;
	padding-left: 20px;
}
.cp_stepflow > li .bubble {
	display: block;
	width: 15px;
	height: 15px;
	margin: 20px auto 0.5em;
	border-radius: 50%;
	background-color: #81bdc9;
}
.cp_stepflow > li .bubble::after {
	position: absolute;
	top: 9px;
	display: block;
	width: calc(100% + 15px);
	height: 2px;
	margin-top:48px;
	content: '';
	background-color: #81bdc9;
	z-index:1;
}
.cp_stepflow > li:last-child .bubble::after {
	width: 0%;
	margin-right: 50%;
}
/* アイコン */
.step-icon {
	text-align:center;
	margin-top:20px;
	margin-bottom:20px;
}
.step-icon img {
	height:40px;
}
.cp_stepflow h3 {
	font-size: 18px;
	color:#006dcc;
	margin-bottom: 10px;
	text-align: center;
}

.cp_stepflow p {
	font-size: 14px;
	line-height: 1.6;
}


/*-------------------------------------　料金　--*/
.trybtn {
	max-width: 280px;
	margin-right: auto;
	margin-bottom: 2em;
	margin-left: auto;
	text-align: center;
}
.trybtn a {
	display: block;
	background-color: #006dcc;
	border-radius:10px;
	color: #fff;
	font-size: 18px;
	font-weight: bold;
	text-decoration: none;
	padding: 7px;
}
.trybtn a:hover {
	background-color: #2186de;
}
.pricearea {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
}
.pricebox {
	position:relative;
	padding: 20px;
	width:32%;
	background-color:#fff;
	border-radius:10px;
}
.plan-badge {
	position:absolute;
	top:0;
	right:20px;
/*	background-color: #006dcc;*/
	background-color: #006dcc;
	color: #fff;
	font-size: 14px;
	display: inline-block;
	padding: 3px 10px 2px;
	border-bottom-right-radius:5px;
	border-bottom-left-radius:5px;
}
.pricebox h3 {
	font-size: 30px;
	color: #4093df;
	text-height: 1em;
	font-weight: normal;
	text-align:center;
	margin-bottom:0.5em;
}
.pricebox h3 span {
	font-size: 16px;
	color: #000;
	font-weight: bold;
	display:block;
}
.pricebox h4 {
	font-size: 14px;
	color: #000;
	padding-top: 5px;
	padding-bottom: 5px;
	font-weight: bold;
}
.price {
	font-size: 36px;
	font-weight: bold;
	text-align: center;
	vertical-align: central;
	line-height: 1em;
}
.price sub {
	font-size: 16px;
	font-weight: normal;
	padding-left:0.3em;
	padding-right:0.3em;
	vertical-align: baseline;
}
dl.dlprice {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  font-size:14px;
  margin-bottom:1em;
}
dl.dlprice dt {
	width: 50%;
	padding-top: 10px;
	padding-bottom: 10px;
	border-bottom: 1px dotted #999;
}
dl.dlprice dd {
	color: #2483D9;
	font-weight:bold;
	width: 50%;
	padding-top: 10px;
	padding-bottom: 10px;
	text-align: right;
	border-bottom: 1px dotted #999;
}
dl.child dt {
	border-bottom-style: none;
	padding-top: 5px;
	padding-bottom: 5px;
}
dl.child dd {
	border-bottom-style: none;
	padding-top: 5px;
	padding-bottom: 5px;
}

/*-------------------------------------　事例　--*/
.ulcase {}
.ulcase li {box-shadow:0px 0px 5px 0px rgba(0,0,0,0.2);}

.jirei-box {
	background-color: #fff;
	padding:20px;
	border-radius:10px;
	box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.1);
	margin-bottom:40px;
	position:relative;
	z-index:1;
}
.jirei-box-img {
	padding:20px;
	margin-left:auto;
	margin-right:auto;
}
.jirei-box-img img {
	border-radius:10px;
	width:100%;
}
.jirei-box-chd {
	padding-top: 20px;
	padding-bottom: 20px;
}
.jirei-box h3 {
	font-size: 30px;
	border-left: 3px solid #4093df;
	padding-left: 20px;
	margin-bottom: 1em;
	line-height: 1.2em;
}
.jirei-box a {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: linear-gradient(to bottom,  rgba(255,255,255,0) 30%,rgba(255,255,255,0.8) 80%,rgba(255,255,255,0.8) 100%);
	z-index:2;
}
.jirei-box a:hover {
	background-color: rgba(204,204,204,0.2);
}

/*-------------------------------------　NEWS　--*/
.post-list {
	margin-bottom:3%;}
dl.dl-news {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
dl.dl-news dt {
	width: 300px;
	text-align: left;
	padding: 10px;
	margin-bottom: 0;
	border-bottom: 1px dashed #666;
	display: flex;
	flex-wrap: nowrap;
}
dl.dl-news dt .date {font-size:16px; width:110px; padding-right:10px;}
dl.dl-news dt .cat span {
	display: block;
	padding: 3px 5px 2px;
	text-align: center;
	
	width: 160px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
	margin-bottom:1px;
}
.cat span {background-color:#336699; color:#fff; font-size:14px;}
.cat .cat-furikodosabisu {background-color:#0099ff !important; color:#fff; font-size:12px;}

dl.dl-news dd {
	font-size:18px;
	padding:10px;
	width: calc(100% - 300px);
	margin-bottom: 0;
	border-bottom: 1px dashed #666;
}
/*-----------------------------------faq--*/
dl.faq {
}
dl.faq dt {
	border-radius: 3px;
	position: relative;
	cursor: pointer;
	background-color: #FFF;
	padding: 20px 20px 20px 45px;
	margin-bottom: 5px;
	font-weight: bold;
}
dl.faq dt {
	border: 1px solid #CCC;
	background-image: url(../images/qaq.png);
	background-repeat: no-repeat;
	background-position: 10px 18px;
}
dl.faq dt:hover {
	background-color:#f2f2f2;}
dl.faq dd {
	border-radius: 3px;
	position: relative;
	background-color: #FFF;
	padding: 20px 20px 20px 45px;
	margin-bottom: 25px;
	margin-top: -3px;
	border: 1px solid #CCC;
}
dl.faq dd {
	position: relative;
}
@media (max-width: 1300px) {
.top h1 { font-size:55px; font-weight:bold; text-align:center;}
.autoplay .gallery {
  height: 200px;
}

}

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

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

.top .inner {
	position: static;
	height: auto;
	width:100%;

	padding-bottom:50px;
	margin-left:auto;
	margin-right:auto;
	top: 0%;
	left: 0%;
	transform: translate(0%, 0%);
}
.top .h1sub { font-size:22px; text-align:center;}
.top h1 { font-size:48px; font-weight:bold; text-align:center;}
.top h1 span {font-size: 62px;}
.top h2 { font-size:36px; font-weight: normal; text-align:center;}
.top .msg { font-size:12px; text-align:center;}
.top ul.ulmerit {
	justify-content: center;
}
.top .row {}
.top .col-50 {
	width:100%;
}
.top .col-40 {
	margin-left:auto;
	margin-right:auto;
}
.top .parent {
}

}
@media screen and (max-width:1000px) {
.item-wap {margin-left:3%;}
.itemch {width: 30%;}
.pricearea {
	flex-wrap: wrap;
}
.pricebox {
	width:49%;
	margin-bottom:3%;
}

}

@media screen and (max-width:820px) {
.gallery ul li {
	width: 160px;
	height: 116px;
	margin-right: 10px;
	border-radius: 10px;
}

/*-------------------------------------　事例　--*/
.ulcase {}
.ulcase li {box-shadow:0px 0px 5px 0px rgba(0,0,0,0.2);}

.jirei-box {
	padding:0px;
}
.jirei-box .col-40 {width: 96%;}
.jirei-box-img {
	padding-top: 4%;
	padding-bottom: 0%;
	padding-right: 2%;
	padding-left: 2%;
}

.jirei-box-img img {
	border-radius:10px;
	width:100%;
}
.jirei-box-chd {
	padding-top: 20px;
	padding-right: 10px;
	padding-bottom: 20px;
	padding-left: 10px;
}
.jirei-box h3 {
	font-size: 24px;
	padding-left:0;
	padding-left: 10px;
	margin-left:0;
}


/*--- 流れ  ---*/
.cp_stepflow > li {
	width:calc(50% - 10px);
}
.cp_stepflow .step-header {
	width: 60px;
	height: 60px;
	top: -30px;
}
.cp_stepflow .step-header span {
	font-size: 24px;
}

.cp_stepflow > li:nth-child(2) .bubble::after {
	width: 0%;
	margin-right: 50%;
}

}

@media screen and (max-width:800px) {
.top h1 { font-size:34px;}
.top h1 span {font-size: 52px;}
.itemch {width: 47%;}

ul.uljirei li {
	width:30%;
}


.system .system01 {
	top: 18%;
	left: 50%;
    transform: translateX(-50%);
	width: 80%;
	font-size: 10px;
	padding: 5px;
}
.system .system02 {
	top: 67.5%;
	left: 0%;
	width: 48%;
	font-size: 10px;
	padding: 5px;
}
.system .system03 {
	top: 67.5%;
	right: 0%;
	width: 48%;
	font-size: 10px;
	padding: 5px;
}

.section {
  /*max-width: 600px;*/
}
.slider div {
}
.slider div p {
	font-size:12px;
}

/*-------------------------------------　NEWS　--*/
.post-list {
	margin-bottom:3%;}
dl.dl-news {
	width: 100%;
}
dl.dl-news dt {
	width: 100%;
	border-bottom-style: none;
}
dl.dl-news dd {
	width: 100%;
}

}

@media screen and (max-width:600px) {
.hikaku {
	width:100%;
	margin-left:0%;
	margin-right:0%;
	margin-bottom:30px;
}
}

@media screen and (max-width:600px) {
.top h1 { font-size:26px;}
.top h1 span {font-size: 36px;}
.pricebox {
	width:99%;
	margin-bottom:3%;
}
ul.uljirei li {
	width:40%;
}

ul.userlogo {}
ul.userlogo li {
	width: 31%;
	margin-right: 1%;
	margin-bottom: 2%;
	margin-left: 1%;
	text-align: center;
	padding: 5px 20px;
	background-color: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
	}
ul.userlogo li img {
	/*max-height: 60px;*/
}
/*--- 流れ  ---*/
.cp_stepflow > li {
	width:calc(100% - 10px);
}

.cp_stepflow > li .bubble {
	display: none;
}
.cp_stepflow > li .bubble::after {
	display: none;
}

.step-icon {
	padding-top:20px;
	text-align:center;
	margin-top:0px;
	margin-bottom:10px;

}

}

@media screen and (max-width:500px) {
	ul.ullead li {
	width: 90%;
}


}

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



}
