@charset "UTF-8";
main {
  background-image: url(../../images/modules/bg_wall.jpg);
  background-size: auto;
  background-repeat: repeat;
}

@media (min-width: 769px) {
  .page_header {
    padding-top: 1.6666666667vw;
  }
}
@media (min-width: 1440px) {
  .page_header {
    padding-top: 24px;
  }
}
@media (max-width: 768px) {
  .page_header {
    padding-top: 12px;
  }
}
.page_header::before {
  content: "";
  display: block;
  background-image: url(../../images/modules/page_header.svg);
  background-repeat: no-repeat;
  background-size: contain;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 769px) {
  .page_header::before {
    width: 17.3611111111vw;
    height: 17.3611111111vw;
  }
}
@media (min-width: 1440px) {
  .page_header::before {
    width: 250px;
    height: 250px;
  }
}
@media (max-width: 768px) {
  .page_header::before {
    width: 180px;
    height: 180px;
  }
}
@media (min-width: 769px) {
  .page_header ul.page_index {
    margin-top: 1.6666666667vw;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
  }
}
@media (min-width: 1440px) {
  .page_header ul.page_index {
    margin-top: 24px;
  }
}
@media (max-width: 768px) {
  .page_header ul.page_index {
    margin-top: 20px;
    margin-bottom: 20px;
  }
}
.page_header ul.page_index li a {
  display: flex;
  align-items: center;
  line-height: 1.6;
  transition: all 0.3s;
}
.page_header ul.page_index li a:hover {
  opacity: 0.6;
}
@media (min-width: 769px) {
  .page_header ul.page_index li a {
    font-size: 1.1111111111vw;
    padding: 0.5em;
  }
}
@media (min-width: 1440px) {
  .page_header ul.page_index li a {
    font-size: 16px;
  }
}
@media (max-width: 768px) {
  .page_header ul.page_index li a {
    font-size: 16px;
    padding: 8px 16px;
  }
}
.page_header ul.page_index li a::before {
  content: "";
  display: inline-block;
  background-image: url("../../images/modules/icon_arrow.svg");
  background-repeat: no-repeat;
  background-size: contain;
}
@media (min-width: 769px) {
  .page_header ul.page_index li a::before {
    width: 1.25vw;
    height: 1.25vw;
  }
}
@media (min-width: 1440px) {
  .page_header ul.page_index li a::before {
    width: 24px;
    height: 24px;
  }
}
@media (max-width: 768px) {
  .page_header ul.page_index li a::before {
    width: 18px;
    height: 18px;
  }
}
.page_header ul.page_index li a::before {
  margin-right: 0.5em;
}

