/**  Mixins */ /*------------------------------------*\
    breakpoint vars
\*------------------------------------*/
/*------------------------------------*\
    breakpoint mixin
\*------------------------------------*/
/** Break desktop first**/
/** Global **/
/*@import url("https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic&display=swap");*/
:root {
  --text-base-2: #393938;
}

.box-list__body ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

.safe-house, .staff__top--body, .message__body, .idea__body, .section-box__content--body, .text-base {
  font-size: 16px;
  line-height: 2.66;
  color: #393938;
}
@media only screen and (min-width: 992px) {
  .safe-house, .staff__top--body, .message__body, .idea__body, .section-box__content--body, .text-base {
    font-size: 18px;
  }
}
.safe-house p, .staff__top--body p, .message__body p, .idea__body p, .section-box__content--body p, .text-base p {
  margin-bottom: 32px;
}
@media only screen and (min-width: 992px) {
  .safe-house p, .staff__top--body p, .message__body p, .idea__body p, .section-box__content--body p, .text-base p {
    margin-bottom: 48px;
  }
}
.safe-house p:last-of-type, .staff__top--body p:last-of-type, .message__body p:last-of-type, .idea__body p:last-of-type, .section-box__content--body p:last-of-type, .text-base p:last-of-type {
  margin: 0;
}

.safe-house figure img {
  box-shadow: 0 5px 7px rgba(0, 0, 0, 0.2);
  border-radius: 10px;
}

body.sub-font {
  font-family: "dnp-shuei-mgothic-std", sans-serif;
}
body.sub-font h1,
body.sub-font h2,
body.sub-font h3,
body.sub-font h4,
body.sub-font h5,
body.sub-font h6 {
  font-family: "dnp-shuei-mgothic-std", sans-serif;
}

.section {
  padding-block: 80px;
}
@media only screen and (min-width: 992px) {
  .section {
    padding-block: 100px;
  }
}
.section--blue {
  background: #f7fbfe;
}

.section--bottom {
  padding-bottom: 80px;
}
@media only screen and (min-width: 992px) {
  .section--bottom {
    padding-bottom: 100px;
  }
}

.page-title {
  text-align: center;
  padding-block: 40px;
}
@media only screen and (min-width: 768px) {
  .page-title {
    padding-block: 50px;
  }
}
.page-title h1 {
  font-weight: 900;
  margin: 0;
  color: #f1eeeb;
  line-height: 1.2;
  font-size: 32px;
}
@media only screen and (min-width: 768px) {
  .page-title h1 {
    font-size: 46px;
  }
}
@media only screen and (min-width: 992px) {
  .page-title h1 {
    font-size: 64px;
  }
}
@media only screen and (min-width: 1200px) {
  .page-title h1 {
    font-size: 82px;
  }
}
.page-title h3 {
  color: #393938;
  font-size: 22px;
  font-weight: 700;
  margin: -20px 0 0;
  line-height: 1.2;
}
@media only screen and (min-width: 768px) {
  .page-title h3 {
    font-size: 28px;
    margin: -25px 0 0;
  }
}
@media only screen and (min-width: 992px) {
  .page-title h3 {
    font-size: 34px;
    margin: -34px 0 0;
  }
}
@media only screen and (min-width: 1200px) {
  .page-title h3 {
    font-size: 40px;
    margin: -40px 0 0;
  }
}
@media only screen and (min-width: 1200px) {
  .page-title--sm h1 {
    font-size: 76px;
  }
}

.section-heading--lg {
  text-align: center;
  display: inline-block;
  margin-block: -20px 30px;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .section-heading--lg {
    margin-block: -30px 30px;
  }
}
@media only screen and (min-width: 992px) {
  .section-heading--lg {
    margin-block: -60px 30px;
  }
}
.section-heading--lg h2 {
  font-weight: 900;
  margin: 0;
  color: #f1eeeb;
  line-height: 1.2;
  font-size: 32px;
}
@media only screen and (min-width: 768px) {
  .section-heading--lg h2 {
    font-size: 46px;
  }
}
@media only screen and (min-width: 992px) {
  .section-heading--lg h2 {
    font-size: 64px;
  }
}
@media only screen and (min-width: 1200px) {
  .section-heading--lg h2 {
    font-size: 82px;
  }
}
.section-heading--lg h3 {
  color: #393938;
  font-size: 22px;
  font-weight: 700;
  margin: -20px 0 0;
  line-height: 1.2;
}
@media only screen and (min-width: 768px) {
  .section-heading--lg h3 {
    font-size: 28px;
    margin: -25px 0 0;
  }
}
@media only screen and (min-width: 992px) {
  .section-heading--lg h3 {
    font-size: 34px;
    margin: -34px 0 0;
  }
}
@media only screen and (min-width: 1200px) {
  .section-heading--lg h3 {
    font-size: 40px;
    margin: -40px 0 0;
  }
}
@media only screen and (min-width: 1200px) {
  .section-heading--lg--sm h1 {
    font-size: 76px;
  }
}

