@charset "UTF-8";
/*--------------------------------------------------
  reset
--------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  font-weight: normal;
  vertical-align: baseline;
	box-sizing: border-box;
}
body {
  line-height:1;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}
ol, ul {
  list-style: none;
}
blockquote, q {
  quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
table, tr, th, td, caption {
  vertical-align: middle;
  text-align: left;
}
img {
  vertical-align: top;
  font-size: 0;
  line-height: 0;
	width: 100%;
}
textarea{
	vertical-align: top;
}


/*--------------------------------------------------
  body
--------------------------------------------------*/
html {
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%;
}
body {
  color: #222;
  font-family: "Noto Sans JP", sans-serif;
}
a {
	display: block;
  color: #222;
  transition: all 0.3s ease;
	text-decoration: none;
	cursor: pointer;
}
img {
	width: 100%;
	max-width: 100%;
}
a:hover {
  opacity: 0.6;
  filter: alpha(opacity=60);
  -ms-filter: "alpha(opacity=60)";
}
body, html {
	height: 100%;
}
.pc_only {
  display: block;
}
.sp_only {
  display: none;
}

@media screen and (max-width: 768px) {
.pc_only {
  display: none;
}  
.sp_only {
  display: block;
}
}


/*--------------------------------------------------
  fonts
--------------------------------------------------*/
.txt {
  text-align: justify;
}
.f_akshar {
  font-family: "Akshar", sans-serif;
  letter-spacing: 0.08em;
}
.f_bold {
  font-weight: bold;
}
.f_bold span {
  font-weight: bold;
}
.t_center {
  text-align: center;
}


/*--------------------------------------------------
  color
--------------------------------------------------*/
.c_wh {
  color: #fff;
}
.c_or {
  color: #EC6C00;
}


/*--------------------------------------------------
  contents
--------------------------------------------------*/
.sec {
  width: 100%;
}
.sec_inner {
  max-width: 1080px;
  margin: auto;
}

@media screen and (max-width: 768px) {
.sec_inner {
  max-width: 100%;
}
}


/*--------------------------------------------------
  header
--------------------------------------------------*/
header {
  width: 100%;
  background: #fff;
  padding: 15px 15px;
  box-sizing: border-box;
}
header .header_inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
header .logo {
  width: 150px;
}
header .company_name {
  width: 180px;
}

@media screen and (max-width: 768px) {
header {
  padding: 8px 8px;
  position: inherit;
	top: inherit;
	z-index: 9999;
}
header .logo {
  width: 30%;
}
header .company_name {
  width: 20%;
}
}


/*--------------------------------------------------
  footer
--------------------------------------------------*/
footer {
  width: 100%;
  background: #fff;
  padding: 40px 20px 40px 35px;
  box-sizing: border-box;
}
footer .footer_inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
footer .logo {
  width: 180px;
}
footer p {
  font-size: 14px;
}

@media screen and (max-width: 768px) {
footer {
  padding: 15px 15px 30% 15px;
}
footer .logo {
  width: 30%;
}
footer p {
  font-size: 11px;
}
}


/*--------------------------------------
  float_btn
---------------------------------------*/
.float_btn {
  position: fixed;
  width: 400px;
  bottom: 20px;
  right: 20px;
  z-index: 555;
  opacity: 0;
  transform: translateY(10px);
  visibility: hidden;
  transition:
    opacity .35s ease,
    transform .35s ease,
    bottom .35s ease;
  will-change: opacity, transform, bottom;
}

.float_btn.is-visible {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}
.float_btn a {
	width: 402px;
}

@media screen and (max-width: 768px) {
.float_btn {
	width: 100%;
  bottom: 20px;
  left: 0;
  right: 0;
  margin: auto;
  padding: 0 20px;
  box-sizing: border-box;
}
.float_btn a {
	width: 100%;
}  
}


/*--------------------------------------
　page_top
---------------------------------------*/
.page_top a {
  display: block;
  position: absolute;
  width: 69px;
  height: 117px;
  background: url("../images/page_top.png") center center no-repeat;
  background-size: 100% auto;
	bottom: 50px;
  left: 0;
	right: 0;
  margin: auto;
}

@media screen and (max-width: 768px) {
.page_top a {
  width: 61px;
  height: 71.5px;
  background: url("../images/sp_page_top.png") center bottom no-repeat;
  background-size: 100% auto;
	bottom: 100px;
}	
}


/*--------------------------------------------------
  mv
--------------------------------------------------*/
.mv {
  width: 100%;
  height: 0;
  background: url("../images/mv.jpg") center top no-repeat;
  background-size: cover;
  padding-top: calc(100%*1080/1920);
  position: relative;
}
.mv .mv_txt {
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap;
}
.mv .mv_cta_btn {
  position: absolute;
  width: 28%;
  bottom: 9%;
  left: 8%;
}

@media screen and (max-width: 768px) {
.mv {
  width: 100%;
  height: 0;
  background: url("../images/sp_mv.jpg") center top no-repeat;
  background-size: cover;
  padding-top: calc(100%*617/375);
}
}


/*--------------------------------------------------
  cta
--------------------------------------------------*/

/*----- cta_block01 -----*/
.cta .cta_block01 {
  margin: 0 0 100px;
  padding: 0 90px;
}

