@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@400;700&family=Noto+Sans+JP:wght@400;700&display=swap");
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  padding: 0;
  margin: 0;
}

body {
  font-family: "Noto Sans JP", sans-serif, Font Awesome\6 Free;
  font-size: 16px;
  line-height: 1.6;
  background: #fff;
  color: #333333;
}

img {
  max-width: 100%;
  height: auto;
}

ul,
ol {
  list-style: none;
  padding: 0;
  margin: 0;
}

section {
  padding: 100px 0;
}

.container {
  width: 1060px;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 30px;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .container {
    padding-left: 24px;
    padding-right: 24px;
  }
}
@media (max-width: 767px) {
  .container {
    padding-left: 16px;
    padding-right: 16px;
  }
}

h2 {
  position: relative;
  color: #000;
  font-size: 20px;
  padding: 10px 0;
  text-align: center;
  margin: 0.5em 0;
}
h2:before {
  content: "";
  position: absolute;
  top: -8px;
  left: 54%;
  width: 150px;
  height: 78px;
  border-radius: 50%;
  border: 5px solid #c5c8c5;
  border-left-color: transparent;
  border-right-color: transparent;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.section_body {
  margin-top: 50px;
}

.section_title {
  text-align: center;
  font-size: 32px;
  font-weight: 700;
}

@media (max-width: 767px) {
  .section_title {
    font-size: 24px;
  }
}

.section_title img {
  margin-right: 20px;
}

.section_lead {
  text-align: center;
  margin-top: 2px;
  padding-left: 50px;
  font-weight: 500;
}

@media (max-width: 767px) {
  .section_lead {
    padding-left: 25px;
  }
}

img {
  max-width: 100%;
}

/*============================= 
header
=============================*/

.header {
  background: #d3cbcb;
  height: 100px;
  position: fixed;
  width: 100%;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.16);
  z-index: 100;
  top: 0;
  left: 0;
}
@media (max-width: 767px) {
  .header {
    height: 60px;
    width: 100%;
  }
}

.header_inner {
  display: flex;
  align-items: center;
  height: 100%;
}

.header_logo a {
  color: #000;
  text-decoration: none;
}

.header_logo {
  display: flex;
  width: 256px;
}
@media (max-width: 767px) {
  .header_logo {
    width: auto;
    font-size: 22px;
  }
  .header_logo a {
    text-decoration: none;
  }
}

.header_nav {
  display: flex;
  align-items: center;
  margin-left: auto;
  font-family: "Lato", sans-serif;
}
@media (max-width: 767px) {
  .header_nav {
    display: none;
  }
}

.header_nav li:not(:first-child) {
  margin-left: 25px;
}
.header_nav li a {
  color: #000;
  text-decoration: none;
  position: relative;
}
.header_nav li a::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 100%;
  height: 2px;
  background: transparent;
  transition: all 0.3s ease 0s;
}
.header_nav li a:hover::after,
.header__nav li a.is-active::after {
  background: #e81919;
}

/*=============================
top
=============================*/

.top {
  background-image: url(../img/shino-Yk0ugIYd5BY-unsplash.jpeg);
  background-size: cover;
  background-position: center;
  width: 100%;
  height: 360px;
  position: relative;
}

.top_content {
  position: absolute;
  top: 65%;
  transform: translate(0, -50%);
  width: 100%;
  z-index: 3;
  text-align: center;
  letter-spacing: 0.1em;
  padding: 0 16px;
  color: #fff;
  text-shadow: 1px 1px 0 #000, -1px -1px 0 #000, -1px 1px 0 #000,
    1px -1px 0 #000, 0px 1px 0 #000, 0-1px 0 #000, -1px 0 0 #000, 1px 0 0 #000;
}

.top-title {
  font-weight: 800;
  font-family: Verdana, Geneva, Tahoma, sans-serif;
  font-size: 60px;
}
@media (max-width: 767px) {
  .top-title {
    width: auto;
    font-size: 34px;
  }
  .sub-title {
    width: auto;
    font-size: 12px;
  }
}

/*============================= 
profile
=============================*/

.profile_content {
  width: 800px;
}

.profile-card {
  display: flex;
  padding: 24px;
}

@media (max-width: 767px) {
  .profile-card {
    display: block;
    width: 100%;
    height: auto;
  }
}

.profile-card_image {
  text-align: center;
  width: 40%;
}

@media (max-width: 767px) {
  .profile-card_image {
    width: 100%;
    height: auto;
  }
}

.profile-card_sns {
  margin-top: 12px;
  display: flex;
}

.profile-card_body {
  padding: 0 0 0 32px;
  width: 60%;
}

@media (max-width: 767px) {
  .profile-card_body {
    width: 100%;
    height: auto;
    font-size: 14px;
  }
}

.sns-link_item img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
}

.profile-card_title {
  font-weight: 500;
  font-size: 13px;
}

.profile-card_name {
  font-weight: 500;
  margin-top: 5px;
  font-size: 24px;
  line-height: 1.2;
}

.profile-card_text {
  margin-top: 16px;
  line-height: 1.6;
}

/*============================= 
service
=============================*/

.service {
  background-color: rgb(236, 230, 230);
}

.service_cards {
  display: flex;
  /* flex-wrap: wrap; */
  justify-content: space-around;
}

@media (max-width: 767px) {
  .service_cards {
    display: block;
    width: 100%;
  }
}

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

.service-card_image img {
  width: 150px;
  height: 150px;
  border-radius: 50%;
}

@media (max-width: 767px) {
  .service-card_image img {
    width: 100%;
    height: auto;
    border-radius: 100px;
  }
}

.service-card_title {
  margin: 16px;
  font-weight: 700;
  font-size: 22px;
  text-align: center;
}

