@import url("https://use.typekit.net/aob0oor.css");
html {
  overflow-y: scroll; }

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, textarea, p, blockquote, th, td {
  margin: 0;
  padding: 0; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

fieldset, img {
  border: 0; }

img {
  vertical-align: bottom; }

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
  font-weight: normal; }

li {
  list-style: none; }

caption, th {
  text-align: left; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal; }

q:before, q:after {
  content: ''; }

abbr, acronym {
  border: 0;
  font-variant: normal; }

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit; }

/*to enable resizing for IE*/
input, textarea, select {
  *font-size: 100%; }

/*because legend doesn't inherit in IE */
legend {
  color: #000; }

del, ins {
  text-decoration: none; }

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  /* 1 */
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
  /* 2 */ }

button,
[type="button"],
[type="reset"],
[type="submit"] {
  cursor: pointer; }

button:disabled,
[type="button"]:disabled,
[type="reset"]:disabled,
[type="submit"]:disabled {
  cursor: default; }

::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/******************************************************

base

******************************************************/
.bg {
  background-color: #1f2a46;
  position: relative; }
  .bg .en-ttl, .bg .midashi {
    color: #d4b572; }

.sec-head .en-ttl {
  font-size: clamp(14px, 1.5vw, 2rem);
  font-weight: normal;
  margin-bottom: 8px; }
.sec-head .lead {
  text-align: center;
  color: #fff;
  padding-top: 3.2rem; }

.item-list {
  margin: 5.6rem auto 0; }
  .item-list > ul {
    display: grid; }
    .item-list > ul > li {
      display: grid;
      grid-template-rows: subgrid;
      grid-row: span 3;
      gap: 0;
      margin-bottom: 4rem; }
  .item-list .image {
    margin-bottom: 8px; }
  .item-list .item-name {
    font-size: clamp(15px, 1.2vw, 1.8rem);
    text-align: center;
    line-height: 1.28;
    color: #fff;
    align-self: center;
    margin-top: 8px; }
    .item-list .item-name .aw {
      line-height: 1; }
  .item-list .text {
    margin-top: 12px; }
    .item-list .text .lead {
      font-size: clamp(13px, 1.1vw, 1.5rem);
      color: #fff;
      line-height: 1.8; }
  @media screen and (max-width: 600px) {
    .item-list {
      margin-top: 32px; } }

/******************************************************

each section

******************************************************/
.main {
  background-color: #1f2a46;
  padding-top: 56px;
  position: relative;
  overflow: hidden; }
  .main img {
    width: 100%;
    height: auto;
    line-height: 1; }
  .main .main-img {
    width: 100%;
    max-width: 1600px;
    margin: auto; }
    .main .main-img .img .note {
      right: auto;
      left: 1rem;
      bottom: 20%; }
  .main .main-title {
    width: 48%;
    max-width: 662px;
    position: absolute;
    left: 50%;
    top: 60%;
    transform: translateX(-50%); }
  .main .main-lead {
    padding: 0 16px;
    transform: translateY(-100%);
    position: relative;
    z-index: 3; }
    .main .main-lead .lead {
      font-size: clamp(16px, 1.6vw, 2rem);
      text-align: center;
      color: #fff; }
  @media screen and (max-width: 1440px) {
    .main .main-img .img .note {
      bottom: 16%; }
    .main .main-lead {
      transform: translateY(-72%); } }
  @media screen and (max-width: 1200px) {
    .main {
      padding-top: 136px; }
      .main .main-img .img img {
        transform: scale(1.2); }
      .main .main-img .note {
        bottom: 12%; }
      .main .main-title {
        top: 64%; }
      .main .main-lead {
        transform: translateY(-56%); } }
  @media screen and (max-width: 960px) {
    .main {
      padding-top: 200px;
      padding-bottom: 80px; }
      .main .main-img .img img {
        transform: scale(1.5); }
      .main .main-img .img .note {
        bottom: 1rem; }
      .main .main-title {
        width: 64%; }
      .main .main-lead {
        transform: none; } }
  @media screen and (max-width: 768px) {
    .main {
      padding-top: 120px; }
      .main .main-title {
        top: 60%; } }
  @media screen and (max-width: 600px) {
    .main {
      padding-top: 200px; }
      .main .main-img .img img {
        transform: scale(2.24); }
      .main .main-img .img .note {
        bottom: 26%; }
      .main .main-title {
        width: 84%;
        top: 60%; }
      .main .main-lead {
        transform: none;
        padding-top: 96px; } }
  @media screen and (max-width: 480px) {
    .main {
      padding-top: 184px; }
      .main .main-title {
        top: 56%; }
      .main .main-lead {
        padding-top: 80px; } }
  @media screen and (max-width: 380px) {
    .main {
      padding-top: 160px;
      padding-bottom: 64px; }
      .main .main-title {
        top: 52%; }
      .main .main-lead {
        padding-top: 56px; } }

.image-gallery .head {
  padding-top: 0;
  padding-bottom: 5.6rem; }
.image-gallery .images .image + .image {
  margin-top: 8rem; }
@media screen and (max-width: 960px) {
  .image-gallery .head {
    padding-bottom: 4rem; } }
@media screen and (max-width: 600px) {
  .image-gallery .images .image + .image {
    margin-top: 5.6rem; } }

#Cont-Quality .item-list {
  max-width: 800px; }
  #Cont-Quality .item-list > ul {
    grid-template-columns: repeat(2, 1fr);
    gap: 0 8%; }
    #Cont-Quality .item-list > ul .item-name {
      font-size: clamp(18px, 1.2vw, 1.8rem); }
