/* リセット
-----------------------------------------------------------*/

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* 全体
-----------------------------------------------------------*/
html {
  scroll-behavior: smooth;
}

body {
  font-family: Arial, sans-serif;
  background-color: #fff;
  color: #000;
  line-height: 1.75;
}

a {
  color: inherit;
  text-decoration: none;
  display: block;
}

a:hover{
text-decoration:underline;
}

.mt20{
  margin-top: 20px!important;
}
.mt40{
  margin-top: 40px!important;
}
.mt60{
  margin-top: 60px!important;
}
.mt80{
  margin-top: 80px!important;
}
.mb80{
  margin-bottom: 80px!important;
}
.pt40{
  padding-top: 40px!important;
}
.pb40{
  padding-bottom: 40px!important;
}

/*改行*/
.spbr{
  display: none;
}

sub{
  font-size: 30%;
}

@media (max-width: 1024px) {
  .spbr{display: block!important;}
  .pcbr{display: none;}
}

/* テキスト
-----------------------------------------------------------*/

p{
  margin-bottom: 16px;
  line-height: 1.75;
}

p.ttl{
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 16px;
}

.read{
  font-size: 20px;
}

h2{
  line-height: 1.5;
  font-size: 48px;
  text-align: center;
  margin-bottom: 40px;
}

h2 span.sub{
  font-size: 28px;
}

suq {font-size: 12px;}

h4 {
    margin-bottom: 16px;
    font-size: 20px;
}

span.red {
    color: #D04322;
}

.txt-c{
  text-align: center;
}

.note{
  font-size:14px!important;
  color: #666;
}

span.marker{
  background: linear-gradient(transparent 70%, #FFC9BE 70%);
}

@media (max-width: 768px) {
  p.ttl{
    font-size: 20px;
  }
}

/* header 
-----------------------------------------------------------*/

header {
  min-width: 100%;
  position: fixed;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 16px;
  background-color: #fff;
  border-bottom: 1px solid #ccc;
  z-index: calc(infinity);
  }

.header-container {
  max-width: 1140px;;
  margin: 0 auto;
display: flex;
justify-content: space-between;
align-items: center;
width: 100%;
max-height: 31px;
}

.header-logo img {
  max-width:160px;
  display: table-cell;
  vertical-align: middle;
  margin-right: 24px;
}

@media (max-width: 1024px) {
  header{
    top: 0;
    left: 0;
    width: 100%; 
    z-index: calc(infinity);
  }

  .header-logo img {
    max-width: 120px;
  }
}

/* メニュー */
.menu {
display: flex;
flex: 1;
justify-content: flex-start;
align-items: center;
}

.menu ul {
display: flex;
list-style: none;
margin-left: 32px; 
}

.menu li {
margin-right: 40px;
}

.menu a {
font-size: 18px;
color: #000;
font-weight: bold;
}

.button a {
  font-size: 16px;
  padding: 5px 20px;
  background-color: #186CFF;
  color: white;
  text-decoration: none;
  border-radius: 9999px;
  max-width: 200px;
}

.button a:hover {
  background-color: #0056b3;
}

/* ハンバーガーメニュー */
.hamburger {
display: none;
cursor: pointer;
width: 30px;
height: 24px; 
position: relative;
}

.hamburger-icon {
width: 30px;
height: 3px;
background-color: #000;
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
transition: 0.3s ease-in-out;
}

.hamburger-icon:before,
.hamburger-icon:after {
content: '';
position: absolute;
width: 30px;
height: 3px;
background-color: #000;
transition: 0.3s ease-in-out;
}

/* 開閉 */
.hamburger-icon:before {
top: -8px;
}

.hamburger-icon:after {
top: 8px;
}

.hamburger-icon.middle {
top: 0;
}

.hamburger.active .hamburger-icon {
background-color: transparent;
}

.hamburger.active .hamburger-icon:before {
transform: rotate(45deg);
top: 0;
}

.hamburger.active .hamburger-icon:after {
transform: rotate(-45deg);
top: 0;
}

.mobile-menu {
  display: none;
  position: absolute;
  top: 57px;
  right: 0;
  background-color: #f8f8f8;
  width: 100%;
  text-align: center;
  padding: 20px 0;
  box-shadow: 0px 2px 5px #00000033;
}

.mobile-menu ul {
padding: 0 20px;
list-style: none;
}

/* スマホメニュー */
.mobile-menu li {font-weight: bold;text-align: left;margin-bottom: 10px;}

.mobile-menu li:last-child a {
  padding: 8px 20px;
  background-color: #186CFF;
  color: white;
  text-decoration: none;
  border-radius: 9999px;
  display: inline-block;
  font-size: 18px;
}

.mobile-menu li:last-child a:hover{
  background-color: #0056b3;
}

@media (max-width: 1024px) {
.menu, .button {
  display: none;
}

.hamburger {
  display: block;
}

.mobile-menu.active {
  display: block;
}
}

/* main 
-----------------------------------------------------------*/

main {
  padding-top: 60px;
}

@media (max-width: 728px) {
  main{
    padding-top: 20px;
  }
}

/* メインビジュアル
-----------------------------------------------------------*/
p#main-visual-heading {
  font-size: 40px;
  font-weight: normal;
  margin-bottom: 24px;
  line-height: 1.2;
}

