/*=============================================
 * body
 *=============================================*/
body {
  background: #f8f8f8;
  color: #202945;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-size: 17px;
  line-height: 29px;
  letter-spacing: 0;
  min-width: inherit;
  min-height: inherit;
  max-height: 100%;
  word-break: break-word; }

@media screen and (max-width: 767px) {
  body {
    font-size: 14px;
    line-height: 22px; } }
/*=============================================
 * <main>
 *=============================================*/
main {
  clear: both;
  width: 100%;
  box-sizing: border-box;
  position: relative;
  margin: 0;
  padding: 0; }

/* =============================================
 * Custom
*=============================================*/
.h-20 {
  font-weight: 700;
  font-size: 20px;
  line-height: 30px; }

.h-22 {
  font-weight: 700;
  font-size: 22px;
  line-height: 32px; }

.h-30 {
  font-weight: 700;
  font-size: 30px;
  line-height: 45px; }

.h-32 {
  font-weight: 700;
  font-size: 32px;
  line-height: 40px; }

@media screen and (max-width: 767px) {
  .h-22 {
    font-size: 18px;
    line-height: 26px; }

  .h-30 {
    font-size: 20px;
    line-height: 30px; } }
/* button */
.button {
  position: relative; }

.button a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 427px;
  height: 87px;
  background: linear-gradient(135deg, #BDD712 0%, #12B8D7 29%, #489EDF 71%, #7C24E1 100%);
  background-size: 150% 100%;
  background-position: center;
  color: #fff;
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.03em;
  line-height: 32px;
  box-sizing: border-box;
  padding: 0 24px;
  position: relative;
  z-index: 1;
  border-radius: 50px;
  box-shadow: 0 6px 9px rgba(0, 0, 0, 0.13); }
  .button a:hover {
    background-size: 100% 100%;
    opacity: 1; }

@media screen and (max-width: 767px) {
  .button a {
    width: 100%;
    height: 70px;
    font-size: 18px; } }
/* -- -- */
.txt-udl {
  text-decoration: underline; }

a.txt-udl:hover {
  text-decoration: none; }

.txt-c {
  text-align: center; }

.txt-j {
  text-align: justify; }

.txt-r {
  text-align: right; }

