@charset "utf-8";

body:has(header) {
    padding-top: 0 !important;
}

section{
	padding:100px 0;
}

.flex-2{
	display:flex;
	gap:40px;
}

.c-button.-icon-dl:before, .c-button.-icon-dl:after,
.cta .c-button.-icon-dl:before, .cta .c-button.-icon-dl:after, .cta .c-button.-icon-time:after{
	border-radius:50%;
}

@media(max-width:767px){
	section{
		padding:40px 0;
	}

}

/*
cta
*********************************/
.cta .flex-2{
	display:flex;
	gap:70px;
	max-width:1075px;
	margin:0 auto;
}

.cta .flex-2 .item{
	max-width:500px;
	width:100%;
}

.cta .flex-2 .item a{
	display: flex;
	justify-content: center;
	align-items: center;
	font-size:20px;
	font-weight:bold;
	width:100%;
	height:100px;
	border-radius:100px;
}

.cta .c-button.-icon-dl:before, 
.cta .c-button.-icon-dl:after,
.cta .c-button.-icon-time:after{
	width:34px;
	height:34px;
}

.cta-ttl{
	font-size:32px;
	font-weight:bold;
	margin:0px 0 40px 0;
	text-align:center;
}
.cta-ttl.fk{
	margin:70px 0 40px 0;
}
.cta-ttl.fk span{
	color:#fff;
	position:relative;
}

.cta-ttl.fk span:before,
.cta-ttl.fk span:after{
	content:"";
	display:block;
	width:2px;
	height:50px;
	background:#fff;
	position: absolute;
	top: 2px;
}
.cta-ttl.fk span:before{
	left:-35px;
	transform: rotate(-20deg);
}
.cta-ttl.fk span:after{
	right:-35px;
	transform: rotate(20deg);
}

.cta.cta02{
	padding:70px;
	border-radius:24px;
	background:linear-gradient(90deg, rgb(210, 216, 245) 0%, rgb(215, 227, 237) 100%);
	margin:50px auto 0 auto;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){
	.cta .flex-2{
		gap:30px;
	}
	.cta-ttl{
		font-size:26px;
	}
	.cta.cta02{
		padding:70px 25px;
	}
	.c-button.-icon-dl:before, 
	.c-button.-icon-dl:after{
		right:15px;
	}
}

@media(max-width:767px){
	.cta-ttl{
		font-size:20px;
	}
	
	.cta-ttl,
	.cta-ttl.fk{
		margin:50px 0 20px 0;
	}
	
	.cta-ttl.fk span{
		display:inline-block;
	}
	
	.cta-ttl.fk span:before,
	.cta-ttl.fk span:after{
		height:60px;
	}
	
	.cta-ttl.fk span:before{
		left:-30px;
		transform: rotate(-25deg);
	}
	.cta-ttl.fk span:after{
		right:-30px;
		transform: rotate(25deg);
	}
	.cta .flex-2{
		flex-flow: column;
		gap:30px;
	}
	
	.cta .flex-2 .item a{
		height:70px;
	}
	
	.cta.cta02{
		margin-top:20px;
		padding:40px 15px;
		background:linear-gradient(180deg, rgb(210, 216, 245) 0%, rgb(215, 227, 237) 100%);
	}
	.cta.cta02 .cta-ttl{
		margin:0 0 20px 0;
	}
}


/*
ttl-box
*********************************/

.ttl-box{
	position:relative;
	margin-bottom:50px;
	border-bottom: 1px solid var(--border);
	height:auto;
	min-height:180px;
}


.ttl-box h2{
	display:block;
	font-size:40px;
	font-weight:bold;
	border-bottom:none;
	padding:0;
	position:absolute;
	bottom:50px;
	left:0;
	margin-bottom:0;
	z-index:2;
	width:100%;
}

.ttl-box .ttl-en{
	position:absolute;
	top:-40px;
	left:0;
	z-index:1;
	color:#fff;
}

.ttl-box .sub-ttl{
	font-size:18px;
	font-weight:bold;
	position:absolute;
	bottom:105px;
	left:3px;
	margin-bottom:0;
	z-index:2;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){
	.ttl-box{
		min-height:95px;
	}
	.ttl-box h2{
		font-size:30px;
	}
}