p#main-visual-heading sub {
  font-size: 14px;
 }

.main-visual {
  max-width: 1140px;
  min-height: 510px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 32px 0 24px;
}

.main-visual-left {
  text-align: center;
  flex: 4;
  padding-right: 20px;
}

.main-visual-left .contact-button {
  max-width: 400px;
  padding: 16px 3px 1px;
  margin-top: 32px;
}

.main-visual-left .logo img{
  max-width: 270px;
}

.main-visual-right {
  flex: 6;
  display: flex;
  justify-content: center;
  align-items: center;
}

.main-visual-right img {
  max-width: 100%;
  max-height: 500px;
}

.features-list {
  list-style: none;
  margin: 32px auto 20px;
  max-width: 307px;
  text-align: left;
}

.features-list li {
  line-height: 24px;
  margin-bottom: 10px;
  font-size: 24px;
  font-weight: bold;
  padding-top: 6px;
}

.features-list li img{
  vertical-align: middle;
  margin-right: 13px;
  height: auto;
  width: 30px;
}

.contact-button {
  padding: 16px 40px 1px;
  background-color: #186CFF;
  color: white;
  border: none;
  border-radius: 9999px;
  cursor: pointer;
  font-size: 30px;
  font-weight: bold;
  max-width: 420px;
  margin: 0 auto;
  line-height: 1.25;
}

.contact-button:hover {
  background-color: #0056b3;
  text-decoration: none;
}

.contact-button .linkicon::after {
  content: "\f35d";
  margin-left: 16px;
  color: #ffffff;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 24px;
}

.icon-white{
  fill: currentColor;
}

.linkicon-small{
  width: 16px;
  height: 16px;
  margin-left: 10px;
  vertical-align: text-top;
}

.linkicon-large{
  width: 24px;
  height: 24px;
  margin-left: 16px;
}

.contact-button p{
  font-size: 16px;
  font-weight: normal
}


@media (max-width: 1024px) {
  .main-visual-left,.main-visual-right{
    flex: 5;
  }
  .main-visual {
    padding: 0 16px;
    margin: 32px auto 0;
  }
  .contact-button,.main-visual-left .contact-button {
    max-width: 420px;
  }
}


@media (max-width: 768px) {

  p#main-visual-heading{
    margin-top: 0;
  }

  .main-visual {
      flex-direction: column;
      padding: 50px 20px 20px;
      width: 100%;
  }

  .main-visual-left {
      padding-right: 0;
      margin-bottom: 20px;
      width: 100%;
  }

  .main-visual-right {
      width: 100%;
  }

  .main-visual-right img {
      max-width: 100%;
      height: auto;
  }

  .contact-button,.main-visual-left .contact-button {
    max-width: 100%;
    padding: 16px 3px 1px;
  }

  .main-visual-left .logo img{
    max-width: 80%;
  }
}

/* セクション 
-----------------------------------------------------------*/

section {
  padding-top: 70px;
  margin-top: -70px;
}

.section-container{
  max-width: 1140px;
  margin: 0 auto;
  padding: 40px 16px 0;
}

@media (max-width: 768px) {
  .section-container{
      max-width: 100%;
      padding: 0 16px;
  }
}

/*セクション1*/
#section1 {
  position: relative;
  padding-bottom: 20px; 
}

.section-background {
  position: relative;
  background-color: #f0f4ff;
  padding: 24px 0;
  margin-bottom: 24px;
}

#section1::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 150px solid transparent;
  border-right: 150px solid transparent;
  border-top: 80px solid #f0f4ff;
}

@media (max-width: 768px) {
  .section-background {
    padding: 40px 0;
  }
}
/* カード */
.card-container {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
  max-width: 1140px;
  margin: 0 auto;
}

.card {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  flex: 1 1 calc(33.333% - 20px);
  max-width: calc(33.333% - 20px);
  align-items: stretch; /* 高さを揃える */
}