.cl-blue {
  color: #3D9FCA; }

.cl-green {
  color: #96BE31; }

.cl-red {
  color: #BD1B21; }

.cl-yellow {
  color: #FFB357; }

.cl-brown {
  color: #634C2E; }

.cl-white {
  color: #fff; }

.cl-orange {
  color: #E64900; }

.udl01 {
  background-image: linear-gradient(#FEFA7F, #FEFA7F);
  background-size: 100% 10px;
  background-repeat: no-repeat;
  background-position: left bottom; }

.fw-r {
  font-weight: 400; }

.fw-m {
  font-weight: 500; }

.fw-b {
  font-weight: 700; }

.fw-black {
  font-weight: 900; }

.bdra-10 {
  border-radius: 10px; }

.bdra-20 {
  border-radius: 20px; }

.bdra-30 {
  border-radius: 30px; }

.img_shadow {
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.05); }

.img-obj {
  width: 100%;
  max-width: inherit;
  height: 100%;
  object-fit: cover; }

@media screen and (max-width: 767px) {
  .bdra-20 {
    border-radius: 10px; }

  .bdra-30 {
    border-radius: 15px; } }
/* -- -- */
.img-zoom,
.img-zoom figure {
  display: block;
  overflow: hidden; }

.img-zoom .img,
.img-zoom .img-obj {
  transition: 0.6s ease-in-out; }

.img-zoom:hover .img,
.img-zoom:hover .img-obj {
  transform: scale(1.07); }

/* -- --*/
.filter-gray {
  filter: grayscale(100%);
  cursor: pointer;
  transition: all 0.3s; }

.filter-gray:hover {
  filter: grayscale(0); }

/* -- --*/
.photo-full img {
  width: 100%;
  max-width: inherit; }

@media screen and (max-width: 767px) {
  .photo-full {
    width: 100%;
    height: 60vw; }

  .photo-full img {
    height: 100%;
    object-fit: cover; } }
/* -- --*/
hr {
  border: 0;
  border-bottom: 1px solid #fff; }

/* -- --*/
.slick-arrow {
  display: block;
  width: 40px;
  height: 40px;
  border: 0;
  cursor: pointer;
  font-size: 0;
  transition: all 0.3s; }
  .slick-arrow:hover {
    opacity: 0.7; }
.slick-prev {
  background: url("../img/common/slider-prev.png") no-repeat center/cover; }
.slick-next {
  background: url("../img/common/slider-next.png") no-repeat center/cover; }
.slick-dots {
  display: flex;
  align-items: center;
  gap: 8px; }
  .slick-dots li {
    width: 8px;
    height: 8px; }
  .slick-dots button {
    display: block;
    width: 100%;
    height: 100%;
    background-color: #D5D5D5;
    border: 0;
    font-size: 0;
    border-radius: 50%;
    cursor: pointer;
    transition: all 0.3s; }
  .slick-dots .slick-active button,
  .slick-dots button:hover {
    background-color: #202945; }

.slider-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px; }
  .slider-nav .slick-dots {
    order: 2; }
  .slider-nav .slick-prev {
    order: 1; }
  .slider-nav .slick-next {
    order: 3; }

/*=============================================
 * <header>
 *=============================================*/
header {
  display: flex;
  align-items: center;
  background: #fff;
  height: 90px;
  position: sticky;
  top: 0;
  padding: 0 50px;
  z-index: 100; }
  header .wrap {
    max-width: 1320px; }
  header .logo {
    flex: 1 0 0; }
    header .logo a {
      display: block;
      width: 195px; }
  header .btn-inq a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 141px;
    height: 54px;
    background-color: #BD1B21;
    color: #fff;
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.14em;
    border-radius: 10px; }
    header .btn-inq a:hover {
      background-color: #202945;
      opacity: 1; }

@media screen and (max-width: 767px) {
  header {
    height: 50px;
    padding: 0; }
    header .logo {
      padding-left: 10px; }
      header .logo a {
        width: 138px; }
    header .btn-inq a {
      height: 50px;
      font-size: 11px;
      border-radius: 0px; } }
/*=============================================
 * <footer>
 *=============================================*/
footer {
  padding: 100px 0; }
  footer nav a {
    display: inline-block;
    background: url("../img/common/icon-blank.png") no-repeat center right/15px auto;
    margin: 0 10px;
    padding-right: 20px; }
    footer nav a:hover {
      text-decoration: underline; }
  footer address {
    font-weight: 500;
    padding-top: 20px; }

@media screen and (max-width: 767px) {
  footer {
    padding: 80px 0; }
    footer .wrap {
      padding: 0; }
    footer nav a {
      margin: 0 5px; }
    footer address {
      padding-top: 10px; } }
.ft-fixed {
  width: 340px;
  position: fixed;
  bottom: 20px;
  right: 20px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
  z-index: 9; }
  .ft-fixed.fixed {
    opacity: 1;
    visibility: visible; }

@media screen and (max-width: 767px) {
  .ft-fixed {
    width: 200px;
    right: 10px;
    bottom: 10px; } }
/*=============================================
 * <section>
 *=============================================*/
#mv {
  background-image: linear-gradient(to top, #F8F8F8, #3EBFF0); }
  #mv .col {
    padding: 40px 0 30px; }
  #mv h1 {
    width: 252px;
    font-weight: 700;
    font-size: 20px;
    line-height: 28px; }
    #mv h1 img {
      margin: 20px 0 45px; }
  #mv .btn-inq {
    padding-top: 45px; }
    #mv .btn-inq a {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      width: 264px;
      height: 49px;
      background-color: #BD1B21;
      color: #fff;
      font-weight: 700;
      font-size: 20px;
      line-height: 30px;
      letter-spacing: 0.04em;
      border-radius: 50px; }
      #mv .btn-inq a:before {
        content: '';
        width: 24px;
        height: 24px;
        background: url("../img/common/icon-email.png") no-repeat center top/cover;
        display: block; }
      #mv .btn-inq a:hover {
        background-color: #202945;
        opacity: 1; }
  #mv figure {
    width: 66.8%;
    position: absolute;
    bottom: 0;
    right: 0; }