@media(max-width:767px){
	.ttl-box{
		min-height:45px;
		margin:0 auto 20px auto;
	}
	.ttl-box h2{
		font-size:20px;
		bottom:28px;
		line-height:1.4;
	}
	.ttl-box .ttl-en{
		font-size:65px;
	}
	
	.ttl-box.sp3{
		min-height:135px;
	}
	.ttl-box.sp3 .ttl-en{
		top:-6px;
	}
}


/*
mv
*****************************/

.mv{
	position:relative;
	z-index:0;
}

.mv:before{
	content:"";
	position:absolute;
	top:0;
	right:0;
	background:url(https://ai.cloudcircus.jp/dcms_media/image/lp/helpdesk/bg-mv.webp) no-repeat center center ;
	background-size:100% auto;
	width:1000px;
	height:877px;
	z-index:-1;
}

.mv__inner {
    display: flex;
    gap: 0px;
    justify-content: space-between;
    max-width: 1600px;
    width:90%;
    padding: 50px 0 0 0 ;
    margin-inline: auto;
    background:none;
}

.mv__left{
	width:50%;
    position:relative;
}
.mv__right{
	width:50%;
    position:relative;
    margin-top:-30px;
}
.mv__right img{
	min-width:800px;
	max-width:800px;
}

.mv__title img{
	width:100%;
}

.mv__checkmark {
    margin-top: 20px;
    padding: 15px;
    background: rgba(255, 255, 255, .8);
    border-radius: 4px;
    max-width: 550px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, .1);
}

.mv__checkmark ul {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
}

.mv__checkmark ul li {
    font-size: 14px;
    font-weight: 700;
    background: url(https://ai.cloudcircus.jp/dcms_media/image/pages/i-check.svg) no-repeat center left;
    background-size: 15px 11px;
    padding-left: 20px;
}

.mv__text{
	font-size:38px;
}
.mv__text02{
	font-size:24px;
	font-weight:bold;
}



@media(max-width:1199px){
	.mv__inner {
		flex-flow: column;
	}
	.mv__left,
	.mv__right{
		display: contents;
	}
	
	.mv__title{order:1;}
	.mv__text{order:2;}
	.mv__text02{order:2;}
	.mv__right img{order:3;}
	.mv__checkmark{order:4;}
	.mv__buttons{order:5;}

}

@media(min-width:1200px) and (max-width:1400px){
	.mv__inner {width:90%;}
	.mv__buttons .c-button{
		font-size:18px;
		width:50%;
	}
	.mv__text{font-size:34px;}
	.mv__right img{min-width:650px;max-width:650px;}
	.mv__title img{width:95%;}
}


@media(min-width:768px) and (max-width:1199px){
	.mv__title,
	.mv__text,
	.mv__text02{text-align:center;}
	.mv__text02{margin-bottom:40px;}
	.mv__title img{max-width:580px;}
	.mv__buttons .c-button{
		width:50%;
	}
	.mv__checkmark{width:85%;max-width:initial;margin:0 auto;}
	.mv__right img{
		min-width:700px;
		max-width:700px;
	}
}


@media(max-width:767px){
	.mv{
		padding-bottom:50px;
	}
	.mv__inner{
		padding-top:115px;
		width:90%;
	}
	.mv__text{
		font-size:30px;
		line-height:1.4;
		margin-bottom:15px;
	}
	.mv__text02{
		font-size:18px;
		line-height:1.4;
		margin-bottom:15px;
	}
	.mv__buttons .c-button{
		font-size:16px;
		width:100%;
	}
	
	.mv__right img{
		min-width:initial;
		max-width:initial;
		width:100%;
	}
	.mv__checkmark{
		margin:0 0 0 0;
	}
	.mv__checkmark ul{
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap:7px;
		width:90%;
		margin:0 auto;
	}
}

/*
problems
*********************************/

#problems{
	background: url(https://ai.cloudcircus.jp/dcms_media/image/lp/helpdesk/bg_problems.webp) no-repeat top center,var(--secondary);
	background-size:cover;
	max-width:1792px;
	width:94%;
	padding:80px 0;
	margin:0 auto;
	border-radius:50px;
	position:relative;
	z-index:1;
}

#problems .ttl-box h2{
	color:#fff;
}

