@charset "UTF-8";
/*!
Theme Name: iblis_2025
Theme URI: https://example.com
Author: iblis
Author URI: https://example.com
Description: 自社メディア用WordPressテーマ
Version: 1.0.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: iblis_2025
*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Racing+Sans+One&display=swap");
.wrapper {
  min-height: 600px;
}

.container {
  display: block;
  margin: 0 auto;
  padding: 0 20px;
  width: 100%;
}
@media screen and (min-width: 451px) {
  .container {
    max-width: 450px;
  }
}
@media screen and (min-width: 769px) {
  .container {
    max-width: 768px;
  }
}
@media screen and (min-width: 1081px) {
  .container {
    max-width: 1080px;
  }
}

b, strong {
  color: #8F0C00;
}

p {
  line-height: 2rem;
}

.fixed-btn {
  position: fixed;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 210;
  right: 300px;
}

.text-red {
  color: #8F0C00;
}

.fw-600 {
  font-weight: 600;
}

.top-title-box {
  text-align: center;
  padding: 40px 0 20px;
}
.top-title-box h1, .top-title-box h2 {
  font-size: 2.5rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .top-title-box h1, .top-title-box h2 {
    font-size: 2rem;
  }
}

.bg-primary {
  background-color: #8F0C00;
}

.bg-black {
  background-color: #151515;
}

.w-100 {
  width: 100%;
}

.section-title-box {
  display: block;
  text-align: center;
}
.section-title-box .subtitle {
  font-family: "Racing Sans One", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 14px;
}
@media screen and (max-width: 768px) {
  .section-title-box .subtitle {
    font-size: 12px;
  }
}
.section-title-box .subtitle {
  position: relative;
}
.section-title-box .subtitle::before {
  content: "";
  position: absolute;
  top: 50%;
  margin-top: -1px;
  width: 25px;
  height: 1px;
  left: -30px;
  background-color: #000000;
}
.section-title-box .subtitle::after {
  content: "";
  position: absolute;
  top: 50%;
  margin-top: -1px;
  right: -30px;
  width: 25px;
  height: 1px;
  background-color: #000000;
}
.section-title-box .subtitle {
  color: #8F0C00;
}
.section-title-box .subtitle-bk {
  font-family: "Racing Sans One", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 14px;
}
@media screen and (max-width: 768px) {
  .section-title-box .subtitle-bk {
    font-size: 12px;
  }
}
.section-title-box .subtitle-bk {
  position: relative;
}
.section-title-box .subtitle-bk::before {
  content: "";
  position: absolute;
  top: 50%;
  margin-top: -1px;
  width: 25px;
  height: 1px;
  left: -30px;
  background-color: #000000;
}
.section-title-box .subtitle-bk::after {
  content: "";
  position: absolute;
  top: 50%;
  margin-top: -1px;
  right: -30px;
  width: 25px;
  height: 1px;
  background-color: #000000;
}
.section-title-box .subtitle-bk {
  color: #000000;
}
.section-title-box .subtitle-bk::after, .section-title-box .subtitle-bk::before {
  background-color: #000000;
}
.section-title-box .title {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  margin-top: 5px;
  margin-bottom: 60px;
  font-size: 28px;
}
@media screen and (max-width: 768px) {
  .section-title-box .title {
    font-size: 18px;
    margin-bottom: 40px;
  }
}
.section-title-box.all-red {
  color: #8F0C00 !important;
}
.section-title-box.all-red .subtitle {
  color: #8F0C00 !important;
}
.section-title-box.all-red .subtitle::after, .section-title-box.all-red .subtitle::before {
  background-color: #8F0C00 !important;
}

.centered-button-bk {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding: 12px;
  border-radius: 6px;
  background-color: #151515;
}
.centered-button-bk .inner {
  display: block;
  text-align: center;
  border-radius: 4px;
  color: #8F0C00;
  border: 1px solid #8F0C00;
  padding: 15px 25px;
}

.centered-button-red {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding: 12px;
  border-radius: 6px;
  background-color: #8F0C00;
}
.centered-button-red .inner {
  display: block;
  text-align: center;
  border-radius: 4px;
  color: #151515;
  border: 1px solid #151515;
  padding: 15px 25px;
}

.mb-20 {
  margin-bottom: 20px;
}

.mb-40 {
  margin-bottom: 40px;
}

.mb-60 {
  margin-bottom: 60px;
}

#pc-global-nav {
  position: fixed;
  z-index: 200;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #8F0C00;
  color: #151515;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 800;
  font-style: normal;
}
#pc-global-nav .box-gnav {
  height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 20px;
}
#pc-global-nav .nav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (max-width: 768px) {
  #pc-global-nav .nav-list {
    display: none;
  }
}
#pc-global-nav .menu-item::after {
  content: "/";
  padding: 0 10px;
}
#pc-global-nav .menu-item:nth-last-of-type(1)::after {
  content: "";
  padding: 0;
}
#pc-global-nav .menu-item a:hover {
  color: #F5F5F5;
}
#pc-global-nav .box-img {
  width: 40px;
}

#nav-drawer {
  position: fixed;
  z-index: 200;
  background-color: #8F0C00;
  width: 100%;
  height: 100%;
  opacity: 0;
  -webkit-transition-duration: 0.3s;
          transition-duration: 0.3s;
  pointer-events: none;
}
#nav-drawer.open {
  opacity: 1;
  pointer-events: all;
}
#nav-drawer .nav-container {
  display: block;
  width: 100%;
  max-width: 1280px;
  padding: 40px;
  height: 100%;
  margin: 0 auto;
}
#nav-drawer header {
  margin-bottom: 90px;
}
#nav-drawer header h2 {
  font-size: 36px;
  font-weight: bold;
  margin-bottom: 34px;
}
@media screen and (max-width: 768px) {
  #nav-drawer header {
    text-align: center;
  }
  #nav-drawer header h2 {
    font-size: 24px;
    margin-bottom: 24px;
  }
  #nav-drawer header {
    margin-bottom: 60px;
  }
}
#nav-drawer .box-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  #nav-drawer .box-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
#nav-drawer .box-img {
  width: 35%;
}
@media screen and (max-width: 768px) {
  #nav-drawer .box-img {
    width: 100%;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    text-align: center;
  }
  #nav-drawer .box-img img {
    width: 50%;
  }
}
#nav-drawer .nav-list-box {
  width: 65%;
  height: 300px;
  position: relative;
}
@media screen and (max-width: 768px) {
  #nav-drawer .nav-list-box {
    width: 100%;
    height: auto;
  }
}
#nav-drawer .nav-list {
  display: grid;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: left;
      -ms-flex-pack: left;
          justify-content: left;
  margin-bottom: 80px;
  font-size: 18px;
  font-weight: bold;
  grid-template-columns: repeat(3, 1fr);
}
@media screen and (max-width: 768px) {
  #nav-drawer .nav-list {
    text-align: center;
    grid-template-columns: 1fr;
  }
}
#nav-drawer .nav-list .menu-item {
  margin-bottom: 25px;
}
#nav-drawer .nav-list .menu-item a::before {
  content: "・";
}
#nav-drawer .nav-list .menu-item a:hover {
  color: #F5F5F5;
}
#nav-drawer .box-link-contact {
  position: absolute;
  left: 0;
  bottom: 0;
  display: block;
  margin: 0 auto;
  width: 100%;
  text-align: center;
  font-family: "Racing Sans One", sans-serif;
  font-weight: 400;
  font-style: normal;
}
#nav-drawer .box-link-contact a {
  padding: 10px 15px;
  font-size: 32px;
}
#nav-drawer .box-link-contact a:hover {
  color: #F5F5F5;
}

#sp-hamburger {
  position: fixed;
  z-index: 210;
  right: 20px;
  bottom: 20px;
  width: 60px;
  height: 60px;
  background-color: #151515;
  border-radius: 50%;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 6px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
#sp-hamburger:hover {
  background-color: black;
}
#sp-hamburger span {
  display: block;
  width: 30px;
  height: 3px;
  background-color: #8F0C00;
  border-radius: 2px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
#sp-hamburger.open span:nth-child(1) {
  -webkit-transform: translateY(9px) rotate(45deg);
          transform: translateY(9px) rotate(45deg);
}
#sp-hamburger.open span:nth-child(2) {
  opacity: 0;
}
#sp-hamburger.open span:nth-child(3) {
  -webkit-transform: translateY(-9px) rotate(-45deg);
          transform: translateY(-9px) rotate(-45deg);
}

.nav-contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 20px;
}

.nav-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}

.nav-logo-img {
  width: 50px;
  height: auto;
}

.nav-logo-text {
  font-size: 1.5rem;
  font-weight: 700;
}

.close-btn {
  width: 30px;
  height: 30px;
  position: relative;
  cursor: pointer;
}
.close-btn span {
  display: block;
  width: 100%;
  height: 2px;
  background-color: #333;
  position: absolute;
  top: 50%;
}
.close-btn span:nth-child(1) {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.close-btn span:nth-child(2) {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.nav-list-box {
  padding: 20px;
}

.nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.nav-item, .nav-item-contact {
  border-bottom: 1px solid #eee;
}
.nav-item a, .nav-item-contact a {
  display: block;
  padding: 15px 0;
  text-decoration: none;
  color: #333;
  font-size: 1.1rem;
}
.nav-item a:hover, .nav-item-contact a:hover {
  color: #8F0C00;
}

.nav-item-contact a {
  color: #8F0C00;
  font-weight: 700;
}

#mt-dummy {
  height: 60px;
}

.footer {
  padding: 60px 20px 40px;
  text-align: center;
}

.footer-logo {
  text-align: center;
  margin-bottom: 60px;
}
.footer-logo .box-img {
  margin: 0 auto;
  width: 100%;
  max-width: 250px;
}

.footer-logo-text {
  font-size: 1.5rem;
  font-weight: 700;
}

.footer-nav-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 20px;
  margin-bottom: 60px;
}
.footer-nav-box .menu-item a {
  text-decoration: none;
  font-size: 18px;
  font-weight: 700;
  color: #000000;
}
.footer-nav-box .menu-item a:hover {
  color: #F5F5F5;
}
@media screen and (max-width: 767px) {
  .footer-nav-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px;
  }
}

.footer-copyright {
  font-size: 12px;
  color: #000000;
}

.home .top-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .home .top-box {
    padding-top: 60px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.home .top-box-left {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.home .top-text {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .home .top-text {
    font-size: 1.8rem;
  }
}
.home .top-text-subtitle {
  font-size: 1.1rem;
  line-height: 1.6;
}
.home .top-box-right {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  text-align: center;
}
.home .top-akuma {
  max-width: 400px;
  height: auto;
}
.home .top-text-name {
  margin-top: 10px;
  font-size: 0.875rem;
}
.home .top-about {
  padding: 60px 20px;
}
.home .top-about .box-text {
  width: 100%;
  max-width: 360px;
  margin: 0 auto;
  margin-bottom: 60px;
}
.home .top-about .letter-spacing {
  letter-spacing: -0.4em;
}
.home .swiper {
  margin-bottom: 20px;
}
.home .top-about-intro-akuma {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .home .top-about-intro-akuma {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.home .top-about-introduction {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-size: 1rem;
  line-height: 1.8;
}
.home .top-about-akuma {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.home .top-about-akuma .top-about-akuma-img {
  max-width: 200px;
}
.home .top-service {
  padding: 60px 20px;
}
.home .top-service .box {
  display: block;
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
}
.home .top-service .service-child {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  background-color: #151515;
  margin-bottom: 20px;
  border-radius: 12px;
  overflow: hidden;
}
.home .top-service .service-child .box-left {
  width: 40%;
}
.home .top-service .service-child .box-right {
  width: 60%;
  padding: 20px;
}
.home .top-service .service-child .box-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  height: 100%;
  padding: 20px;
  border: 1px solid #8F0C00;
  border-radius: 8px;
}
.home .top-service .service-child .text-body {
  margin-bottom: 20px;
}
.home .top-service .service-child .box-link-detail {
  width: 100%;
  text-align: right;
}
.home .top-service .service-child .link-detail {
  color: #8F0C00;
}
.home .top-service .service-child .link-detail:hover {
  color: #F5F5F5;
}
.home .top-service h3 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: 20px;
  color: #8F0C00;
  padding-bottom: 15px;
  margin-bottom: 5px;
  border-bottom: 1px solid #8F0C00;
}
.home .top-service p {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-size: 16px;
  color: #8F0C00;
}
@media screen and (max-width: 768px) {
  .home .top-service .service-child {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .home .top-service .service-child .box-right {
    width: 100%;
  }
  .home .top-service .service-child .box-left {
    width: 100%;
  }
}
.home .top-articles {
  padding: 60px 20px;
}
.home .new {
  margin-top: 40px;
}
.home .new-box {
  display: grid;
  grid-template-columns: repeat(2, 1fr) 1fr;
  gap: 20px;
}
@media screen and (max-width: 1024px) {
  .home .new-box {
    grid-template-columns: 1fr;
  }
}
.home .new-article-box {
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.home .new-article-box:hover {
  -webkit-transform: translateY(-5px);
          transform: translateY(-5px);
}
.home .new-article-box a {
  text-decoration: none;
  color: inherit;
}
.home .new-article-img {
  width: 100%;
  height: 200px;
  -o-object-fit: cover;
     object-fit: cover;
}
.home .new-article-text-box {
  padding: 20px;
}
.home .new-article-title {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.home .new-article-text {
  font-size: 0.875rem;
  line-height: 1.6;
  color: #666;
}
.home .new-other-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.home .new-other-box-bar {
  border: 0;
  border-top: 1px solid #eee;
}
.home .new-other-box-individual {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15px;
  padding: 15px 0;
}
.home .new-other-box-individual a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15px;
  text-decoration: none;
  color: inherit;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.home .new-other-box-individual a:hover .new-other-box-text {
  color: #8F0C00;
}
.home .new-other-box-img {
  width: 80px;
  height: 80px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 5px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.home .new-other-box-text {
  font-size: 0.875rem;
  line-height: 1.6;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.home .top-works {
  padding: 60px 20px;
}
.home .works-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 1024px) {
  .home .works-list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .home .works-list {
    grid-template-columns: 1fr;
  }
}
.home .works-item {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.home .works-item:hover {
  -webkit-transform: translateY(-5px);
          transform: translateY(-5px);
}
.home .works-item-link {
  text-decoration: none;
  color: inherit;
  display: block;
}
.home .works-item-thumbnail {
  width: 100%;
  height: 200px;
  overflow: hidden;
}
.home .works-item-thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.home .works-item-content {
  padding: 20px;
}
.home .works-item-title {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.home .works-item-meta {
  font-size: 0.875rem;
  color: #999;
  margin-bottom: 10px;
}
.home .works-item-meta time {
  margin-right: 10px;
}
.home .works-item-type {
  display: inline-block;
  padding: 2px 8px;
  background-color: #eee;
  border-radius: 3px;
  font-size: 0.75rem;
}
.home .works-item-excerpt {
  font-size: 0.875rem;
  line-height: 1.6;
  color: #666;
}
.home .top-service-menu {
  padding: 60px 20px;
}
.home .service-menu-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 1024px) {
  .home .service-menu-list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .home .service-menu-list {
    grid-template-columns: 1fr;
  }
}
.home .service-menu-card {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  -webkit-transition: -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
  transition: -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
  transition: transform 0.3s, box-shadow 0.3s;
  transition: transform 0.3s, box-shadow 0.3s, -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
}
.home .service-menu-card:hover {
  -webkit-transform: translateY(-5px);
          transform: translateY(-5px);
  -webkit-box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}
.home .service-menu-card a {
  text-decoration: none;
  color: inherit;
  display: block;
  height: 100%;
}
.home .service-menu-content {
  padding: 40px 20px;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-height: 200px;
}
.home .service-menu-title {
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 15px;
  color: #8F0C00;
}
@media screen and (max-width: 767px) {
  .home .service-menu-title {
    font-size: 1.1rem;
  }
}
.home .service-menu-description {
  font-size: 0.875rem;
  line-height: 1.8;
}

.top-contact {
  padding-top: 50px;
  padding-bottom: 50px;
}

.top-company {
  padding: 60px 20px;
}

.company-profile {
  width: 100%;
  max-width: 800px;
  margin: 40px auto 0;
  border-collapse: collapse;
}

.company-profile-block {
  border-bottom: 1px solid #eee;
}
.company-profile-block:last-child {
  border-bottom: none;
}

.profile-heading {
  width: 200px;
  padding: 20px;
  background-color: #f9f9f9;
  font-weight: 700;
  text-align: left;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .profile-heading {
    display: block;
    width: 100%;
    border-bottom: 1px solid #eee;
  }
}

.profile-text {
  padding: 20px;
  line-height: 1.8;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .profile-text {
    display: block;
    width: 100%;
  }
}

#page-philosophy {
  margin-top: 120px;
}
#page-philosophy .mission h3, #page-philosophy .value h3 {
  font-size: 20px;
  color: #8F0C00;
  margin-bottom: 10px;
  font-weight: bold;
  color: #000000;
}
#page-philosophy .mission h3 span, #page-philosophy .value h3 span {
  color: #8F0C00;
}
#page-philosophy .box-text-body {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
#page-philosophy .message .content-title {
  font-size: 20px;
  text-align: center;
  margin-bottom: 2rem;
  color: #8F0C00;
  font-weight: 600;
}
#page-philosophy .message .box-text-body {
  margin: 0 auto;
  width: 100%;
  max-width: 600px;
  padding: 40px 20px 20px 20px;
  background-color: #f0f0f0;
  border-radius: 6px;
}
#page-philosophy .message .box-text-body p {
  margin-bottom: 1.2rem;
}
#page-philosophy .message .box-text-body span {
  color: #8F0C00;
  font-weight: 600;
}
#page-philosophy .message-end {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.contact {
  padding: 60px 20px;
}

.top-titlebox-contact {
  text-align: center;
  margin-bottom: 40px;
}

.contact-title {
  font-size: 2.5rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .contact-title {
    font-size: 2rem;
  }
}

#page-services {
  margin-top: 120px;
}
@media screen and (max-width: 767px) {
  #page-services {
    margin-top: 80px;
  }
}

.service-category {
  margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .service-category {
    margin-bottom: 60px;
  }
}

#web-production,
#lp-creation,
#system-development,
#maintenance {
  margin-top: -80px;
  padding-top: 80px;
}

.service-category-header {
  text-align: center;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .service-category-header {
    margin-bottom: 40px;
  }
}
.service-category-header .category-title {
  font-size: 32px;
  font-weight: 700;
  color: #8F0C00;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .service-category-header .category-title {
    font-size: 24px;
    margin-bottom: 15px;
  }
}
.service-category-header .category-description {
  font-size: 16px;
  line-height: 1.8;
  color: #000000;
}
@media screen and (max-width: 767px) {
  .service-category-header .category-description {
    font-size: 14px;
  }
}

.service-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .service-list {
    gap: 30px;
  }
}

.service-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding: 30px;
  background-color: #fafafa;
  border-radius: 8px;
  -webkit-transition: -webkit-box-shadow 0.3s ease;
  transition: -webkit-box-shadow 0.3s ease;
  transition: box-shadow 0.3s ease;
  transition: box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
.service-item:hover {
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 767px) {
  .service-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px;
    padding: 20px;
  }
}

.service-image {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 300px;
          flex: 0 0 300px;
  min-width: 0;
}
@media screen and (max-width: 767px) {
  .service-image {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    width: 100%;
  }
}
.service-image img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 4px;
  display: block;
}

.service-content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-width: 0;
}
.service-content .service-name {
  font-size: 22px;
  font-weight: 700;
  color: #000000;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .service-content .service-name {
    font-size: 18px;
  }
}
.service-content .service-price {
  font-size: 18px;
  font-weight: 600;
  color: #8F0C00;
  margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .service-content .service-price {
    font-size: 16px;
  }
}
.service-content .service-description {
  font-size: 15px;
  line-height: 1.8;
  color: #000000;
  margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .service-content .service-description {
    font-size: 14px;
  }
}
.service-content .service-features {
  list-style: disc;
  padding-left: 20px;
  margin-bottom: 10px;
}
.service-content .service-features li {
  font-size: 14px;
  line-height: 1.8;
  color: #000000;
  margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
  .service-content .service-features li {
    font-size: 13px;
  }
}
.service-content .service-note {
  font-size: 13px;
  line-height: 1.8;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .service-content .service-note {
    font-size: 12px;
  }
}

.page-archive {
  padding: 60px 20px;
}

.page-header {
  text-align: center;
  margin-bottom: 60px;
}

.page-title {
  font-size: 2.5rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .page-title {
    font-size: 2rem;
  }
}

.posts-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .posts-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}

.post-card {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  -webkit-transition: -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
  transition: -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
  transition: transform 0.3s, box-shadow 0.3s;
  transition: transform 0.3s, box-shadow 0.3s, -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
}
.post-card:hover {
  -webkit-transform: translateY(-5px);
          transform: translateY(-5px);
  -webkit-box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

.post-card-link {
  text-decoration: none;
  color: inherit;
  display: block;
}

.post-card-thumbnail {
  width: 100%;
  height: 250px;
  overflow: hidden;
  background-color: #f0f0f0;
}
.post-card-thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.post-card-thumbnail.no-image {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: linear-gradient(135deg, #f5f5f5, #e0e0e0);
}
.post-card-thumbnail.no-image span {
  color: #999;
  font-size: 1rem;
}
@media screen and (max-width: 767px) {
  .post-card-thumbnail {
    height: 200px;
  }
}

.post-card:hover .post-card-thumbnail img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.post-card-content {
  padding: 20px;
}

.post-card-title {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 15px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .post-card-title {
    font-size: 1.1rem;
  }
}

.post-card-meta {
  margin-bottom: 15px;
}

.post-card-date {
  font-size: 0.875rem;
  color: #999;
}

.post-card-categories {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.category-badge {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
  padding: 4px 12px;
  background-color: #f0f0f0;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
}
.category-badge .category-icon-small {
  width: 16px;
  height: 16px;
  -o-object-fit: contain;
     object-fit: contain;
}

.post-card-tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 6px;
}

.tag-badge {
  display: inline-block;
  padding: 3px 10px;
  background-color: #fff;
  border: 1px solid #ddd;
  border-radius: 15px;
  font-size: 0.75rem;
  color: #666;
}

.page-archive .pagination {
  margin-top: 60px;
  text-align: center;
}
.page-archive .pagination .nav-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.page-archive .pagination a,
.page-archive .pagination span {
  display: inline-block;
  padding: 10px 15px;
  background-color: #f0f0f0;
  border-radius: 5px;
  text-decoration: none;
  color: inherit;
  -webkit-transition: background-color 0.3s, color 0.3s;
  transition: background-color 0.3s, color 0.3s;
}
.page-archive .pagination a:hover,
.page-archive .pagination span:hover {
  background-color: #8F0C00;
  color: #fff;
}
.page-archive .pagination a.current,
.page-archive .pagination span.current {
  background-color: #8F0C00;
  color: #fff;
}

.no-posts {
  text-align: center;
  padding: 60px 20px;
  color: #999;
  font-size: 1.1rem;
}

.works-archive {
  padding: 60px 20px;
}

.archive-header {
  text-align: center;
  margin-bottom: 60px;
}

.archive-title {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .archive-title {
    font-size: 2rem;
  }
}

.term-description {
  font-size: 1rem;
  line-height: 1.8;
  color: #666;
}

.works-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .works-list {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}

.works-item {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  -webkit-transition: -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
  transition: -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
  transition: transform 0.3s, box-shadow 0.3s;
  transition: transform 0.3s, box-shadow 0.3s, -webkit-transform 0.3s, -webkit-box-shadow 0.3s;
}
.works-item:hover {
  -webkit-transform: translateY(-5px);
          transform: translateY(-5px);
  -webkit-box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

.works-item-link {
  text-decoration: none;
  color: inherit;
  display: block;
}

.works-item-thumbnail {
  width: 100%;
  height: 250px;
  overflow: hidden;
  background-color: #f0f0f0;
}
.works-item-thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
@media screen and (max-width: 767px) {
  .works-item-thumbnail {
    height: 200px;
  }
}

.works-item:hover .works-item-thumbnail img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.works-item-content {
  padding: 20px;
}

.works-item-title {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 15px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .works-item-title {
    font-size: 1.1rem;
  }
}

.works-item-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 15px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 15px;
  font-size: 0.875rem;
  color: #999;
}

.works-item-type {
  display: inline-block;
  padding: 4px 12px;
  background-color: #f0f0f0;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #333;
}

.works-item-excerpt {
  font-size: 0.9rem;
  line-height: 1.6;
  color: #666;
  margin-bottom: 15px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.works-item-tech {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 6px;
}
.works-item-tech .tech-tag {
  display: inline-block;
  padding: 3px 10px;
  background-color: #fff;
  border: 1px solid #ddd;
  border-radius: 15px;
  font-size: 0.75rem;
  color: #666;
}

.works-archive .pagination {
  margin-top: 60px;
  text-align: center;
}
.works-archive .pagination .nav-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.works-archive .pagination a,
.works-archive .pagination span {
  display: inline-block;
  padding: 10px 15px;
  background-color: #f0f0f0;
  border-radius: 5px;
  text-decoration: none;
  color: inherit;
  -webkit-transition: background-color 0.3s, color 0.3s;
  transition: background-color 0.3s, color 0.3s;
}
.works-archive .pagination a:hover,
.works-archive .pagination span:hover {
  background-color: #8F0C00;
  color: #fff;
}
.works-archive .pagination a.current,
.works-archive .pagination span.current {
  background-color: #8F0C00;
  color: #fff;
}

.no-posts {
  text-align: center;
  padding: 60px 20px;
  color: #999;
  font-size: 1.1rem;
}

.post-single {
  padding: 60px 20px;
}

.post-title {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .post-title {
    font-size: 1.5rem;
  }
}

.post-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
  margin-bottom: 40px;
  padding-bottom: 20px;
  border-bottom: 1px solid #eee;
}

.post-date {
  color: #999;
}

.post-tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
}
.post-tags .tag-label {
  font-weight: 700;
  margin-right: 10px;
}
.post-tags a {
  display: inline-block;
  padding: 5px 15px;
  background-color: #f0f0f0;
  border-radius: 20px;
  text-decoration: none;
  color: inherit;
  font-size: 0.875rem;
}
.post-tags a:hover {
  background-color: #8F0C00;
  color: #fff;
}

.post-content {
  font-size: 1rem;
  line-height: 1.8;
}
.post-content h2, .post-content h3, .post-content h4 {
  margin: 40px 0 20px;
}
.post-content p {
  margin-bottom: 20px;
}
.post-content img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  margin: 20px 0;
}

.error-404 {
  padding: 100px 20px;
  min-height: 60vh;
  text-align: center;
}

.error-404-content {
  max-width: 600px;
  margin: 0 auto;
}

.error-404-title {
  font-size: 6rem;
  font-weight: 700;
  color: #8F0C00;
  margin-bottom: 20px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .error-404-title {
    font-size: 4rem;
  }
}

.error-404-message {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .error-404-message {
    font-size: 1.2rem;
  }
}

.error-404-description {
  font-size: 1rem;
  line-height: 1.8;
  color: #666;
  margin-bottom: 40px;
}

.error-404-actions {
  margin-top: 40px;
}

.btn-home {
  display: inline-block;
  padding: 15px 60px;
  background-color: #8F0C00;
  color: #fff;
  text-decoration: none;
  border-radius: 30px;
  font-weight: 700;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.btn-home:hover {
  opacity: 0.8;
}
@media screen and (max-width: 767px) {
  .btn-home {
    padding: 12px 40px;
    font-size: 0.9rem;
  }
}

.works-archive {
  padding: 60px 20px;
}

.archive-header {
  text-align: center;
  margin-bottom: 60px;
}

.archive-title {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .archive-title {
    font-size: 2rem;
  }
}

.term-description {
  font-size: 1rem;
  line-height: 1.8;
  color: #666;
}

.works-single {
  padding: 60px 20px;
}

.works-thumbnail {
  margin-bottom: 40px;
}
.works-thumbnail img {
  width: 100%;
  height: auto;
  border-radius: 10px;
}

.works-title {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .works-title {
    font-size: 1.5rem;
  }
}

.works-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
  margin-bottom: 40px;
  padding-bottom: 20px;
  border-bottom: 1px solid #eee;
}

.works-date {
  color: #999;
}

.works-project-type,
.works-tech-stack {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
}
.works-project-type .tech-label,
.works-tech-stack .tech-label {
  font-weight: 700;
  margin-right: 10px;
}
.works-project-type a,
.works-tech-stack a {
  display: inline-block;
  padding: 5px 15px;
  background-color: #f0f0f0;
  border-radius: 20px;
  text-decoration: none;
  color: inherit;
  font-size: 0.875rem;
}
.works-project-type a:hover,
.works-tech-stack a:hover {
  background-color: #8F0C00;
  color: #fff;
}

.project-type-link,
.tech-tag {
  display: inline-block;
  padding: 5px 15px;
  background-color: #f0f0f0;
  border-radius: 20px;
  text-decoration: none;
  color: inherit;
  font-size: 0.875rem;
}
.project-type-link:hover,
.tech-tag:hover {
  background-color: #8F0C00;
  color: #fff;
}

.works-content {
  font-size: 1rem;
  line-height: 1.8;
}
.works-content h2, .works-content h3, .works-content h4 {
  margin: 40px 0 20px;
}
.works-content p {
  margin-bottom: 20px;
}
.works-content img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  margin: 20px 0;
}

.pagination {
  margin-top: 60px;
  text-align: center;
}
.pagination .nav-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.pagination .nav-links a,
.pagination .nav-links span {
  display: inline-block;
  padding: 10px 15px;
  background-color: #f0f0f0;
  border-radius: 5px;
  text-decoration: none;
  color: inherit;
}
.pagination .nav-links a:hover,
.pagination .nav-links span:hover {
  background-color: #8F0C00;
  color: #fff;
}
.pagination .nav-links a.current,
.pagination .nav-links span.current {
  background-color: #8F0C00;
  color: #fff;
}

.no-posts {
  text-align: center;
  padding: 60px 20px;
  color: #999;
}

#wpcf7-f36-o1 {
  display: block;
  margin: 0 auto;
  width: 100%;
  max-width: 500px;
  background-color: #F5F5F5;
  padding: 20px;
  border-radius: 12px;
}
#wpcf7-f36-o1 span {
  display: block;
}
#wpcf7-f36-o1 input, #wpcf7-f36-o1 textarea {
  padding: 6px;
  width: 100%;
  border: 1px solid #151515;
  border-radius: 6px;
}
#wpcf7-f36-o1 input[type=submit] {
  cursor: pointer;
  margin-top: 40px;
  text-align: center;
  border-radius: 8px;
  border-color: transparent;
  background-color: #151515;
  color: #F5F5F5;
}
#wpcf7-f36-o1 input[type=submit]:hover {
  background-color: #8F0C00;
}

.noto-serif-200 {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 200;
  font-style: normal;
}

.noto-sans-200 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 200;
  font-style: normal;
}

.noto-serif-300 {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}

.noto-sans-300 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}

.noto-serif-400 {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.noto-sans-400 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.noto-serif-500 {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.noto-sans-500 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.noto-serif-600 {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}

.noto-sans-600 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}

.noto-serif-700 {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.noto-sans-700 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.noto-serif-800 {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 800;
  font-style: normal;
}

.noto-sans-800 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 800;
  font-style: normal;
}

.noto-serif-900 {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 900;
  font-style: normal;
}

.noto-sans-900 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 900;
  font-style: normal;
}

.racing-sans-one-regular {
  font-family: "Racing Sans One", sans-serif;
  font-weight: 400;
  font-style: normal;
}

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

.body-top {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
}

.body {
  background-color: #F5F5F5;
}/*# sourceMappingURL=style.css.map */