.cta .cta_block01 .campaign_gift {
  margin: 0 0 15px;
  position: relative;
}
.cta .cta_block01 .campaign_gift .txt_box {
  position: absolute;
  width: 100%;
  text-align: center;
  bottom: 24px;
  left: 0;
  z-index: 10;
}

/* ↓↓↓ modal click ↓↓↓ */
.js-modal-open {
	color: #222;
	font-size: 20px;
  font-weight: bold;
  border-bottom: 2px solid #222;
  line-height: 1.2em;
	text-align: center;
	display: inline-block;
}
.js-modal-open::after{
	content: "";
  display: inline-block;
  position: relative;
  width: 18px;
  height: 18px;
  background: url("../images/download.svg") center center no-repeat;
  background-size: 100% auto;
  top: 2px;
  margin: 0 0 0 4px;
}
/* ↑↑↑ modal click ↑↑↑ */

.cta .cta_block01 .campaign_gift .note {
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  margin: .5rem 0 0;
}
.cta .cta_block01 .campaign_change {
  margin: 0 0 30px;
}
.cta .cta_block01 .campaign_txt {
  font-size: 30px;
}

/*----- cta_block02 -----*/
.cta_block02 {
  width: 100%;
  height: 320px;
  background: url("../images/contact_bg.png") center center no-repeat;
  background-size: 100% auto;
  display: flex;
  justify-content: center;
  align-items: center;
}
.cta_block02 .left {
  margin: 0 70px 0 0;
}
.cta_block02 .f_eng {
  color: #fff;
  font-size: 14px;
  margin: 0 0 5px;
}
.cta_block02 h3 {
  color: #fff;
  font-size: 31px;
  font-weight: bold;
  margin: 0 0 15px;
}
.cta_block02 .consult_txt {
  color: #fff;
  font-size:  18px;
  text-align: justify;
  line-height: 1.8em;
}
.cta_block02 .cta_btn a {
  width: 370px;
}

/*----- cta_01 -----*/
.cta_01 {
  padding: 140px 0 140px;
  position: relative;
}
.cta_01::before,
.cta_01::after {
  content: "";
  display: block;
  position: absolute;
}
.cta_01::before {
  width: 484px;
  height: 838px;
  background: url("../images/shape_01.png") center top no-repeat;
  background-size: 100% auto;
  top: 0;
  right: 0;
  z-index: -10;
}
.cta_01::after {
  width: 188.5px;
  height: 326px;
  background: url("../images/shape_02.png") center bottom no-repeat;
  background-size: 100% auto;
  bottom: 0;
  left: 0;
  z-index: -10;
}

/*----- cta_last -----*/
.cta_last {
  padding: 0 0 220px;
  box-sizing: border-box;
  position: relative;
}
.cta_last .cta_last_bg {
  position: absolute;
  width: 100%;
  height: 380px;
  background: url("../images/cta_last_bg.jpg") center bottom no-repeat;
  background-size: cover;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -10;
}

@media screen and (max-width: 768px) {
  
/*----- cta_block01 -----*/
.cta .cta_block01 {
  margin: 0 0 40px;
  padding: 0 0;
}
.cta .cta_block01 .campaign_gift .txt_box {
  bottom: 8%;
}
  
/* ↓↓↓ modal click ↓↓↓ */  
.js-modal-open {
	font-size: 3.5vw;
  border-bottom: 1px solid #222;
}
.js-modal-open::after{
  width: 1rem;
  height: 1rem;
  background: url("../images/download.svg") center center no-repeat;
  background-size: 100% auto;
  top: 0;
  margin: 0 0 0 .4rem;
}
/* ↑↑↑ modal click ↑↑↑ */  
  
.cta .cta_block01 .campaign_gift .note {
  font-size: 2.2vw;
  margin: .6rem 0 0;
}
.cta .cta_block01 .campaign_change {
  margin: 0 0 10px;
}
.cta .cta_block01 .campaign_txt {
  font-size: 18px;
}
.cta .cta_block01 .campaign_txt span {
  font-size: 28px;
}

/*----- cta_block02 -----*/
.cta_block02 {
  width: 100%;
  height: auto;
  background: url("../images/sp_contact_bg.png") center center no-repeat;
  background-size: 100% auto;
  display: block;
  padding: 70px 30px 55px;
  box-sizing: border-box;
}
.cta_block02 .left {
  margin: 0 0 20px 0;
}
.cta_block02 .f_eng {
  font-size: 12px;
  margin: 0 0 5px;
}
.cta_block02 h3 {
  font-size: 25px;
  margin: 0 0 15px;
}
.cta_block02 .consult_txt {
  font-size:  15px;
  line-height: 1.8em;
}
.cta_block02 .cta_btn a {
  width: 100%;
}

/*----- cta_01 -----*/
.cta_01 {
  padding: 60px 20px 60px;
}
.cta_01::before {
  width: 71.5px;
  height: 123.5px;
  background: url("../images/sp_shape_01.png") center top no-repeat;
  background-size: 100% auto;
  top: 0;
  right: 0;
  z-index: -10;
}
.cta_01::after {
  content: "";
  display: none;
  position: inherit;
  width: inherit;
  height: inherit;
  background: none;
  background-size: 100% auto;
  bottom: inherit;
  left: inherit;
  z-index: -10;
}

/*----- cta_last -----*/
.cta_last {
  padding: 0 20px 200px;
}
.cta_last .cta_last_bg {
  position: absolute;
  width: 100%;
  height: 309px;
  background: url("../images/sp_cta_last_bg.jpg") center bottom no-repeat;
  background-size: cover;
}
}


