@charset "utf-8";
/* CSS Document */
/* /////////////////////////////// リセット / ノーマライズ / サニタイズ */
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;
  vertical-align: baseline;
}
ol, ul {
  list-style: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
a {
  color: inherit;
  text-decoration: none;
}
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
/* /////////////////////////////// 共通設定 */
body {
  background: #FDFDFD;
  line-height: 1.75;
  font-family: "Zen Maru Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #142b3d;
  font-weight: 600;
  overflow-x: hidden;
}
@media screen and (max-width: 480px) {
  body {
    min-width: initial;
  }
}
@media screen and (min-width: 768px) {
  body {
    font-size: 20px;
  }
}
.inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 16px;
  overflow-x: hidden;
}
@media (min-width: 768px) {
  .sp-no {
    display: block;
  }
  .pc-no {
    display: none;
  }
}
@media (max-width: 767px) {
  .inner {
    padding: 0 16px;
  }
  .sp-no {
    display: none;
  }
  .pc-no {
    display: block;
  }
}
/* 画像 */
img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}
/* youtube */
.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.youtube iframe {
  width: 100%;
  height: 100%;
}
/* 文字 */
/* p:not(:first-child) {
  margin-top: 20px;
} */
/* /////////////////////////////// コンテナ */
.container {
  width: 92%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
/* /////////////////////////////// MV */
.main-visual {
  background-image: url("../images/mv_bg.jpg");
  -webkit-background-size: cover;
  background-size: cover;
  background-position: center;
  text-align: center;
}
.main-visual img {
  padding: 16px 16px 0 16px;
}
@media (min-width: 768px) {
  .main-visual img {
    padding: 32px 16px 0 16px;
  }
}
/* /////////////////////////////// コンテンツ */
.fc-blue {
  color: #0066ff;
}
.fc-gray {
  color: #575757;
}
/* イントロ */
.intro-body {
  position: relative;
  background-color: #e8f0fd;
  padding: 30px 0;
}
.intro-body h2 {
  text-align: center;
  font-size: clamp(24px, 2.5vw, 43px);
  line-height: 1.5;
}
.intro-body h2 + p {
  margin-top: 20px;
  font-size: clamp(16px, 2.5vw, 22px);
}
.intro-body:after {
  content: "";
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
  bottom: -30px;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 115px solid transparent;
  border-left: 115px solid transparent;
  border-top: 48px solid #e8f0fd;
  border-bottom: 0;
}
.intro-hikaku {
  padding-top: 48px;
}
@media (min-width: 768px) {
  .intro-body {
    padding: 40px 0;
  }
  .intro-body h2 + p {
    text-align: center;
  }
  .intro-hikaku {
    padding-top: 68px;
  }
}
/* 比較表 */
.hikaku-table th, .hikaku-table td {
  padding: 10px;
  line-height: 1.5;
}
.hikaku-table tr:first-child th {
  color: #fff;
}
.hikaku-table tr:first-child th:nth-child(2) {
  background-color: #0066ff;
}
.hikaku-table tr:first-child th:nth-child(3) {
  background-color: #ababab;
}
.hikaku-table tr th:first-child {
  white-space: nowrap;
  vertical-align: middle;
}
.hikaku-table tr:nth-child(2n) th {
  background-color: #e7e7e7;
}
.hikaku-table tr:nth-child(2n+1) th {
  background-color: #f8f8f8;
}
.hikaku-table tr:nth-child(2n) td:nth-child(2) {
  background-color: #e5efff;
}
.hikaku-table tr:nth-child(2n+1) td:nth-child(2) {
  background-color: #f8fbff;
}
.hikaku-table tr:nth-child(2n) td:nth-child(3) {
  background-color: #e7e7e7;
}
.hikaku-table tr:nth-child(2n+1) td:nth-child(3) {
  background-color: #f8f8f8;
}
.hikaku-table tr:nth-child(2) td {
  font-size: clamp(22px, 2.5vw, 42px);
  line-height: 1.0;
}
.hikaku-table tr:nth-child(2) td span {
  font-size: clamp(13px, 2.5vw, 20px);
  display: block;
  margin-bottom: 8px;
}
.hikaku-table tr:nth-child(5) td:nth-child(3) span {
  display: block;
  font-size: clamp(13px, 2.5vw, 18px);
}
.hikaku-table + p {
  line-height: 1.5;
  margin-top: 20px;
}
@media (max-width: 767px) {
  .hikaku-table {
    text-align: center;
  }
  .hikaku-table td {
    vertical-align: middle;
  }
}
@media (min-width: 768px) {
  .hikaku-table {
    width: 100%;
    font-size: 22px;
  }
  .hikaku-table th, .hikaku-table td {
    padding: 20px 16px;
  }
  .hikaku-table td {
    text-align: center;
  }
  .hikaku-table tr:nth-child(3) td {
    font-size: 32px;
  }
  .hikaku-table tr:nth-child(2) td, .hikaku-table tr:nth-child(3) td {
    width: 40%;
  }
}
/* 動画でCheck */
.movie {
  padding-top: 60px;
}
.movie h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #0066ff;
}
.youtube {
  margin-top: 20px;
}
@media (min-width: 768px) {
  .movie {
    padding-top: 80px;
  }
}
/* お任せください */
.omakase {
  margin-top: 60px;
  background-color: #0066ff;
  padding-top: 30px;
}
.omakase-box {
  display: flex;
  flex-direction: column-reverse;
}
.omakase h2 {
  text-align: center;
  font-size: 24px;
  line-height: 1.5;
  color: #fff;
}
.omakase-link {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.omakase-tel {
  width: 100%;
  margin-top: 20px;
  text-align: center;
}
.omakase-tel a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fffd36;
  font-size: 46px;
  line-height: 1.0;
}
.omakase-tel img {
  margin-right: 10px;
  width: 32px;
}
.omakase-tel span {
  display: block;
  margin-top: 8px;
  font-size: 14px;
  color: #fff;
}
.omakase-mail, .omakase-line {
  width: calc((100% - 10px) / 2);
  margin-top: 10px;
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}
.omakase-mail a, .omakase-line a {
  display: block;
  padding: 12px 6px;
}
.omakase-mail img, .omakase-line img {
  display: block;
  margin: 0 auto;
  height: 30px;
  width: 30px;
  object-fit: contain;
}
.omakase-mail {
  background-color: #fffd36;
}
.omakase-line {
  background-color: #06c755;
  color: #fff;
}
.omakase-staff {
  margin-top: 20px;
  text-align: center;
}
.omakase-staff img {
  width: 120px;
}
@media (min-width: 768px) {
  .omakase {
    margin-top: 80px;
    padding-bottom: 30px;
  }
  .omakase-box {
    position: relative;
    display: flex;
    flex-direction: row;
  }
  .omakase-staff img {
    width: 180px;
    position: absolute;
    bottom: -30px;
  }
  .omakase-body {
    margin-left: 210px;
    width: 100%;
  }
  .omakase-link {
    display: flex;
    flex-wrap: nowrap;
  }
  .omakase-tel {
    width: 80%;
    margin-right: 30px;
    flex-grow: 0;
  }
  .omakase h2 {
    text-align: left;
  }
  .omakase-tel img {
    width: auto;
  }
  .omakase-tel a {
    justify-content: flex-start;
    line-height: 1.0;
    font-size: 42px;
    white-space: nowrap;
  }
  .omakase-tel span {
    text-align: left;
    font-size: 20px;
  }
  .omakase-line, .omakase-mail {
    font-size: 18px;
    max-width: 220px;
  }
  .omakase-line {
    margin-left: 10px;
  }
  .omakase-mail img, .omakase-line img {
    margin-bottom: 5px;
  }
}
@media (min-width: 1200px) {
  .omakase-tel a {
    font-size: 60px;
  }
}
/* 特長 */
.features {
  padding-top: 30px;
}
.features-txt01 {
  text-align: center;
  font-size: clamp(16px, 2.5vw, 36px);
}
.features-txt01 + div {
  text-align: center;
}
.features-txt01 + div img {
  width: 280px;
}
.features-txt02 {
  text-align: center;
  color: #0066ff;
  font-size: clamp(22px, 2.5vw, 46px);
}
.marker {
  background: linear-gradient(transparent 60%, #ff6 60%);
}
.features-txt03 {
  font-size: clamp(14px, 2.5vw, 20px);
  margin-top: 20px;
}
.kouka-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 10px;
}
.kouka-list > li {
  margin-top: 10px;
  width: calc((100% - 10px) / 2);
  border: 3px solid #0066ff;
  border-radius: 6px;
  padding: 10px;
  color: #0066ff;
  text-align: center;
}
.features-list {
  margin-top: 30px;
}
.features-item {
  display: flex;
  flex-direction: column;
  background-color: #e8f0fd;
  padding: 16px;
}
.features-body p {
  margin-top: 20px;
}
.features-image {
  margin-top: 20px;
}
.features-item + .features-item {
  margin-top: 30px;
}
@media (min-width: 768px) {
  .features {
    padding-top: 60px;
  }
  .features-txt01 {
    line-height: 1.5;
  }
  .features-txt01 + div img {
    width: 400px;
  }
  .features-txt03 {
    text-align: center;
  }
  .kouka-list {
    flex-wrap: nowrap;
    justify-content: center;
  }
  .kouka-list > li {
    width: auto;
    padding: 20px 40px;
    border: 6px solid #0066ff;
    border-radius: 12px;
    font-size: 30px;
    white-space: nowrap;
    margin-left: 10px;
    margin-right: 10px;
  }
  .features-item {
    justify-content: space-between;
    flex-direction: row;
    padding: 20px 20px 40px 20px;
  }
  .features-item.reverse {
    flex-direction: row-reverse;
  }
  .features-body {
    flex: 2;
    max-width: 573px;
  }
  .features-image {
    flex: 1;
    margin-left: 30px;
  }
  .features-item.reverse .features-image {
    margin-left: 0;
    margin-right: 30px;
  }
}
@media (min-width: 1200px) {
  .features-item {
    padding: 20px 80px 40px 80px;
  }
}
/* 料金プラン */
.price {
  margin-top: 60px;
}
.price h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #0066ff;
}
.price-table {
  margin-top: 20px;
}
.price-table tr {
  border-bottom: 2px solid #0066ff;
}
.price-table th {
  text-align: left;
}
.price-table th, .price-table td {
  padding: 10px;
  line-height: 1.5;
}
.price-table td {
  white-space: nowrap;
  vertical-align: middle;
}
.price-table + p {
  margin-top: 20px;
  font-size: 14px;
  line-height: 1.5;
}
.price-button {
  margin-top: 20px;
  background-color: #fffd36;
  text-align: center;
  border-radius: 10px;
}
.price-button a {
  display: block;
  padding: 16px 32px;
}
@media (min-width: 768px) {
  .price-table {
    width: 980px;
    margin-left: auto;
    margin-right: auto;
    font-size: 22px;
  }
  .price-table td {
    text-align: center;
  }
  .price-table th {
    text-align: center;
    white-space: nowrap;
  }
  .price-table th, .price-table td {
    padding: 20px;
  }
  .price-table td:nth-child(2), .price-table td:nth-child(3) {
    width: 40%;
  }
  .price-table + p {
    text-align: center;
  }
  .price-button {
    width: 377px;
    margin-left: auto;
    margin-right: auto;
  }
}
/* 対応エリア */
.area {
  margin-top: 60px;
}
.area h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #0066ff;
}
.area-body h3 {
  margin-top: 20px;
  font-size: 20px;
}
.area-body h3 + p {
  margin-top: 10px;
}
.area-image {
  margin-top: 30px;
}
.area-body p + p {
  margin-top: 20px;
}
@media (min-width: 768px) {
  .area-box {
    display: flex;
    justify-content: space-between;
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
  }
  .area-body {
    max-width: 500px;
  }
  .area-image {
    margin-left: 30px;
  }
}
/* 作業の流れ */
.flow {
  background-color: #e8f0fd;
  padding-top: 30px;
  padding-bottom: 30px;
}
.flow h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #0066ff;
}
.flow-list {
  margin-top: 20px;
}
.flow-item {
  position: relative;
  background-color: #fff;
  padding: 16px;
}
.flow-item:not(:last-child):after {
  position: absolute;
  content: "";
  bottom: -41px;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 26px solid transparent;
  border-left: 26px solid transparent;
  border-top: 25px solid #0066ff;
  border-bottom: 0;
}
.flow-item + .flow-item {
  margin-top: 60px;
}
.flow-item h3 {
  font-size: 26px;
  color: #0066ff;
  display: flex;
  align-items: center;
}
.flow-nb {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  background-color: #0066ff;
  color: #fff;
  border-radius: 50%;
  text-align: center;
  box-sizing: border-box;
  margin-right: 10px;
}
.flow-item h3 + p {
  margin-top: 10px;
}
.flow-image {
  margin-top: 20px;
}
.flow-link {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 20px;
}
.flow-tel a {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 42px;
  line-height: 1.0;
}
.flow-tel img {
  margin-right: 10px;
  width: 32px;
}
.flow-tel span {
  display: block;
  margin-top: 8px;
  font-size: 14px;
}
.flow-mail, .flow-line {
  width: calc((100% - 10px) / 2);
  margin-top: 10px;
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  padding: 12px 6px;
  text-align: center;
}
.flow-mail img, .flow-line img {
  display: block;
  margin: 0 auto;
  height: 30px;
  width: 30px;
  object-fit: contain;
}
.flow-mail {
  background-color: #fffd36;
}
.flow-line {
  background-color: #06c755;
  color: #fff;
}
@media (min-width: 768px) {
  .flow {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .flow-item {
    display: flex;
    justify-content: space-between;
    padding: 30px;
  }
  .flow-body {
    flex: 2;
    max-width: 460px;
  }
}
/* お客様の声 */
.case {
  margin-top: 60px;
}
.case h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #0066ff;
}
.case-before {
  position: relative;
  margin-top: 20px;
}
.case-before:after {
  position: absolute;
  content: "";
  bottom: -41px;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 26px solid transparent;
  border-left: 26px solid transparent;
  border-top: 25px solid #0066ff;
  border-bottom: 0;
}
.case-after {
  margin-top: 60px;
}
.case-box + p {
  margin-top: 20px;
  margin-bottom: 60px;
}
@media (min-width: 768px) {
  .case .container {
    max-width: 1000px;
  }
  .case-box {
    margin-top: 20px;
    position: relative;
    display: flex;
    justify-content: space-between;
  }
  .case-before, .case-after {
    margin-top: 0;
  }
  .case-before {
    position: static;
  }
  .case-before:after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    border-top: 29px solid transparent;
    border-bottom: 29px solid transparent;
    border-left: 37px solid #0066ff;
    border-right: 0;
  }
}
/* デメリット */
.demerrit {
  margin-top: 30px;
}
.demerrit h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #0066ff;
}
.demeritt-box01 {
  position: relative;
  background-color: #f7f7f7;
  padding: 16px;
}
/*.demeritt-box01:after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 -6px 0 -6px;
  height: 120px;
  background-image: url("../images/demeritto_arrow.png");
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center top;
}*/
.demeritt-item {
  display: flex;
  align-items: center;
  margin-top: 20px;
  line-height: 1.5;
}
.demeritt-item img {
  display: block;
  width: 32px;
  margin-right: 10px;
}
.demeritt-item span {
  display: block;
}
.demerrit-box02 {
  margin-top: 30px;
}
.staff02 {
  text-align: center;
}
.staff02 img {
  width: 260px;
}
@media (min-width: 768px) {
  .demeritt-item img {
    width: 56px;
    margin-right: 40px;
  }
  .demeritt-box01 {
    font-size: 28px;
  }
  .demerrit-box02 {
    display: flex;
    justify-content: center;
  }
  .demerrit-box02 > div:first-child {
    max-width: 480px;
  }
  .demerrit-box02 > div:last-child {
    margin-left: 30px;
  }
  .staff02 img {
    width: 320px;
  }
}
@media (min-width: 1200px) {
  .demerrit {
    margin-top: 60px;
  }
  .demeritto_arrow {
    display: none;
  }
  .demeritt-box01 {
    border: 24px solid #e5e5e6;
    padding-right: 50px;
    padding-left: 50px;
  }
  .demeritt-box01:after {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    left: 0;
    margin: 0 -24px;
    height: 245px;
    background-image: url("../images/__demeritto_arrow.png");
    -webkit-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
  }
  .demerrit-box02 {
    margin-top: 245px;
  }
}
/* よくあるご質問 */
.faq {
  margin-top: 60px;
}
.faq h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #0066ff;
}
.faq-list {
  margin-top: 20px;
}
.faq-item {
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 5px;
  border-bottom: 2px solid #d6dde3;
}
.faq-item summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  padding: 1em 2em 1em 3em;
  color: #333333;
  font-weight: 600;
  cursor: pointer;
}
.faq-item summary::before, .faq-item p::before {
  position: absolute;
  left: 1em;
  font-weight: 600;
  font-size: 1.3em;
}
.faq-item summary::before {
  color: #0066ff;
  content: "Q";
}
.faq-item summary::after {
  transform: translateY(-25%) rotate(45deg);
  width: 7px;
  height: 7px;
  margin-left: 10px;
  border-bottom: 3px solid #333333b3;
  border-right: 3px solid #333333b3;
  content: '';
  transition: transform .5s;
}
.faq-item[open] summary::after {
  transform: rotate(225deg);
}
.faq-item p {
  position: relative;
  transform: translateY(-10px);
  opacity: 0;
  margin: 0;
  padding: .3em 3em 1.5em;
  color: #333;
  transition: transform .5s, opacity .5s;
}
.faq-item[open] p {
  transform: none;
  opacity: 1;
}
.faq-item p::before {
  color: #ff8d8d;
  line-height: 1.2;
  content: "A";
}
@media (min-width: 768px) {
  .faq-item {
    max-width: 980px;
  }
}
/* お問合せ */
.contact {
  margin-top: 60px;
  padding: 30px 0;
  background-color: #0066ff;
}
.contact h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #fff;
}
.contact-box p {
  color: #fff;
  margin-top: 20px;
}
.contact-image img {
  width: 260px;
}
.contact-image {
  text-align: center;
  margin: 20px 0;
}
.contact-tel {
  width: 100%;
  margin-top: 20px;
  text-align: center;
}
.contact-tel a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fffd36;
  font-size: 46px;
  line-height: 1.0;
}
.contact-tel img {
  margin-right: 10px;
  width: 32px;
}
.contact-tel span {
  display: block;
  margin-top: 8px;
  font-size: 14px;
  color: #fff;
}
.google-form {
  max-width: 980px;
  margin-top: 30px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 30px;
  background-color: #e6f0ff;
  border-radius: 10px;
}
@media (min-width: 768px) {
  .contact {
    padding-top: 60px;
  }
  .contact-box {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .contact-body {
    flex: 1;
    max-width: 580px;
  }
  .contact-image {
    width: 400px;
    margin-left: 60px;
  }
  .contact-image img {
    width: auto;
  }
  .contact-tel {
    text-align: left;
  }
  .contact-tel a {
    justify-content: flex-start;
  }
  .bnr_line {
    text-align: center;
  }
}
/* 会社概要 */
.company {
  background-color: #0066ff;
  padding: 30px 0;
}
.company h2 {
  text-align: center;
  font-size: clamp(26px, 2.5vw, 52px);
  color: #fff;
}
.company-table {
  margin-top: 20px;
  color: #fff;
  width: 100%;
}
.company-table tr {
  border-bottom: 1px solid #fff;
}
.company-table th {
  text-align: left;
  white-space: nowrap;
}
.company-table th, .company-table td {
  padding: 10px;
  line-height: 1.5;
}
@media (min-width: 768px) {
  .company {
    padding-bottom: 60px;
  }
  .company-table {
    max-width: 980px;
    margin-right: auto;
    margin-left: auto;
  }
  .company-table th, .company-table td {
    padding: 40px 20px;
  }
}
/* /////////////////////////////// フッター */
footer {
  padding: 16px;
  background-color: #0056d6;
  color: #fff;
  text-align: center;
  font-size: 15px;
}