@media screen and (max-width: 1023px) {
  #mv {
    overflow: hidden; }
    #mv .wrap {
      max-width: 100%;
      padding: 0; }
    #mv .col {
      width: max-content;
      margin: 0 auto; }
    #mv h1 {
      width: 220px; }
    #mv figure {
      width: auto;
      margin: 0 -6vw;
      position: static; } }
@media screen and (max-width: 767px) {
  #mv .col {
    width: 220px;
    text-align: center;
    padding: 30px 0 0; }
  #mv h1 {
    font-size: 18px;
    line-height: 26px; }
    #mv h1 img {
      margin: 20px 0 25px; }
  #mv .btn-inq a {
    gap: 8px;
    width: 192px;
    height: 44px;
    font-size: 16px;
    margin: 0 auto; } }
@media screen and (min-width: 1321px) {
  #mv .wrap {
    max-width: 1320px; } }
/* -- -- */
.top__slider {
  padding-top: 20px; }
  .top__slider .swiper .swiper-wrapper {
    transition-timing-function: linear; }
  .top__slider .swiper-slide {
    width: 300px;
    height: 200px;
    margin: 0 15px;
    border-radius: 20px;
    overflow: hidden; }
    .top__slider .swiper-slide img {
      position: absolute;
      top: 0;
      left: 0; }

@media screen and (max-width: 767px) {
  .top__slider {
    padding-top: 10px; }
    .top__slider .swiper-slide {
      width: 180px;
      height: 120px;
      margin: 0 9px; } }
/* -- -- */
#retention {
  padding: 100px 0 150px; }
  #retention h2 {
    background: url("../img/index/retention-icon-1.png") no-repeat center top/57px auto;
    font-weight: 700;
    font-size: 30px;
    line-height: 45px;
    padding-top: 64px; }
  #retention .box-1 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    font-size: 15px;
    line-height: 29px;
    padding-top: 55px; }
    #retention .box-1 .col {
      background-color: #fff;
      border-radius: 40px;
      padding: 30px 30px;
      position: relative;
      box-shadow: 0 20px 50px rgba(0, 0, 0, 0.1); }
      #retention .box-1 .col:not(:last-child):after {
        content: '';
        width: 50px;
        height: 30px;
        background: url("../img/index/retention-arrow-1.png") no-repeat center top/cover;
        position: absolute;
        top: calc(50% - 15px);
        left: calc(100% - 10px);
        z-index: 1; }
    #retention .box-1 .no {
      display: flex;
      align-items: center;
      justify-content: center;
      background-color: #202945;
      color: #fff;
      width: 40px;
      height: 35px;
      position: absolute;
      top: -20px;
      left: calc(50% - 20px);
      font-weight: 700;
      font-size: 24px;
      line-height: 1;
      border-radius: 50%;
      padding-bottom: 5px; }
    #retention .box-1 h3 {
      text-align: center;
      margin: 0 -30px; }
      #retention .box-1 h3 small {
        font-size: 16px; }
    #retention .box-1 figure {
      padding-top: 25px; }
    #retention .box-1 ol {
      list-style: decimal;
      padding: 15px 0 0 20px; }
    #retention .box-1 .arrow {
      width: 12px;
      margin: 10px auto 5px; }
      #retention .box-1 .arrow img {
        display: block; }
    #retention .box-1 .txt {
      line-height: 24px;
      padding-top: 15px; }
      #retention .box-1 .txt strong {
        font-weight: 700;
        font-size: 16px; }
  #retention .box-2 {
    max-width: 900px;
    background-color: #fff;
    border-radius: 40px;
    margin: 100px auto 0;
    padding: 35px 50px;
    position: relative;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.1);
    box-sizing: border-box; }
    #retention .box-2:before {
      content: '';
      width: 40px;
      height: 40px;
      background: url("../img/index/retention-icon-2.png") no-repeat center top/cover;
      position: absolute;
      top: -20px;
      left: calc(50% - 20px); }
    #retention .box-2 figure {
      padding-top: 30px; }
    #retention .box-2 .arrow {
      max-width: 21px;
      margin: 0 auto;
      padding: 25px 0 10px; }
      #retention .box-2 .arrow img {
        display: block; }
    #retention .box-2 .h-20 {
      padding-top: 30px; }
      #retention .box-2 .h-20 span {
        display: inline-block;
        background-color: #202945;
        color: #fff;
        border-radius: 4px;
        margin: 0 4px;
        padding: 0 10px; }