/*--------------------------------------------------
  situation
--------------------------------------------------*/
.situation {
  width: 100%;
  min-width: 1080px;
  height: 606px;
  background: url("../images/situation_bg.jpg") center center no-repeat;
  background-size: cover;
  padding: 30px 0 0;
  box-sizing: border-box;
  position: relative;
}
.situation::before {
  content: "";
  display: block;
  position: absolute;
  width: 224px;
  height: 616px;
  background: url("../images/txt_01.png") center top no-repeat;
  background-size: 100% auto;
  bottom: 0;
  right: 0;
}
.situation .img_box {
  position: absolute;
  width: 100%;
  max-width: 1440px;
  min-width: 1080px;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
.situation .img_box img {
  display: block;
  width: 100%;
  height: auto;
}

/*----- ttl_box -----*/
.situation .ttl_box {
  background: #fff;
  box-shadow: 10px 10px #E8380D;
  padding: 20px 20px 17px 25px;
  box-sizing: border-box;
  display: inline-block;
  position: relative;
}
.situation .ttl_box::before,
.situation .ttl_box::after {
  content: "";
  display: block;
  position: absolute;
}
.situation .ttl_box::before {
  bottom: 25px;
  left: -20px;
  border: none;
  border-top: solid 25px transparent;
  border-right: solid 20px #fff;
  z-index: 100;
}
.situation .ttl_box::after {
  bottom: 15px;
  left: -12px;
  border: none;
  border-top: solid 25px transparent;
  border-right: solid 20px #E8380D;
  z-index: -10;
}
.situation .ttl_box p {
  font-size: 14px;
  margin: 0 0 10px;
}
.situation .ttl_box h3 {
  font-size: 24px;
  font-weight: bold;
}

@media screen and (max-width: 768px) {
.situation {
  min-width: 100%;
  height: 0;
  background: url("../images/sp_situation_bg.jpg") center center no-repeat;
  background-size: 100% auto;
  padding: 161.6% 20px 0;
  box-sizing: border-box;
}
.situation::before {
  width: 100%;
  height: 100%;
  background: url("../images/sp_txt_01.png") center center no-repeat;
  background-size: 100% auto;
  bottom: 0;
  /*left: 0;*/
  right: 0;
  /*margin: auto;*/
  transform: translate(0,50%);
  z-index: 100;
  overflow: hidden;
}
.situation .img_box {
  display: none;
  position: inherit;
  width: inherit;
  max-width: inherit;
  min-width: inherit;
  bottom: inherit;
  left: inherit;
  right: inherit;
  margin: auto;
}
.situation .img_box img {
  display: none;
  width: inherit;
  height: inherit;
}

/*----- ttl_box -----*/
.situation .ttl_area {
  position: absolute;
  top: 30px;
  left: 30px;
}
.situation .ttl_box {
  box-shadow: 5px 5px #E8380D;
  padding: 15px 15px 15px 15px;
}
.situation .ttl_box::before {
  bottom: 20px;
  left: -15px;
  border: none;
  border-top: solid 20px transparent;
  border-right: solid 15px #fff;
  z-index: 100;
}
.situation .ttl_box::after {
  bottom: 10px;
  left: -7px;
  border: none;
  border-top: solid 20px transparent;
  border-right: solid 15px #E8380D;
  z-index: -10;
}
.situation .ttl_box p {
  font-size: 12px;
  margin: 0 0 5px;
}
.situation .ttl_box h3 {
  font-size: 18px;
}
}


/*--------------------------------------------------
  future
--------------------------------------------------*/
.future {
  min-width: 1080px;
  background: #EAF0F4;
  position: relative;
  overflow: hidden;
  z-index: 0;
}
.future::before {
  content: "";
  display: block;
  position: absolute;
  width: 224px;
  height: 2172px;
  background: url("../images/txt_02.png") center top no-repeat;
  background-size: 100% auto;
  top: 80px;
  right: 0;
}
.future .future_ptn {
  padding: 240px 0 160px 0;
  box-sizing: border-box;
  position: relative;
}
.future .future_ptn::before,
.future .future_ptn::after {
  content: "";
  display: block;
  position: absolute;
}
.future .future_ptn::before {
  width: 534px;
  height: 926.5px;
  background: url("../images/future_ptn01.png") center top no-repeat;
  background-size: 100% auto;
  top: 0;
  left: 0;
}
.future .future_ptn::after {
  width: 25%;
  height: 100%;
  background: url("../images/future_ptn02.png") center bottom no-repeat;
  background-size: 100% auto;
  bottom: 0;
  right: 0;
  z-index: 1;
}
.future .sec_inner {
  width: 1080px;
  min-width: 1080px;
}

/*----- main_txt -----*/
.future .main_txt {
  margin: 0 0 160px;
  padding: 0 0 0 260px;
  box-sizing: border-box;
}
.future .main_txt .ttl_box {
  margin: 0 0 30px 18.0em;
  position: relative;
}
.future .main_txt .ttl_box::before {
  content: "";
  display: block;
  position: absolute;
  width: 86px;
  height: 83px;
  background: url("../images/ptn_01.png") center center no-repeat;
  background-size: 100% auto;
  bottom: 100%;
  left: -30px;
}
.future .main_txt .ttl_box p {
  font-size: 22px;
}
.future .main_txt .txt_box p {
  font-size: 32px;
  line-height:  1.8em;
}
.future .main_txt .txt_box p.txt01 {
  margin: 0 0 40px;
}
.future .main_txt .txt_box p .highlight {
  padding: 0 6px 0 8px;
  box-sizing: border-box;
  position: relative;
}
.future .main_txt .txt_box p .highlight::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1.4em; /* 背景の高さ（文字の高さに合わせて調整） */
  background: linear-gradient(to right, #E66B01, #F39800);
  transform: skewX(-20deg); /* ← 斜め感を出す */
  z-index: -1;
}
.future .main_txt .txt_box p .line01 { margin-left: 7.5em; }
.future .main_txt .txt_box p .line02 { margin-left: 6em; }
.future .main_txt .txt_box p .line03 { margin-left: 4.5em; }
.future .main_txt .txt_box p .line04 { margin-left: 3em; }
.future .main_txt .txt_box p .line05 { margin-left: 1.5em; }
.future .main_txt .txt_box p .line06 { margin-left: 0; }

/*----- block_area -----*/
.future .block_area {
  padding: 120px 0;
  box-sizing: border-box;
}
.future .block {
  min-width: 1080px;
  margin: 0 0 100px;
  position: relative;
}
.future .block .left {
  width: 48%;
}
.future .block .right {
  position: absolute;
  width: 750px;
  left: 55%;
}
.future .block01 .right {
  top: -30px;
  z-index: 20;
}
.future .block02 .right {
  top: -120px;
  z-index: 10;
}
.future .block03 .right {
  top: -100px;
  z-index: 0;
}
.future .block .left .ttl_box02 {
  margin: 0 0 25px;
  position: relative;
}
.future .block .left .ttl_box02 .f_eng {
  font-size: 14px;
  margin: 0 0 10px;
}
.future .block .left .ttl_box02 h3 {
  font-size: 32px;
  font-weight: bold;
}
.future .block .left .ttl_box02 .num {
  font-size: 120px;
  font-weight: bold;
  letter-spacing: 0em;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -10;
}
.future .block .img_box {
  width: 435px;
  margin: 0 0 25px;
}
.future .block .txt_box p {
  font-size: 18px;
  line-height: 2.0em;
}
.future .block .txt_box p.note {
  font-size: 10px;
}

@media screen and (max-width: 768px) {
.future {
  min-width: 100%;
}
.future::before {
  content: "";
  display: none;
  position: inherit;
  width: inherit;
  height: inherit;
  background: none;
  background-size: 100% auto;
  top: inherit;
  right: inherit;
}
.future .future_ptn {
  padding: 120px 20px 70px 20px;
}
.future .future_ptn::before {
  width: 186px;
  height: 322px;
  background: url("../images/sp_future_ptn01.png") center top no-repeat;
  background-size: 100% auto;
  top: 0;
  right: 0;
  left: inherit;
}
.future .future_ptn::after {
  width: 100%;
  height: 100%;
  background: url("../images/sp_future_ptn02.png") left bottom no-repeat;
  background-size: 100% auto;
  bottom: 0;
  right: 0;
  z-index: -1;
}
.future .sec_inner {
  width: 100%;
  min-width: 100%;
}

/*----- main_txt -----*/
.future .main_txt {
  margin: 0 0 0;
  padding: 0 0 0 0;
}
.future .main_txt .ttl_box {
  margin: 0 0 20px 1.0em;
}
.future .main_txt .ttl_box::before {
  content: "";
  display: block;
  position: absolute;
  width: 43px;
  height: 42px;
  background: url("../images/ptn_01.png") left  center no-repeat;
  background-size: 100% auto;
  bottom: 100%;
  left: -15px;
}
.future .main_txt .ttl_box p {
  font-size: 11px;
}
.future .main_txt .txt_box p {
  font-size: 5.2vw;
  line-height:  1.8em;
}
.future .main_txt .txt_box p.txt01 {
  margin: 0 0 20px;
}
.future .main_txt .txt_box p .highlight {
  padding: 0 6px 0 8px;
}
.future .main_txt .txt_box p .highlight::before {
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1.4em; /* 背景の高さ（文字の高さに合わせて調整） */
  background: linear-gradient(to right, #E66B01, #F39800);
  transform: skewX(20deg); /* ← 斜め感を出す */
  z-index: -1;
}
.future .main_txt .txt_box p .line01 { margin-left: 0; }
.future .main_txt .txt_box p .line02 { margin-left: 0; }
.future .main_txt .txt_box p .line03 { margin-left: 0; }
.future .main_txt .txt_box p .line04 { margin-left: 0; }
.future .main_txt .txt_box p .line05 { margin-left: 0; }
.future .main_txt .txt_box p .line06 { margin-left: 0; }

/*----- block_area -----*/
.future .block_area {
  padding: 60px 0 45px;
}
.future .block {
  min-width: 100%;
  margin: 0 0 55px;
  position: inherit;
}
.future .block:last-child {
  margin: 0 0 0;
}
.future .block .left {
  width: 100%;
}
.future .block .right {
  display: none;
  position: inherit;
  width: 100%;
  left: inherit;
}
.future .block01 .right {
  top: inherit;
  z-index: 20;
}
.future .block02 .right {
  top: inherit;
  z-index: 10;
}
.future .block03 .right {
  top: inherit;
  z-index: 0;
}
.future .block .sp_img_box {
  width: calc(100% + 40px);
  margin: 0 20px 15px -20px;
}
.future .block .left .ttl_box02 {
  margin: 0 0 20px;
  position: relative;
  z-index: 10;
}
.future .block .left .ttl_box02 .f_eng {
  font-size: 12px;
  margin: 0 0 10px;
}
.future .block .left .ttl_box02 h3 {
  font-size: 6.5vw;
}
.future .block .left .ttl_box02 .num {
  font-size: 90px;
}
.future .block .img_box {
  width: 100%;
  margin: 0 0 20px;
}
.future .block .txt_box p {
  font-size: 15px;
  line-height: 1.8em;
  margin: 0 0 10px;
}
.future .block .txt_box p.note {
  font-size: 10px;
}  
}


/*--------------------------------------------------
  simulation
--------------------------------------------------*/
.simulation {
  background: #EAF0F4;
  position: relative;
}
.simulation::before {
  content: "";
  display: block;
  position: absolute;
  width: 75%;
  height: 100%;
  background: url("../images/shape_03.png") left top no-repeat;
  background-size: 100% 100%;
  top: top;
  left: 0;
}

/*----- SIMULATION 上下に配置 -----*/
.simulation .sec_inner {
  padding: 180px 0 270px;
  box-sizing: border-box;
  position: relative;
}
.simulation .sec_inner::before,
.simulation .sec_inner::after {
  content: "";
  display: block;
  position: absolute;
  width: 806px;
  height: 217px;
}
.simulation .sec_inner::before {
  background: url("../images/txt_03.png") center center no-repeat;
  background-size: 100% auto;
  top: 30px;
  left: 0;
}
.simulation .sec_inner::after {
  background: url("../images/txt_04.png") center center no-repeat;
  background-size: 100% auto;
  bottom: 30px;
  right: 0;
}

/*----- ttl_block -----*/
.simulation .ttl_block {
  margin: 0 0 0;
  padding: 0 0 0 90px;
  box-sizing: border-box;
}
.simulation .ttl_box {
  position: relative;
}
.simulation .ttl_box::before {
  content: "";
  display: block;
  position: absolute;
  width: 86px;
  height: 83px;
  background: url("../images/ptn_02.png") center center no-repeat;
  background-size: 100% auto;
  bottom: 100%;
  left: -30px;
}
.simulation .ttl_box p {
  font-size: 20px;
}
.sim_slider {
  padding: 80px 0 0;
  box-sizing: border-box;
}

/*----- person -----*/
.simulation .person {
  color: #fff;
  font-size: 18px;
  text-align: center;
  padding: 10px 20px;
  box-sizing: border-box;
  display: inline-block;
  position: relative;
  z-index: 2;
}
.simulation .person::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 2.5em; /* 背景の高さ（文字の高さに合わせて調整） */
  background: linear-gradient(to bottom, #D9341D, #EA5529);
  transform: skewX(-20deg); /* ← 斜め感を出す */
  bottom: 0;
  left: 0;
  z-index: -1;
}
.simulation .person span.slash {
  color: #F6BBA9;
  font-size: 24px;
}
.simulation .person span.price01 {
  font-size: 25px;
  padding: 0 3px;
  box-sizing: border-box;
}
.simulation .person span.txt01 {
  font-size: 15px;
}
.simulation .item_inner {
  box-shadow: 0 0 10px rgba(0,0,0,0.10);
  margin: -1.5em 0 0;
  z-index: -2;
}

/*----- block01 -----*/
.simulation .block01 {
  background: #fff;
  padding: 10px 20px 0;
  box-sizing: border-box;
}
.table_data table {
  width: 100%;
  box-sizing: border-box;
}
.table_data table tr {
  width: 100%;
  box-sizing: border-box;
}
.table_data table th {
  font-size: 15px;
  border-bottom: 1px solid #E5E5E5;
  padding: 15px 0;
  box-sizing: border-box;
}
.table_data table td {
  font-size: 15px;
  border-bottom: 1px solid #E5E5E5;
  padding: 15px 0;
  box-sizing: border-box;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.table_data table th.last,
.table_data table td.last {
  border-bottom: none;
}
.table_data table th.last {
  font-size: 17px;
  font-weight: bold;
}
.table_data table td.last {
  display: block;
  text-align: right;
}
.table_data table td.last span {
  color: #EA8900;
  font-size: 42px;
}
.table_data table td img {
  width: 12px;
  height: 12px;
}
.table_data table td span {
  font-size: 28px;
  font-family: "Akshar", sans-serif;
  padding: 0 5px 0 5px;
}

/*----- block02 -----*/
.simulation .block02 {
  background: #F1F1F1;
  padding: 60px 20px 20px;
  box-sizing: border-box;
  position: relative;
}
.simulation .block02::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 35px;   /* 三角形の高さ */
  background: #fff;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  top: 0;
  left: 0;
  z-index: 1;   /* 必要なら重なり順を明示 */
}
.simulation .block02 .price_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}
.simulation .block02 .left p {
  font-size: 15px;
  line-height: 1.3em;
}
.simulation .block02 .right p span {
  color: #EA5529;
  font-size: 46px;
  letter-spacing: -0.03em;
  padding: 0 3px 0 0;
  box-sizing: border-box;
}
.simulation .block02 .right p {
  font-size: 15px;
}

@media screen and (max-width: 768px) {
.simulation::before {
  width: 100%;
  height: 100%;
  background: url("../images/sp_shape_03.png") left center no-repeat;
  background-size: 100% 100%;
  top: top;
  left: 0;
}

/*----- SIMULATION 上下に配置 -----*/
.simulation .sec_inner {
  padding: 100px 20px 120px;
  box-sizing: border-box;
  position: relative;
}
.simulation .sec_inner::before {
  content: "";
  display: block;
  position: absolute;
  width: 97px;
  height: 653px;
}
.simulation .sec_inner::before {
  background: url("../images/sp_txt_03.png") center center no-repeat;
  background-size: 100% auto;
  top: 30px;
  left: 0;
}
.simulation .sec_inner::after {
  content: "";
  display: none;
  position: inherit;
  width: inherit;
  height: inherit;
  background: none;
  background-size: 100% auto;
  bottom: inherit;
  right: inherit;
}

/*----- ttl_block -----*/
.simulation .ttl_block {
  margin: 0 0 50px;
  padding: 0 0 0 1.0em;
  box-sizing: border-box;
}
.simulation .ttl_box {
  position: relative;
}
.simulation .ttl_box::before {
  width: 43px;
  height: 42px;
  background: url("../images/ptn_02.png") center center no-repeat;
  background-size: 100% auto;
  bottom: 100%;
  left: -15px;
}
.simulation .ttl_box p {
  font-size: 18px;
}
.sim_slider {
  padding: 0 0 0;
  box-sizing: border-box;
}

/*----- person -----*/
.simulation .person_area {
  text-align: right;
  margin: auto;
}  
.simulation .person {
  font-size: 14px;
  padding: 5px 15px;
}
.simulation .person::before {
  width: 100%;
  height: 2.5em; /* 背景の高さ（文字の高さに合わせて調整） */
  background: linear-gradient(to bottom, #D9341D, #EA5529);
  transform: skewX(20deg); /* ← 斜め感を出す */
}
.simulation .person span.slash {
  font-size: 18px;
}
.simulation .person span.price01 {
  font-size: 20px;
  padding: 0 3px;
}
.simulation .person span.txt01 {
  font-size: 12px;
}
.simulation .item_inner {
  box-shadow: 0 0 10px rgba(0,0,0,0.10);
  margin: -1.5em 0 0;
}

/*----- block01 -----*/
.simulation .block01 {
  padding: 10px 20px 0;
}
.table_data table th {
  font-size: 13px;
  padding: 15px 0;
}
.table_data table td {
  font-size: 13px;
  padding: 15px 0;
}
.table_data table th.last {
  font-size: 14px;
}
.table_data table td.last span {
  font-size: 36px;
}
.table_data table td img {
  width: 9px;
  height: 8px;
}
.table_data table td span {
  font-size: 20px;
  font-family: "Akshar", sans-serif;
  padding: 0 5px 0 5px;
}

/*----- block02 -----*/
.simulation .block02 {
  padding: 45px 20px 20px;
}
.simulation .block02::before {
  width: 100%;
  height: 20px;   /* 三角形の高さ */
}
.simulation .block02 .price_box {
  text-align: center;
  display: block;
}
.simulation .block02 .left p {
  font-size: 14px;
  line-height: 1.0em;
  margin: 0 0 10px;
}
.simulation .block02 .right p span {
  font-size: 45px;
  letter-spacing: inherit;
  padding: 0 3px 0 0;
}
.simulation .block02 .right p {
  font-size: 15px;
}  
}


/*--------------------------------------------------
  slick
--------------------------------------------------*/
button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* ===== Slick ===== */
.sim_slider .slick-list {
  /*段差ON時に以下を有効化（上余白確保）*/
  padding: 40px 0 0;
  margin-top: -40px;
}
.sim_slider .slick-slide {
  padding: 0 1px; /* カード間の余白 */
  box-sizing: border-box;
}

/* ===== 内側の .sim_card だけ縮小 ===== */
.sim_slider .sim_card {
  transition: transform .35s ease, opacity .35s ease, filter .35s ease;
  transform: scale(.88);
  opacity: .75;
  will-change: transform;
}

/* 中央スライドは等倍＆前面 */
.sim_slider .slick-center .sim_card {
  transform: scale(1);
  opacity: 1;
  z-index: 3;
}

/* ===== 段差（縦オフセット）機能：ONにしたいときは下3行を有効化 =====（JS側の applyPositionClasses もアンコメント) */
.sim_slider .is-right .sim_card { transform: translateY(-5%) scale(.88); }
.sim_slider .is-center .sim_card { transform: translateY(8%) scale(1);   }
.sim_slider .is-left  .sim_card { transform: translateY(10%) scale(.88); }
 

/* ===== 右下カスタムカウンター ===== */
.slide-counter {
  position: absolute;
  right: 40px;
  bottom: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: "Akshar", sans-serif;
  font-weight: 500;
  z-index: 5;
}

/* 丸い矢印ボタン（画像を背景として使用） */
.slide-counter .prev-btn,
.slide-counter .next-btn {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: url("../images/slide_arrow.png") center center no-repeat;
  background-size: cover;
  cursor: pointer;
  border: none;
  transition: opacity 0.3s ease;
}
.slide-counter .prev-btn:hover,
.slide-counter .next-btn:hover {
  opacity: 0.8;
}

/* 右矢印は画像を左右反転で流用 */
.slide-counter .next-btn {
  transform: scaleX(-1);
}

/* 数字部分 */
.slide-counter .current {
  font-size: 30px;
  font-weight: 700;
  color: #E86B11; /* オレンジ */
}
.slide-counter .slash {
  font-size: 24px;
}
.slide-counter .total {
  font-size: 18px;
}

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

/* ===== Slick ===== */
.sim_slider .slick-list {
  /*段差ON時に以下を有効化（上余白確保）*/
  padding: 10px 0 0;
  margin-top: -10px;
}
.sim_slider .slick-slide {
  padding: 0 10px; /* カード間の余白 */
}

/* ===== 内側の .sim_card だけ縮小 ===== */
.sim_slider .sim_card {
  transform: scale(1);
  opacity: 1;
}
  
/* ===== 段差（縦オフセット）機能：ONにしたいときは下3行を有効化 =====（JS側の applyPositionClasses もアンコメント）*/
.sim_slider .is-right .sim_card { transform: translateY(1%) scale(.88); }
.sim_slider .is-center .sim_card { transform: translateY(1%) scale(1);   }
.sim_slider .is-left  .sim_card { transform: translateY(1%) scale(.88); }  

/* ===== 右下カスタムカウンター ===== */
.slide-counter {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 40px;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: "Akshar", sans-serif;
  font-weight: 500;
  z-index: 5;
}

/* 丸い矢印ボタン（画像を背景として使用） */
.slide-counter .prev-btn,
.slide-counter .next-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: url("../images/slide_arrow.png") center center no-repeat;
  background-size: cover;
  cursor: pointer;
  border: none;
  transition: opacity 0.3s ease;
}
.slide-counter .prev-btn:hover,
.slide-counter .next-btn:hover {
  opacity: 0.8;
}

/* 右矢印は画像を左右反転で流用 */
.slide-counter .next-btn {
  transform: scaleX(-1);
}

/* 数字部分 */
.slide-counter .current {
  font-size: 26px;
}
.slide-counter .slash {
  font-size: 24px;
}
.slide-counter .total {
  font-size: 18px;
}
}