#problems .ttl-box .ttl-en{
	color:rgba(255,255,255,0.2);
}

#problems .card-box{
	background:#fff;
	border-radius:16px;
	padding:65px 0;
	position:relative;
}

#problems .card-box ul{
	display: flex;
	flex-flow: column;
	gap:30px;
	max-width:885px;
	margin:0 auto;
}

#problems .card-box ul li{
	font-size:28px;
	font-weight:400;
	background:url(https://ai.cloudcircus.jp/dcms_media/image/lp/helpdesk/i-check.svg) no-repeat left top;
	padding-left:55px;
}


#problems .card-box ul li strong{
	font-weight:bold;
	background: rgb(0 0 0 / 0%) linear-gradient(transparent 93%, #F55959 0);
	padding-bottom:3px;
}


#problems .card-box .img-left{
	position:absolute;
	bottom:0;
	left:25px;
}

#problems .card-box .img-right{
	position:absolute;
	bottom:0;
	right:25px;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){
	#problems{
		border-radius: 30px;
	}
	#problems .card-box{
		padding:60px 30px 160px 50px;
	}
	#problems .card-box ul{
		gap:5px;
	}
	#problems .card-box ul li{
		font-size:18px;
		background: url(https://ai.cloudcircus.jp/dcms_media/image/lp/helpdesk/i-check.svg) no-repeat left top 10px;
		background-size:33px auto;
		padding-top:10px;
		padding-left:40px;
		padding-bottom:10px;
	}
}

@media(max-width:767px){
	#problems{
		width:100%;
		border-radius:40px;
	}
	#problems .ttl-box{
		max-width:90%;
		min-height: 60px;
	}
	#problems .ttl-box h2{
		bottom:10px;
	}
	#problems .card-box{
		padding:30px 15px 160px 20px;
	}
	#problems .card-box ul{
		gap:20px;
	}
	#problems .card-box ul li{
		font-size:16px;
		background-size:32px auto;
		padding-top:3px;
		padding-left:40px;
	}
	#problems .card-box .img-left{left:calc(50% - 125px);}
	#problems .card-box .img-right{right:calc(50% - 125px);}
}

/*
solution
*********************************/
section#solution{
	padding-bottom:0;
}

#solution .solution-txt{
	font-size:26px;
	font-weight:bold;
	line-height:1.8;
}

#solution .grid{
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap:0;
}

#solution .grid .item{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-flow: column;
	gap:20px;
	padding:70px 30px;
	position:relative;
}

#solution .grid .item:first-child:after{
	content:"";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	right: 0;
	width:1px;
	height:80%;
	background:var(--border);
}

#solution .grid .item:nth-child(3):before,
#solution .grid .item:nth-child(5):before{
	content:"";
	position: absolute;
	top: 0;
	left: 0;
	width:200%;
	height:1px;
	background:var(--border);
}

#solution .grid .item:nth-child(3):after,
#solution .grid .item:nth-child(5):after{
	content:"";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	right: 0;
	width:1px;
	height:80%;
	background:var(--border);
}

#solution .grid .item .img-box{
	display: flex;
	justify-content: center;
	align-items: center;
	width:100%;
	height:220px;
}

#solution .grid .item h3{
	font-size:24px;
	text-align:center;
	margin-top:10px;
}

.results-grid{
	gap:40px 63px;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){
	#solution .solution-txt{
		font-size:18px;
	}
}

@media(max-width:767px){
	#solution .solution-txt{
		font-size:18px;
	}
	#solution .grid{
		grid-template-columns: 1fr;
	}
	#solution .grid .item:first-child:after{
		width:100%;
		height:1px;
		top:initial;
		transform:initial;
		left:0;
		bottom:0;
	}
	#solution .grid .item:nth-child(3):before,
	#solution .grid .item:nth-child(5):before{
		width:100%;
		height:1px;
		top:0;
		transform:initial;
		left:0;
		bottom:initial;
	}
	#solution .grid .item:nth-child(3):after,
	#solution .grid .item:nth-child(5):after{
		width:100%;
		height:1px;
		top:initial;
		transform:initial;
		left:0;
		bottom:0;
	}
	#solution .grid .item{
		padding:30px;
	}
	
	#solution .grid .item .img-box{
		height:180px;
	}
	
	#solution .grid .item .img-box img{
		width:auto;
		height:160px;
	}
	#solution .grid .item h3{
		font-size:20px;
	}
	
	#problems + #solution{
		padding-top:70px;
	}

}