@media screen and (max-width: 1200px) {
  #retention .box-1 h3 {
    font-size: 18px; } }
@media screen and (max-width: 1023px) {
  #retention .wrap {
    max-width: 100%;
    padding: 0 30px; }
  #retention .box-1 {
    display: block;
    font-size: 14px;
    line-height: 22px;
    margin: 0 -30px;
    padding-top: 0; }
    #retention .box-1 .slick-list {
      padding: 36px 30px 126px; }
    #retention .box-1 .slick-track {
      display: flex; }
      #retention .box-1 .slick-track:before, #retention .box-1 .slick-track:after {
        display: none; }
    #retention .box-1 .col {
      width: 320px;
      height: auto;
      float: none;
      margin-right: 30px;
      padding: 20px 20px;
      box-sizing: border-box; }
      #retention .box-1 .col:after {
        display: none; }
      #retention .box-1 .col + .col:after {
        display: block; }
      #retention .box-1 .col.col-3:after {
        display: none; }
    #retention .box-1 h3 small {
      font-size: 13px; }
    #retention .box-1 .txt .arrow {
      margin-top: 5px;
      margin-bottom: 5px; }
    #retention .box-1 .txt strong {
      font-size: 14px; }
  #retention .slider-nav {
    margin-top: -105px;
    position: relative;
    z-index: 1; }
  #retention .box-2 {
    padding: 35px; } }
@media screen and (max-width: 1023px) {
  #retention {
    padding: 50px 0 80px; }
    #retention h2 {
      background-size: 40px auto;
      font-size: 20px;
      line-height: 30px;
      margin: 0 -10px;
      padding-top: 48px; }
    #retention .box-1 .col {
      width: calc(100vw - 70px);
      max-width: 320px;
      border-radius: 20px; }
      #retention .box-1 .col:not(:last-child):after {
        width: 40px;
        height: 24px;
        top: calc(50% - 12px);
        left: calc(100% - 5px); }
    #retention .box-1 .no {
      width: 30px;
      height: 30px;
      padding-bottom: 0;
      font-size: 18px;
      top: -15px; }
    #retention .box-2 {
      border-radius: 20px;
      padding: 25px 0; }
      #retention .box-2:before {
        width: 32px;
        height: 32px;
        top: -16px; }
      #retention .box-2 figure {
        padding-top: 0; }
      #retention .box-2 .h-20 {
        font-size: 14px;
        line-height: 20px;
        padding-top: 10px; }
        #retention .box-2 .h-20 span {
          margin: 3px 2px;
          padding: 0 5px; }
      #retention .box-2 .arrow {
        width: 12px;
        padding: 10px 0 5px; } }
@media screen and (min-width: 1301px) {
  #retention .wrap {
    max-width: 1260px; } }
/* -- -- */
#experience {
  background: url("../img/index/bg01.png") no-repeat center/cover;
  padding: 150px 0; }
  #experience .wrap {
    background-color: #fff;
    border-radius: 40px;
    padding: 50px 70px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.1); }
  #experience .txt {
    padding-top: 35px; }
  #experience figure {
    padding-top: 48px; }

@media screen and (max-width: 767px) {
  #experience {
    padding: 0; }
    #experience .wrap {
      border-radius: 0;
      padding: 80px 20px;
      box-shadow: none; }
    #experience .txt {
      padding-top: 15px; }
    #experience figure {
      padding-top: 30px; } }
@media screen and (min-width: 1201px) {
  #experience .wrap {
    max-width: 1000px; } }