.heading-dot {
  background: url("../images/heading-dot.png") no-repeat 0 0/32px;
  padding-left: 40px;
  font-size: 24px;
  font-weight: 700;
  gap: 0 15px;
  display: flex;
  flex-wrap: wrap;
  line-height: 1.2;
  align-items: flex-end;
  margin: 0 0 30px;
  min-height: 32px;
  color: #393938;
}
@media only screen and (min-width: 768px) {
  .heading-dot {
    margin: 0 0 40px;
    font-size: 28px;
    background-size: 40px;
    min-height: 40px;
    padding-left: 46px;
    gap: 0 20px;
  }
}
@media only screen and (min-width: 992px) {
  .heading-dot {
    font-size: 34px;
    background-size: 46px;
    min-height: 46px;
    padding-left: 50px;
  }
}
.heading-dot small {
  font-size: 14px;
}

.sub-heading-dot {
  background: url("../images/heading-dot.png") no-repeat 0 0/26px;
  padding-left: 32px;
  font-size: 22px;
  font-weight: 700;
  gap: 10px 15px;
  display: flex;
  flex-wrap: wrap;
  line-height: 1.2;
  align-items: flex-end;
  margin: 0 0 30px;
  min-height: 26px;
  color: #68777d;
}
@media only screen and (min-width: 768px) {
  .sub-heading-dot {
    margin: 0 0 40px;
    font-size: 24px;
    background-size: 32px;
    min-height: 32px;
    padding-left: 40px;
    gap: 10px 20px;
  }
}
@media only screen and (min-width: 992px) {
  .sub-heading-dot {
    font-size: 30px;
    background-size: 37px;
    min-height: 37px;
    padding-left: 45px;
  }
}
.sub-heading-dot small {
  font-size: 16px;
  font-weight: 400;
  color: #393938;
}
@media only screen and (min-width: 768px) {
  .sub-heading-dot small {
    font-size: 18px;
  }
}
.sub-heading-dot strong {
  font-size: 14px;
  font-weight: 700;
}
@media only screen and (min-width: 768px) {
  .sub-heading-dot strong {
    font-size: 16px;
  }
}
.sub-heading-dot--column {
  flex-direction: column;
  align-items: flex-start;
}
.sub-heading-dot--column small {
  font-weight: 700;
}

.heading-bg {
  background: #7bbde3;
  color: var(--white);
  font-weight: 700;
  font-size: 20px;
  text-align: center;
  border-radius: 100px;
  padding: 8px 32px;
  min-height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 20px;
  line-height: 1.3;
}
@media only screen and (min-width: 768px) {
  .heading-bg {
    font-size: 26px;
  }
}
.heading-bg--pink {
  background: #d7a398;
}

.heading-outline {
  border: 2px solid #d7a398;
  font-weight: 700;
  font-size: 20px;
  text-align: center;
  border-radius: 100px;
  padding: 8px 32px;
  min-height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 20px;
  line-height: 1.3;
  color: #d7a398;
}
@media only screen and (min-width: 768px) {
  .heading-outline {
    font-size: 26px;
  }
}

.btn-dot {
  background: url("../images/about/arrow-dot.png") no-repeat calc(100% - 18px) 50%/32px;
  font-size: 20px;
  font-weight: 700;
  display: flex;
  flex-wrap: wrap;
  line-height: 1.2;
  align-items: flex-end;
  color: #68777d;
  padding: 11px 85px 11px 32px;
  border: 1px solid #7bbde3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 100px;
  flex-wrap: wrap;
  gap: 0 20px;
}
@media only screen and (min-width: 768px) {
  .btn-dot {
    margin: 0 0 40px;
    font-size: 24px;
    background-size: 40px;
    gap: 0 26px;
  }
}
@media only screen and (min-width: 992px) {
  .btn-dot {
    font-size: 30px;
    background-size: 46px;
  }
}
.btn-dot small {
  font-size: 14px;
}
@media only screen and (min-width: 768px) {
  .btn-dot small {
    font-size: 16px;
  }
}