/*
data
*********************************/

#data{
	background:#fff;
	max-width:1790px;
	width:94%;
	margin:100px auto 50px auto;
	border-radius: 60px;
}

#data .ttl-box .ttl-en{
	color:#EBEFFD;
}

#data .data-flex{
	display:flex;
	flex-wrap: wrap;
	gap:100px 40px;
}

#data .cta .cta-ttl.fk span{
	color:#333;
}
#data .cta .cta-ttl.fk span:before,
#data .cta .cta-ttl.fk span:after{
	background:#333;
}

@media(min-width:768px){
	#data .data-flex .item.data-pc-half{
		width:calc((100% - 40px) / 2);
	}
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){
	#data{
		border-radius:30px;
	}
}

@media(max-width:767px){
	#data{
		width:94%;
		margin: 50px auto;
		padding:70px 15px 50px 15px;
		border-radius:40px;
	}
	#data .ttl-box{
		min-height: 60px;
	}
	#data .inner{
		width:100%;
	}
	#data .data-flex{
		gap:20px;
	}
}

/*
case
***********************************/

#case{
	padding-bottom:0;
}

#case .problem-card{
	margin-bottom:40px;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){

}

@media(max-width:767px){
	#solution + #case{
		padding-top:70px;
	}
	.problem-card{
		margin-top:50px;
	}
	.problem-card-head{
		margin-top:-30px;
	}
	.problem-card-head h4{
		text-align:center;
	}
}


/*
who-we-are
***********************************/

#who-we-are .copy-txt{
	margin-bottom:20px;
}

#who-we-are img{
	margin-top:60px;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){
	#who-we-are .copy-txt{
		font-size:22px;
	}
	#who-we-are .copy-txt br{
		display:none;
	}
}

@media(max-width:767px){
	#who-we-are{
		padding:100px 0 40px 0;
	}
	#who-we-are img{
		margin-top:40px;
	}
}

/*
usecase
***********************************/

#usecase{
	padding-bottom:0;
}


.problem-intro{
	max-width: 1200px;
	width:100%;
	margin-left:0;
}

.problem-intro + .problem-intro{
	margin-top:40px;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){

}

@media(max-width:767px){
	.problem-intro .item-right h3{
		text-align:center;
	}
}

/*
function
***********************************/
#function{
	padding:60px 0;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){

}

@media(max-width:767px){
	#function{
		padding:40px 0 ;
	}
	#function + .inner .cta.cta02{
		margin-top:0;
	}
}


/*
top-section07
***********************************/

section.top-section07{
	padding:0;
}

.top-section07__inner{
	max-width:1790px;
	width:90%;
	padding:85px 70px ;
	background-size:cover;
}
.top-section07 .ttl-box h2,
.top-section07 .ttl-box .sub-ttl{
	color:#fff;
}

.top-section07 .ttl-box .ttl-en{
	color:rgba(255,255,255,0.2);
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){
	.top-section07__inner{
		padding:100px 15px 50px 15px;
		width:94%;
		border-radius: 30px;
	}
	.top-section07 .ttl-box .sub-ttl{
		bottom:90px;
	}
	.top-section07__grid-item-title{
		font-size:30px;
	}
	.top-section07__grid-item-title span{
		font-size:60px;
	}
}

@media(max-width:767px){
	.top-section07__inner{
		padding:100px 15px 50px 15px;
		background: var(--secondary);
    	border-radius:30px;
	}
	.top-section07 .ttl-box{
		min-height: 60px;
	}
	.ttl-box .sub-ttl{
		bottom:87px;
	}
}

/*
top-section09
***********************************/
.top-section09 .ttl-box .sub-ttl{
	color:#878B93;
}

@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){

}