@media (min-width: 769px) {
  .page_cmn section {
    padding-top: 2.7777777778vw;
    padding-bottom: 2.7777777778vw;
  }
}
@media (min-width: 1440px) {
  .page_cmn section {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .page_cmn section {
    padding-top: 16px;
    padding-bottom: 16px;
  }
}
@media (min-width: 769px) {
  .page_cmn section:last-child {
    padding-bottom: 5.5555555556vw;
  }
}
@media (min-width: 1440px) {
  .page_cmn section:last-child {
    padding-bottom: 80px;
  }
}
@media (max-width: 768px) {
  .page_cmn section:last-child {
    padding-bottom: 32px;
  }
}

.page_about #section01 p {
  letter-spacing: 0;
}
.page_about #section01 p .add_kana {
  display: inline-block;
  position: relative;
}
.page_about #section01 p .add_kana::before {
  position: absolute;
  top: -0.8em;
  left: 50%;
  transform: translateX(-50%);
  content: "カルー";
  display: block;
  font-weight: 400;
  font-size: 66.6%;
  width: -moz-max-content;
  width: max-content;
}
@media (min-width: 769px) {
  .page_about #section02 figure {
    padding-left: 1.3888888889vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section02 figure {
    padding-left: 20px;
  }
}
@media (max-width: 768px) {
  .page_about #section02 figure {
    padding-top: 2em;
  }
}
@media (min-width: 769px) {
  .page_about #section02 p {
    padding-right: 1.3888888889vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section02 p {
    padding-right: 20px;
  }
}
@media (min-width: 769px) {
  .page_about #section03 .pc_width55 .pc_flex {
    margin-top: 3.4722222222vw;
    justify-content: space-between;
    align-items: center;
  }
}
@media (min-width: 1440px) {
  .page_about #section03 .pc_width55 .pc_flex {
    margin-top: 50px;
  }
}
@media (min-width: 769px) {
  .page_about #section03 .pc_width55 .pc_flex figure {
    width: 30%;
  }
}
.page_about #section03 .pc_width55 .pc_flex figure img {
  width: 60%;
  margin-right: auto;
  margin-left: auto;
  display: block;
}
@media (max-width: 768px) {
  .page_about #section03 .pc_width55 .pc_flex figure img {
    width: 160px;
    margin-bottom: 24px;
  }
}
@media (min-width: 769px) {
  .page_about #section03 .pc_width55 .pc_flex h3 {
    width: 70%;
  }
}
.page_about #section03 .feature_img img {
  display: block;
  width: 80%;
  margin-right: auto;
  margin-left: auto;
}
@media (max-width: 768px) {
  .page_about #section03 .feature_img img {
    width: min(100%, 430px);
  }
}
.page_about #section03 ol.feature {
  margin-bottom: 1em;
}
@media (min-width: 769px) {
  .page_about #section03 ol.feature {
    margin-top: 1.6666666667vw;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media (min-width: 1440px) {
  .page_about #section03 ol.feature {
    margin-top: 24px;
  }
}
@media (max-width: 768px) {
  .page_about #section03 ol.feature {
    flex-direction: column;
  }
}
.page_about #section03 ol.feature li {
  position: relative;
  background-color: #f2efda;
  display: flex;
  flex-direction: column;
}
@media (min-width: 769px) {
  .page_about #section03 ol.feature li {
    width: 24%;
    padding: 3.4722222222vw 1.3888888889vw 2.7777777778vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section03 ol.feature li {
    padding: 50px 20px 40px;
  }
}
@media (max-width: 768px) {
  .page_about #section03 ol.feature li {
    width: min(100%, 430px);
    padding: 40px 20px 40px;
    margin-right: auto;
    margin-left: auto;
    margin-top: 24px;
  }
}
.page_about #section03 ol.feature li h3 {
  font-weight: 600;
  margin-bottom: 1em;
}
@media (min-width: 769px) {
  .page_about #section03 ol.feature li h3 {
    font-size: 1.9444444444vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section03 ol.feature li h3 {
    font-size: 28px;
  }
}
@media (max-width: 768px) {
  .page_about #section03 ol.feature li h3 {
    font-size: 20px;
  }
}
.page_about #section03 ol.feature li h3 .en {
  position: absolute;
  color: #dea837;
  font-weight: 600;
  font-size: 171%;
  font-style: italic;
  display: block;
  transform: scaleY(1.2);
}
@media (min-width: 769px) {
  .page_about #section03 ol.feature li h3 .en {
    right: 1.1111111111vw;
    top: 1.1111111111vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section03 ol.feature li h3 .en {
    right: 16px;
    top: 16px;
  }
}
@media (max-width: 768px) {
  .page_about #section03 ol.feature li h3 .en {
    right: 16px;
    top: 16px;
  }
}
.page_about #section03 ol.feature li h3.add_pd {
  padding-top: 0.5em;
  padding-bottom: 0.5em;
}
.page_about #section03 ol.feature li p {
  letter-spacing: 0;
  margin-top: auto;
}
@media (min-width: 769px) {
  .page_about #section04 .block_primary {
    position: relative;
  }
}
@media (min-width: 769px) {
  .page_about #section04 .section_image {
    position: absolute;
    top: -3.8888888889vw;
    right: -3.8888888889vw;
    width: 54.8611111111vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section04 .section_image {
    width: 790px;
  }
}
@media (min-width: 769px) {
  .page_about #section04 ul {
    margin-top: 3.4722222222vw;
    margin-bottom: 3.4722222222vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section04 ul {
    margin-top: 50px;
    margin-bottom: 50px;
  }
}
@media (max-width: 768px) {
  .page_about #section04 ul {
    margin-bottom: 24px;
  }
}
.page_about #section04 ul li {
  border-bottom: solid 1px #989898;
}
@media (min-width: 769px) {
  .page_about #section04 ul li {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    width: -moz-max-content;
    width: max-content;
    padding-top: 1.3888888889vw;
    padding-bottom: 1.3888888889vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section04 ul li {
    padding-top: 20px;
    padding-bottom: 20px;
  }
}
@media (max-width: 768px) {
  .page_about #section04 ul li {
    padding-top: 20px;
    padding-bottom: 20px;
  }
}
.page_about #section04 ul li:last-child {
  border-bottom: none;
}
.page_about #section04 ul li h4 {
  margin-bottom: initial;
  display: flex;
  align-items: center;
}
@media (min-width: 769px) {
  .page_about #section04 ul li h4 {
    font-size: 1.9444444444vw;
    margin-right: 1em;
  }
}
@media (min-width: 1440px) {
  .page_about #section04 ul li h4 {
    font-size: 2.8rem;
  }
}
@media (max-width: 768px) {
  .page_about #section04 ul li h4 {
    font-size: 2rem;
    margin-bottom: 0.8em;
  }
}
.page_about #section04 ul li h4::before {
  content: "";
  display: inline-block;
  background-image: url("../../images/about/pict01.svg");
  background-repeat: no-repeat;
  background-size: contain;
}
@media (min-width: 769px) {
  .page_about #section04 ul li h4::before {
    width: 4.1666666667vw;
    height: 3.6111111111vw;
  }
}
@media (min-width: 1440px) {
  .page_about #section04 ul li h4::before {
    width: 60px;
    height: 52px;
  }
}
@media (max-width: 768px) {
  .page_about #section04 ul li h4::before {
    width: 40px;
    height: 35px;
  }
}
.page_about #section04 ul li h4::before {
  margin-right: 0.5em;
}
.page_about #section04 ul li p {
  line-height: 1.4;
}
@media (min-width: 769px) {
  .page_about #section04 ul li:nth-child(1) {
    padding-right: 1em;
  }
}
@media (min-width: 769px) {
  .page_about #section04 ul li:nth-child(2) {
    padding-right: 5em;
  }
}
@media (min-width: 769px) {
  .page_about #section04 ul li:nth-child(3) {
    padding-right: 5em;
  }
}
.page_about #section04 ul li:nth-child(2) h4::before {
  background-image: url("../../images/about/pict02.svg");
}
.page_about #section04 ul li:nth-child(3) h4::before {
  background-image: url("../../images/about/pict03.svg");
}
.page_about #section04 ul li:nth-child(4) h4::before {
  background-image: url("../../images/about/pict04.svg");
}

@media (min-width: 769px) {
  .bnr_link {
    margin-top: 3.4722222222vw;
  }
}
@media (min-width: 1440px) {
  .bnr_link {
    margin-top: 50px;
  }
}
@media (max-width: 768px) {
  .bnr_link {
    margin-top: 32px;
  }
}
.bnr_link a {
  display: block;
  transition: all 0.3s;
}
.bnr_link a:hover {
  opacity: 0.6;
}
@media (min-width: 769px) {
  .bnr_link a {
    width: 48%;
  }
}
@media (max-width: 768px) {
  .bnr_link a + a {
    margin-top: 20px;
  }
}
/*# sourceMappingURL=about.css.map */
