/* ==================================================
	base
================================================== */

.main_content img {
	height: auto;
}

/* ----------------------------------------
	color
---------------------------------------- */
/* ----------------------------------------
  color
---------------------------------------- */

:root {
  --electric-blue: #024ad8;
  --power-storm: #568393;
  --orange-bloom: #ff5050;
  --standard-gray: #e6e6e6;
  --light-gray: #f5f5f5;
  --gray: #ccc;
  --black: #1a1a1a;
  --black-hover: #3d3d3d;
  --white: #fff;
}

.bg_e6e6e6 { background-color: #e6e6e6 !important; }
.bg_f4f4F4 { background-color: #f4f4F4; }

.fc_blue { color: var(--electric-blue) !important; }
.fc_power_storm { color: var(--power-storm) !important; }
.fc_orange { color: var(--orange-bloom) !important; }

.bg_standard_gray { background-color: var(--standard-gray) !important; }
.bg_light_gray { background-color: var(--light-gray) !important; }
.bg_black { background-color: var(--black) !important; }


/* ----------------------------------------
  ボタン
---------------------------------------- */

.anchor_navi_menu_cta .main_content .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  padding: 12px 16px;
  text-align: center;
  border-radius: 8px;
}
.anchor_navi_menu_cta .main_content .button.line {
  border: none;
  outline-offset: -1px;
  outline-width: 1px;
  outline-style: solid;
}

/* primary */
.main_content .button.primary {
  background: var(--black);
}
.main_content .button.primary:hover {
  background: var(--black-hover);
}

/* critical */
.main_content .button.critical {
  background: var(--electric-blue);
}
.main_content .button.critical:hover {
  background: #103fb2;
}

/* white */
.main_content .button.white {
  background: #fff;
}
.main_content .button.white:hover {
  color: #fff;
  background: #024ad8;
}

/* critical, line */
.main_content .button.critical.line {
  color: var(--electric-blue);
  background: transparent;
  outline-color: var(--electric-blue);
}
.main_content .button.critical.line:hover {
  color: #fff;
  background: var(--electric-blue);
}

/* ghost */
.main_content .c-button-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: .2s;
  min-height: 48px;
  padding: 12px;
  text-decoration: none !important;
  border-radius: 8px;
}
.main_content .c-button-ghost .c-button__text {
  color: var(--electric-blue);
}
.main_content .c-button-ghost .c-button__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
}
.main_content .c-button-ghost .c-button__icon::after {
  content: "";
  width: 24px;
  height: 24px;
  background-image: url('data:image/svg+xml;charset=UTF-8,<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M13.89 4.014a.527.527 0 0 0-.244.137.497.497 0 0 0-.083.588c.023.047.46.488 3.38 3.408l3.352 3.354h-8.93c-7.955 0-8.936.002-8.984.014a.509.509 0 0 0-.367.373.67.67 0 0 0 .016.28.51.51 0 0 0 .362.317c.053.012 1.276.014 8.982.014h8.92l-3.352 3.353c-3.626 3.628-3.383 3.38-3.424 3.518a.494.494 0 0 0 .26.575.479.479 0 0 0 .444 0l.077-.038 3.806-3.806c3.523-3.523 3.808-3.81 3.835-3.865a.49.49 0 0 0 .056-.236.49.49 0 0 0-.056-.236c-.027-.054-.312-.342-3.835-3.865-3.62-3.62-3.81-3.807-3.87-3.84a.507.507 0 0 0-.345-.045z" fill="%23024ad8"></path></svg>');
}
.main_content .c-button-ghost:hover {
  background-color: #c9e0fc;
}


/* ==================================================
  anchor_navi
================================================== */


.anchor_navi {
  position: relative;
  z-index: 100;
  width: 100%;
}
.anchor_navi.is_fixed,
body.anchor_navi_opened .anchor_navi {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 102;
}
.anchor_navi_menu > li > a {
  color: #fff;
  text-decoration: none !important;
}
.anchor_navi_menu_cta {
  display: flex;
  gap: 16px;
}