/* -- -- */
#features {
  background-color: #fff;
  padding: 100px 0; }
  #features h2 {
    background: url("../img/index/features-icon.png") no-repeat center top/56px auto;
    padding: 62px 0 48px; }
  #features .block {
    background-color: #F5F5F7;
    border-radius: 40px;
    padding: 80px 70px;
    overflow: hidden; }
  #features .box-1 {
    display: flex;
    justify-content: space-between;
    gap: 36px;
    padding-bottom: 36px; }
    #features .box-1 .col {
      width: 584px; }
    #features .box-1 h3 {
      font-weight: 700;
      font-size: 25px;
      line-height: 36px;
      color: #BD1B21; }
      #features .box-1 h3 span {
        display: inline-block;
        background-color: #BD1B21;
        color: #fff;
        font-size: 15px;
        line-height: 22px;
        border-radius: 12px;
        margin-bottom: 10px;
        padding: 7px 12px; }
    #features .box-1 .txt {
      padding-top: 20px; }
    #features .box-1 dl {
      display: grid;
      grid-template-columns: auto 1fr;
      gap: 36px;
      padding-top: 30px; }
      #features .box-1 dl + dl {
        padding-top: 20px; }
      #features .box-1 dl dt {
        color: #BD1B21;
        font-weight: 700;
        font-size: 14px;
        line-height: 14px;
        text-transform: uppercase; }
        #features .box-1 dl dt span {
          display: block;
          font-size: 60px;
          line-height: 60px; }
      #features .box-1 dl dd {
        font-weight: 700;
        font-size: 19px; }
    #features .box-1 figure {
      width: 261px; }
      #features .box-1 figure img {
        filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.25)); }
  #features .box-2 {
    display: flex;
    justify-content: space-between;
    gap: 36px;
    padding-bottom: 60px; }
    #features .box-2 .col {
      width: 664px; }
    #features .box-2 .txt {
      padding-top: 30px; }
      #features .box-2 .txt p + p {
        padding-top: 30px; }
    #features .box-2 figure {
      width: 300px; }
      #features .box-2 figure img {
        filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.25)); }
  #features .advance {
    display: flex;
    align-items: center;
    gap: 20px;
    font-weight: 700;
    font-size: 18px;
    line-height: 26px;
    margin-bottom: 52px; }
    #features .advance:before, #features .advance:after {
      content: '';
      border-top: 2px solid #202945;
      flex: 1 0 0; }
  #features .slider {
    width: 100%;
    max-width: 624px;
    margin: 0 auto; }
    #features .slider .slick-list {
      overflow: visible;
      margin: 0 -30px; }
    #features .slider .slick-slide {
      display: flex;
      align-items: flex-start;
      gap: 15px;
      margin: 0 30px; }
      #features .slider .slick-slide figure {
        text-align: center;
        padding-top: 26px; }
      #features .slider .slick-slide figcaption {
        width: max-content;
        font-weight: 700;
        font-size: 14px;
        line-height: 20px;
        padding-top: 10px; }
      #features .slider .slick-slide .img-l {
        order: 1; }
      #features .slider .slick-slide .img-r {
        order: 3; }
      #features .slider .slick-slide .txt {
        background-color: #fff;
        font-weight: 400;
        font-size: 15px;
        line-height: 23px;
        border-radius: 10px;
        margin-left: 20px;
        padding: 20px;
        position: relative;
        filter: drop-shadow(0 10px 20px rgba(0, 0, 0, 0.15));
        order: 2; }
        #features .slider .slick-slide .txt:before {
          content: '';
          width: 0;
          height: 0;
          border-width: 13px 20px 13px 0;
          border-color: transparent #fff transparent transparent;
          border-style: solid;
          position: absolute;
          top: 30px;
          right: 100%; }
    #features .slider .slide-1 .img-l img {
      max-width: 58px; }
    #features .slider .slide-1 .img-r img {
      max-width: 48px; }
    #features .slider .slide-2 .img-l img {
      max-width: 61px; }
    #features .slider .slide-2 .img-r img {
      max-width: 56px; }
    #features .slider .slide-3 .img-l img {
      max-width: 44px; }
    #features .slider .slide-3 .img-r img {
      max-width: 60px; }
    #features .slider .slide-4 .img-l img {
      max-width: 90px; }
    #features .slider .slide-4 .img-r img {
      max-width: 82px; }
    #features .slider .slide-5 .img-l img {
      max-width: 55px; }
    #features .slider .slide-5 .img-r img {
      max-width: 44px; }
  #features .slider-nav {
    padding-bottom: 30px; }
  #features .note {
    font-weight: 400;
    font-size: 13px;
    line-height: 20px; }

@media screen and (max-width: 1023px) {
  #features .box-1,
  #features .box-2 {
    flex-direction: column;
    align-items: center; } }