/*--------------------------------------------------
  company
--------------------------------------------------*/
.company {
  position: relative;
}
.company::before {
  content: "";
  display: block;
  position: absolute;
  width: 421px;
  height: 728.5px;
  background: url("../images/shape_04.png") center center no-repeat;
  background-size: 100% auto;
  top: 0;
  left: 0;
  z-index: -1;
}
.company .sec_inner {
  padding: 230px 0 180px;
  box-sizing: border-box;
}
.company .txt_block {
  display: flex;
  justify-content: center;
}
.company .img_box {
  width: 20%;
  margin: 0 120px 0 0;
}
.company .txt_box h3 {
  font-size: 48px;
  font-weight: bold;
  line-height: 1.3em;
  letter-spacing: 0.08em;
  margin: 0 0 40px;
}
.company .txt_box p {
  font-size: 20px;
  line-height: 2.0em;
  letter-spacing: 0.1em;
}
.company .txt_box p.txt01 {
  margin: 0 0 20px;
}

@media screen and (max-width: 768px) {
.company {
  position: relative;
}
.company::before {
  width: 79.5px;
  height: 138px;
  background: url("../images/sp_shape_04.png") center center no-repeat;
  background-size: 100% auto;
}
.company .sec_inner {
  padding: 100px 20px 70px;
}
.company .txt_block {
  display: block;
}
.company .img_box {
  width: 80%;
  margin: 0 auto 40px;
}
.company .txt_box h3 {
  font-size: 28px;
  margin: 0 0 20px;
}
.company .txt_box p {
  font-size: 15px;
  line-height: 1.8em;
}
.company .txt_box p.txt01 {
  margin: 0 0 10px;
}  
}