@media screen and (max-width: 600px) {
  #Cont-Quality .item-list {
    width: 88%; }
    #Cont-Quality .item-list > ul {
      grid-template-columns: 1fr; } }

#Cont-Equipment .item-list {
  max-width: 960px; }
  #Cont-Equipment .item-list > ul {
    grid-template-columns: repeat(3, 1fr);
    gap: 0 5%; }
@media screen and (max-width: 600px) {
  #Cont-Equipment .item-list > ul {
    grid-template-columns: repeat(2, 1fr); } }

#Cont-Plan .plan-list {
  max-width: 960px;
  margin: 4rem auto 0; }
  #Cont-Plan .plan-list > ul {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: stretch;
    align-content: flex-start; }
    #Cont-Plan .plan-list > ul > li {
      width: 47%; }
      #Cont-Plan .plan-list > ul > li img {
        width: 100%;
        height: auto;
        line-height: 1; }
      #Cont-Plan .plan-list > ul > li a {
        display: block;
        width: 100%; }
        #Cont-Plan .plan-list > ul > li a .plan-fig {
          background-color: rgba(255, 255, 255, 0.75);
          position: relative; }
        #Cont-Plan .plan-list > ul > li a .plan-bg {
          width: 100%;
          height: 100%;
          background-color: #a18c64;
          transition: all .6s;
          position: absolute;
          left: 0;
          top: 0;
          mix-blend-mode: multiply; }
        #Cont-Plan .plan-list > ul > li a .type {
          width: 100%;
          position: absolute;
          left: 50%;
          top: 50%;
          transform: translate(-50%, -50%); }
        #Cont-Plan .plan-list > ul > li a:hover .plan-bg {
          background-color: rgba(161, 140, 100, 0); }
@media screen and (max-width: 600px) {
  #Cont-Plan .plan-list > ul > li {
    width: 100%; }
    #Cont-Plan .plan-list > ul > li + li {
      margin-top: 40px; } }

#Cont-Plan .plan-list2 {
  max-width: 660px;
  margin: 4rem auto 0; }
  #Cont-Plan .plan-list2 > ul {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: stretch;
    align-content: flex-start; }
    #Cont-Plan .plan-list2 > ul > li {
      width: 47%; }
      #Cont-Plan .plan-list2 > ul > li img {
        width: 100%;
        height: auto;
        line-height: 1; }
      #Cont-Plan .plan-list2 > ul > li a {
        display: block;
        width: 100%; }
        #Cont-Plan .plan-list2 > ul > li a img {
          transition: filter 0.5s; }
        #Cont-Plan .plan-list2 > ul > li a:hover img {
          filter: brightness(1.2); }
@media screen and (max-width: 600px) {
  #Cont-Plan .plan-list2 {
    max-width: 280px; }
    #Cont-Plan .plan-list2 > ul > li {
      width: 100%; }
      #Cont-Plan .plan-list2 > ul > li + li {
        margin-top: 40px; } }