@media screen and (max-width: 767px) {
  #features {
    background: #F4F4F5;
    padding: 80px 0;
    overflow: hidden; }
    #features h2 {
      background-size: 40px auto;
      padding: 50px 0 25px; }
    #features .block {
      background: transparent;
      border-radius: 0;
      padding: 0;
      overflow: visible; }
    #features .box-1 {
      gap: 30px;
      padding-bottom: 60px; }
      #features .box-1 .col {
        width: 100%; }
      #features .box-1 h3 {
        text-align: center;
        font-size: 20px;
        line-height: 30px; }
        #features .box-1 h3 span {
          font-size: 11px;
          line-height: 16px;
          border-radius: 6px;
          margin-bottom: 5px;
          padding: 5px 8px; }
      #features .box-1 .txt {
        padding-top: 10px; }
      #features .box-1 dl {
        gap: 20px;
        padding-top: 25px; }
        #features .box-1 dl + dl {
          padding-top: 20px; }
        #features .box-1 dl dt {
          font-size: 10px;
          line-height: 10px; }
          #features .box-1 dl dt span {
            font-size: 40px;
            line-height: 40px; }
        #features .box-1 dl dd {
          font-size: 14px;
          line-height: 22px; }
    #features .advance {
      margin-bottom: 12px; }
    #features .box-2 {
      padding-bottom: 35px; }
      #features .box-2 .col {
        width: 100%; }
      #features .box-2 h3 {
        font-size: 17px;
        line-height: 25px;
        text-align: center;
        margin: 0 -10px; }
      #features .box-2 .txt {
        padding-top: 16px; }
        #features .box-2 .txt figure {
          width: 50%;
          float: right;
          margin: 0 0 15px 15px; }
    #features .slider {
      padding-bottom: 20px; }
      #features .slider .slick-list {
        margin: 0 -5px; }
      #features .slider .slick-track {
        display: flex; }
        #features .slider .slick-track:before, #features .slider .slick-track:after {
          display: none; }
      #features .slider .slick-slide {
        height: auto;
        float: none;
        justify-content: center;
        flex-wrap: wrap;
        gap: 10px;
        background-color: #fff;
        box-shadow: 0 5px 10px rgba(0, 0, 0, 0.15);
        border-radius: 10px;
        margin: 0 5px;
        padding: 15px; }
        #features .slider .slick-slide figure {
          display: grid;
          grid-template-columns: 30px 1fr;
          align-items: center;
          gap: 5px;
          padding-top: 0; }
          #features .slider .slick-slide figure img {
            max-width: 100% !important; }
        #features .slider .slick-slide figcaption {
          font-size: 12px;
          line-height: 15px;
          padding-top: 0; }
        #features .slider .slick-slide .img-l {
          order: 1; }
        #features .slider .slick-slide .img-r {
          order: 2;
          position: relative;
          padding-left: 32px; }
          #features .slider .slick-slide .img-r:before {
            content: '';
            width: 22px;
            height: 12px;
            background: url("../img/index/features-arrow.png") no-repeat center top/cover;
            position: absolute;
            top: calc(50% - 6px);
            left: 0; }
        #features .slider .slick-slide .txt {
          width: 100%;
          background-color: transparent;
          border-radius: 0;
          padding: 0;
          order: 3;
          font-size: 13px;
          line-height: 19px; }
          #features .slider .slick-slide .txt:before {
            display: none; }
    #features .slider-nav {
      padding-bottom: 20px; }
    #features .note {
      text-align: left; } }