@media(max-width:767px){
	.top-section09{
		padding:100px 0 0 0;
	}
	
	.top-section09 .ttl-box{
		width:94%;
	}
	.top-section09 .ttl-box .sub-ttl{
		bottom:52px;
	}
	.top-section09__grid-item{
		width:75%;
	}
}

/*
guide02
***********************************/
#guide02{
	padding-bottom:0;
}

#guide02 .cta{
	overflow:hidden;
}

#guide02 .cta-ttl{
	position:relative;
	padding-bottom:30px;
}

#guide02 .cta-ttl:after{
	content:"";
	display:block;
	position:absolute;
	bottom:0;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	width:200%;
	height:1px;
	background:#C7CFEA;
}

#guide02 .cta .flex-2{
	gap:105px;
}

#guide02 .cta .flex-2 .item p{
	text-align:center;
}
#guide02 .cta .flex-2 a{
	margin-top:30px;
}


@media(min-width:1200px) and (max-width:1400px){

}
@media(min-width:768px) and (max-width:1199px){
	#guide02 .cta .flex-2{
		gap:30px;
	}
	#guide02 .cta .flex-2 .item p br{
		display:none;
	}
}

@media(max-width:767px){
	#guide02 h2{
		width:94%;
		margin-left:auto;
		margin-right:auto;
	}
	#guide02 .inner{
		width:100%;
	}
	#guide02 .step-flow{
		margin-top:30px;
		width:94%;
		margin-left:auto;
		margin-right:auto;
	}
	#guide02 .cta{
		margin-top:40px;
		border-radius:0;
	}
	
	#guide02 .cta02-in{
		padding:30px 15px;
		background:#fff;
		border-radius:20px;
	}
	
	#guide02 .cta-ttl{
		line-height:1.8;
	}
	#guide02 .cta .flex-2{
		gap:40px;
	}
	#guide02 .flex-2 p{
		line-height:1.8;
	}
	#guide02 .cta .flex-2 a{
		margin-top:20px;
	}
}


/*
top-section10
***********************************/
.top-section10{
	padding:80px 0 100px 0;
}

.top-section10 .ttl-box .ttl-en{
	color:#EBEFFD;
}

.top-section10 .ttl-box .sub-ttl{
	color:#878B93;
	font-weight:bold;
}

.top-section10__inner{
	min-width:initial;
	width:90%;
	padding: 85px 70px;
}

.top-section10__grid{
	width:100%;
}

.top-section10__grid-item{
	width:calc( (100% - 60px) / 3);
}

@media(min-width:768px){
	.top-section10__title{
		min-height:75px;
	}
}
@media(min-width:768px) and (max-width:1199px){
	.top-section10__inner{
		width:94%;
		padding: 85px 20px;
		border-radius: 30px;
	}
	.top-section10__grid-item{
		width:calc( (100% - 30px) / 2);
	}
}

@media(max-width:767px) {
	.top-section10{
		padding-top:40px;
	}
	.top-section10__grid{
		margin-top:30px;
	}
	.top-section10__grid-item{
		width:100%;
	}
	.top-section10__inner{
		padding:65px 15px 50px 15px;
		border-radius:20px;
	}
	.top-section10 .ttl-box .sub-ttl{
		bottom:55px;
	}
}

/*
footer
****************************/

.l-footer .hero-section{
	justify-content: space-between;
	gap:100px;
}

.footer-txt-main{font-size:42px;margin-bottom:15px;}
.footer-txt-sub{font-size:24px;}

@media(min-width:768px) and (max-width:1199px){
	.l-footer .hero-section .logo-image{width:230px;}
	.footer-txt-main{font-size:20px;margin-bottom:15px;}
	.footer-txt-sub{font-size:14px;}
	.footer-txt-sub br{display:block;}
	.l-footer .hero-section{
		gap:40px;
	}
	.l-footer .text-container{
		font-size:26px;
	}
}
@media(max-width:767px){
	.l-footer .hero-section{
		padding-left:10px;
		align-items:flex-start;
		gap:30px;
	}
	.l-footer .hero-section .logo-image{
		width:240px;
		margin:0 auto;
	}
	.footer-txt-main{font-size:28px;margin-bottom:15px;}
	.footer-txt-sub{font-size:16px;}
}