@media (max-width: 1023px) {
  .anchor_navi_content {
    position: relative;
    z-index: 1;
    min-height: 62px;
    background: #000;
    border-top: 1px solid #e8e8e8;
    border-bottom: 1px solid #e8e8e8;
  }
  body:not(.anchor_navi_opened) .anchor_navi_content {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
  }
  .anchor_navi_trigger {
    display: flex;
    align-items: center;
    height: 44px;
    padding: 0 20px;
    cursor: pointer;
  }
  .anchor_navi_trigger h5 {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 20px;
	color: #fff;
  }
  .anchor_navi_trigger h5::after {
    content: "";
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    background-image: url('data:image/svg+xml;charset=UTF-8,<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M4.394 8.512a.518.518 0 0 0-.249.14.495.495 0 0 0-.081.59c.014.03 1.04 1.063 3.83 3.853 3.418 3.419 3.818 3.815 3.87 3.843.154.08.317.08.476-.001.06-.031.28-.249 3.86-3.83 2.624-2.622 3.806-3.81 3.824-3.841a.5.5 0 0 0-.07-.614.52.52 0 0 0-.353-.153.602.602 0 0 0-.224.055c-.059.027-.215.181-3.669 3.635L12 15.796l-3.608-3.607c-3.454-3.454-3.61-3.608-3.67-3.635a.5.5 0 0 0-.328-.042z"></path></svg>');
  }
  .anchor_navi_trigger.is_active h5::after {
    transform: rotate(180deg);
  }
  .anchor_navi_menu {
    display: none;
    opacity: 0;
  }
  body.anchor_navi_opened .anchor_navi_menu {
    opacity: 1;
  }
  .anchor_navi_menu > li > a {
    display: flex;
    align-items: center;
    height: 44px;
    padding: 0 20px;
  }
  .anchor_navi_menu_cta {
    padding: 12px 20px;
  }
  .anchor_navi.is_fixed .anchor_navi_overlay {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    width: 100%;
  }
  body.anchor_navi_opened .anchor_navi_overlay {
    height: 100dvh;
    background: rgb(26 26 26 / .5);
    backdrop-filter: blur(16px);
  }
  body.anchor_navi_opened {
    overflow: hidden;
    height: 100%;
  }
}

@media (max-width: 479px) {
  .anchor_navi_menu_cta {
    display: none;
  }
  body.anchor_navi_opened .anchor_navi_menu_cta {
    display: flex;
  }
}

@media (max-width: 767px) {
  .anchor_navi_menu_cta {
    gap: 10px;
  }
  .anchor_navi_menu_cta .button {
    padding: 12px 10px;
    font-size: 14px;
  }
}

@media (min-width: 1024px) {
  .anchor_navi {
    padding: 0 20px;
    background: #000;
  }
  .anchor_navi_trigger {
    display: none;
  }
  .anchor_navi_content {
    display: flex;
    justify-content: space-between;
    gap: 30px;
    max-width: 1220px;
    margin: 0 auto;
  }
  .anchor_navi_menu {
    display: flex !important;
  }
  .anchor_navi_menu > li {
    position: relative;
    transition: background .1s ease-in,color .1s ease-in;
    padding: 6px 0;
  }
  /*
  .anchor_navi_menu > li:hover {
    background: #c9e0fc;
  }*/
  .anchor_navi_menu > li > a {
    display: flex;
    align-items: center;
    height: 100%;
    padding: 0 20px;
  }
  .anchor_navi_menu > li:hover > a,
  .anchor_navi_menu > li > a.is_current {
    /* color: #024ad8; */
    border-bottom: solid 2px #fff;
  }
  .anchor_navi_menu > li::after {
    display: block;
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    transition: background .1s ease-in;
    opacity: 0;
    height: 2px;
    background: #0e3191;
  }
  .anchor_navi_menu > li:hover::after,
  .anchor_navi_menu > li:has(> .is_current)::after {
    opacity: 1;
  }
  .anchor_navi_menu_cta {
    padding: 12px 0;
  }
}

@media (min-width: 1024px) and (max-width: 1279px) {
  .anchor_navi_menu > li > a {
    padding: 0 16px;
    font-size: 15px;
  }
  .anchor_navi_menu_cta .button {
    font-size: 15px;
  }
}



/* ----------------------------------------
  local_navi
---------------------------------------- */

.local_navi {
  transition: .5s;
  z-index: 101;
}
body.anchor_navi_fixed .local_navi {
  transform: translateY(-100%);
}

/* ----------------------------------------
  page_top
---------------------------------------- */

body.anchor_navi_opened .page_top_btn {
  z-index: 100;
}



/* ==================================================
	common
================================================== */

/* ----------------------------------------
	cont_wrap
---------------------------------------- */

@media screen and (min-width: 1024px) {
	.cont_wrap {
		padding-top: 60px;
	}
}



/* ----------------------------------------
	p
---------------------------------------- */

.main_content div + p,
.main_content ul + p,
.main_content ol + p,
.main_content img + p {
	margin-top: 1em;
}



/* ----------------------------------------
	a
---------------------------------------- */

.content a {
	color: #000;
	text-decoration: underline;
}
.content a:hover {
	text-decoration: none;
}



/* ----------------------------------------
	title
---------------------------------------- */

.title {
	padding: 25px 0;
}

