@charset "UTF-8";
/* * {outline: 1px solid magenta;} */
html {
    margin: 0 !important;
    padding: 0 !important;
}
body {
    width: 100%;
    overflow-x: hidden;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;/* iOSのスムーズスクロールを有効化 */
    -ms-scroll-chaining: none;/* スクロールのオーバーシュートを無効 */
    overscroll-behavior: none;/* スクロールのオーバーシュートを無効 */
    background-color: #fff;
    color: #333;
/*
    font-family: "Noto Sans", sans-serif;
    font-weight: 400;
*/
    font-size: 16px;
    line-height: 1.5;
    -ms-text-size-adjust: 100%;/* スマホでの自動文字サイズ調整を無効化 */
    -webkit-text-size-adjust: 100%;/* スマホでの自動文字サイズ調整を無効化 */
    text-rendering: geometricPrecision;/* フォントアンチエイリアスの調整 */
    -webkit-font-smoothing: antialiased;/* フォントアンチエイリアスの調整 */
    -moz-osx-font-smoothing: grayscale;/* フォントアンチエイリアスの調整 */
    -webkit-tap-highlight-color: rgba(0, 0, 0, .2);/* タップ時のハイライトを指定色に変更 */
}
.formbox { 
	width:80%;
	margin: 0 auto 0 auto;
}
.next-btn-002 {
    width: 90px;
    margin: 0 auto;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    display: inline-block;
    padding: 0 30px 10px;
    color: #09056F;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
  }
  
  .next-btn-002::after {
    content: '';
    position: absolute;
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 45px solid transparent;
    border-right: 45px solid transparent;
    border-top: 24px solid #09056F;
  }
  
  .btn-text {
    position: relative;
    font-size: 14px;
    font-weight: 300;
    z-index: 1;
  }

    .Close500 {
        display: block;
    }
    .Open500 {
        display: none;
    }
/* top-vew */
/* top-vew */
#TOPmode {
    display: block;
}
#TOP1024mode {
    display: none;
}
#top-vew {
    background: url(../images/top-texture003.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}
.top-vew {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100vh;
    /* アニメーション分余裕を持たせる */
}


/* 画像配置レイヤー */
.top-vew-overlay {
    /* position: absolute; */
    position: relative;
    overflow: hidden;
    z-index: 100;
    width: 100%;
    height: 100vh;
    font-size: 60px;
    font-weight: 700;
    color: #333;
}
.top-vew-logo {
    position: absolute;
    top: 30%;
    left: 10%;
    transform: translateY(-50%);
    width: 38%;
    max-width: 800px;
    height: auto;
}
.top-vew-logo img {
    width: 100%;
    max-width: 800px;
    height: auto;
}
.top-vew-ch {
    position: absolute;
    top: 50%;
    left: 10%;
    transform: translateY(-50%);
    width: 38%;
    max-width: 800px;
    height: auto;
}
.next-btn-001 {
    width: 90px;
    height: 30px;
    margin: 0 auto;
    position: absolute;
    z-index: 999;
    bottom: 50px;
    left: 50%;
    transform: translateX(-50%);
    display: inline-block;
    padding: 0 30px 10px;
    color: #09056F;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
  }
  .next-btn-001::after {
    content: '';
    position: absolute;
    z-index: 999;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 45px solid transparent;
    border-right: 45px solid transparent;
    border-top: 24px solid #09056F;
  }
.next-btn-001 .btn-text {
    z-index: 999;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    font-size: 14px;
    font-weight: 300;
    z-index: 1;
  }