.card-content {
  text-align: center;
  padding: 20px;
  flex: 1; /* 残りのスペースを埋めるようにする */
}

.card-title {
  font-size: 28px;
  margin: 0 0 10px;
}

.card-text {
  font-size: 20px;
  margin: 0;
  font-weight: bold;
}

.card-image {
  overflow: hidden;
  flex: 0 0 auto;
  display: flex;
  justify-content: center;
  align-items: flex-end; /* イラストの横のラインを下に揃える */
}

.card-image img {
  max-height: 168px; 
  height: auto;
  object-fit: cover;
  padding-bottom: 8px;
}

.card-text sub{
  font-size: 12px;
}

@media (max-width: 768px) {
  .card {
      max-width: 100%;
      flex: 1 1 100%;
  }

  .card-content {
      padding: 20px;
  }

  .card-image {
      flex: 0 0 auto;
      max-height: none;
  }
}


/*セクション2*/
.section2-container {
display: flex;
flex-wrap: wrap;
max-width: 820px;
margin: 0 auto;
border-radius: 10px;
overflow: hidden;
}

.section2-container .image {
flex: 4;
max-width: 40%;
}

.section2-container .image img {
width: 100%;
height: auto;
display: block;
object-fit: cover;
}

.section2-container .text {
flex: 6; 
padding: 40px 20px 0;
max-width: 60%;
}

.section2-container .text h3 {
margin-top: 0;
}

@media (max-width: 768px) {
.section2-container {
    flex-direction: column;
}

.section2-container .image, .section2-container .text {
    max-width: 100%;
}

.section2-container .image {
    order: 1;
}

.section2-container .text {
    order: 2;
    padding: 40px 0 20px;
    text-align: center;
}
}

/*セクション3*/
.section3-container {
  display: flex;
  flex-wrap: wrap;
  max-width: 1140px;
  margin: 0 auto 32px;
}

h2#section3-2-heading,h2#section3-3-heading{
  font-size:32px!important;
}

.section3-image {
  flex: 3;
  max-width: 30%;
}

.section3-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  border: 4px solid #EEEEEE;
  border-radius: 16px;
}

.section3-text-content {
  flex: 7;
  max-width: 70%;
  padding: 0 0 0 32px;
}

.section3-text-content h3 {
  font-size: 24px;
  font-weight: bold;
  margin: 0 auto 16px;
}

.section3-text-content p {
  font-size: 16px;
}

.note a {
  color: #186CFF;
  display: inline;
  text-decoration: underline;
}
.note_linkicon::after {
  content: "\f35d";
  color: #186CFF;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 16px;
  text-decoration: none;
}

@media (max-width: 768px) {
  .section3-container {
      display: block;
  }

  .section3-image {
      flex: 1;
      max-width: 100%;
  }

  .section3-text-content {
      flex: 1; 
      max-width: 100%;
      padding: 16px 0;
  }
}

/* お問い合わせエリア
-----------------------------------------------------------*/

.inquiry-area{
  background-color:#f0f4ff;
  padding:60px 16px ;
}
.inquiry-area-container{
  text-align: center;
  max-width: 1140px;
  margin: 0 auto;
}


a.faqs-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #000000;
  transition: opacity 0.4s;
  width: 100%;
  opacity: 1;
}
a {
  color: inherit;
  text-decoration: none;
  display: block;
}
ユーザー エージェント スタイルシート
a:-webkit-any-link {
  color: -webkit-link;
  cursor: pointer;
}
.faqs-item {
  width: 100%;
  padding-bottom: 24px;
  margin-bottom: 24px;
  border-bottom: 2px solid #eeeeee;
  font-size: 16px;
  text-align: left;
  line-height: 1.5;
}
body {
  font-family: Arial, sans-serif;
  background-color: #fff;
  color: #000;
  line-height: 1.75;
}

@media (max-width: 768px) {
  .inquiry-area-container{
    width: 100%;
  }
}

/* FAQ 
-----------------------------------------------------------*/
.faqs-item {
  width: 100%;
  padding-bottom: 24px;
  margin-bottom: 24px;
  border-bottom: 2px solid #eeeeee;
  font-size: 16px;
  text-align: left;
  line-height: 1.5;
}

.faqs-item-first{
  border-top: #eee solid 2px;
  padding-top: 24px;
}

a.faqs-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #000000;
  transition: opacity 0.4s;
  width: 100%;
  opacity: 1;
}

a.faqs-title:hover {
  text-decoration: none;
  opacity: 0.4;
}

@media print, screen and (max-width: 768px) {
  a.faqs-title {
    align-items: start;
    opacity: 1 !important;
    color: #000000 !important;
  }
}