@media screen and (min-width: 768px) {
	.title {
		padding-right: 0px;
		padding-left: 0px;
	}
}



/* ==================================================
	main
================================================== */

.main {
	background: #fff;
	height: auto;
	padding-bottom: 3rem;
}
.main .img_area img {
	object-fit: contain;
    width: 100%;
    height: 100%;
    object-position: right bottom;
}
/*.main h1 {
	margin-bottom: 15px;
	font-size: 7.5rem;
	font-weight: normal;
	line-height: 1.2;
} */
.main .movie .text_area {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
	/* .main {
		height: 350px;
    } */
	.main .img_area {
		height: 300px;
	}
	.main .img_area img {
		object-position: center bottom;
	}
	/* .main .movie .text_area {
		top: 25%;
	} */
}
@media screen and (min-width: 768px) {
	/* .main {
		height: 350px;
	} */
	.main .img_area {
		height: 330px;
	}
	.main .inner {
		position: absolute;
		top: 40%;
		left: 0;
		transform: translateY(-50%);
		width: 100%;
		padding: 0 20px;
	}
	/* .main .card {
		width: 450px;
		padding: 20px;
	}
	.main h1 {
		font-size: 4.5rem;
	} */
}
@media screen and (min-width: 1024px) {
	.main .img_area {
		height: 490px;
	}
	.main .inner {
		top: 50%;
		left: 0;
	}
	/* .main .card {
		width: 610px;
		padding: 30px;
	}
	.main h1 {
		font-size: 7rem;
	} */
}
/* @media screen and (min-width: 1220px) {
	.main .card {
		margin-left: 100px;
	}
} */



/* ==================================================
	inquiry_service
================================================== */

#inquiry_service {
	margin-top: 0;
}




/* ==================================================

	#local_navi_2

================================================== */

#local_navi_2 .local_navi {
	position: relative;
	width: 100%;
}
#local_navi_2 .local_navi_fixed {
	position: fixed;
	top: 0;
}

@media screen and (min-width: 1024px) {
	#local_navi_2 .local_navi {
		width: 1000px;
	}
}

/* ==================================================
	#local_navi_2 local_navi_menu (mobile)
================================================== */

@media screen and (max-width: 1023px) {
	#local_navi_2 .local_navi_trigger {
		position: relative;
		padding: 0 1.6rem 0 4rem;
		line-height: 4.8rem;
		background: #fff;
		cursor: pointer;
	}
	#local_navi_2 .local_navi_trigger::after {
		content: "";
		position: absolute;
		top: 100%;
		left: 0;
		width: 100%;
		height: 1px;
		background: #ccc;
	}
	#local_navi_2 .local_navi .local_navi_menu {
		display: none;
		position: absolute;
		width: 100%;
	}

	/* aroptimization */
	#local_navi_2 .local_navi_trigger::before,
	#local_navi_2 .local_navi_level2_trigger::after {
		font-family: HPIcons;
		font-style: normal;
		font-weight: normal;
		font-variant: normal;
		text-transform: none;
		vertical-align: bottom;
	}
	#local_navi_2 .local_navi_trigger::before,
	#local_navi_2 .local_navi_level2_trigger::after {
		content: "\E90c";
		position: absolute;
		top: 50%;
		left: 1.6rem;
		transform: translateY(-50%);
		color: #0096d6;
		font-size: 18px;
	}
	#local_navi_2 .local_navi_level2_trigger::after {
		left: 50%;
		transform: translate(-50%,-50%);
	}
	#local_navi_2 .local_navi_trigger.local_navi_open::before,
	#local_navi_2 .local_navi_level2_open .local_navi_level2_trigger::after {
		content: "\E90b";
	}



	/* level1 -------------------- */

	#local_navi_2 .local_navi_menu_level1 {
		overflow-y: scroll;
		width: 100%;
		background: #fff;
	}
	#local_navi_2 .local_navi_menu_level1 > li {
		background: #f2f2f2;
		border-top: 1px solid #ccc;
	}
	#local_navi_2 .local_navi_menu_level1 > li:last-child {
		border-bottom: 1px solid #ccc;
	}
	#local_navi_2 .local_navi_menu_level1 > li a {
		display: block;
		padding: 1.2rem 1.6rem;
	}
	#local_navi_2 .local_navi_menu_level1 > li a:hover {
		text-decoration: none;
	}
	#local_navi_2 .local_navi_menu_level1 > li.local_navi_level2_open {
		background: rgba(0,150,214,.1);
	}

	#local_navi_2 .local_navi_menu_level1 > li > a:not(:only-child) {
		display: inline-block;
		width: calc(100% - 50px);
		border-right: 1px solid #ccc;
	}
	#local_navi_2 .local_navi_level2_trigger {
		display: inline-block;
		position: relative;
		width: 50px;
		padding: 1.2rem 0;
		cursor: pointer;
	}



	/* level2 -------------------- */

	#local_navi_2 .local_navi_menu_level2_area {
		display: none;
		background: #fff;
	}
	#local_navi_2 .local_navi_menu_level2 > li {
		border-top: 1px dotted #ccc;
	}
}



