@charset "UTF-8";
html {
    height: 100%;
    margin: 0;
    padding: 0;
    font-size: 62.5%;
}
body {
    width: 100%;
    height: 100%;
    color: #404040;
    font-family: 'Noto Sans JP', sans-serif;
    position: relative;
    line-height: 2.0rem;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    background-image: url(../img/header_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
}

a {
  text-decoration: none;
  color: #000000;
}
a:hover {
  text-decoration: underline;
  color: #000000;
}

/****** header ******/
header {
  width: 100%;
  box-sizing: border-box;
  padding: 30px 20px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  background: #ffffff;
}
header .header-inner {
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
}
header .header-inner .header-main {
  display: flex;
  box-sizing: border-box;
  align-items: center;
}
header .header-inner .header-main h1 {
  height: 40px;
  box-sizing: border-box;
}
header .header-inner .header-main h1 img {
  height: 40px;
  width: auto;
}
header .header-inner .header-main .header-sub {
  font-size: 1.6rem;
  line-height: 2.0rem;
  padding-left: 15px;
}
header .header-inner .navi-list {
  display: flex;
  list-style: none;
}
header .header-inner .navi-list li {
  padding-right: 20px;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
header .header-inner .navi-list li:last-child {
  padding-right: 0;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
header .header-inner .navi-list li a {
  color: #000000;
  text-decoration: none;
}
header .header-inner .navi-list li a:hover {
  color: #666666;
  text-decoration: none;
}
header .header-inner .navi-list .navi-active {
  color: #000000;
  text-decoration: none;
}
header .header-inner .navi-list .navi-active a {
  color: #666666;
  text-decoration: none;
}
header .header-inner .navi-list .navi-active a:hover {
  color: #666666;
  text-decoration: none;
}
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: space-around;
  width: 2rem;
  height: 2rem;
  cursor: pointer;
  position: relative;
}
.hamburger .bar {
  width: 2rem;
  height: 0.25rem;
  background-color: #ffa5a5;
  transition: all 0.3s ease-in-out;
  position: absolute;
}
.hamburger .bar:nth-child(1) {
  top: 0.375rem;
}
.hamburger .bar:nth-child(2) {
  top: 0.875rem;
}
.hamburger .bar:nth-child(3) {
  top: 1.375rem;
}
.header-white-background {
  background-color: #ffffff;
}

/****** wrapper ******/
#wrapper {
  width: 100%;
  padding-top: 140px;
  box-sizing: border-box;
  flex: 1;
}

/****** main visual ******/
/* Main Visual Base Styles */
.main-visual {
  width: 100%;
  height: 500px;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
}

.main-visual .main-visual-inner {
  width: 94%;
  margin: 0 auto;
  display: flex;
  transition: transform 0.4s ease;
  gap: 40px;
  box-sizing: border-box;
}

/* 各スライドの横幅を、gap分を引いた値に調整 */
.slide {
  flex: 0 0 calc(100%);
  box-sizing: border-box;
}

/* Visual Content */
/* 親コンテナ：スライド全体 */
.visual-cont {
  width: 94%;
  margin: 0 auto;
  position: relative; /* 絶対配置の基準 */
  height: 450px;      /* コンテンツの高さ、必要に応じ調整 */
  overflow: hidden;
  text-align: center;
}
/* 画像部分：右寄せ、幅72.1% */
.visual-pic-pos {
  position: absolute;
  top: 0;
  right: 0;
  width: 72.1%;
  height: 100%;
  box-sizing: border-box;
}
.visual-pic-pos img {
  max-width: auto;
  max-height: 450px;
  display: block;
  margin-left: auto;
  margin-right: 0;
}
.visual-pic-pos .pic-detail {
  width: 100%;
  max-height: 450px;
  position: relative;
}
.visual-pic-pos .pic-detail .btn-detail {
  position: absolute;
  bottom: 20px;
  right: 10px;
  border: 1px solid #ffa5a5;
  padding: 10px 35px 10px 15px;
  background: #ffffff url('../img/arrow_detail.png') no-repeat right 12px center;
  background-size: 16px 13px;
  border-radius: 20px;
  font-size: 1.4rem;
  line-height: 1.4rem;
}
.visual-pic-pos .pic-detail .btn-detail:hover {
  opacity: 0.8;
}
.visual-pic-pos .pic-detail .btn-detail a {
  display: inline-block;
}
.visual-pic-pos .pic-detail .btn-detail a:hover {
  text-decoration: none;
}
/* テキストオーバーレイ：画像と同じ位置・サイズに固定 */
.visual-ttl-pos {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}
/* .ttl-main-area 内のテキストを、左寄せ・縦中央に配置 */
.ttl-main-area {
  position: relative;
  width: 100%;
  height: 100%;
  padding-left: 20px;   /* 左余白（必要に応じ調整） */
  display: flex;
  flex-direction: column;
  justify-content: center; /* 垂直中央揃え */
  align-items: flex-start;   /* 横は左寄せ */
  text-align: left;
}
/* 既存のテキスト用スタイル */
.visual-ttl-bg {
  background: #ffffff;
  box-sizing: border-box;
  padding: 20px;
  margin-bottom: 10px;
  display: inline-block;
}
.visual-ttl-bg .visual-ttl {
  background: var(--gradation01, linear-gradient(90deg, #FFB677 0.6%, #FFA5A5 24.06%, #96ACDC 48.11%, #81BFD2 78.93%, #77D89D 100%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: 'Noto Sans JP', serif;
  font-size: 3.8rem;
  line-height: 4.8rem;
}
.visual-ttl-bg .visual-ttll-sub {
  font-size: 1.4rem;
  line-height: 2.0rem;
  padding-top: 10px;
}
/* Slider Arrows */
.slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
  height: 60px;
  background: none;
  border: none;
  font-size: 0;
  cursor: pointer;
  z-index: 10;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.prev {
  left: 1rem;
  background-image: url('../img/arrow_v_l.png');
}
.next {
  right: 1rem;
  background-image: url('../img/arrow_v_r.png');
}
/* Slider Dots */
.slider-dots {
  display: flex;
  gap: 1.0rem;
  list-style: none;
  margin: 0;
  padding: 30px 0 0 0;
  justify-content: center;
}
.slider-dots li {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #e4e4e4;
  border: 2px solid #ffffff;
  cursor: pointer;
  box-shadow: inset 0 0 5px rgba(0,0,0,.1);
}
.slider-dots li.active {
  background: #FFA5A5;
}

.ttl-motion-fir {
  animation: ttl-motion01 0.3s linear forwards;
}

.ttl-motion-sec {
  animation: ttl-motion01 0.4s linear forwards;
}

@keyframes ttl-motion01 {
  0% {
      clip-path: inset(0 100% 0 0);
  }

  100% {
      clip-path: inset(0);
  }
}

/****** top contents ******/
/* top title */
.top-ttl {
  font-size: 3.2rem;
  line-height: 3.2rem;
  font-weight: bold;
  background-image: url('../img/ttl_dot.png');
  background-repeat: no-repeat;
  background-position: left bottom;
  padding-bottom: 30px;
  margin-bottom: 40px;
  background-size: auto 15px;
}
/* top introducion */
.top-introduction {
  width: 1200px;
  margin: 0 auto;
  padding: 60px 0 80px 0;
  box-sizing: border-box;
}
.top-introduction .inner-introduction {
  list-style: none;
  display: flex;
}
.top-introduction .inner-introduction a {
  display: block;
  text-decoration: none;
}
.top-introduction .inner-introduction a:hover {
  display: block;
  text-decoration: none;
  opacity: 0.8;
}
.top-introduction .inner-introduction li {
  width: 270px;
  margin-right: 40px;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
}
.top-introduction .inner-introduction li:last-child {
  width: 270px;
  margin-right: 0;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
}
.top-introduction .inner-introduction .inner-cont-pic {
  padding: 16px;
  background: #f5f5f5;
  display: flex;
  align-items: center;
  border-radius: 5px 5px 0 0;
}
.top-introduction .inner-introduction .inner-cont-pic .cont-name {
  flex: 1;
}
.top-introduction .inner-introduction .inner-cont-pic .cont-name .txt-b-place {
  font-size: 1.4rem;
  line-height: 2.0rem;
  padding-bottom: 8px;
}
.top-introduction .inner-introduction .inner-cont-pic .cont-name .txt-s-name {
  font-size: 1.8rem;
  line-height: 2.4rem;
  font-weight: bold;
}
.top-introduction .inner-introduction .inner-cont-pic .cont-pic {
  width: 140px;
}
.top-introduction .inner-introduction .inner-cont-pic .cont-pic img {
  width: 140px;
  height: auto;
}
.top-introduction .inner-introduction .inner-cont-intro {
  padding: 16px;
  font-size: 1.8rem;
  line-height: 2.4rem;
}
.top-introduction .intro-btn-area {
  box-sizing: border-box;
  padding-top: 40px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.top-introduction .intro-btn-area .btn-intro {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 10px 70px 10px 15px;
  background: #ffffff;
  font-size: 1.8rem;
  line-height: 1.4;
  color: #404040;
  text-decoration: none;
  border-radius: 20px;
  box-sizing: border-box;
}
.top-introduction .intro-btn-area .btn-intro::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 60px;
  height: 60px;
  background: url('../img/icon_senior_arrow.png') no-repeat center center;
  background-size: contain;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.15);
  border-radius: 50%;
  pointer-events: none;
}
.top-introduction .intro-btn-area .btn-intro:hover {
  opacity: 0.8;
  text-decoration: none;
}
/* top about */
.top-about {
  width: 100%;
  box-sizing: border-box;
  max-height: 352px;
  padding: 50px 0;
  background: url('../img/bg_top_about.png') no-repeat center center;
  background-size: cover;
  margin-bottom: 80px;
}
.top-about .inner-about {
  width: 1200px;
  margin: 0 auto;
  text-align: center;
}
.top-about .inner-about .about-ttl {
  font-size: 3.2rem;
  line-height: 3.2rem;
  background: var(--gradation01, linear-gradient(90deg, #FFB677 0.6%, #FFA5A5 24.06%, #96ACDC 48.11%, #81BFD2 78.93%, #77D89D 100%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: 'Noto Sans JP', serif;
  padding-bottom: 30px;
}
.top-about .inner-about .about-txt {
  font-size: 2.0rem;
  line-height: 4.0rem;
  font-weight: bold;
}

/****** top can do ******/
.top-can-do {
  width: 1200px;
  margin: 0 auto;
  padding: 0 0 80px 0;
  box-sizing: border-box;
}
.top-can-do .inner-can-do {
  list-style: none;
  display: flex;
  align-items: stretch;
  gap: 50px;
  padding-top: 70px;
}
.top-can-do .inner-can-do li {
  width: 575px;
  border-radius: 5px;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  overflow: visible;
  position: relative;
  background: url('../img/bg_top_cando.png') no-repeat top center;
  background-size: cover;
  padding: 16px;
}
.top-can-do .inner-can-do li .can-do-cont {
  box-sizing: border-box;
  padding: 16px;
  height: 100%;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  overflow: visible;
  background: #ffffff;
  border-radius: 5px;
}
.top-can-do .inner-can-do li .can-do-cont .can-do-icon {
  box-sizing: border-box;
  margin: -70px auto 20px auto;
}
.top-can-do .inner-can-do li .can-do-cont .can-do-ttl {
  font-size: 2.0rem;
  line-height: 2.0rem;
  background: var(--gradation01, linear-gradient(90deg, #FFB677 0%,
  #FFA5A5 40%,
  #96ACDC 50%,
  #81BFD2 60%,
  #77D89D 100%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: 'Noto Sans JP', serif;
  font-weight: bold;
  text-align: center;
  padding-bottom: 16px;
}
.top-can-do .inner-can-do li .can-do-cont .can-do-txt {
  font-size: 1.4rem;
  line-height: 2.0rem;
  padding-bottom: 16px;
}

/****** top request ******/
.top-request {
  width: 1200px;
  margin: 0 auto;
  padding: 0 0 80px 0;
  box-sizing: border-box;
}
.top-request .inner-request {
  list-style: none;
  display: flex;
  align-items: stretch;
  gap: 50px;
}
.top-request .inner-request li {
  width: 575px;
  border-radius: 5px;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  overflow: visible;
  position: relative;
  background: url('../img/bg_top_cando.png') no-repeat top center;
  background-size: cover;
  padding: 16px;
}
.top-request .inner-request li .request-cont {
  box-sizing: border-box;
  padding: 16px;
  height: 100%;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  overflow: visible;
  background: #ffffff;
  border-radius: 5px;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
.top-request .inner-request li .request-cont .request-pic {
  background: #f5f5f5;
  border-radius: 5px;
  text-align: center;
  padding: 8px;
  box-sizing: border-box;
  margin-bottom: 20px;
}
.top-request .inner-request li .request-cont .request-pic img {
  height: 188px;
  width: auto;
  object-fit: contain;
}

/****** top manner ******/
.top-manner{
  width: 1200px;
  margin: 0 auto;
  padding: 0 0 80px 0;
  box-sizing: border-box;
}
.top-manner .inner-manner {
  list-style: none;
  display: flex;
  align-items: stretch;
  gap: 50px;
}
.top-manner .inner-manner li {
  width: 575px;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  overflow: visible;
  position: relative;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
.top-manner .inner-manner li .manner-cont {
  box-sizing: border-box;
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.top-manner .inner-manner li .manner-cont .manner-pic {
  margin-top: auto;
  background: #f5f5f5;
  border-radius: 5px;
  text-align: center;
  padding: 8px;
  box-sizing: border-box;
  margin-bottom: 20px;
}
.top-manner .inner-manner li .manner-cont .manner-pic img {
  height: 188px;
  width: auto;
  object-fit: contain;
}

/****** top how use ******/
.top-how-use {
  width: 1200px;
  margin: 0 auto;
  padding: 0 0 80px 0;
  box-sizing: border-box;
}
.top-how-use .inner-how-use {
  list-style: none;
}
.top-how-use .inner-how-use li {
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  margin-bottom: 40px;
}
.top-how-use .inner-how-use li.how-use-arrow {
  width: 100%;
  text-align: center;
  border-radius: 0;
  box-shadow: none;
}
.top-how-use .inner-how-use li.how-use-arrow img {
  display: block;
  margin: 0 auto;
}
.top-how-use .inner-how-use li:last-child {
  margin-bottom: 0;
}
.top-how-use .inner-how-use li .how-use-cont {
  box-sizing: border-box;
  padding: 16px;
  height: 100%;
  width: 100%;
  display: flex;
  justify-content: flex-start;
}
.top-how-use .inner-how-use li .how-use-cont .how-use-txt {
  font-size: 1.8rem;
  line-height: 2.6rem;
  flex: 1;
  order: 0;
  box-sizing: border-box;
  padding-right: 20px;
}
.top-how-use .inner-how-use li .how-use-cont .how-use-txt .how-use-step-txt {
  color: #ffa5a5;
  font-size: 2.4rem;
  font-weight: bold;
  padding-bottom: 20px;
}
.top-how-use .inner-how-use li .how-use-cont .how-use-pic {
  background: #f5f5f5;
  border-radius: 5px;
  text-align: center;
  padding: 10px 0;
  box-sizing: border-box;
  width: 338px;
  order: 1;
}
.top-how-use .inner-how-use li .how-use-cont .how-use-pic img {
  height: 200px;
  width: auto;
  object-fit: contain;
}

/****** top faq ******/
.top-faq {
  width: 1200px;
  margin: 0 auto;
  padding: 0 0 80px 0;
  box-sizing: border-box;
}
.top-faq .inner-faq {
  list-style: none;
}
.top-faq .inner-faq li {
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  margin-bottom: 40px;
}
.top-faq .inner-faq li:last-child {
  margin-bottom: 0;
}
.top-faq .inner-faq .qa-block {
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 16px;
}
.top-faq .inner-faq .qa-question {
  display: flex;
  align-items: flex-start;
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid #e4e4e4;
}
.top-faq .inner-faq .qa-question-icon {
  width: 40px;
  height: 40px;
  background-color: #ffffff;
  border: 1px solid #ff9696;
  color: #ff9696;
  font-size: 1.8rem;
  line-height: 1;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 20px;
  flex-shrink: 0;
}
.top-faq .inner-faq .qa-answer {
  display: flex;
  align-items: flex-start;
}
.top-faq .inner-faq .qa-answer-icon {
  width: 40px;
  height: 40px;
  background-color: #ff9696;
  border: 1px solid #ff9696;
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 20px;
  flex-shrink: 0;
}
.top-faq .inner-faq .qa-text {
  font-size: 1.8rem;
  line-height: 2.6rem;
  margin-top: 6px;
}

/****** top tax ******/
.top-tax {
  width: 1200px;
  margin: 0 auto;
  padding: 0 0 80px 0;
  box-sizing: border-box;
}
.top-tax .inner-tax {
  width: 100%;
  background: url('../img/bg_top_message.png') no-repeat top center;
  background-size: cover;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  border-radius: 5px;
  box-sizing: border-box;
  padding: 16px;
}
.top-tax .inner-tax .tax-cont {
  background: #ffffff;
  padding: 16px;
  border-radius: 5px;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
.top-tax .inner-tax .tax-cont .tax-inner-cont {
  box-sizing: border-box;
  display: flex;
  align-items: center;
}
.top-tax .inner-tax .tax-cont .tax-inner-cont .tax-pic {
  box-sizing: border-box;
  width: 110px;
}
.top-tax .inner-tax .tax-cont .tax-inner-cont .tax-pic img {
  width: 110px;
  height: auto;
}
.top-tax .inner-tax .tax-cont .tax-inner-cont .tax-txt {
  box-sizing: border-box;
  padding-left: 20px;
  font-size: 2.0rem;
  line-height: 3.0rem;
  flex: 1;
}

/****** top message ******/
.top-message {
  width: 1200px;
  margin: 0 auto;
  padding: 0 0 100px 0;
  box-sizing: border-box;
}
.top-message .inner-message {
  width: 100%;
  background: url('../img/bg_top_message.png') no-repeat top center;
  background-size: cover;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  border-radius: 5px;
  box-sizing: border-box;
  padding: 16px;
}
.top-message .inner-message .message-cont {
  background: #ffffff;
  padding: 16px;
  border-radius: 5px;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
.top-message .inner-message .message-cont .message-ttl {
  font-size: 2.0rem;
  line-height: 2.8rem;
  padding-bottom: 20px;
  font-weight: bold;
}
.top-message .inner-message .message-cont .message-inner-cont {
  box-sizing: border-box;
  display: flex;
}
.top-message .inner-message .message-cont .message-inner-cont .message-pic {
  box-sizing: border-box;
  width: 270px;
}
.top-message .inner-message .message-cont .message-inner-cont .message-pic img {
  width: 270px;
  height: auto;
}
.top-message .inner-message .message-cont .message-inner-cont .message-txt {
  box-sizing: border-box;
  padding-left: 20px;
  flex: 1;
}

/****** footer ******/
footer {
  box-sizing: border-box;
  background: #ffffff;
  padding: 30px 20px;
  border-top: 1px solid #e4e4e4;
}
footer .footer-info-area {
  max-width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
}
footer .footer-info-area .footer-nav {
  box-sizing: border-box;
  font-size: 1.2rem;
  line-height: 1.8rem;
  list-style: none;
  display: flex;
}
footer .footer-info-area .footer-nav li {
  margin-right: 20px;
}
footer .footer-info-area .footer-nav li:last-child {
  margin-right: 0;
}
footer .footer-info-area .footer-bsi {
  box-sizing: border-box;
  font-size: 1.0rem;
  line-height: 1.6rem;
  list-style: none;
  display: flex;
  align-items: center;
}
footer .footer-info-area .footer-bsi .bsi-txt-pos {
  box-sizing: border-box;
  font-size: 1.0rem;
  line-height: 1.6rem;
  padding-right: 10px;
}
footer .footer-info-area .footer-bsi .bsi-logo-pos {
  box-sizing: border-box;
}
footer .footer-copyright {
  box-sizing: border-box;
  font-size: 1.2rem;
  line-height: 1.8rem;
  text-align: center;
  padding-top: 30px;
}

/******************************************************
smartphone
******************************************************/
@media screen and (max-width: 768px) {
/****** header ******/
header {
  padding: 20px 15px;
}
header .header-inner {
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
}
header .header-inner .header-main {
  display: block;
  box-sizing: border-box;
}
header .header-inner .header-main h1 {
  height: 30px;
  box-sizing: border-box;
}
header .header-inner .header-main h1 img {
  height: 30px;
  width: auto;
}
header .header-inner .header-main .header-sub {
  font-size: 1.2rem;
  line-height: 1.8rem;
  padding-top: 10px;
  padding-left: 0;
}
.hamburger {
  display: flex;
}
.hamburger.open .bar:nth-child(1) {
  transform: translateY(0.5rem) rotate(45deg);
}
.hamburger.open .bar:nth-child(2) {
  opacity: 0;
}
.hamburger.open .bar:nth-child(3) {
  transform: translateY(-0.5rem) rotate(-45deg);
}
header .header-inner .navi-list {
  display: none;
  flex-direction: column;
  position: fixed;
  top: 98px;
  left: 0;
  width: 100%;
  height: calc(100% - 98px);
  background-color: #fff;
  overflow-y: auto;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
  z-index: 1;
}
header .header-inner .navi-list li {
  padding: 20px 0 20px 20px;
  font-size: 1.6rem;
  line-height: 2.2rem;
  border-top: 1px solid #e4e4e4;
}
header .header-inner .navi-list li:last-child {
  padding: 20px 0 20px 20px;
  font-size: 1.6rem;
  line-height: 2.2rem;
  border-bottom: 1px solid #e4e4e4;
}
.hamburger.open + .navi-list {
  display: flex;
}

/****** wrapper ******/
#wrapper {
  width: 100%;
  padding-top: 120px;
  box-sizing: border-box;
  flex: 1;
}

/****** main visual ******/
/* メインビジュアルの基本スタイル */
.main-visual {
  width: 100%;
  height: 380px;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
}

.main-visual .main-visual-inner {
  width: 94%;
  margin: 0 auto;
  display: flex;
  transition: transform 0.4s ease;
  gap: 40px;
  box-sizing: border-box;
}

/* 親コンテナ：スライド全体 */
.visual-cont {
  width: 94%;
  margin: 0 auto;
  position: relative; /* 絶対配置の基準 */
  height: 350px; /* コンテンツの高さ、必要に応じ調整 */
  overflow: hidden;
  text-align: center;
}

/* 画像部分：右下に配置 */
.visual-pic-pos {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 90%;
  height: 100%; /* 親要素の高さに合わせる */
  display: flex;
  align-items: flex-end; /* 下寄せ */
  justify-content: flex-end; /* 右寄せ */
}
.visual-pic-pos img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.visual-pic-pos .pic-detail .btn-detail {
  position: absolute;
  bottom: 10px;
  right: 10px;
  border: 1px solid #ffa5a5;
  padding: 10px 15px;
  padding: 10px 30px 10px 10px;
  background: #ffffff url('../img/arrow_detail.png') no-repeat right 12px center;
  background-size: 16px 13px;
  border-radius: 20px;
  font-size: 1.2rem;
  line-height: 1.2rem;
}

/* テキストオーバーレイ：左上に固定 */
.visual-ttl-pos {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

/* .ttl-main-area 内のテキストを、左寄せ・縦方向に整列 */
.ttl-main-area {
  position: relative;
  width: 100%;
  height: 100%;
  padding-left: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  text-align: left;
}

/* 既存のテキスト用スタイル */
.visual-ttl-bg {
  background: #ffffff;
  box-sizing: border-box;
  padding: 10px;
  margin-bottom: 10px;
  display: inline-block;
}
.visual-ttl-bg .visual-ttl {
  background: var(--gradation01, linear-gradient(90deg, #FFB677 0.6%, #FFA5A5 24.06%, #96ACDC 48.11%, #81BFD2 78.93%, #77D89D 100%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: 'Noto Sans JP', serif;
  font-size: 2.0rem;
  line-height: 3.0rem;
}

/* スライダー矢印 */
.slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 40px;
  background: none;
  border: none;
  font-size: 0;
  cursor: pointer;
  z-index: 10;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.prev {
  left: 0.5rem;
  background-image: url('../img/arrow_v_l.png');
  background-size: 20px 40px;
}
.next {
  right: 0.5rem;
  background-image: url('../img/arrow_v_r.png');
  background-size: 20px 40px;
}

/* スライダードット */
.slider-dots {
  display: flex;
  gap: 1.0rem;
  list-style: none;
  margin: 0 auto;
  padding: 10px 0;
  justify-content: center;
}
.slider-dots li {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #e4e4e4;
  border: 2px solid #ffffff;
  cursor: pointer;
  box-shadow: inset 0 0 5px rgba(0,0,0,.1);
}
.slider-dots li.active {
  background: #FFA5A5;
}

/****** top contents ******/
/* top title */
.top-ttl {
  font-size: 2.4rem;
  line-height: 3.4rem;
  font-weight: bold;
  background-image: url('../img/ttl_dot.png');
  background-repeat: no-repeat;
  background-position: left bottom;
  padding-bottom: 30px;
  margin-bottom: 40px;
  background-size: auto 10px;
}
/* top introducion */
.top-introduction {
  width: 96%;
  margin: 0 auto;
  padding: 60px 0 50px 0;
  box-sizing: border-box;
}
.top-introduction .inner-introduction {
  flex-wrap: wrap;
  gap: 16px;
}
.top-introduction .inner-introduction li {
  width: calc(50% - 8px);
  margin-right: 0;
}
.top-introduction .inner-introduction li:last-child {
  width: calc(50% - 8px);
  margin-right: 0;
}
.top-introduction .inner-introduction .inner-cont-pic {
  padding: 16px;
  background: #f5f5f5;
  display: block;
  text-align: center;
  border-radius: 5px 5px 0 0;
}
.top-introduction .inner-introduction .inner-cont-pic .cont-name {
  padding-bottom: 10px;
}
.top-introduction .inner-introduction .inner-cont-pic .cont-pic {
  width: 100%;
}
.top-introduction .inner-introduction .inner-cont-pic .cont-pic img {
  width: 80%;
  height: auto;
}
.top-introduction .inner-introduction .inner-cont-intro {
  padding: 16px;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
/* top about */
.top-about {
  width: 100%;
  box-sizing: border-box;
  padding: 30px 0;
  background: url('../img/bg_top_about.png') no-repeat center center;
  background-size: cover;
  margin-bottom: 50px;
}
.top-about .inner-about {
  width: 94%;
  margin: 0 auto;
  text-align: center;
}
.top-about .inner-about .about-ttl {
  font-size: 2.4rem;
  line-height: 3.4rem;
  background: var(--gradation01, linear-gradient(90deg, #FFB677 0.6%, #FFA5A5 24.06%, #96ACDC 48.11%, #81BFD2 78.93%, #77D89D 100%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: 'Noto Sans JP', serif;
  padding-bottom: 30px;
}
.top-about .inner-about .about-txt {
  font-size: 1.4rem;
  line-height: 2.4rem;
  font-weight: bold;
}
/****** top can do ******/
.top-can-do {
  width: 94%;
  margin: 0 auto;
  padding: 0 0 50px 0;
  box-sizing: border-box;
}
.top-can-do .inner-can-do {
  list-style: none;
  display: block;
  padding-top: 70px;
}
.top-can-do .inner-can-do li {
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  overflow: visible;
  position: relative;
  margin-bottom: 100px;
  background: url('../img/bg_top_cando.png') no-repeat top center;
  background-size: cover;
  padding: 16px;
  box-sizing: border-box;
}

.top-can-do .inner-can-do li:last-child {
  margin-top: 70px;
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  overflow: visible;
  position: relative;
  margin-bottom: 0;
  background: url('../img/bg_top_cando.png') no-repeat top center;
  background-size: cover;
  padding: 16px;
  box-sizing: border-box;
}

/****** top request ******/
.top-request {
  width: 94%;
  margin: 0 auto;
  padding: 0 0 50px 0;
  box-sizing: border-box;
}
.top-request .inner-request {
  list-style: none;
  display: block;
  box-sizing: border-box;
}
.top-request .inner-request li {
  width: 100%;
  border-radius: 5px;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  overflow: visible;
  position: relative;
  background: url('../img/bg_top_cando.png') no-repeat top center;
  background-size: cover;
  padding: 16px;
  box-sizing: border-box;
  margin-bottom: 30px;
}
.top-request .inner-request li:last-child {
  width: 100%;
  border-radius: 5px;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  overflow: visible;
  position: relative;
  background: url('../img/bg_top_cando.png') no-repeat top center;
  background-size: cover;
  padding: 16px;
  box-sizing: border-box;
  margin-bottom: 0;
}
.top-request .inner-request li .request-cont {
  box-sizing: border-box;
  padding: 16px;
  height: 100%;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  overflow: visible;
  background: #ffffff;
  border-radius: 5px;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
.top-request .inner-request li .request-cont .request-pic {
  background: #f5f5f5;
  border-radius: 5px;
  text-align: center;
  padding: 8px;
  box-sizing: border-box;
  margin-bottom: 20px;
}
.top-request .inner-request li .request-cont .request-pic img {
  height: auto;
  width: 100%;
  object-fit: contain;
}

/****** top manner ******/
.top-manner{
  width: 94%;
  margin: 0 auto;
  padding: 0 0 50px 0;
  box-sizing: border-box;
}
.top-manner .inner-manner {
  list-style: none;
  display: block;
}
.top-manner .inner-manner li {
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  overflow: visible;
  position: relative;
  font-size: 1.4rem;
  line-height: 2.0rem;
  margin-bottom: 30px;
}
.top-manner .inner-manner li .manner-cont {
  box-sizing: border-box;
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.top-manner .inner-manner li .manner-cont .manner-pic {
  margin-top: auto;
  background: #f5f5f5;
  border-radius: 5px;
  text-align: center;
  padding: 8px;
  box-sizing: border-box;
  margin-bottom: 20px;
  display: block;
}
.top-manner .inner-manner li .manner-cont .manner-pic img {
  height: auto;
  width: 100%;
  object-fit: contain;
}

/****** top how use ******/
.top-how-use {
  width: 94%;
  margin: 0 auto;
  padding: 0 0 50px 0;
  box-sizing: border-box;
}
.top-how-use .inner-how-use {
  list-style: none;
}
.top-how-use .inner-how-use li {
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: block;
  margin-bottom: 20px;
}
.top-how-use .inner-how-use li.how-use-arrow {
  width: 100%;
  text-align: center;
  border-radius: 0;
  box-shadow: none;
}
.top-how-use .inner-how-use li.how-use-arrow img {
  display: block;
  margin: 0 auto;
}
.top-how-use .inner-how-use li .how-use-cont {
  box-sizing: border-box;
  padding: 16px;
  height: 100%;
  width: 100%;
  display: block
}
.top-how-use .inner-how-use li .how-use-cont .how-use-txt {
  font-size: 1.4rem;
  line-height: 2.0rem;
  box-sizing: border-box;
  padding-right: 0;
  padding-bottom: 20px;
}
.top-how-use .inner-how-use li .how-use-cont .how-use-txt .how-use-step-txt {
  color: #ffa5a5;
  font-size: 2.0rem;
  font-weight: bold;
  padding-bottom: 20px;
}
.top-how-use .inner-how-use li .how-use-cont .how-use-pic {
  background: #f5f5f5;
  border-radius: 5px;
  text-align: center;
  padding: 10px 0;
  box-sizing: border-box;
  width: 100%;
}

/****** top faq ******/
.top-faq {
  width: 94%;
  margin: 0 auto;
  padding: 0 0 50px 0;
  box-sizing: border-box;
}
.top-faq .inner-faq {
  list-style: none;
}
.top-faq .inner-faq li {
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  display: flex;
  margin-bottom: 40px;
}
.top-faq .inner-faq li:last-child {
  margin-bottom: 0;
}
.top-faq .inner-faq .qa-block {
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 16px;
}
.top-faq .inner-faq .qa-question {
  display: flex;
  align-items: flex-start;
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid #e4e4e4;
}
.top-faq .inner-faq .qa-question-icon {
  width: 40px;
  height: 40px;
  background-color: #ffffff;
  border: 1px solid #ff9696;
  color: #ff9696;
  font-size: 1.4rem;
  line-height: 1;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 20px;
  flex-shrink: 0;
}
.top-faq .inner-faq .qa-answer {
  display: flex;
  align-items: flex-start;
}
.top-faq .inner-faq .qa-answer-icon {
  width: 40px;
  height: 40px;
  background-color: #ff9696;
  border: 1px solid #ff9696;
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 20px;
  flex-shrink: 0;
}
.top-faq .inner-faq .qa-text {
  font-size: 1.4rem;
  line-height: 2.0rem;
  margin-top: 12px;
}

/****** top tax ******/
.top-tax {
  width: 94%;
  margin: 0 auto;
  padding: 0 0 50px 0;
  box-sizing: border-box;
}
.top-tax .inner-tax {
  width: 100%;
  background: url('../img/bg_top_cando.png') no-repeat top center;
  background-size: cover;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  border-radius: 5px;
  box-sizing: border-box;
  padding: 16px;
}
.top-tax .inner-tax .tax-cont {
  background: #ffffff;
  padding: 16px;
  border-radius: 5px;
}
.top-tax .inner-tax .tax-cont .tax-inner-cont {
  box-sizing: border-box;
  display: block;
}
.top-tax .inner-tax .tax-cont .tax-inner-cont .tax-pic {
  box-sizing: border-box;
  width: 100%;
  text-align: center;
}
.top-tax .inner-tax .tax-cont .tax-inner-cont .tax-txt {
  box-sizing: border-box;
  padding-top: 20px;
  padding-left: 0;
  font-size: 1.6rem;
  line-height: 2.6rem;
}

/****** top message ******/
.top-message {
  width: 94%;
  margin: 0 auto;
  padding: 0 0 80px 0;
  box-sizing: border-box;
}
.top-message .inner-message {
  width: 100%;
  background: url('../img/bg_top_message.png') no-repeat top center;
  background-size: cover;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  border-radius: 5px;
  box-sizing: border-box;
  padding: 16px;
}
.top-message .inner-message .message-cont {
  background: #ffffff;
  padding: 16px;
  border-radius: 5px;
  font-size: 1.4rem;
  line-height: 2.0rem;
}
.top-message .inner-message .message-cont .message-inner-cont {
  box-sizing: border-box;
  display: block;
}
.top-message .inner-message .message-cont .message-inner-cont .message-pic {
  box-sizing: border-box;
  width: 100%;
}
.top-message .inner-message .message-cont .message-inner-cont .message-pic img {
  width: 100%;
  height: auto;
}
.top-message .inner-message .message-cont .message-inner-cont .message-txt {
  box-sizing: border-box;
  padding-top: 20px;
  padding-left: 0;
}

/****** footer ******/
footer {
  box-sizing: border-box;
  background: #ffffff;
  padding: 20px 10px;
  border-top: 1px solid #e4e4e4;
}
footer .footer-info-area {
  max-width: 100%;
  margin: 0 auto;
  display: block;
  box-sizing: border-box;
  text-align: center;
}
footer .footer-info-area .footer-copyright {
  box-sizing: border-box;
  font-size: 1.2rem;
  line-height: 1.8rem;
  text-align: center;
}
footer .footer-info-area .footer-nav {
  box-sizing: border-box;
  font-size: 1.2rem;
  line-height: 1.8rem;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding-bottom: 20px;
}
footer .footer-info-area .footer-nav li {
  margin-bottom: 10px;
}
footer .footer-info-area .footer-nav li:last-child {
  margin-bottom: 0;
}
footer .footer-info-area .footer-bsi {
  box-sizing: border-box;
  font-size: 1.0rem;
  line-height: 1.6rem;
  list-style: none;
  display: block;
}
footer .footer-info-area .footer-bsi .bsi-txt-pos {
  box-sizing: border-box;
  font-size: 1.0rem;
  line-height: 1.6rem;
  padding-right: 0;
  padding-bottom: 10px;
  text-align: center;
}
footer .footer-info-area .footer-bsi .bsi-logo-pos {
  box-sizing: border-box;
}
footer .footer-copyright {
  box-sizing: border-box;
  font-size: 1.2rem;
  line-height: 1.8rem;
  text-align: center;
  padding-top: 30px;
}
}

/****** clearfix ******/
.clearfix::after {
    content: "";
    display: block;
    clear: both;
}

/****** common style ******/
.mb5 { margin-bottom: 5px; }
.mb10 { margin-bottom: 10px; }
.mb20 { margin-bottom: 20px; }
.mb30 { margin-bottom: 30px; }
.mb40 { margin-bottom: 40px; }
.mb50 { margin-bottom: 50px; }
.mb60 { margin-bottom: 60px; }
.mb70 { margin-bottom: 70px; }
.mb80 { margin-bottom: 80px; }
.mb90 { margin-bottom: 90px; }
.mb100 { margin-bottom: 100px; }