/* アニメーション */
.top-vew-cut001 {
    position: absolute;
    top: -100px;
    right: -100px;
    height: 180px;
    width: 500px;
    background-color: #fff;
    transform: rotate(23deg);
}
.top-vew-cut002 {
    position: absolute;
    bottom: -50px;
    left: -50px;
    height: 80px;
    width: 200px;
    background-color: #fff;
    transform: rotate(23deg);
}
.top-info {
    position: absolute;
    z-index: 10;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 1520px;
    height: 100%;
    max-height: 96px;
    padding-bottom: 30px;
    box-sizing: border-box;
    background-color: #fff;
    font-size: 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
/* 布生地レイヤー */
.top-vew-top, .top-vew-mid, .top-vew-bottom {
    position: fixed;
    top: 0;
    right: 0;
    width: 200vw;
    max-width: 3800px;
    height: 100vh;
    background-size: cover;
    background-position: center;
    background-repeat: repeat-x;
    will-change: transform, opacity;
    transition: transform 0.1s linear, opacity 0.1s linear;
}
  
.top-vew-top {
    background: url(../images/top-texture003.jpg);
    /* background: url(../images/top-vew.jpg); */
    z-index: 3;
    background-size: cover;
    background-position: center;
}
.top-vew-mid {
    /* background: url(../images/top-texture002.jpg); */
    background: url(../images/top-texture003.jpg);
    z-index: 2;
}
.top-vew-bottom {
    /* background: url(../images/top-texture001.jpg); */
    background: url(../images/top-texture003.jpg);
    z-index: 1;
}
@media screen and (max-width: 1600px) {
.top-vew-item001 {
    /* キャッチコピー */
    position: absolute;
    top: 30%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
    font-size: 42px;
    text-align: center;
    line-height: 1;
    font-weight: 700;
    color: #fff;
}
.top-vew-item002 {
    /* ロゴ */
    position: absolute;
    top: 36%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 50;
    width: 520px;
}
.top-vew-item003 {
    position: absolute;
    top: 41.7%;
    left: 2.2%;
    z-index: 70;
    width: 320px;
    height: auto;
}

}
/* ----------- top-vew ---------- */
/* ----------- service ---------- */
.service .next-btn-002 {
    color: #fff;
    margin-top: 51px;
    margin-bottom: 26px;
}
.service .next-btn-002::after {
    border-top: 24px solid #02A0E8;
}
.service {
    position: relative;
    background-color: #00324D;
}
.service-style {
    width: 100%;
    max-width: 1410px;
    height: auto;
    margin: 0 auto;
    padding: 95px 0;
    box-sizing: border-box;
    color: #fff;
}
.service-style-001 {
    width: 100%;
    max-width: 960px;
    height: auto;
    margin: 0 auto;
    font-size: 23px;
    text-align: center;
}
.break {
  display: inline-block;
}
.service-style-002-title {
    font-size: 33px;
    font-weight: 500;
    text-align: center;
    margin: 90px auto 50px;
}
.service-style-002-01 {
    display: flex;
    gap: 50px;
}
.service-style-002-01 li {
    width: 100%;
    max-width: 440px;
    height: 570px;
    overflow: hidden;
}
.service-style-002-list-img {
    width: 100%;
    height: auto;
    aspect-ratio: 440 / 330;
    overflow: hidden;
}
.service-style-002-list-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.service-style-002-list-text {
    position: relative;
    width: 100%;
    max-height: 240px;
    height: 100%;
    color: #333;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0 30px;
    box-sizing: border-box;
    background-color: #fff;
}
.service-style-002-list-text-top {
    text-align: center;
    font-size: 32px;
    line-height: 1;
    font-weight: 400;
    margin-top: 0px;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 10px;
    padding-top: 0px;
    height: 35px;
}

.service-style-002-list-text-bottom {
    font-size: 14px;
    text-align: justify;
    line-height: 1.6;	
	margin-top: 0px;
}

.service-style-002-list-pic {
    position: absolute;
    bottom: 10px;
    display: flex;
    gap: 10px;
}
.service-style-002-list-pic li {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border: 2px solid #333333;
    height: 20px;
    width: 90px;
}
.service-style-002-list-pic li {
    font-size: 16px;
    height: 22px;
    width: 94px;
}
.service-style-003-01 {
    margin: 76px auto 20px;
    text-align: center;
    line-height: 1;
    font-weight: 400;
    display: block;
    height: 146px;
}
.text-item-001 {
    margin: 0 auto;
    text-align: center;
}
.service-style-003-01 .t01 {
    font-size: 29px;
    margin-bottom: 20px;
}
.service-style-003-01 .t02 {
    text-align: center;
    font-size: 50px;
}
.text-item-002 {
    margin: 0 auto;
    text-align: center;
}
.service-style-003-02 .t03 {
    font-size: 50px;
    font-weight: 400;
    margin: 0 auto;
    text-align: center;
}
.service-style-004 {
    margin-top: 30px;
    display: block;
    margin-bottom: 52px;
}
.service-style-004-01 {
    font-size: 33px;
    color: #FFFF00;
    text-align: center;
    margin: 40px auto 60px;
}
.service-style-004-02 ul {
    max-width: 1490px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}
.service-style-004-list {
    max-width: 480px;
    width: calc((100% - 40px) / 3);
    height: auto;
}
.service-style-004-list-img {
    position: relative;
    max-width: 480px;
    width: 100%;
    height: auto;
    aspect-ratio: 480 / 375;
    border-radius: 25px;
    overflow: hidden;
}
.service-style-004-list-img-text {
    font-size: 40px;
    line-height: 1;
    position: absolute;
    bottom: 20px;
    left: 20px;
    text-align: left;
}
.service-style-004-list-text {
    width: 100%;
    padding: 20px;
    box-sizing: border-box;
}
@media screen and (max-width: 1600px) {
.service-style-002-01 {
    display: flex;
    justify-content: center;
    gap: 20px;
}
.service-style-002-01 li {
    width: 100%;
    max-width: 320px;
    height: 480px;
    overflow: hidden;
}
.service-style-002-list-text-top {
    text-align: center;
    font-size: 24px;
    line-height: 1;
    font-weight: 400;
    margin: 0 auto 10px;
	padding-top:30px;
	height: 35px;

}
.service-style-002-list-text {
    position: relative;
    width: 100%;
    max-height: 240px;
    height: 100%;
    color: #333;
    /*display: flex;*/
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0 16px;
    box-sizing: border-box;
    background-color: #fff;
    display: block;
}
.service-style-002-list-pic {
    font-size: 14px;
    position: absolute;
    bottom: 10px;
    display: flex;
    gap: 10px;
}
.service-style-002-list-pic li {
    width: 60px;
    height: 20px;
    font-size: 14px;
}
.service-style-003-01 {
    margin: 76px auto 20px;
    text-align: center;
    line-height: 1;
    font-weight: 400;
}
.text-item-001 {
    margin: 0 auto;
    text-align: center;
}
.service-style-003-01 .t01 {
    font-size: 29px;
    margin-bottom: 20px;
}
.service-style-003-01 .t02 {
    text-align: center;
    font-size: 42px;
}
.text-item-002 {
    margin: 0 auto;
    text-align: center;
}
.service-style-003-02{
    padding-top: 40px;
    display: block;
}
.service-style-003-02 .t03 {
    font-size: 42px;
    font-weight: 400;
    margin: 0 auto;
    text-align: center;
}
.service-style-004-01 {
    font-size: 29px;
    color: #FFFF00;
    text-align: center;
    margin: 40px auto 60px;
}

.service-style-004-02 ul {
    max-width: 1200px;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    padding: 0 40px;
    box-sizing: border-box;
}
.service-style-004-list-img-text {
    font-size: 40px;
    line-height: 1;
    position: absolute;
    bottom: 20px;
    left: 20px;
    font-weight: 600;
    text-shadow: 2px 2px 2px #090909;
}
}

/* ----------- service ---------- */
/* ----------- space-area ---------- */
.space-area {
    background: url(../images/space-area-001.jpg);
    width: 100%;
    height: auto;
    aspect-ratio: 1920 / 440;
    overflow: hidden;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    font-size: 32px;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
/* ----------- space-area ---------- */
/* ----------- space-area ---------- */
.schedule {
    margin: 140px auto 200px;
}
.schedule-style-001 {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.schedule-style-001-001 {
    position: absolute;
    z-index: 100;
    left: 50%;
    transform: translateX(-50%);
    font-size: 40px;
    font-weight: 400;
    white-space: nowrap;
}
.schedule-style-001-break {
    display: none;
}
.schedule-style-001-002 {
    position: relative;
    left: -260px;
    width: 1250px;
    height: auto;
}
.schedule-style-001-003 {
    position: absolute;
    top: 50%;
    transform: translatey(-50%);
    left: 1000px;
    max-width: 582px;
    width: 100%;
    margin-top: 60px;
}
.schedule-style-001-003-text {
    font-size: 24px;
    font-weight: 400;
    line-height: 1.5;
}
.schedule-style-001-003-img {
    margin: 120px auto auto 30px;
}
.schedule-style-002 {
    position: relative;
    width: 100%;
    height: auto;
    padding: 40px 0 0;
    box-sizing: border-box;
}
/* 制作スケジュール */
.schedule-style-001-004 {
    font-size: 44px;
    font-weight: 400; 
    margin: 0 auto;
    text-align: center;
}
.flow-style {
  margin: 60px auto 60px;
}
.flow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px; /* 矢印含めた間隔調整 */
  padding-left: 0;
  list-style: none;
}

.flow > li {
  display: flex;
  justify-content: center;
  align-items: center;
}

.flow > li dl {
  width: 200px;
  height: 200px;
  padding: 30px 20px;
  margin: 0;
  border: 3px solid #02A0E8;
  border-radius: 100%;
  box-sizing: border-box;
  text-align: center;
}

.flow > li dl dt {
  font-size: 30px;
  font-weight: 600;
  margin-top: 20px;
  margin-bottom: 20px;
  color: #02A0E8;
}

.flow > li dl dd {
  font-size: 16px;
  color: #02A0E8;
}

/* 矢印用のli */
.flow > li.arrow {
  position: relative;
}

/* 矢印の装飾（斜めの線2本で矢印形） */
.flow > li.arrow::before,
.flow > li.arrow::after {
  content: "";
  position: absolute;
  width: 14px;
  height: 1px;
  background-color: #222;
  top: 50%;
  left: 7px;
  transform-origin: left center;
}

.flow > li.arrow::before {
  transform: rotate(135deg);
}

.flow > li.arrow::after {
  transform: rotate(225deg);
}

/* 制作スケジュール */
.contact-btn-002 {
    margin: 0 auto;
    color: #fff;
    font-size: 32px;
    background-color: #02A0E8;
    width: 545px;
    height: 80px;
    transition: background-color .4s;
    border: #02A0E8 solid 2px;
}
.contact-btn-002 a {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.contact-btn-002:hover {
    color: #02A0E8;
    background-color: #fff;
    border: #02A0E8 solid 2px;
}
.schedule-text {
    font-size: 26px;
    text-align: center;
    margin: 30px auto 40px;
}
.schedule-contact {
    margin-bottom: 200px;
}
@media screen and (max-width: 1600px) {
    .schedule {
    margin: 100px auto 80px;
    }
    .schedule-contact {
    margin-bottom: 160px;
    }
    .schedule-style-001-001 {
        font-size: 32px;
    }
    .schedule-style-001-002 {
        position: relative;
        left: -180px;
        width: 900px;
        height: auto;
    }
    .schedule-style-001-003 {
        right: 0;
        left: auto;
        margin-right: 60px;
    }
    .schedule-style-001-003-text {
        font-size: 20px;
    }
    .schedule-style-001-003-img {
        margin: 60px auto auto 30px;
    }
    .schedule-style-001-004 {
    font-size: 32px;
    }
}
@media screen and (max-width: 1200px) {
.schedule-style-flow {
    margin: 40px auto 60px;
    box-sizing: border-box;
}
.schedule-style-flow .flow > li dl {
    width: 150px;
    height: 150px;
    padding: 15px 10px;
    margin: 0;
    border: 2px solid #02A0E8;
}

/* .schedule-style-flow .flow > li:not(:first-child) dl::before {
    content: "";
    width: 14px;
    height: 14px;
    margin-right: 10px;
    display: inline-block;
    border-top: 1px solid #222;
    border-right: 1px solid #222;
    position: absolute;
    top: calc(50% - 8px);
    left: -35px;
    transform: rotate(45deg);
} */
.schedule-style-flow .flow > li dl dt {
    font-size: 24px;
    margin-top: 26px;
    margin-bottom: 6px;
    text-align: center;
}
.schedule-style-flow .flow > li dl dd {
    font-size: 14px;
}
.contact-btn-002 {
    margin: 0 auto;
    color: #fff;
    font-size: 28px;
    background-color: #02A0E8;
    width: 300px;
    height: 60px;
}
}
/* ----------- special-area ---------- */
/* ----------- special-area ---------- */
.special-style-001-title {
    max-width: 1135px;
    width: 100%;
    margin-bottom: 86px;
    margin-left: 0;
}
.special-style-001-title-01 {
    padding-right: 210px;
    text-align: center;
    font-size: 40px;
    border-bottom: #333 1px solid;
}
.special-style-001-title-02 {
    padding-left: 120px;
    text-align: center;
    font-size: 24px;
    margin-top: 16px;
}

.special-style-002-1 {
    max-width: 1200px;
    width: 90%;
    height: 257px;
    padding: 30px 0;
    background-color: #1A3E76;
    color: #fff;
    font-size: 26px;
    margin-left: 0;
    margin-right: auto;
    margin-bottom: 15px;
}
.special-style-002-1 .wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.special-style-002-1-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 90%;
    text-align: end;
    margin: auto;
}
.special-style-002-1-img {
    width: 100%;
    max-width: 1040px;
    aspect-ratio: 1040 / 157;
    height: auto;
    margin-left: 0;
    margin-right: auto;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.special-style-002-1-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.special-style-002-2 {
    max-width: 1200px;
    width: 90%;
    height: 257px;
    padding: 30px 0;
    background-color: #1A3E76;
        color: #fff;
        font-size: 26px;
    margin-left: auto;
    margin-right: 0;
    margin-bottom: 15px;
}
.special-style-002-2 .wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.special-style-002-2-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 90%;
    text-align: end;
    margin: auto;
}
.special-style-002-2-img {
    width: 100%;
    max-width: 730px;
    aspect-ratio: 730 / 157;
    height: auto;
    margin-left: auto;
    margin-right: 100px;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.special-style-002-2-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.special-style-002-3 {
    max-width: 1200px;
    width: 90%;
    height: 257px;
    padding: 30px 0;
    background-color: #1A3E76;
    color: #fff;
    font-size: 26px;
    margin: 0 auto;
}
.special-style-002-3 .wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.special-style-002-3-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 90%;
    margin: auto;
}
.special-style-002-3-img {
    width: 100%;
    max-width: 940px;
    aspect-ratio: 940 / 157;
    height: auto;
    margin-left: auto;
    margin-right: 100px;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.special-style-002-3-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.special-style-002-4 {
    max-width: 1600px;
    width: 100%;
    margin: 60px auto 138px;
    text-align: end;
    font-size: 45px;
}

/* オリジナル製品ボタン */
.special-style-002-5 {
  position: relative;
  max-width: 1700px;
  aspect-ratio: 1500/247;
  width: 80%;
  overflow: hidden;
  margin: 0 auto 0px;
  border: #00324D 1px solid;
}
.special-style-002-5 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.special-style-002-5::before,
.special-style-002-5::after,
.special-style-002-5 span::before,
.special-style-002-5 span::after {
  content: "";
  position: absolute;
  background: #00324D;
  transition: all 0.4s ease;
}
/* 上線 */
.special-style-002-5::before {
  height: 2px;
  width: 0;
  top: 0;
  left: 0;
}
/* 右線 */
.special-style-002-5::after {
  width: 2px;
  height: 0;
  top: 0;
  right: 0;
}
/* 下線 */
.special-style-002-5 span::before {
  height: 2px;
  width: 0;
  bottom: 0;
  right: 0;
}
/* 左線 */
.special-style-002-5 span::after {
  width: 2px;
  height: 0;
  bottom: 0;
  left: 0;
}
/* ホバー時の動き */
.special-style-002-5 a:hover{
    opacity: 1;
}
/* 上線 */
.special-style-002-5:hover::before {
    width: 100%;
}
/* 右線 */
.special-style-002-5:hover::after {
    height: 100%;
}
/* 下線 */
.special-style-002-5:hover span::before {
    width: 100%;
}
/* 左線 */
.special-style-002-5:hover span::after {
    height: 100%;
}
.special-style-002-5 span {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
/* オリジナル製品ボタンここまで */



@media screen and (max-width: 1600px) {
    .special-style-001-title-01 {
    font-size: 32px;
}
    .special-style-001-title {
    max-width: 1135px;
    width: 100%;
    margin-bottom: 48px;
    margin-left: 0;
}
.special-style-002-1 {
    max-width: 1200px;
    width: 90%;
    height: 200px;
    padding: 30px 0;
    background-color: #1A3E76;
    color: #fff;
    font-size: 26px;
    margin-left: 0;
    margin-right: auto;
    margin-bottom: 15px;
}
.special-style-002-2 {
    max-width: 1200px;
    width: 90%;
    height: 200px;
    padding: 30px 0;
    background-color: #1A3E76;
    color: #fff;
    font-size: 26px;
    margin-left: auto;
    margin-right: 0;
    margin-bottom: 15px;
}
.special-style-002-3 {
    max-width: 1200px;
    width: 90%;
    height: 200px;
    padding: 30px 0;
    background-color: #1A3E76;
    color: #fff;
    font-size: 26px;
    margin-left: 0;
    margin-right: auto;
    margin-bottom: 15px;
}
.special-style-002-4 {
    max-width: 1280px;/* padding分 */
    width: 100%;
    margin: 60px auto 138px;
    padding: 0 40px;
    box-sizing: border-box;
    text-align: end;
    font-size: 40px;
}
}
/* ----------- company ---------- */
/* ----------- company ---------- */
.company {
    margin: 60px auto 190px;
}
.company-style-001-text {
    font-size: 28px;
    text-align: center;
    margin-top: 0px;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 40px;
	padding-top: 100px;
}
.company-style-001-map {
    position: relative;
    max-width: 1480px;
    width: 100%;
    margin: 60px auto 138px;
    padding: 0 40px 300px;
    box-sizing: border-box;
}
.company-style-001-logo {
    width: 100%;
    max-width: 275px
}
.company-style-001-map-text {
    display: flex;
    flex-direction: column;
    gap: 50px;
    margin-top: 60px;
    margin-left: 30px;
}
.company-style-001-flex {
    display: flex;
    gap: 5px;
}
/* フェードイン＋左から右へ移動 */
@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translateX(-50px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
.company-style-001-flex {
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.company-style-001-flex.is-visible {
  animation: fadeInRight 0.6s forwards;
}

.company-style-001-border {
    color: rgb(0, 113, 188);
    font-size: 16px;
    font-weight: 700;
    padding-left: 12px;
    padding-bottom: 4px;
    margin-bottom: 8px;
    border-bottom: #000 solid 1px;
    width: 470px;
}
.company-style-001-name {
    padding-left: 12px;
}
.company-location {
    display: flex;
    align-items: center;
    gap: 5px; 
    margin-top: 16px;
    padding-left: 12px;
    font-size: 12px;
}
.company-location img {
    height: 18px;
    width: auto;
}
.company-data {
    font-size: 14px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.company-back {
    position: absolute;
    z-index: -1;
    right: 0;
    bottom: 0;
    width: 900px;
    height: auto;
}
.company-back img {
    width: 900px;
    height: auto;
}
.company-style-002-client-title {
    font-size: 27px;
    text-align: center;
    margin: 0 auto 50px;
}
.company-style-002-client {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    max-width: 1300px;
    margin: 0 auto;
}
.company-style-002-client li {
    width: 325px;
    padding-left: 24px;
    padding-bottom: 20px;
    box-sizing: border-box;
}
.company-style-002-client .client-w {
    width: 487.5px;
}
@media screen and (max-width: 1400px) {
    .company-style-002-client {
        max-width: 975px;
}
}
@media screen and (max-width: 1200px) {
    .company-style-002-client {
        max-width: 650px;
}
}
/* ------------------------------------------------------- custom-ware */
/* custom-ware ------------------------------------------------------ */
/* ----------- custom-top-vew ---------- */
/* ----------- custom-top-vew ---------- */
.custom-top-vew {
    position: relative;
    height: 100vh;
    width: 100%;
    /* overflow-x: hidden; */
}
.custom-top-back {
    position: absolute;
    right: 0;
    top: 70%;
    transform: translatey(-50%);
    height: 950px;
    width: 2348px;
    background: url(../images/custom-top-vew-back.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}
.custom-top-001 {
    width: 1000px;
    position: absolute;
    top: 7.4%;
    right: -10.4%;
        opacity: 0;
        animation: fadeUp 1s ease forwards;
        animation-delay: 0.2s;
}
@keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.custom-top-001-cover {
    width: 100%;
    position: absolute;
    bottom: 0;
}
.custom-top-text {
    max-width: 1680px;
    width: 100%;
    height: 100%;
    margin: auto;
    padding: 0 40px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
}
.custom-top-text-inn {
    position: relative;
    z-index: 50;
    max-width: 690px;
    width: 100%;
    /* width: 36%; */
    margin-left: 0;
}
.custom-top-text001 {
    font-size: 84px;
    color: #6F1A1A;
    line-height: 1.0;
}
.custom-top-text002 {
    font-size: 25px;
    color: #000;
    margin: 60px auto 150px;
}
.custom-top-text003 {
    font-size: 37px;
    color: #0D1577;
            opacity: 0;
        animation: fadeUp 1s ease forwards;
        animation-delay: 0.6s;
}
@media screen and (max-width: 1600px) {
    .custom-top-001 {
        width: 900px;
        position: absolute;
        top: 7.4%;
        right: -10.4%;
    }
    .custom-top-text001 {
        font-size: 72px;
    }
    .custom-top-text003 {
        font-size: 30px;
    }
    }
@media screen and (max-width: 1400px) {
.custom-top-001 {
    width: 800px;
}
}
/* ----------- case ---------- */
/* ----------- case ---------- */
.case {
    position: relative;
    z-index: 99;
    width: 100%;
    height: 100%;
    /* background-color: #fff; */
}
.case-inn-top {
    font-size: 37px;
    color: #0D1577;
    max-width: 1680px;
    width: 100%;
    margin: 40px auto 50px;
    padding: 0 40px;
    box-sizing: border-box;
}
.case-list {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    max-width: 1680px;
    width: 100%;
    margin: 0 auto 120px;
    padding: 0 40px;
    box-sizing: border-box;
}
.case-list li {
    width: calc((100% - 60px) / 4); /* gapが20px×(4-1)=60px */
    max-width: 390px;
    aspect-ratio: 390 / 290;
    border-radius: 10px;
    overflow: hidden;
}
.case-list li img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
@media screen and (max-width: 1600px) {
    .case-list {
    gap: 20px;
    max-width: 1210px;
    width: 100%;
    margin: 0 auto 120px;
    padding: 0 40px;
    box-sizing: border-box;
}
.case-list li {
    width: calc((100% - 40px) / 3);
    max-width: 390px;
    aspect-ratio: 390 / 290;
    border-radius: 10px;
    overflow: hidden;
}
}
/* ----------- original ---------- */
/* ----------- original ---------- */
.schedule-flow {
    padding: 0 10px;
}
.original {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.original-back-01 {
    width: 740px;
    position: absolute;
    z-index: -1;
    left: 0;
    top: 50%;
    transform: translatey(-50%);
}
.original-back-02 {
    width: 916px;
    position: absolute;
    z-index: -1;
    right: 0;
    top: 50%;
    transform: translatey(-50%);
}
.original-001-img {
    position: relative;
    left: -3%;
    width: 67%;
    max-width: 1320px;
    height: auto;
    aspect-ratio: 1320 / 380;
    border-radius: 15px;
    overflow: hidden;
}
.original-001-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.original-002 {
    display: flex;
    align-items: center;
    gap: 50px;
    margin: 40px auto 100px;
    padding: 0 40px;
    box-sizing: border-box;
}
.original-002-img {
    width: 100%;
    max-width: 490px;
    height: auto;
    aspect-ratio: 490 / 220;
    overflow: hidden;
    margin: 0 9%;
}
.original-002-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.original-002-text-01 {
    font-size: 40px;
    color: #0D1577;
}
.original-002-text-02 {
    font-size: 30px;
    color: #0D1577;
}
.original-003 {
    display: flex;
    /* align-items: center; */
    justify-content: space-between;
    /* padding-left: 40px; */
    box-sizing: border-box;
}
.original-003-img {
    position: relative;
    left: 7.5%;
}
.original-003-text {
    font-size: 42px;
    color: #0D1577;
    margin: 26px auto 0;
    padding-left: 40px;
    box-sizing: border-box;
}
.original-003-text-01 {
    font-size: 40px;
    color: #0D1577;
}
.original-003-text-02 {
    font-size: 30px;
    color: #0D1577;
    text-align: left;
    width: 100%;
    box-sizing: border-box;
}
.original-004 {
    width: 100%;
    margin-top: 20px;
}
.original-004-img {
    margin-left: auto;
    margin-right: 0;
    width: 46%;
    max-width: 900px;
    height: auto;
    aspect-ratio: 900 / 362;
    overflow: hidden;
    margin-right: 0;
}
.original-004-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
@media screen and (max-width: 1600px) {
    .original-002-text-01 {
        font-size: 36px;
        color: #0D1577;
    }
    .original-002-img {
        max-width: 400px;
    }
    .original-002-text-02 {
        font-size: 24px;
        color: #0D1577;
    }
    .original-003-text {
        font-size: 36px;
    }
    .original-003-text-02 {
        font-size: 24px;
        color: #0D1577;
    }
}

/* ------------------------------------------------------- facilities */
/* facilities ------------------------------------------------------ */
/* ----------- facilities-top-vew ---------- */
/* ----------- facilities-top-vew ---------- */


/* ----------- facilities-about ---------- */
.facilities-top-vew {
    height: 200px;
    width: 100%;
	background-color: #0B083F;
}
.test-top-vew {
    height: 200px;
    width: 100%;
	background-color: #115F90;
}

#facilities-about {
  /* background: url(../images/facilities-back.jpg) no-repeat center center; */
  background-size: cover;
  background-attachment: fixed; /* 背景を固定 */
  background-position: center;
  padding: 50px 0; /* 上下の余白。必要に応じて調整 */
  box-sizing: border-box;
}

.facilities-about {
  max-width: 1410px;
  width: 100%;
  margin: 0 auto;
  padding: 0 0 200px;
  box-sizing: border-box;
}

/* 各figureも背景の前にしっかり表示するため */
.facilities-about figure {
  position: relative;
  z-index: 2;
}

.facilities-title {
    font-size: 36px;
    font-weight: 500;
    padding: 70px 0;
}
.about-machine {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 20px;
    line-height: 1;
}
.about-machine-02 {
    font-weight: 300;
    font-size: 0.7em;
}
.about-ruby {
    color: #09056F;
    font-size: 14px;
}
.facilities-about-001 {
    width: 100%;
    display: flex;
    gap: 50px;
    align-items: center;
    justify-content: center;
    /* margin: 80px auto; */
    padding: 100px 0;
    border-top: #999 solid 1px;
    border-bottom: #999 solid 1px;
    box-sizing: border-box;
}
.facilities-about-001-img {
    width: 530px;
    /* width: 100%; */
    /* max-width: 530px; */
    height: auto;
    aspect-ratio: 530 / 330;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.facilities-about-001-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.facilities-about-001-text li {
    width: 445px;
}
.facilities-about-001-text ul {
    display: flex;
    gap: 50px;
}
.about-contest {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.facilities-about-002 {
    width: 100%;
    display: flex;
    gap: 50px;
    align-items: center;
    /* justify-content: center; */
    justify-content: end;
    /* margin: 80px auto; */
    padding: 100px 0;
    border-bottom: #999 solid 1px;
    box-sizing: border-box;
}
.facilities-about-002-img {
    width: 100%;
    max-width: 440px;
    height: auto;
    aspect-ratio: 440 / 270;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.facilities-about-002-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.facilities-about-002-text {
    width: 870px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.facilities-about-002-text ul {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.facilities-about-003 {
    width: 100%;
    display: flex;
    gap: 50px;
    align-items: center;
    /* justify-content: center; */
    justify-content: left;
    /* margin: 80px auto; */
    padding: 100px 0;
    border-bottom: #999 solid 1px;
    box-sizing: border-box;
}
.facilities-about-003-img {
    width: 100%;
    max-width: 430px;
    height: auto;
    aspect-ratio: 430 / 270;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.facilities-about-003-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.facilities-about-003-text {
    width: 870px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.facilities-about-003-text ul {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.facilities-about-004 {
    width: 100%;
    display: flex;
    gap: 50px;
    align-items: center;
}
.facilities-about-004 {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    /* margin: 80px auto; */
    padding: 100px 0;
    border-bottom: #999 solid 1px;
    box-sizing: border-box;
}
.facilities-about-004-img {
    width: 530px;
    /* width: 100%; */
    /* max-width: 530px; */
    height: auto;
    aspect-ratio: 530 / 330;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.facilities-about-004-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.facilities-about-004-text ul {
    display: flex;
    gap: 50px;
}
.facilities-about-004-text li {
    width: 445px;
}

.facilities-about-005 {
    width: 100%;
    display: flex;
    gap: 50px;
    align-items: center;
    /* margin: 80px auto; */
    padding: 100px 0;
    border-bottom: #999 solid 1px;
    box-sizing: border-box;
}
.facilities-about-005 {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.facilities-about-005-img {
    width: 530px;
    /* width: 100%; */
    /* max-width: 530px; */
    height: auto;
    aspect-ratio: 530 / 330;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.facilities-about-005-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.facilities-about-005-text ul {
    display: flex;
    gap: 50px;
}
.facilities-about-005-text li {
    width: 445px;
}

.facilities-list {
    max-width: 1490px;
    width: 100%;
    margin: 0 auto;
    padding: 0 20px 200px;
    box-sizing: border-box;
}

.table-flex {
    display: flex;
    justify-content: center;
    gap: 40px;
}
.table-wrap {
  width: 100%;
  max-width: 640px;
  /* margin: 20px auto; */
}
.table-row {
  display: flex;
  padding: 8px 0;
}
.cell.item {
  width: 285px;
  padding: 8px;
  box-sizing: border-box;
  font-weight: 700;
}
.cell.group {
  display: flex;
  flex: 1;
}
.cell.group .sub {
  flex: 1;
  padding: 8px;
  box-sizing: border-box;
}





@media screen and (max-width: 1600px) {
    .about-contest {
    display: contents;
    }
    .facilities-about-001-text ul {
    display: flex;
    flex-direction: column;
    gap: 20px;
    }
    .facilities-about-002-text {
        max-width: 650px;
        width: 100%;
    }
    .facilities-about-003-text {
        max-width: 650px;
        width: 100%;
    }
    .facilities-about-004-text ul {
    display: flex;
    flex-direction: column;
    gap: 20px;
    }
    .facilities-about-005-text ul {
    display: flex;
    flex-direction: column;
    gap: 20px;
    }
    .facilities-about {
    padding: 0 20px; /* 上下の余白。必要に応じて調整 */
    box-sizing: border-box;
    }
    .facilities-title {
    font-size: 36px;
    font-weight: 500;
    padding: 70px 30px;
}
}
@media screen and (max-width: 1490px) {
    .table-flex {
        display: flex;
        flex-direction: column;
        gap: 0;
    }
    .table-row {
        display: flex;
        padding: 0 0 8px;
    }
    .table-row:nth-child(1) {
        font-size: 20px;
        padding: 0 0 8px;
    }
    .cell.group .sub {
        flex: 1;
        padding: 0px;
        box-sizing: border-box;
    }
    .cell.item {
        width: 285px;
        padding: 0px;
        box-sizing: border-box;
        font-weight: 700;
    }

    .table-wrap {
        width: 100%;
        max-width: 705px;
        margin: 0px auto;
    }
    .column-none {
        display: none;
    }
}
@media screen and (max-width: 1070px) {
    .facilities-about-001-img {
        width: 100%;
        max-width: 530px;
        height: auto;
        aspect-ratio: 530 / 330;
        overflow: hidden;
        position: relative;
        object-fit: cover;
    }
    .facilities-about-001-text {
        max-width: 445px;
        width: 100%;
    }
    .facilities-about-001-text li {
        width: 100%;
    }
    .facilities-about-004-img {
        width: 100%;
        max-width: 530px;
        height: auto;
        aspect-ratio: 530 / 330;
        overflow: hidden;
        position: relative;
        object-fit: cover;
    }
    .facilities-about-004-text {
        max-width: 445px;
        width: 100%;
    }
    .facilities-about-004-text li {
        width: 100%;
    }
    .facilities-about-005-img {
        width: 100%;
        max-width: 530px;
        height: auto;
        aspect-ratio: 530 / 330;
        overflow: hidden;
        position: relative;
        object-fit: cover;
    }
    .facilities-about-005-text {
        max-width: 445px;
        width: 100%;
    }
    .facilities-about-005-text li {
        width: 100%;
    }
    .facilities-about-001 {
        flex-direction: column;
    }
    .facilities-about-002 {
        flex-direction: column;
    }
    .facilities-about-003 {
        flex-direction: column;
    }
    .facilities-about-004 {
        flex-direction: column;
    }
    .facilities-about-005 {
        flex-direction: column;
    }
}

/* ------------------------------------------------------- company.html */
/* company.html ------------------------------------------------------ */
/* ----------- company-top-vew ---------- */
/* ----------- company-top-vew ---------- */
.Sawarabi {
    font-family: "Sawarabi Mincho", serif;
    font-weight: 400;
    font-style: normal;
}
.Notosans {
    font-family: "Noto Sans", sans-serif;
}
.company-top-vew {
    height: 300px;
    width: 100%;
	background-color: #0B083F;
}
.company-about {
  max-width: 1490px;
  width: 100%;
  margin: 0 auto;
    /* margin-left: 0;
    margin-right: auto; */
  padding: 0 0 200px;
  box-sizing: border-box;
}
.company-prof-title {
    color: #707070;
    font-size: 46px;
    text-align: center;
}
.company-about-flex {
    display: flex;
    justify-content: center;
	margin-top:50px;
}
.company-prof-table {
    display: flex;
    flex-direction: column;
    gap: 40px;
    width: 100%;
    padding: 60px 100px;
    box-sizing: border-box;
}
.company-prof-table li {
    display: flex;
}
.company-prof-item01 {
    display: flex;
}
.company-prof-item01-post {
    width: 160px;
}
.company-prof-name {
    width: 230px;
}

.company-history {
    box-sizing: border-box;
}
.company-history-vew {
    display: flex;
    gap: 20px;
    padding: 90px 50px;
}
.company-history-vew-img {
    max-width: 330px;
    width: 100%;
    height: 100%;
    aspect-ratio: 330 / 230;
    background-color: #000;
    overflow: hidden;
    position: relative;
    object-fit: cover;
}
.company-history-vew-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.company-history-cont {
    font-weight: 500;
    padding: 20px 50px;
}
.company-history-cont-title {
    font-size: 38px;
    color: #707070;
    margin-bottom: 10px;
}
.company-history-cont-title span {
    margin: 0 60px;
    font-size: 32px;
}
.company-history-flex {
    display: flex;
    gap: 20px;
}
.company-history-no {
    display: flex;
    flex-direction: column;
    gap: 50px;
    margin: 100px 0 70px;
    color: #1395fe;
}
.company-history-line {
    display: flex;
    flex-direction: column;
    position: relative;
    padding: 100px 0 0;
}
.company-history-line li {
    width: 20px;
    border-bottom: #1395fe solid 1px;
}
.company-history-line li:nth-child(1) {
    position: relative;
    top: 10px;
}
.company-history-line li:nth-child(2) {
    position: relative;
    top: 84px;
}
.company-history-line li:nth-child(3) {
    position: relative;
    top: 158px;
}
.company-history-line li:nth-child(4) {
    position: relative;
    top: 232px;
}
.company-history-line li:nth-child(5) {
    position: relative;
    top: 304px;
}
.company-history-line li:nth-child(6) {
    position: relative;
    top: 376px;
}
.company-history-line::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 1.5px;
    height: 100%;
    background-color: #1395fe;
    z-index: 0;
}
.company-history-item {
    margin: 20px 0;
    line-height: 1.7;
}
.company-history-item li:nth-child(1) {
    position: relative;
    top: 20px;
    margin: 20px 0;
}
.company-history-item li:nth-child(2) {
    position: relative;
    top: 20px;
}
.company-history-item li:nth-child(3) {
    position: relative;
    top: 128px;
}
.company-history-item li:nth-child(4) {
    position: relative;
    top: 180px;
}
.company-history-item li:nth-child(5) {
    position: relative;
    top: 200px;
}
.company-history-item02 {
    color: rgb(0, 113, 188);
    font-size: 16px;
    font-weight: 700;
    margin-left: 140px;
}
@media screen and (max-width: 1420px) {
    .company-about-flex {
        max-width: 768px;
        margin: 0 auto;
        padding: 0 20px;
        box-sizing: border-box;
        flex-direction: column;
    }
    .company-prof-name {
        width: 200px;
    }
}

/* ------------------------------------------------------- ear-pad.html */
/* ear-pad.html ------------------------------------------------------ */
/* ----------- ear-pad-top-vew ---------- */
/* ----------- ear-pad-top-vew ---------- */

.ear-pad-top-vew {
    position: relative;
    height: 100vh;
    width: 100%;
    background-color: #111;
    color: #fff;
    overflow: hidden;
}
.ear-pad-top-vew .next-btn-001::after {
    content: '';
    position: absolute;
    z-index: 999;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 45px solid transparent;
    border-right: 45px solid transparent;
    border-top: 24px solid #ffffff;
}
.ear-pad-top-vew-img {
    position: absolute;
    right: -120px;
    bottom: 0;
    max-width: 1000px;
    width: 100%;
    height: auto;
}
.ear-pad-top-vew-img img {
    max-width: 1000px;
    width: 100%;
    height: auto;
}
.ear-pad-top-vew-title {
    position: absolute;
    top: 24%;
    margin-left: 10%;
}
.ear-pad-top-vew-title-001 {
    font-size: 7vw;
    line-height: 1;
    color: yellow;
}
.ear-pad-top-vew-title-002 {
    font-size: 2.4vw;
    line-height: 1;
}
.ear-pad-top-vew-sub {
    position: absolute;
    bottom: 24%;
    margin-left: 10%;
    font-size: 1.6vw;
}
.ear-pad-top-vew-sub-001 {
    font-size: 1.6em;
}
.ear-pad-top-vew-sub-001 span {
    color: yellow;
}
.ear-pad-top-vew-sub-002 {
    margin-left: 10%;
    white-space: nowrap;
}
#ear-pad-about {
    background-color: #111;
}
.ear-pad-about {
    max-width: 1490px;
    width: 100%;
    margin: 0 auto;
    padding: 80px 0;
    box-sizing: border-box;
    color: #fff;
}
.ear-pad-abou-list001 {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin-bottom: 40px
}
.ear-pad-abou-list001 li {
    display: flex;
    align-items: end;
    width: calc( 50% - 80px );
}
.ear-pad-abou-list002 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 5%;
}
.ear-pad-abou-list001 .ear-pad-abou-list-img {
    position: relative;
    max-width: 300px;
    width: 100%;
    height: auto;
    aspect-ratio: 300 / 400;
    overflow: hidden;
}
.ear-pad-abou-list002 .ear-pad-abou-list-img {
    position: relative;
    max-width: 400px;
    width: 100%;
    height: auto;
    aspect-ratio: 400 / 300;
    overflow: hidden;
}
.ear-pad-abou-list-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.ear-pad-abou-list-text {
    margin-top: 20px;
    text-align: center;
}
@media screen and (max-width: 1455px) {
    .ear-pad-abou-list001 li {
    display: flex;
    align-items: center;
    flex-direction: column;
    width: calc( 50% - 80px );
}
}

#ear-pad {
    background-color: #111;
}
.ear-pad {
    max-width: 1490px;
    width: 100%;
    margin: 0 auto;
    padding: 80px 0;
    box-sizing: border-box;
    color: #fff;
}
.ear-pad-list {
    display: flex;
    justify-content: center;
    gap: 10px;
}
.ear-pad-list-img {
    position: relative;
    max-width: 330px;
    width: 100%;
    height: auto;
    aspect-ratio: 330 / 670;
    overflow: hidden;
	margin: 0 3px 0 3px;
}

.ear-pad-list-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

#maker-brand {
    background-color: #111;
}
.maker-brand {
    max-width: 1490px;
    width: 100%;
    margin: 0 auto;
    padding: 80px 0;
    box-sizing: border-box;
    color: #fff;
}
.maker-brand-title {
    margin: 40px auto 100px;
    text-align: center;
    font-size: 24px;
    box-sizing: border-box;
}
.maker-brand-list {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    max-width: 1300px;
    margin: 0 auto;
}
.maker-brand-list li {
    width: 325px;
    text-align: left;
    padding-left: 24px;
    padding-bottom: 20px;
    box-sizing: border-box;
}
.maker-brand-list li a {
    text-align: left;
}