/* -- -- */
#omnichannel {
  background-color: #fff;
  padding: 100px 0; }
  #omnichannel h2 {
    background: url("../img/index/omnichannel-icon.png") no-repeat center top/56px auto;
    padding: 62px 0 50px; }
  #omnichannel .box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 36px;
    background-color: #F5F5F7;
    padding: 40px 30px 40px 70px;
    border-radius: 40px; }
    #omnichannel .box + .box {
      margin-top: 100px; }
    #omnichannel .box .col {
      width: 520px; }
    #omnichannel .box h3 {
      font-weight: 700;
      font-size: 25px;
      line-height: 36px; }
      #omnichannel .box h3 span {
        display: inline-block;
        background-color: #FDC02D;
        color: #202945;
        font-size: 15px;
        line-height: 22px;
        border-radius: 12px;
        margin-bottom: 10px;
        padding: 7px 12px; }
      #omnichannel .box h3 small {
        font-weight: 400;
        font-size: 14px;
        line-height: 20px; }
      #omnichannel .box h3 sup {
        font-size: 16px; }
    #omnichannel .box .txt {
      padding-top: 20px; }
    #omnichannel .box dl {
      display: grid;
      grid-template-columns: auto 1fr;
      gap: 36px;
      padding-top: 30px; }
      #omnichannel .box dl + dl {
        padding-top: 20px; }
      #omnichannel .box dl dt {
        color: #FDC02D;
        font-weight: 700;
        font-size: 14px;
        line-height: 14px;
        text-transform: uppercase; }
        #omnichannel .box dl dt span {
          display: block;
          font-size: 60px;
          line-height: 60px; }
      #omnichannel .box dl dd {
        font-weight: 700;
        font-size: 19px; }
    #omnichannel .box .note {
      font-weight: 400;
      font-size: 13px;
      line-height: 20px;
      padding-top: 30px; }
    #omnichannel .box .box-btn {
      padding-top: 30px; }
      #omnichannel .box .box-btn a {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 312px;
        height: 46px;
        border-radius: 50px;
        background-color: #202945;
        color: #fff;
        margin: 0 auto; }
        #omnichannel .box .box-btn a:hover {
          background-color: #FDC02D;
          color: #202945;
          opacity: 1; }
    #omnichannel .box figure {
      width: 422px; }
      #omnichannel .box figure img {
        filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.25)); }
  #omnichannel .btn-inq {
    padding-top: 100px; }
    #omnichannel .btn-inq a {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      width: 264px;
      height: 49px;
      background-color: #FF4141;
      color: #fff;
      font-weight: 700;
      font-size: 20px;
      line-height: 30px;
      letter-spacing: 0.04em;
      border-radius: 50px;
      margin: 0 auto; }
      #omnichannel .btn-inq a:before {
        content: '';
        width: 24px;
        height: 24px;
        background: url("../img/common/icon-email.png") no-repeat center top/cover;
        display: block; }
      #omnichannel .btn-inq a:hover {
        background-color: #202945;
        opacity: 1; }

@media screen and (max-width: 1023px) {
  #omnichannel .box {
    flex-direction: column;
    padding: 40px 30px; } }
@media screen and (max-width: 767px) {
  #omnichannel {
    padding: 80px 0; }
    #omnichannel .wrap {
      padding: 0; }
    #omnichannel h2 {
      background-size: 40px auto;
      padding: 50px 0 35px; }
    #omnichannel .box {
      background: transparent;
      border-radius: 0;
      padding: 0 30px; }
      #omnichannel .box + .box {
        margin-top: 80px; }
      #omnichannel .box .col {
        width: 100%; }
      #omnichannel .box figure {
        width: 300px; }
      #omnichannel .box h3 {
        text-align: center;
        font-size: 20px;
        line-height: 30px; }
        #omnichannel .box h3 span {
          font-size: 11px;
          line-height: 16px;
          border-radius: 6px;
          margin-bottom: 5px;
          padding: 5px 8px; }
        #omnichannel .box h3 small {
          font-size: 14px; }
        #omnichannel .box h3 sup {
          font-size: 13px; }
      #omnichannel .box dl {
        gap: 20px;
        padding-top: 25px; }
        #omnichannel .box dl + dl {
          padding-top: 20px; }
        #omnichannel .box dl dt {
          font-size: 10px;
          line-height: 10px; }
          #omnichannel .box dl dt span {
            font-size: 40px;
            line-height: 40px; }
        #omnichannel .box dl dd {
          font-size: 14px;
          line-height: 22px; }
      #omnichannel .box .note {
        text-align: center;
        padding-top: 20px; }
      #omnichannel .box .box-btn {
        padding-top: 25px; }
        #omnichannel .box .box-btn a {
          width: 256px;
          height: 40px;
          font-size: 14px; }
    #omnichannel .btn-inq {
      padding-top: 80px; }
      #omnichannel .btn-inq a {
        width: 192px;
        height: 44px;
        font-size: 16px; } }