@media (max-width: 767px) {
  .service-card_text {
    padding: 0 20px;
  }
}

.service-card {
  padding: 24px 20px;
  background: #fff;
}

.service_card {
  width: calc(33.3% - 24px * 2 / 3);
}
*/ .service_card:nth-child(n + 2) {
  margin-left: 24px;
}

@media (max-width: 767px) {
  .service_card {
    width: 100%;
    height: auto;
    margin-bottom: 20px;
    background: #fff;
  }
}

/*============================= 
work
=============================*/

.work_cards {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}

@media (max-width: 767px) {
  .work_cards {
    display: block;
    width: 100%;
  }
}

.work_card {
  width: calc(33.3% - 24px * 2 / 3);
  box-shadow: 0 0 3px 0 rgb(0 0 0 / 16%);
}
@media (max-width: 767px) {
  .work_card {
    display: block;
    width: 100%;
    height: auto;
    margin-bottom: 20px;
    background: #fff;
  }
}

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

.work-card_image img {
  width: 100%;
  height: auto;
}

@media (max-width: 767px) {
  .work-card_image img {
    width: 100%;
    height: auto;
  }
}

.work-card_body {
  padding: 12px 12px 20px;
}

.work-card_title {
  font-weight: 500;
  font-size: 18px;
  text-align: center;
  font-weight: 700;
}

.work-card_text {
  font-size: 14px;
  line-height: 1.6;
  margin-top: 8px;
}

/*============================= 
contact
=============================*/

.contact {
  background-color: rgb(236, 230, 230);
}

.contact_text {
  text-align: center;
}

@media (max-width: 767px) {
  .contact_text {
    font-size: 12px;
  }
}

.sns-box {
  display: flex;
  margin-top: 42px;
  justify-content: center;
  gap: 1rem;
}

.contact_img {
  display: block;
}

.contact_img img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
}

.contact_name {
  display: inline-block;
  margin-top: 8px;
  font-size: 14px;
}

@media (max-width: 767px) {
  .contact_name {
    display: none;
  }
}

.btn-sns {
  width: 4.5rem;
  height: 4.5rem;
  padding-top: 1rem;
  box-sizing: border-box;
  color: #fff;
  fill: #fff;
  font-size: 1.5rem;
  text-align: center;
  text-decoration: none;
  line-height: 1;
}

.btn-sns div {
  margin-top: 0.5rem;
  font-size: 0.8rem;
}

.btn-sns:hover svg {
  animation: scale 1s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
}

.btn-form {
  background-color: blue;
}

.btn-x {
  background-color: #111319;
}

.btn-instagram {
  background-color: #d300c5;
}

@keyframes scale {
  from {
    transform: scale(0);
    opacity: 1;
  }

  to {
    transform: scale(1);
    opacity: 1;
  }
}

/*============================= 
footer
=============================*/

.footer {
  background: #555;
  color: #fff;
  padding: 12px 0;
  font-size: 13px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
    Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
  letter-spacing: normal;
}

.footer_copyright {
  text-align: center;
}

/*=============================
form
=============================*/

.end-message {
  display: none;
}

.false-message {
  display: none;
}

/*=============================
drawer
=============================*/

.drawer-icon {
  position: fixed;
  top: 20px;
  right: 16px;
  z-index: 300;
  display: none;
  transition: transform 0.5s ease 0s;
}
@media (max-width: 767px) {
  .drawer-icon {
    display: block;
  }
}
.drawer-icon.is-active {
  transform: translateX(-230px);
}
.drawer-icon.is-active .drawer-icon_bar1 {
  transform: rotate(-45deg);
  top: 8px;
}
.drawer-icon.is-active .drawer-icon_bar2 {
  display: none;
}
.drawer-icon.is-active .drawer-icon_bar3 {
  transform: rotate(45deg);
  top: 8px;
}

.drawer-icon_bars {
  width: 22px;
  height: 20px;
  display: block;
  position: relative;
}

.drawer-icon_bar1,
.drawer-icon_bar2,
.drawer-icon_bar3 {
  position: absolute;
  width: 22px;
  height: 4px;
  background: #fff;
  top: 0;
  left: 0;
}
.drawer-icon_bar1 {
  top: 0;
}

.drawer-icon_bar2 {
  top: 8px;
}

.drawer-icon_bar3 {
  top: 16px;
}

.drawer-content {
  width: 230px;
  height: 100%;
  position: fixed;
  right: 0;
  top: 0;
  background: #fff;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.16);
  z-index: 299;
  transform: translateX(105%);
  transition: transform 0.5s ease 0s;
}
.drawer-content.is-active {
  transform: translateX(0);
}

.drawer-content_item {
  border-bottom: 1px dotted #707070;
}
.drawer-content_item a {
  display: block;
  color: #707070;
  text-decoration: none;
  padding: 18px 20px;
  position: relative;
}
.drawer-content_item a::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 11px;
  background: url(../img/arrow-b.png\ 20-45-51-142.png) no-repeat center
    center/contain;
}

.drawer-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  z-index: 298;
  display: none;
}
.drawer-background.is-active {
  display: block;
}

/*=============================
to-top
=============================*/

.to-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease 0s;
}
@media (max-width: 767px) {
  .to-top {
    right: 12px;
    bottom: 12px;
  }
}
.to-top.is-show {
  opacity: 1;
  visibility: visible;
}
.to-top a {
  text-decoration: none;
  transition: all 0.3s ease 0s;
}
.to-top a:hover {
  opacity: 0.7;
}
.to-top a img {
  width: 60px;
}
@media (max-width: 767px) {
  .to-top a img {
    width: 40px;
  }
}
}