/* ----------------------------------------
	block
---------------------------------------- */

@media screen and (max-width: 1023px) {
	#local_navi_2 .local_navi.style_block {
		border-bottom: none;
	}
	#local_navi_2 .local_navi.style_block .local_navi_trigger {
		color: #fff;
		background: #333;
	}
	#local_navi_2 .local_navi.style_block .local_navi_trigger::after {
		content: none;
	}
	#local_navi_2 .local_navi.style_block .local_navi_menu_level1 > li > a br {
		display: none;
	}
}

@media screen and (max-width: 1023px) {
    .secondary_navi .button_pc {
        margin-left: 10px;
        white-space: nowrap;
    }
}


/* ==================================================
	optimization
================================================== */

.optimization li div {
	grid-template-rows: 1fr;
	grid-row-gap: 30px;
	margin-top: 30px;
}

/* .optimization > li {
	margin-top: 50px;
	padding: 0 15px;
} */
.optimization .img_area {
	text-align: center;
}
.optimization .text_area {
	margin-top: 30px;
}
.optimization .btn_area {
	margin-top: 25px;
}

@media screen and (min-width: 768px) {
	.optimization li {
		display: grid;
		grid-template-columns: 1fr 1fr;
		grid-column-gap: 30px;
		grid-auto-flow: row;
		margin-top: 30px;
	}
}

/* @media screen and (min-width: 1024px) {
	.optimization.col_lg_3 > li {
		width: 33.33333%;
	}
} */







/* ==================================================
	faq
================================================== */

.faq__list {
	/* counter-reset: num; */
	margin-top: -15px;
}
.faq__list dt {
	position: relative;
	margin-top: 30px;
	/* padding-left: 45px; */
	font-size: 18px;
}
.faq__list dt::before {
	counter-increment: num;
	/* content: "Q" counter(num) "."; */
	position: absolute;
	left: 0;
}
.faq__list dd {
	/* margin-top: 12px; */
	padding: 0 0 30px 0;
	font-size: 15px;
	border-bottom: 1px solid #000;
}





.movie .img_area img {
    width: auto;
    max-width: 100%;
}
.movie .img_area {
    position: relative;
}
.movie .img_area .play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    margin-top: 0;
}




/* ==================================================

	accordion

================================================== */

.acco_trigger {
	display: block;
	cursor: pointer;
}
.acco_content {
	display: none;
}



/* common -------------------- */

.acco_basic .acco_trigger,
.acco_cyan .acco_trigger {
	position: relative;
	padding: .8em 4rem .8em 1.6rem;
	transition: .2s;
}
.acco_basic .acco_trigger::after,
.acco_cyan .acco_trigger::after {
	font-family: HPIcons;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	vertical-align: bottom;
}
.acco_basic .acco_trigger::after,
.acco_cyan .acco_trigger::after {
	content: "\E90c";
	position: absolute;
	top: 50%;
	right: 1.6rem;
	transform: translateY(-50%);
	font-size: 18px;
}
.acco_basic .acco_trigger.acco_open::after,
.acco_cyan .acco_trigger.acco_open::after {
	content: "\E90b";
}
.acco_basic .acco_content,
.acco_cyan .acco_content {
	padding: 1.6rem;
	background: var(--light-gray);
}

@media screen and (min-width: 1024px) {
	.acco_basic .acco_trigger,
	.acco_cyan .acco_trigger {
		padding: .8em 50px .8em 20px;
	}
	.acco_basic .acco_content,
	.acco_cyan .acco_content {
		padding: 20px;
	}
	.acco_basic .acco_trigger::after,
	.acco_cyan .acco_trigger::after {
		right: 20px;
	}
}



/* basic -------------------- */

.acco_basic {
	border-top: 1px solid var(--gray);
}
.acco_basic .acco_trigger {
	background: var(--light-gray);
	border-bottom: 1px solid var(--gray);
}
.acco_basic .acco_trigger:hover,
.acco_basic .acco_open {
	background: var(--light-gray);
}
.acco_basic .acco_content {
	border-bottom: 1px solid var(--gray);
}



/* cyan -------------------- */

.acco_cyan .acco_trigger {
	color: var(--white);
	line-height: 1.4;
	background: linear-gradient(to bottom, var(--electric-blue), var(--electric-blue));
	border-top: 1px solid var(--white);
}