/*--------------------------------------------------
モーダル
--------------------------------------------------*/
.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
}
.modal__bg {
  background: rgba(0,0,0,0.5);
  height: 100vh;
  position: absolute;
  width: 100%;
	margin: 0 0 0;
}
.modal__content {
  width: 1080px;
  height: 90%;
	background: #fff;
	padding: 50px 50px;
	box-sizing: border-box;
	position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
	overflow: hidden;
  overflow-y: scroll;
}
.js-modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10;
  width: 4rem;
  height: 4rem;
  cursor: pointer;
}
.js-modal-close::before,
.js-modal-close::after {
  content: '';
  position: absolute;
  margin: auto;
  top: 2rem;
  left: .6rem;
  width: 3rem;
  height: .2rem;
  background: #222;
  transform: rotate(45deg);
}
.js-modal-close::after {
  transform: rotate(-45deg);
}

@media screen and (max-width: 768px) {
.modal__bg {
  padding: 0 20px;
	box-sizing: border-box;
}
.modal__content {
  width: 90%;
	height: 90%;
	padding: 40px 20px;
}
.js-modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10;
  width: 4rem;
  height: 4rem;
  cursor: pointer;
}
.js-modal-close::before,
.js-modal-close::after {
  content: '';
  position: absolute;
  margin: auto;
  top: 2rem;
  left: .6rem;
  width: 3rem;
  height: .2rem;
  background: #222;
  transform: rotate(45deg);
}
.js-modal-close::after {
  transform: rotate(-45deg);
}	
}


