@charset "UTF-8";
/* CSS Information
---------------------------------------------------------------
Site URL:https://
File name:style.css
Summary:base styles
Created:2026-04-01
--------------------------------------------------------------- */
/* Link */
/* ------------------------------------------------------------ */
a {
  color: #111;
  text-decoration: none;
}

a[href^="tel:"] {
  pointer-events: none;
  cursor: text;
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  a[href^="tel:"] {
    pointer-events: auto;
    cursor: pointer;
  }
}

/* Animation */
/* ------------------------------------------------------------ */
a,
img {
  transition: all 0.5s ease;
}

.alpha:hover {
  filter: alpha(opacity=60);
  opacity: 0.6;
}

/* Font */
/* ------------------------------------------------------------ */
sup {
  font-size: 66%;
  vertical-align: top;
}

sub {
  font-size: 66%;
  vertical-align: baseline;
}

/* インデント1文字分 */
/* ------------------------------------------------------------ */
.indent {
  text-indent: -1em;
  margin-left: 1em;
}

/* HR */
/* ------------------------------------------------------------ */
hr {
  width: 100%;
  height: 1px;
  margin: min(4.392vw, 60px) auto;
  padding: 0;
  display: block;
  border: 0;
  border-top: 1px #000 solid;
}
@media screen and (max-width: 768px) {
  hr {
    margin: 8vw auto;
  }
}

/* pc_mode / sp_mode */
/* ------------------------------------------------------------ */
.pc {
  display: inherit;
}

