@charset "UTF-8";
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

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

body {
  font-family: "メイリオ", Meiryo, YuGothic, "Yu Gothic", sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: #212529;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background: #FFF;
  overflow-x: hidden;
  overflow-wrap: break-word;
  padding-top: 0px;
}

@media screen and (max-width: 767px) {
  body {
    padding-top: 0px;
  }
}

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

.section {
  padding-top: 60px;
  padding-bottom: 60px;
  max-width: 1500px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .section {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

.inner {
  width: 930px;
  max-width: 100%;
  margin: 0 auto;
  height: inherit;
}

@media (min-width: 768px) and (max-width: 990px) {
  .inner {
    max-width: 720px;
  }
}

@media screen and (max-width: 767px) {
  .inner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.btn {
  border: 5px solid rgba(255, 255, 255, 0.3);
  -webkit-box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.2);
          box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.2);
}

.container-fluid {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

.breadcrumb {
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 5px 1rem;
  margin-bottom: 1rem;
  list-style: none;
  background-color: #f2f2f2;
  border-radius: .25rem;
  margin-top: 10px;
  font-size: 14px;
}

.breadcrumb-item.active {
  color: #5e666d;
}

.breadcrumb-item + .breadcrumb-item {
  padding-left: .5rem;
}

.breadcrumb-item + .breadcrumb-item::before {
  display: inline-block;
  padding-right: .5rem;
  color: #6c757d;
  content: "/";
}

.breadcrumb-item a {
  color: #007bff;
  text-decoration: none;
  background-color: transparent;
}

.page-header {
  position: relative;
  color: #ffffff;
  text-align: left;
  background: url(../photo/com_sonota.fw.png) no-repeat 50% center;
  background-size: cover;
  padding-top: 80px;
  padding-bottom: 80px;
  padding-left: 16px;
  padding-right: 16px;
  margin-top: 51px;
}

@media screen and (max-width: 767px) {
  .page-header {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.container_bg {
  margin: 0 auto;
  max-width: 930px;
}

.page-header_pageTitle {
  margin: 1.2rem 0;
  font-size: 3rem;
  line-height: 1.1;
  text-shadow: 2px 4px 3px rgba(0, 0, 0, 0.5);
  font-weight: bold;
}

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

.container  {
  max-width: 960px;
}

.row  {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-right: -15px;
  margin-left: -15px;
}

.col-12  {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 100%;
          flex: 0 0 100%;
  max-width: 100%;
}

.mb-4,  .my-4  {
  margin-bottom: 1.5rem !important;
}

.mt-4,  .my-4  {
  margin-top: 1.5rem !important;
}

.card-header:first-child  {
  border-radius: calc(.25rem - 1px) calc(.25rem - 1px) 0 0;
}

.card-header  {
  padding: .75rem 1.25rem;
  margin-bottom: 0;
  background-color: rgba(0, 0, 0, 0.03);
  border-bottom: 1px solid rgba 0, 0, 0, 0.125;
}

.col-sm  {
  -ms-flex-preferred-size: 0;
      flex-basis: 0;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  max-width: 100%;
}

.col-12  {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 100%;
          flex: 0 0 100%;
}

.h3,  h3  {
  font-size: 1.75rem;
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2,  h3,  h4, h5, h6  {
  margin-bottom: .5rem;
  font-weight: 500;
  line-height: 1.2;
}

a  {
  color: #007bff;
  text-decoration: none;
  background-color: transparent;
}

.col-auto {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: auto;
  max-width: 100%;
}

.card-body  {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  padding: 1.25rem;
}

.pt-2,  .py-2  {
  padding-top: 0.5rem !important;
}

.border-top  {
  border-top: 1px solid  #dee2e6 !important;
}

p  {
  margin-top: 0;
  margin-bottom: 1rem;
}

dl, ol,  ul  {
  margin-top: 0;
  margin-bottom: 1rem;
}