.faqs-title:hover {
  cursor: pointer;
}

.faqs-title:after {
  content: "";
  flex-shrink: 0;
    width: 30px;  /* アイコンの幅 */
    height: 30px; /* アイコンの高さ */
    margin-top: -4px;
    margin-left: 32px;
    background: #186CFF;
    mask: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path fill="%23186CFF" d="M416 208H272V64c0-17.7-14.3-32-32-32s-32 14.3-32 32v144H32c-17.7 0-32 14.3-32 32s14.3 32 32 32h176v144c0 17.7 14.3 32 32 32s32-14.3 32-32V272h144c17.7 0 32-14.3 32-32s-14.3-32-32-32z"/></svg>') no-repeat center;
    -webkit-mask: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path fill="%23186CFF" d="M416 208H272V64c0-17.7-14.3-32-32-32s-32 14.3-32 32v144H32c-17.7 0-32 14.3-32 32s14.3 32 32 32h176v144c0 17.7 14.3 32 32 32s32-14.3 32-32V272h144c17.7 0 32-14.3 32-32s-14.3-32-32-32z"/></svg>') no-repeat center;
    mask-size: contain;
    -webkit-mask-size: contain;
}

.faqs-title-inside,
.faqs-content {
  display: flex;
  flex-wrap: nowrap;
  font-size: 20px;
  font-weight: bold;
}

.faqs-content-inside p{
  font-weight: normal;
  font-size: 18px;
}

.faqs-title-inside::before,
.faqs-content::before {
  content: "";
  display: inline-block;
  min-width: 16px;
  height: auto;
  margin-right: 32px;
}

.faqs-title-inside::before {
  background: url(../img/img-q.png) no-repeat;
  background-size: contain;
}

.faqs-content::before {
  margin-top: 4px;
  background: url(../img/img-a.png) no-repeat;
  background-size: contain;
}

.is-display:after {
  content: "";
  flex-shrink: 0;
    width: 24px;
    height: 24px;
    margin-top: -4px;
    margin-left: 32px;
    background: #186CFF;
    mask: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="%23186CFF" d="M480 480H32c-17.7 0-32-14.3-32-32s14.3-32 32-32h448c17.7 0 32 14.3 32 32s-14.3 32-32 32z"/></svg>') no-repeat center;
    -webkit-mask: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="%23186CFF" d="M480 480H32c-17.7 0-32-14.3-32-32s14.3-32 32-32h448c17.7 0 32 14.3 32 32s-14.3 32-32 32z"/></svg>') no-repeat center;
    mask-size: contain;
    -webkit-mask-size: contain;
}

.is-display {
  opacity: 1 !important;
  margin-bottom: 24px;
  color: #000000 !important;
}

.faqs-content {
  padding: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
}

article .faqs-content p {
  margin-bottom: 24px;
  font-size: 16px;
}

article .faqs-content p:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 357px) {
.faqs-title-inside::before,
.faqs-content::before {
  min-width: 12px;
  margin-right: 12px;
}
}

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

  .faqs-title-inside::before {
    margin-top: 4px;
  }
  .faqs-content::before {
    margin-top: .5rem;
  }

  .three-column-width {
    width: 100%;
  }

  .article-card-item.page-link {
    margin: 7px 0;
  }
  .article-card-item:first-child {
    margin-top: 0;
  }
  .article-card-item:last-child {
    margin-bottom: 0;
  }

  .flex-column-reverse-sp {
    flex-direction: column-reverse;
  }
}

/* footer
-----------------------------------------------------------*/
footer{
  border-top: 1px solid #CCCCCC;
  margin: 100px auto 0;
  padding: 32px 16px;
}

.footer-container{
  max-width: 1140px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
}

footer .corporate-logo {
  width: 160px;
  height: 35px;
  margin: 0 24px 16px 0;
  padding: 0 12px;
}

footer ul li{
  list-style: none;
}

footer a{
  color: #004ADE;
}

.footer_navi{
  flex: 3;
  max-width: 15%;
}

.utility_navi li {
  padding:0 4px 2px 12px;
}

.footer-right{
  margin-left: 24px;
}

.row {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(var(--bs-gutter-y)* -1);
  margin-right: calc(var(--bs-gutter-x)* -0.5);
  margin-left: calc(var(--bs-gutter-x)* -0.5);
}
@media screen and (max-width: 1024px) {
  .footer_navi{
    max-width: 25%;
  }
}
@media screen and (max-width: 768px) {
  footer .corporate-logo{
    padding: 0;
    max-width: 120px;
  }

  .footer-right{
    margin-left: 0;
  }
}