/*--------------------------------------------------
モーダルの中身
--------------------------------------------------*/
.modal .wrap01 {
  margin: 0 0 70px;
}
.modal .wrap h3 {
  color: #fff;
	font-size: 20px;
  font-weight: bold;
  background: #EA522A;
  margin: 0 0 20px;
  padding: 10px 5px;
  box-sizing: border-box;
  display: inline-block;
}
.modal .wrap p {
  font-size: 15px;
  line-height: 1.8em;
  margin: 0 0 30px;
}

/* ol ul 共通 */
.modal ol.num,
.modal ol.eng,
.modal ul.mark,
.modal ul.point {
  counter-reset: no;
}
.modal ol.num li,
.modal ol.eng li,
.modal ul.mark li,
.modal ul.remark li,
.modal ul.point li {
  font-size: 15px;
  line-height: 1.8em;
  padding: 0 0 0 20px;
  box-sizing: border-box;
  position: relative;
}
.modal ol.num li:last-child,
.modal ol.eng li:last-child,
.modal ul.mark li:last-child,
.modal ul.remark li:last-child,
.modal ul.point li:last-child {
	margin: 0 0 0;
}

/* ol num */
.modal ol.num li {
  margin: 0 0 20px;
  counter-increment: count;
}
.modal ol.num li::before{
  counter-increment: no;
  content: counter(no) '.';
	position: absolute;
	top: 0;
	left: 0;
	color: #222;
	font-size: 16px;
  font-weight: 700;
}