.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .sp {
    display: inherit;
  }
}
/* Style */
/* ------------------------------------------------------------ */
html {
  scroll-behavior: smooth;
  -ms-overflow-style: none;
  scrollbar-width: none;
  font-size: 1.171vw;
}
@media screen and (max-width: 768px) {
  html {
    font-size: 3.733vw;
  }
}
html body {
  background: #fff;
}
html body::-webkit-scrollbar {
  display: none;
}
html body header {
  background: url("../img/bg-header.png") no-repeat center center/cover;
}
html body header .inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: min(87.848vw, 1200px);
  height: min(51.245vw, 700px);
  padding: 0;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  html body header .inner {
    width: 100%;
    height: 100%;
    aspect-ratio: 96/35;
  }
}
html body header .inner ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(0.732vw, 10px);
}
@media screen and (max-width: 768px) {
  html body header .inner ul {
    gap: 1.333vw;
  }
}
html body header .inner ul li:nth-of-type(n+2) {
  border-left: 1px #fff solid;
  padding-left: min(2.196vw, 30px);
}
@media screen and (max-width: 768px) {
  html body header .inner ul li:nth-of-type(n+2) {
    padding-left: 4vw;
  }
}
html body header .inner ul li a {
  display: block;
}
html body header .inner ul li a img {
  width: auto;
  height: min(4.392vw, 60px);
}
@media screen and (max-width: 768px) {
  html body header .inner ul li a img {
    height: 5.333vw;
  }
}
html body header .inner h1 {
  color: #fff;
  font-size: min(6.875rem, 110px);
  font-weight: 800;
  text-align: center;
  text-shadow: 0 min(0.366vw, 5px) min(0.571vw, 7.8px) #272D78, 0 0 min(1.054vw, 14.4px) #272D78;
  margin-top: min(7.321vw, 100px);
}
@media screen and (max-width: 768px) {
  html body header .inner h1 {
    font-size: 2rem;
    margin-top: 4vw;
  }
}
html body header .inner p {
  color: #fff;
  font-size: min(1.875rem, 30px);
  font-weight: 800;
  text-align: center;
  text-shadow: 0 min(0.22vw, 3px) min(0.293vw, 4px) #272D78, 0 0 min(1.054vw, 14.4px) #272D78;
  line-height: 1.5;
  margin-top: min(2.196vw, 30px);
}
@media screen and (max-width: 768px) {
  html body header .inner p {
    font-size: 0.714rem;
    margin-top: 2.667vw;
  }
}
html body main section .inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: min(87.848vw, 1200px);
  padding: min(14.641vw, 200px) 0;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  html body main section .inner {
    width: 100%;
    padding: 26.667vw 5.333vw;
  }
}
html body main section#section1 {
  background: url("../img/bg-section1.png") no-repeat center center/cover;
}
html body main section#section1 .inner h2 {
  color: #33529F;
  font-size: min(3.125rem, 50px);
  font-weight: 800;
  text-align: center;
}
@media screen and (max-width: 768px) {
  html body main section#section1 .inner h2 {
    font-size: 1.714rem;
    line-height: 1.5;
  }
}
html body main section#section1 .inner ul {
  display: block;
  margin-top: min(4.392vw, 60px);
}
@media screen and (max-width: 768px) {
  html body main section#section1 .inner ul {
    margin-top: 8vw;
  }
}
html body main section#section1 .inner ul li {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  font-size: min(1.75rem, 28px);
  font-weight: 800;
}
@media screen and (max-width: 768px) {
  html body main section#section1 .inner ul li {
    font-size: 1rem;
  }
}
html body main section#section1 .inner ul li:nth-of-type(n+2) {
  margin-top: min(2.196vw, 30px);
}
@media screen and (max-width: 768px) {
  html body main section#section1 .inner ul li:nth-of-type(n+2) {
    margin-top: 4vw;
  }
}
html body main section#section1 .inner ul li img {
  width: min(3.367vw, 46px);
  margin-right: min(0.732vw, 10px);
}
@media screen and (max-width: 768px) {
  html body main section#section1 .inner ul li img {
    width: 5.333vw;
    margin-right: 1.333vw;
  }
}
html body main section#section1 .inner p {
  background: url("../img/bg-solve.png") no-repeat center center/cover;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  aspect-ratio: 400/59;
  color: #33529F;
  font-size: min(3.125rem, 50px);
  font-weight: 800;
  margin-top: min(4.392vw, 60px);
}
@media screen and (max-width: 768px) {
  html body main section#section1 .inner p {
    font-size: 1.428rem;
    margin-top: 8vw;
  }
}
html body main section#section2 {
  background: url("../img/bg-section2.png") no-repeat center center/cover;
}
html body main section#section2 .inner h2 {
  color: #fff;
  font-size: min(3.125rem, 50px);
  font-weight: 800;
  text-align: center;
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner h2 {
    font-size: 1.714rem;
    line-height: 1.5;
  }
}
html body main section#section2 .inner h2:nth-of-type(n+2) {
  margin-top: min(14.641vw, 200px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner h2:nth-of-type(n+2) {
    margin-top: 26.667vw;
  }
}
html body main section#section2 .inner h2:nth-of-type(3) {
  font-size: min(2.75rem, 44px);
  line-height: 2;
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner h2:nth-of-type(3) {
    font-size: 1.142rem;
  }
}
html body main section#section2 .inner h2:nth-of-type(3) span {
  font-weight: 800;
  padding-bottom: min(0.732vw, 10px);
  border-bottom: min(0.293vw, 4px) solid #F6BD35;
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner h2:nth-of-type(3) span {
    padding-bottom: 1.333vw;
    border-bottom: 0.533vw solid #F6BD35;
  }
}
html body main section#section2 .inner > ul:nth-of-type(1) {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: min(2.196vw, 30px);
  width: 100%;
  margin-top: min(4.392vw, 60px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(1) {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 8vw;
    margin-top: 8vw;
  }
}
html body main section#section2 .inner > ul:nth-of-type(1) li {
  width: 100%;
}
html body main section#section2 .inner > ul:nth-of-type(1) li h3 {
  background: url("../img/bg-service.png") no-repeat center center/cover;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  aspect-ratio: 380/73;
  color: #fff;
  font-size: min(1.75rem, 28px);
  font-weight: 800;
  padding-left: min(0.732vw, 10px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(1) li h3 {
    font-size: 1.428rem;
    padding-left: 2.667vw;
  }
}
html body main section#section2 .inner > ul:nth-of-type(1) li figure {
  margin-top: min(1.464vw, 20px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(1) li figure {
    margin-top: 2.667vw;
  }
}
html body main section#section2 .inner > ul:nth-of-type(1) li figure img {
  width: 100%;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption p {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: min(10.249vw, 140px);
  color: #fff;
  font-size: min(1.25rem, 20px);
  font-weight: 800;
  line-height: 1.5;
  text-align: center;
  border-bottom: min(0.146vw, 2px) #fff solid;
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption p {
    height: auto;
    font-size: 1rem;
    padding: 2.667vw;
  }
}
html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption ul {
  display: block;
  margin-top: min(0.732vw, 10px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption ul {
    margin-top: 2.667vw;
  }
}
html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption ul li {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  color: #F6BD35;
  font-size: min(1.25rem, 20px);
  font-weight: 800;
  margin-top: min(1.464vw, 20px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption ul li {
    font-size: 1rem;
    margin-top: 2.667vw;
  }
}
html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption ul li img {
  width: min(2.196vw, 30px);
  margin-right: min(0.732vw, 10px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(1) li figure figcaption ul li img {
    width: 4vw;
    margin-right: 1.333vw;
  }
}
html body main section#section2 .inner > ul:nth-of-type(2) {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-top: min(4.392vw, 60px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(2) {
    flex-direction: column;
    justify-content: center;
    gap: 4vw;
    margin-top: 8vw;
  }
}
html body main section#section2 .inner > ul:nth-of-type(2) li {
  background: url("../img/bg-reasons.png") no-repeat center center/cover;
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(41.728vw, 570px);
  aspect-ratio: 285/47;
  color: #272D78;
  font-size: min(1.75rem, 28px);
  font-weight: 800;
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(2) li {
    width: 100%;
    font-size: 1.142rem;
  }
}
html body main section#section2 .inner > ul:nth-of-type(2) li:nth-of-type(n+3) {
  margin-top: min(2.196vw, 30px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner > ul:nth-of-type(2) li:nth-of-type(n+3) {
    margin-top: 0;
  }
}
html body main section#section2 .inner .btn {
  width: min(22.401vw, 306px);
  margin-top: min(2.928vw, 40px);
}
@media screen and (max-width: 768px) {
  html body main section#section2 .inner .btn {
    width: 40vw;
    margin-top: 8vw;
  }
}
html body footer {
  background: url("../img/bg-section3.png") no-repeat center center/cover;
  padding: min(14.641vw, 200px) 0;
}
@media screen and (max-width: 768px) {
  html body footer {
    width: 100%;
    padding: 26.667vw 5.333vw;
  }
}
html body footer .inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: min(87.848vw, 1200px);
  padding: min(1.464vw, 20px);
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.4);
}
@media screen and (max-width: 768px) {
  html body footer .inner {
    width: 100%;
    padding: 2.667vw;
  }
}
html body footer .inner > div {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: min(7.321vw, 100px) 0;
  background: #fff;
}
@media screen and (max-width: 768px) {
  html body footer .inner > div {
    padding: 13.333vw 0;
  }
}
html body footer .inner > div h2 {
  color: #33529F;
  font-size: min(3.125rem, 50px);
  font-weight: 800;
}
@media screen and (max-width: 768px) {
  html body footer .inner > div h2 {
    font-size: 1.428rem;
    line-height: 1.5;
  }
}
html body footer .inner > div address {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: min(4.392vw, 60px);
}
@media screen and (max-width: 768px) {
  html body footer .inner > div address {
    margin-top: 8vw;
  }
}
html body footer .inner > div address p {
  text-align: center;
  font-size: min(1.75rem, 28px);
  font-weight: 800;
  line-height: 1.25;
}
@media screen and (max-width: 768px) {
  html body footer .inner > div address p {
    font-size: 1rem;
    line-height: 1.5;
  }
}
html body footer .inner > div address p:nth-of-type(n+2) {
  margin-top: min(1.464vw, 20px);
}
@media screen and (max-width: 768px) {
  html body footer .inner > div address p:nth-of-type(n+2) {
    margin-top: 2.667vw;
  }
}
html body footer .inner > div address p a {
  font-size: min(1.75rem, 28px);
  font-weight: 800;
}
@media screen and (max-width: 768px) {
  html body footer .inner > div address p a {
    font-size: 1rem;
  }
}
html body footer .inner > div small {
  display: block;
  width: 100%;
  text-align: center;
  font-size: min(0.875rem, 14px);
  margin-top: min(4.392vw, 60px);
}
@media screen and (max-width: 768px) {
  html body footer .inner > div small {
    font-size: 0.714rem;
    margin-top: 8vw;
  }
}/*# sourceMappingURL=style.css.map */