@charset "UTF-8";

.p-aim {
  color: #000;
}
.p-aim_inner {
  margin-right: auto;
  margin-left: auto;
  width: 90%;
  max-width: 1220px;
}
@media screen and (min-width: 768px) {
  .p-aim_inner--pc {
    margin-right: auto;
    margin-left: auto;
    width: 90%;
    max-width: 1220px;
  }
}
.p-aim_table {
  width: 100%;
  font-size: 0.8rem;
}
@media screen and (min-width: 768px) {
  .p-aim_table {
    font-size: 1.6rem;
  }
}
.p-aim_table th,
.p-aim_table td {
  padding: 8px 0;
  line-height: 1.5;
  text-align: center;
  vertical-align: middle;
}
@media screen and (min-width: 768px) {
  .p-aim_table th,
  .p-aim_table td {
    padding: 16px 8px;
  }
}
.p-aim_table th {
  background: #000;
  color: #fff;
  font-weight: bold;
}
.p-aim_table th.accent {
  background: #00a0e9;
  color: #fff;
}
.p-aim_table th.accent strong {
  font-size: 140%;
}
.p-aim_table td {
  background: #e4e4e5;
}
.p-aim_table td.accent {
  background: #dff2fc;
  color: #0068b7;
}
.p-aim_table_balloon {
  position: relative;
  display: inline-block;
  border: 4px solid #009fe8;
  border-radius: 8px;
  margin-top: 0.5rem;
  padding: 0.5em 2em;
  color: #009fe8;
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .p-aim_table_balloon {
    font-size: 2rem;
  }
}
.p-aim_table_balloon::before {
  position: absolute;
  bottom: 100%;
  right: 2.4rem;
  border-style: solid;
  border-width: 0px 0px 20px 20px;
  border-color: transparent transparent #009fe8 transparent;
  content: "";
}
@media screen and (min-width: 768px) {
  .p-aim_table_balloon::before {
    right: 108px;
  }
}
.p-aim_ttl01 {
  position: relative;
  color: #005393;
  font-weight: bold;
  font-size: 1.9rem;
}
@media screen and (max-width: 767px) {
  .p-aim_ttl01 {
    border-bottom: 1px solid #000;
    padding-bottom: 10px;
    text-align: center;
  }
}
@media screen and (min-width: 768px) {
  .p-aim_ttl01 {
    font-size: 3.2rem;
  }
}
@media screen and (min-width: 768px) {
  .p-aim_ttl01::before {
    position: absolute;
    top: 50%;
    right: 0;
    width: 100%;
    height: 1px;
    background: #000;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    content: "";
  }
}
@media screen and (min-width: 768px) {
  .p-aim_ttl01_inner {
    position: relative;
    z-index: 1;
    padding-right: 1em;
    background: #fff;
  }
}
.p-aim_ttl02 {
  position: relative;
  padding-left: 24px;
  font-weight: bold;
  font-size: 1.9rem;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .p-aim_ttl02 {
    font-size: 3.2rem;
  }
}
.p-aim_ttl02::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 8px;
  height: 80%;
  background: #005393;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  content: "";
}
.p-aim_txt {
  font-size: 1.4rem;
  line-height: 1.75;
}
@media screen and (min-width: 768px) {
  .p-aim_txt {
    font-size: 1.6rem;
  }
}
.p-aim_txt--red {
  color: #e60012;
}
.p-aimBtn {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .p-aimBtn {
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 767px) {
  .p-aimBtn > * {
    width: 100%;
  }
}
.p-aimBtn_btn, .p-aimBtn_btn--contact {
  display: block;
  position: relative;
  border-radius: 8px;
  background: #005393;
  color: #fff !important;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-aimBtn_btn, .p-aimBtn_btn--contact {
    width: 100%;
    padding: 0 1em;
    line-height: 44px;
  }
}
@media screen and (min-width: 768px) {
  .p-aimBtn_btn, .p-aimBtn_btn--contact {
    padding: 0 32px;
    min-width: 320px;
    line-height: 64px;
    font-size: 2rem;
  }
}
.p-aimBtn_btn::before, .p-aimBtn_btn--contact::before {
  position: absolute;
  top: 50%;
  right: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  width: 6px;
  height: 6px;
  -webkit-transform: translate(0, -50%) rotate(45deg);
          transform: translate(0, -50%) rotate(45deg);
  content: "";
}
@media screen and (min-width: 768px) {
  .p-aimBtn_btn::before, .p-aimBtn_btn--contact::before {
    right: 16px;
    width: 10px;
    height: 10px;
  }
}
@media screen and (min-width: 768px) {
  .p-aimBtn_btn:hover, .p-aimBtn_btn--contact:hover {
    text-decoration: none !important;
  }
}
.p-aimBtn_btn--contact {
  background: #f0a400;
}
.p-aimMv {
  background: #005393;
}
.p-aimMv_mv {
  margin-right: auto;
  margin-left: auto;
  max-width: 1120px;
}
.p-aimMv_mv img {
  vertical-align: middle;
}
.p-aimProduct {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[1];
  grid-template-columns: repeat(1, 1fr);
}
@media screen and (min-width: 768px) {
  .p-aimProduct {
    -ms-grid-columns: 30% 1fr;
    grid-template-columns: 30% 1fr;
    gap: 16px 10px;
  }
}
.p-aimProduct_inner {
  padding: 16px 5%;
}
@media screen and (min-width: 768px) {
  .p-aimProduct_inner {
    padding: 16px 32px 0;
  }
}
.p-aimProduct_ttl01 {
  border-left: 3px solid #005393;
  padding-left: 8px;
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 1.3;
}
@media screen and (min-width: 768px) {
  .p-aimProduct_ttl01 {
    font-size: 2rem;
  }
}
.p-aimProduct_ttl02 {
  border-top: 2px dotted #009fe8;
  margin-top: 16px;
  padding-top: 16px;
  color: #009fe8;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .p-aimProduct_ttl02 {
    font-size: 2rem;
  }
}
.p-aimProduct_ttl02:first-of-type {
  border-top: 0;
}
.p-aimProduct_txt {
  font-size: 1.4rem;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .p-aimProduct_txt {
    font-size: 1.6rem;
  }
}
.p-aimProduct_term {
  position: relative;
  background: #005393;
  color: #fff;
}
.p-aimProduct_term::before {
  position: absolute;
  content: "";
}
@media screen and (max-width: 767px) {
  .p-aimProduct_term::before {
    top: 100%;
    left: 50%;
    border: 14px solid transparent;
    border-top: 14px solid #005393;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
@media screen and (min-width: 768px) {
  .p-aimProduct_term::before {
    top: 50%;
    left: 100%;
    border: 14px solid transparent;
    border-left: 14px solid #005393;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
  }
}
.p-aimProduct_term_ttl {
  border-bottom: 1px solid #fff;
  margin-right: 16px;
  margin-left: 16px;
  padding-bottom: 10px;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
}
.p-aimProduct_term_ttl--first {
  display: block;
  margin: 16px 0;
  padding: 16px 0;
  width: 100%;
  background: #fff;
  color: #000;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-aimProduct_term_ttl--first {
    font-size: 2rem;
  }
}
.p-aimProduct_body {
  background: radial-gradient(#f3f6fa, #d6e0ee);
}
.p-aimProduct_body_ttl--first {
  display: block;
  padding: 16px 0;
  background: #fff;
  color: #009fe8;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-aimProduct_body_ttl--first {
    margin: 16px 0;
    font-size: 2rem;
  }
}
@media screen and (min-width: 768px) {
  .p-aimProduct_body_pic {
    flex: 1.5 1;
  }
}
@media screen and (min-width: 768px) {
  .p-aimProduct_body_body {
    padding-bottom: 40px;
    flex: 1 1;
  }
}
@media screen and (min-width: 768px) {
  .p-aimProduct_body_inner {
    display: flex;
    align-items: flex-end;
  }
}