/* ol eng */
.modal ol.eng {
  counter-reset: alpha;
}
.modal .wrap01 ol.eng li {
  margin: 0 0 8px;
}
.modal .wrap01 ol.eng li:first-child {
  margin: 5px 0 8px;
}
.modal .wrap02 ol.eng li {
  margin: 0 0 20px;
}
.modal ol.eng li::before{
  counter-increment: alpha;
  content: counter(alpha, upper-alpha) '.';
	position: absolute;
	top: 0;
	left: 0;
	color: #222;
	font-size: 16px;
  font-weight: normal;
}

/* ol mark */
.modal ul.mark li {
  margin: 0 0 8px;
}
.modal ul.mark li:first-child {
  margin: 5px 0 8px;
}
.modal ul.mark li::before{
  content: "※";
	position: absolute;
	top: 0;
	left: 0;
	color: #222;
	font-size: 15px;
}

/* ol mark */
.modal ul.remark {
  margin: 30px 0 0;
}
.modal ul.remark li {
  font-weight: bold;
  margin: 0 0 8px;
}
.modal ul.remark li::before{
  content: "※";
	position: absolute;
	top: 0;
	left: 0;
	color: #222;
	font-size: 15px;
  font-weight: bold;
}

/* ol point */
.modal ul.point li {
  margin: 0 0 8px;
}
.modal ul.point li:first-child {
  margin: 5px 0 8px;
}
.modal ul.point li::before{
  content: "";
	position: absolute;
	top: 12px;
	left: 5px;
  width: 4px;
  height: 4px;
  background: #222;
  border-radius: 100px;
}