.btn-outline--second {
  font-weight: 700;
  color: #7bbde3;
  border: 2px solid #7bbde3;
  border-radius: 100px;
  display: flex;
  flex-wrap: wrap;
  line-height: 1.4;
  align-items: flex-end;
  padding: 11px 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  flex-wrap: wrap;
  gap: 0 5px;
  font-size: 22px;
}
@media only screen and (min-width: 992px) {
  .btn-outline--second {
    font-size: 28px;
  }
}
.btn-outline--second small {
  font-size: 18px;
  font-weight: 400;
  color: #393938;
}
@media only screen and (min-width: 992px) {
  .btn-outline--second small {
    font-size: 24px;
  }
}

.content-bg {
  position: relative;
  z-index: 1;
  padding: 60px 0 60px 20px;
}
@media only screen and (min-width: 768px) {
  .content-bg {
    padding: 80px 0 80px 30px;
  }
}
@media only screen and (min-width: 992px) {
  .content-bg {
    padding-left: 60px;
  }
}
.content-bg::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: calc(100% + 20px);
  height: 100%;
  background: #fcf7f9;
  z-index: -1;
}
@media only screen and (min-width: 1140px) {
  .content-bg::before {
    width: calc(50vw + 50% - 7px);
  }
}
.content-bg__heading {
  font-size: 22px;
  font-weight: 700;
  color: #d7a398;
  text-align: center;
  margin: 0 0 30px;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .content-bg__heading {
    margin: 0 0 50px;
    font-size: 28px;
  }
}
@media only screen and (min-width: 992px) {
  .content-bg__heading {
    font-size: 36px;
  }
}
.content-bg__heading small {
  font-size: 18px;
}
@media only screen and (min-width: 768px) {
  .content-bg__heading small {
    font-size: 20px;
  }
}
@media only screen and (min-width: 992px) {
  .content-bg__heading small {
    font-size: 24px;
  }
}
@media only screen and (min-width: 768px) {
  .content-bg__content {
    display: flex;
  }
}
.content-bg__content--body {
  margin-bottom: 40px;
}
@media only screen and (min-width: 768px) {
  .content-bg__content--body {
    width: 71.5%;
    padding-right: 40px;
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 992px) {
  .content-bg__content--body {
    padding-right: 55px;
  }
}
.content-bg__content--body .btn-outline--second {
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .content-bg__content--body .btn-outline--second {
    margin-top: 50px;
  }
}
@media only screen and (min-width: 768px) {
  .content-bg__content figure {
    width: 28.5%;
  }
}
.content-bg__content figure img {
  width: 100%;
}
.content-bg .heading-outline {
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .content-bg .heading-outline {
    margin-top: 50px;
  }
}
.content-bg__box {
  background: var(--white);
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(0, 0, 0, 0.2);
  padding: 20px;
  margin-top: 30px;
  text-align: center;
  font-size: 18px;
  line-height: 2.4;
  color: var(--text-body-2);
}
@media only screen and (min-width: 768px) {
  .content-bg__box {
    padding: 20px 30px;
    margin-top: 45px;
    font-size: 20px;
  }
}
.content-bg__box h3 {
  font-size: 22px;
  font-weight: 700;
  color: #d7a398;
  margin: 0 0 20px;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .content-bg__box h3 {
    font-size: 28px;
  }
}
.content-bg__box h6 {
  margin: 0;
  font-size: 16px;
  font-weight: 400;
  color: var(--text-body-2);
  line-height: 1.8125;
  border-top: 1px solid #d7a398;
  padding-top: 16px;
  margin-top: 16px;
  text-align: left;
}
.content-bg--sm {
  padding-block: 40px;
}
.content-bg--left {
  padding-left: 0;
  padding-right: 20px;
}
@media only screen and (min-width: 768px) {
  .content-bg--left {
    padding-right: 30px;
  }
}
@media only screen and (min-width: 992px) {
  .content-bg--left {
    padding-right: 60px;
  }
}
.content-bg--left::before {
  left: auto;
  right: 0;
}
.content-bg--blue::before {
  background: #f7fbfe;
}
.content-bg--blue .content-bg__heading {
  color: #7bbde3;
}
.content-bg--gray::before {
  background: #f6f6f6;
}

.card-image {
  text-align: center;
  margin: 0 0 20px;
}
.card-image img {
  width: 100%;
  box-shadow: 0 7px 5px rgba(0, 0, 0, 0.2);
  border-radius: 10px;
}
.card-image figcaption {
  color: #7bbde3;
  font-weight: 700;
  font-size: 18px;
  margin-top: 30px;
  line-height: 1.8;
}
@media only screen and (min-width: 992px) {
  .card-image figcaption {
    font-size: 21px;
  }
}
.card-image figcaption strong {
  font-size: 24px;
  font-weight: 700;
  margin-left: 15px;
}
@media only screen and (min-width: 992px) {
  .card-image figcaption strong {
    font-size: 30px;
  }
}

.section-box {
  background: var(--white);
  box-shadow: 0 7px 5px rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  padding: 20px;
}
@media only screen and (min-width: 768px) {
  .section-box {
    padding: 40px;
  }
}
@media only screen and (min-width: 992px) {
  .section-box {
    padding: 60px;
  }
}
.section-box + .section-box {
  margin-top: 60px;
}
@media only screen and (min-width: 768px) {
  .section-box + .section-box {
    margin-top: 80px;
  }
}
@media only screen and (min-width: 992px) {
  .section-box + .section-box {
    margin-top: 120px;
  }
}
.section-box h6 {
  font-size: 18px;
  font-weight: 400;
  color: #68777d;
  line-height: 1.444;
}
.section-box h6 strong {
  font-weight: 700;
}
.section-box h6 span {
  color: #d7a398;
}
.section-box p span {
  color: #d7a398;
}
.section-box__content {
  margin-bottom: 30px;
}
@media only screen and (min-width: 768px) {
  .section-box__content {
    display: flex;
  }
}
.section-box__content--body {
  margin-bottom: 30px;
}
@media only screen and (min-width: 768px) {
  .section-box__content--body {
    width: 70%;
    padding-right: 40px;
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 992px) {
  .section-box__content--body {
    padding-right: 65px;
  }
}
@media only screen and (min-width: 768px) {
  .section-box__content figure {
    width: 30%;
  }
}
.section-box__content figure img {
  border-radius: 10px;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .section-box__content--lg .section-box__content--body {
    width: 75%;
    padding-right: 15px;
  }
}
@media only screen and (min-width: 768px) {
  .section-box__content--lg figure {
    width: 25%;
  }
}
.section-box__button {
  display: flex;
  gap: 20px;
  justify-content: center;
  margin-top: 30px;
}

.child-center {
  display: flex;
  justify-content: center;
}

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

.text-brow {
  color: #d7a398;
}

.img-shadow {
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(0, 0, 0, 0.2);
}

.margin-top {
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .margin-top {
    margin-top: 50px;
  }
}

/** Pages **/
.idea__body {
  text-align: center;
}
.idea__body h3 {
  color: #d7a398;
  margin: 0 0 20px;
  line-height: 1.6;
  font-size: 20px;
}
@media only screen and (min-width: 768px) {
  .idea__body h3 {
    margin: 0 0 30px;
    font-size: 26px;
  }
}
@media only screen and (min-width: 992px) {
  .idea__body h3 {
    font-size: 36px;
  }
}
.idea__body h4 {
  font-size: 18px;
  font-weight: 700;
  color: #d7a398;
  margin: 10px 0 35px;
  line-height: 1.6;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0 20px;
}
@media only screen and (min-width: 768px) {
  .idea__body h4 {
    margin: 10px 0 45px;
    font-size: 21px;
    gap: 0 25px;
  }
}
.idea__body h4 strong {
  font-weight: 400;
  font-size: 24px;
}
@media only screen and (min-width: 768px) {
  .idea__body h4 strong {
    font-size: 32px;
  }
}
@media only screen and (min-width: 992px) {
  .idea__body h4 strong {
    font-size: 40px;
  }
}
.idea__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 50px 30px;
}
@media only screen and (min-width: 768px) {
  .idea__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media only screen and (min-width: 992px) {
  .idea__list {
    gap: 30px 70px;
  }
}
.idea__item {
  box-shadow: 0px 7px 5px rgba(0, 0, 0, 0.2);
  border-radius: 10px;
}
.idea__item picture {
  display: block;
}
.idea__item picture img {
  border-radius: 10px 10px 0 0;
  aspect-ratio: 1.3;
  object-fit: cover;
  width: 100%;
}
.idea__item--body {
  border-radius: 0 0 10px 10px;
  background: var(--white);
  text-align: center;
  padding: 0 20px 25px;
  position: relative;
  z-index: 1;
}
.idea__item--body figure {
  width: 88px;
  height: 88px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  margin: -44px 0 0;
  background: var(--white);
}
@media only screen and (min-width: 768px) {
  .idea__item--body figure {
    width: 60px;
    height: 60px;
    margin-top: -30px;
  }
}
@media only screen and (min-width: 992px) {
  .idea__item--body figure {
    width: 88px;
    height: 88px;
    margin-top: -44px;
  }
}
.idea__item--body figure img {
  max-width: 60%;
  max-height: 60%;
}
.idea__item--body h3 {
  font-size: 32px;
  font-weight: 500;
  color: #393938;
  margin: 0 0 8px;
  line-height: 1.2;
}
.idea__item--body p {
  margin: 0;
  font-size: 14px;
  color: #888;
  font-weight: 500;
  line-height: 1.2;
}

.message .content-bg {
  padding-top: 50px;
}
@media only screen and (min-width: 768px) {
  .message__body figure {
    margin: -14% 0 20px 35px;
    float: right;
    width: 36%;
  }
}
.message__body picture {
  position: absolute;
  z-index: -1;
  width: 27%;
  bottom: 0;
  transform: translateY(40%);
  right: 20%;
}
@media only screen and (min-width: 768px) {
  .message__body picture {
    right: 0;
  }
}
.message__body picture img {
  width: 100%;
}

.staff__top {
  margin-bottom: 40px;
}
@media only screen and (min-width: 768px) {
  .staff__top {
    display: flex;
    margin-bottom: 55px;
  }
}
@media only screen and (min-width: 768px) {
  .staff__top figure {
    width: 33%;
  }
}
.staff__top figure img {
  max-width: 275px;
}
.staff__top figure figcaption {
  color: #68777d;
}
@media only screen and (min-width: 768px) {
  .staff__top--body {
    width: 67%;
    padding-left: 40px;
  }
}
.staff__top--body h3 {
  font-weight: 700;
  font-size: 22px;
  color: #68777d;
  border-bottom: 1px solid #68777d;
  margin: 0 0 20px;
  padding-bottom: 15px;
}
@media only screen and (min-width: 992px) {
  .staff__top--body h3 {
    font-size: 34px;
  }
}

.box-list__heading {
  background: #7bbde3;
  display: flex;
  justify-content: space-between;
  border-radius: 10px 10px 0 0;
  padding: 10px 20px;
  min-height: 76px;
  flex-direction: column;
  gap: 10px 20px;
}
@media only screen and (min-width: 768px) {
  .box-list__heading {
    padding: 10px 30px;
    align-items: center;
    flex-direction: row;
  }
}
@media only screen and (min-width: 992px) {
  .box-list__heading {
    padding: 10px 45px;
  }
}
.box-list__heading h3 {
  font-size: 20px;
  font-weight: 700;
  color: var(--white);
  margin: 0;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .box-list__heading h3 {
    font-size: 24px;
  }
}
@media only screen and (min-width: 992px) {
  .box-list__heading h3 {
    font-size: 30px;
  }
}
.box-list__heading h4 {
  font-size: 18px;
  font-weight: 700;
  color: var(--white);
  margin: 0;
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .box-list__heading h4 {
    font-size: 22px;
  }
}
@media only screen and (min-width: 992px) {
  .box-list__heading h4 {
    font-size: 28px;
  }
}
.box-list__heading h4 small {
  font-size: 14px;
  font-weight: 400;
}
@media only screen and (min-width: 992px) {
  .box-list__heading h4 small {
    font-size: 18px;
  }
}
.box-list__body {
  background: var(--white);
  border-radius: 0 0 10px 10px;
  color: var(--text-base-2);
  padding: 30px 20px;
}
@media only screen and (min-width: 768px) {
  .box-list__body {
    padding: 30px;
  }
}
@media only screen and (min-width: 768px) {
  .box-list__body {
    padding: 45px;
  }
}
.box-list__body ul {
  font-weight: 500;
  display: flex;
  gap: 36px 40px;
  flex-wrap: wrap;
  font-size: 20px;
}
@media only screen and (min-width: 768px) {
  .box-list__body ul {
    font-size: 22px;
  }
}
@media only screen and (min-width: 992px) {
  .box-list__body ul {
    font-size: 26px;
    gap: 36px 84px;
  }
}
.box-list__body ul li {
  width: 100%;
  display: flex;
  gap: 0 15px;
  position: relative;
  padding-left: 13px;
}
@media only screen and (min-width: 768px) {
  .box-list__body ul li {
    width: calc(50% - 42px);
  }
}
.box-list__body ul li::before {
  content: "";
  background: #7BBDE3;
  width: 5px;
  height: 5px;
  border-radius: 100%;
  position: absolute;
  left: 0;
  top: 13px;
}
@media only screen and (min-width: 768px) {
  .box-list__body ul li::before {
    top: 16px;
  }
}
@media only screen and (min-width: 992px) {
  .box-list__body ul li::before {
    top: 18px;
  }
}
.box-list__body ul li strong {
  font-weight: 700;
  min-width: 50px;
}
.box-list__body ul li del {
  flex-basis: 0;
  flex-grow: 1;
  border-bottom: 3px dotted #68777d;
  align-self: center;
  min-width: 20px;
}
.box-list__body ul li span {
  min-width: 50px;
  white-space: nowrap;
}
.box-list__body ul li small {
  font-weight: 500;
  font-size: 14px;
}
@media only screen and (min-width: 992px) {
  .box-list__body ul li small {
    font-size: 18px;
  }
}
.box-list__body ul li.full {
  width: 100%;
}
.box-list__body ul li.full span {
  white-space: normal;
}

.box-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media only screen and (min-width: 768px) {
  .box-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 992px) {
  .box-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.box-grid__item {
  background: #F2F8FC;
  padding: 18px;
  border-radius: 10px;
  font-size: 16px;
  line-height: 1.625;
  color: #393938;
}
.box-grid__item h4 {
  position: relative;
  font-size: 22px;
  font-weight: 700;
  color: #68777d;
  margin: 0 0 10x;
  text-align: center;
  line-height: 1.27;
  padding-bottom: 14px;
}
.box-grid__item h4::after {
  content: "";
  width: 92px;
  height: 3px;
  border-radius: 5px;
  background: #CAE5F4;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.box-grid__item p:last-of-type {
  margin: 0;
}

.examination {
  font-size: 18px;
  line-height: 1.44;
}
.examination p {
  margin-bottom: 26px;
}

.box-icon {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px 32px;
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .box-icon {
    grid-template-columns: repeat(2, 1fr);
    margin-top: 40px;
  }
}
@media only screen and (min-width: 992px) {
  .box-icon {
    grid-template-columns: repeat(4, 1fr);
  }
}
.box-icon__item {
  background: var(--white);
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(0, 0, 0, 0.2);
  padding: 10px 5px 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
}
.box-icon__item figure {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 110px;
}
.box-icon__item figure img {
  max-width: 110px;
  max-height: 90px;
}
.box-icon__item p {
  margin: 0;
  font-size: 18px;
  line-height: 1.6;
  color: #393938;
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.box-icon__item h3 {
  margin: 15px auto 0;
  color: #d7a398;
  font-size: 20px;
  font-weight: 500;
  border-top: 1px solid #d7a398;
  line-height: 1.52;
  padding-top: 20px;
  max-width: calc(100% - 30px);
  flex-basis: 0;
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .box-icon__item h3 {
    font-size: 25px;
  }
}
.box-icon__item:first-child p {
  font-size: 17px;
}

.safe-house {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
}
@media only screen and (min-width: 768px) {
  .safe-house {
    grid-template-columns: 1fr 30%;
  }
}
@media only screen and (min-width: 992px) {
  .safe-house {
    gap: 30px 50px;
  }
}
@media only screen and (min-width: 768px) {
  .safe-house__content {
    grid-column: 1/2;
    grid-row: 1/2;
  }
}
@media only screen and (min-width: 768px) {
  .safe-house__bottom {
    grid-column: 1/2;
    grid-row: 2/3;
  }
}
.safe-house__bottom h3 {
  font-size: 19px;
  font-weight: 500;
  color: #7bbde3;
  line-height: 1.4;
  margin: 30px 0 20px;
  text-align: center;
}
@media only screen and (min-width: 992px) {
  .safe-house__bottom h3 {
    font-size: 21px;
    margin: 40px 0 30px;
  }
}
.safe-house__bottom .btn-dot {
  width: 100%;
  justify-content: space-between;
}
.safe-house figure {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media only screen and (min-width: 768px) {
  .safe-house figure {
    grid-column: 2/3;
    grid-row: 1/4;
    gap: 46px;
  }
}
.safe-house figure img {
  width: 100%;
}

/*# sourceMappingURL=new.css.map */