@media screen and (max-width: 768px) {
.modal .wrap01 {
  margin: 0 0 50px;
}
.modal .wrap h3 {
	font-size: 16px;
  margin: 0 0 20px;
  padding: 8px 3px;
}
.modal .wrap p {
  font-size: 13px;
  line-height: 1.8em;
  margin: 0 0 30px;
}

/* ol ul 共通 */
.modal ol.num li,
.modal ol.eng li,
.modal ul.mark li,
.modal ul.remark li,
.modal ul.point li {
  font-size: 13px;
  line-height: 1.8em;
  padding: 0 0 0 18px;
}

/* ol num */
.modal ol.num li {
  margin: 0 0 15px;
}
.modal ol.num li::before{
	top: -1px;
	left: 0;
	font-size: 15px;
}

/* ol eng */
.modal .wrap01 ol.eng li {
  margin: 0 0 8px;
}
.modal .wrap01 ol.eng li:first-child {
  margin: 5px 0 8px;
}
.modal .wrap02 ol.eng li {
  margin: 0 0 20px;
}
.modal ol.eng li::before{
	top: 0;
	left: 0;
	font-size: 15px;
}

/* ol mark */
.modal ul.mark li {
  margin: 0 0 8px;
}
.modal ul.mark li:first-child {
  margin: 5px 0 8px;
}
.modal ul.mark li::before{
	top: 0;
	left: 0;
	font-size: 13px;
}

/* ol mark */
.modal ul.remark {
  margin: 25px 0 0;
}
.modal ul.remark li {
  margin: 0 0 8px;
}
.modal ul.remark li::before{
	top: 0;
	left: 0;
	font-size: 15px;
}

/* ol point */
.modal ul.point li {
  margin: 0 0 8px;
}
.modal ul.point li:first-child {
  margin: 5px 0 8px;
}
.modal ul.point li::before{
	top: 10px;
	left: 6px;
  width: 3px;
  height: 3px;
}
}

