@charset "utf-8";

/* Base */
.hidden {position: absolute; top: -9999px; left: -9999px; opacity: 0;}
@media (hover: hover) {}
@media screen and (max-width: 1399px) {}
@media screen and (max-width: 767px) {}
@media screen and (max-width: 499px) {}



/* Intro-hero */
.intro-hero {position: relative; overflow: hidden; padding-block: 100px 60px; height: 553px; color: #fff;}
.intro-hero-bg {position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; z-index: -1;}
.intro-hero-container {display: flex; flex-direction: column; justify-content: flex-end; height: 100%;}
.intro-hero-title {font-size: 110px; font-family: var(--font-tertiary); font-weight: 300;}

@media screen and (max-width: 1399px) {
  .intro-hero {height: 380px; padding-block: 80px 40px;}
  .intro-hero-title {font-size: 62px;}
}
@media screen and (max-width: 767px) {
  .intro-hero {height: 320px;}
  .intro-hero-title {font-size: 42px;}
}
@media screen and (max-width: 499px) {}



/* LNB */
.lnb-bar {--theme: #bdbdbd; --active-theme: var(--primary-dark); border-block: 1px solid var(--theme);}
.lnb-bar-container {padding-block: 15px;}
.lnb-bar-pages {display: flex; gap: 2em;}
.lnb-bar-pages a {display: flex; align-items: center; gap: .5em; color: var(--theme); padding-block: 10px; padding-right: 1em;}
.lnb-bar-pages a::before {display: block; content: ''; width: 0.375em; height: 0.375em; border-radius: 50%; background: var(--theme); flex-shrink: 0;}
.lnb-bar-pages a.active {color: var(--active-theme); font-weight: 700; pointer-events: none;}
.lnb-bar-pages a.active::before {background: var(--active-theme);}
@media (hover: hover) {
  .lnb-bar-pages a:hover {--theme: #333;}
}
@media screen and (max-width: 1399px) {
  .lnb-bar {font-size: 15px;}
}
@media screen and (max-width: 767px) {
  .lnb-bar {position: fixed; bottom: 0; left: 0; width: 100%; z-index: 4444; background: #fff;}
  .lnb-bar-container {width: 100%; padding-block: 5px; padding-inline: 15px; overflow: auto hidden;}
  .lnb-bar-pages {gap: 1em;}
  .lnb-bar-pages a {flex-shrink: 0; padding-inline: 0.6em;}
  .lnb-bar-pages a::before {display: none;}
}
@media screen and (max-width: 499px) {}



/* Layouts */
.sp-document {padding-block: 116px 0; font-size: 20px; color: #7E808B; word-break: keep-all;}
.sp-section {margin-bottom: 181px;}
.sp-article {margin-block: 90px;}
.sp-banner {padding-block: 115px; background: #F9F9F9;}
.sp-banner.white {background: white;}
.sp-banner.sky {background: #F1FAFD;}
.sp-section-head {margin-bottom: 55px;}

.ly-divided {display: grid; gap: 20px; grid-template-columns: repeat(6, 1fr);}
.ly-divided-head {grid-column: 1 / 2;}
.ly-divided-body {grid-column: 2 / 7;}
.ly-divided-full {grid-column: 1 / 7;}

@media screen and (max-width: 1399px) {
  .sp-document {font-size: 18px;}
  .sp-section {margin-bottom: 100px;}
  .sp-banner {padding-block: 80px;}
  .sp-section-head {margin-bottom: 30px;}

  .ly-divided-head,
  .ly-divided-body,
  .ly-divided-full {grid-column: span 6;}
}
@media screen and (max-width: 767px) {
  .sp-document {font-size: 15px; padding-top: 70px;}
  .sp-section {margin-bottom: 80px;}
  .sp-banner {padding-block: 60px;}
  .sp-section-head {margin-bottom: 20px;}
}



/* Fonts */
.sp-section-title {font-size: 26px; font-weight: 700; color: var(--primary);}
.sp-section-title.gray {color: #BDBDBD;}
.heading1 {color: #000; font-size: 48px; font-weight: 500; letter-spacing: -0.04em; line-height: 1.4; margin-bottom: 1em; word-break: keep-all;}
.heading2 {color: #000; font-size: 35px; font-weight: 400; letter-spacing: -0.04em; line-height: 1.4; margin-bottom: 1em; word-break: keep-all;}
.heading3 {color: #000; font-size: 26px; font-weight: 700; line-height: 1.4; margin-bottom: .4em; word-break: keep-all;}

.leading {margin-block: .7em; line-height: 1.7;}

@media screen and (max-width: 1399px) {
  .sp-section-title {font-size: 24px;}
  .heading1 {font-size: 38px;}
  .heading2 {font-size: 30px;}
  .heading3 {font-size: 24px;}
}
@media screen and (max-width: 767px) {
  .sp-section-title {font-size: 20px;}
  .heading1 {font-size: 28px;}
  .heading2 {font-size: 24px;}
  .heading3 {font-size: 20px;}
}
@media screen and (max-width: 499px) {}




/* Elements */
.overflow-container-x {position: relative; overflow: auto hidden; padding-block: 20px;}
.overflow-container-x .overflow-item {min-width: 680px;}
.overflow-container-notice {position: sticky; left: 0; display: none; align-items: center; gap: .5em; font-size: 15px; margin-bottom: 0.8em; color: #7F8FA1; font-weight: 700;}
.overflow-container-notice::before {content: ''; width: 0; height: 0; border-left: 1em solid #7F8FA1; border-block: .5em solid transparent;}
.overflow-container-notice::after {content: '좌우로 스와이프 해주세요.'; }

.diagram-box {background-color: #F9F9F9; border-radius: 40px; padding: 60px;}

.icon-hover-cards {display: flex; border-radius: 14px; background: #F8F8F8;}
.icon-hover-cards .item {width: 100%; text-align: center; display: flex; flex-direction: column; align-items: center; padding: 30px 10px; position: relative; cursor: pointer; border-radius: 14px;}
.icon-hover-cards .item:not(:last-child)::after {position: absolute; top: 50%; right: 0; width: 1px; height: calc(100% - 30px); background: #DCDCDC; content: ''; transform: translate(0, -50%);}
.icon-hover-cards .item .icon {position: relative; margin-bottom: 22px;}
.icon-hover-cards .item .icon img {width: 66px; height: 66px; object-fit: contain;}
.icon-hover-cards .item .icon .white {position: absolute; top: 0; left: 0; opacity: 0;}
.icon-hover-cards .item .icon .gray {opacity: 1;}
.icon-hover-cards .item .cont {}
.icon-hover-cards .item .cont .tit {display: block; font-size: 22px; font-weight: 700; margin-bottom: 0.3em;}
.icon-hover-cards .item .cont .desc {display: block; font-size: 16px; opacity: 0;}
.icon-hover-cards .item .ico--plus {--size: 18px; --color: #7E808B; --border-width: 3px; position: absolute; bottom: 30px; left: 50%; transform: translate(-50%);}

.icon-hover-cards.no-hover-effect .item {cursor: initial;}
.icon-hover-cards.no-hover-effect .item .cont .tit {color: var(--primary);}
.icon-hover-cards.no-hover-effect .item .cont .desc {opacity: 1;}
.icon-hover-cards.no-hover-effect .item .ico--plus {display: none;}


.icon-tab-buttons {display: flex; border-radius: 14px; background: #f8f8f8; margin-block: 50px 100px; scroll-margin-top: 50px;}
.icon-tab-button {width: 100%; text-align: center; display: flex; flex-direction: column; align-items: center; padding: 30px 20px; position: relative; cursor: pointer; border-radius: 14px; color: #C7C7C7;}
.icon-tab-button:not(:last-child)::after {position: absolute; top: 50%; right: 0; width: 1px; height: calc(100% - 30px); background: #DCDCDC; content: ''; transform: translate(0, -50%);}
.icon-tab-button .num {font-size: 17px; font-weight: 700; position: absolute; top: 13px; left: 18px;}
.icon-tab-button .icon {position: relative; margin-bottom: 22px;}
.icon-tab-button .icon .active {position: absolute; top: 0; left: 0; opacity: 0;}

.icon-tab-button.active {z-index: 10; background: #fff; box-shadow: 5px 5px 15px rgb(0,0,0,.15); color: var(--primary); font-weight: 700; pointer-events: none;}
.icon-tab-button.active::after {display: none;}
.icon-tab-button.active .icon .active {opacity: 1;}
.icon-tab-button.active .icon .off {opacity: 0;}

@media screen and (min-width: 1400px) {
  .icon-hover-cards:not(.no-hover-effect) .item:hover {z-index: 10; background: var(--primary); color: #fff; box-shadow: 5px 5px 15px rgb(0,0,0,.15);}
  .icon-hover-cards:not(.no-hover-effect) .item:hover::after {display: none;}
  .icon-hover-cards:not(.no-hover-effect) .item:hover .icon .white {opacity: 1;}
  .icon-hover-cards:not(.no-hover-effect) .item:hover .icon .gray {opacity: 0;}
  .icon-hover-cards:not(.no-hover-effect) .item:hover .cont .desc {opacity: 1;}
  .icon-hover-cards:not(.no-hover-effect) .item:hover .ico--plus {opacity: 0;}

  .icon-tab-button:not(.active):hover {color: var(--primary);}
  .icon-tab-button:not(.active):hover .icon .active {opacity: 1;}
  .icon-tab-button:not(.active):hover .icon .off {opacity: 0;}
}
@media screen and (max-width: 1399px) {
  .diagram-box {padding: 40px 20px; border-radius: 30px;}

  .icon-hover-cards .item {cursor: default; padding: 25px 15px;}
  .icon-hover-cards .item .icon img {width: 44px; height: 44px;}
  .icon-hover-cards .item .cont .tit {font-size: 18px; color: var(--primary);}
  .icon-hover-cards .item .cont .desc {opacity: 1;}
  .icon-hover-cards .item .ico--plus {display: none;}

  .icon-tab-buttons {display: grid; grid-template-columns: repeat(3, 1fr); margin-block: 30px;}
  .icon-tab-button {padding: 25px 15px;}
  .icon-tab-button:not(:last-child)::after {display: none;}
  .icon-tab-button .icon {margin-bottom: 10px;}
  .icon-tab-button .icon img {width: 80px;}
}
@media screen and (max-width: 767px) {
  .overflow-container-notice {display: flex;}

  .diagram-box {padding: 25px 15px; border-radius: 15px;}

  .icon-hover-cards {flex-direction: column; padding-block: 10px;}
  .icon-hover-cards .item {flex-direction: row; align-items: flex-start; text-align: left; gap: 20px; padding: 15px;}
  .icon-hover-cards .item:not(:last-child)::after {width: calc(100% - 30px); height: 1px; left: 50%; top: auto; bottom: 0; right: auto; transform: translate(-50%);}
  .icon-hover-cards .item .icon {flex-shrink: 0; margin-bottom: 0;}

  .icon-tab-buttons {grid-template-columns: repeat(1, 1fr); border-radius: 10px;}
  .icon-tab-button {flex-direction: row; text-align: left; gap: 20px; padding-block: 10px; border-radius: 10px;}
  .icon-tab-button:not(:last-child)::after {width: calc(100% - 30px); height: 1px; left: 50%; top: auto; bottom: -1px; right: auto; transform: translate(-50%); display: block;}
  .icon-tab-button .num {font-size: 14px; position: static;}
  .icon-tab-button .icon {margin-bottom: 0;}
  .icon-tab-button .icon img {width: 60px;}
}
@media screen and (max-width: 499px) {}



/* Company */
.cp-ov-overview-diagram {display: flex; align-items: center; justify-content: center;}
.cp-ov-overview-diagram .item {position: relative; display: flex; align-items: center; gap: 24px; margin-inline: -1px;}
.cp-ov-overview-diagram .item .icon {border-radius: 50%; border: 1px dotted #707070; padding: 18px; position: relative;}
.cp-ov-overview-diagram .item .icon::after, .cp-ov-overview-diagram .item .icon::before {content: ''; width: 12px; height: 12px; border-radius: 50%; background: var(--primary-dark); position: absolute; top: 50%;}
.cp-ov-overview-diagram .item .icon::before {left: 0; transform: translate(-50%, -50%);}
.cp-ov-overview-diagram .item .icon::after {right: 0; transform: translate(50%, -50%);}
.cp-ov-overview-diagram .item .icon img {border-radius: 50%; box-shadow: 15px 15px 15px rgb(0,0,0,.03);}
.cp-ov-overview-diagram .item .txt {font-size: 29px; word-break: keep-all;}
.cp-ov-overview-diagram .item .txt b {color: var(--primary-dark);}
.cp-ov-overview-diagram .item:nth-child(1) .txt {order: 0; text-align: right;}
.cp-ov-overview-diagram .item:nth-child(1) .icon {order: 1;}

.cp-ov-service-cards {display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;}
.cp-ov-service-cards > li {border-radius: 40px; overflow: hidden; position: relative; color: #fff; padding: 27px 27px 38px 27px; display: flex; flex-direction: column; justify-content: space-between; text-align: center; height: 460px;}
.cp-ov-service-cards > li img {position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; z-index: -1;}
.cp-ov-service-cards > li .num {font-size: 18px; font-weight: 600; margin-left: auto;}
.cp-ov-service-cards.type2 > li .desc {font-size: 30px; font-weight: 400; line-height: 1.2; height: 2.4em; display: flex; align-items: center; justify-content: center;}

.bi-types {display: flex; flex-direction: column; gap: 38px;}
.bi-types-group {display: grid; grid-template-columns: 195px 1fr; gap: 12px;}
.bi-types-group .tit {font-weight: 700;}
.bi-types-group .items {display: grid; grid-template-columns: repeat(2, 1fr); gap: 15px;}
.bi-types-group .items > li {display: flex; align-items: center; justify-content: center; height: 210px; border: 1px solid #D8D8D8; border-radius: 10px;}
.bi-types-group .items > li > img {display: block;}

@media (hover: hover) {}
@media screen and (max-width: 1399px) {
  .cp-ov-overview-diagram {flex-direction: column;}
  .cp-ov-overview-diagram .item .txt {font-size: 24px;}
  .cp-ov-overview-diagram .item .icon {width: 200px; height: 200px; padding: 12px;}
  .cp-ov-overview-diagram .item:nth-child(1) .icon::after {display: none;}
  .cp-ov-overview-diagram .item:nth-child(2) .icon::before {display: none;}

  .cp-ov-service-cards > li {border-radius: 20px; height: 320px; padding: 20px;}
  .cp-ov-service-cards.type2 > li .desc {font-size: 20px;}

  #cp-bi-story .icon-hover-cards {flex-direction: column; padding-block: 10px;}
  #cp-bi-story .icon-hover-cards .item {flex-direction: row; align-items: flex-start; text-align: left; gap: 20px; padding: 15px;}
  #cp-bi-story .icon-hover-cards .item:not(:last-child)::after {width: calc(100% - 30px); height: 1px; left: 50%; top: auto; bottom: 0; right: auto; transform: translate(-50%);}
  #cp-bi-story .icon-hover-cards .item .icon {flex-shrink: 0; margin-bottom: 0;}

  .bi-types-group .items > li {height: auto;}
  .bi-types-group .items > li img {width: 180px;}
}
@media screen and (max-width: 767px) {
  .cp-ov-overview-diagram .item {gap: 15px;}
  .cp-ov-overview-diagram .item .txt {font-size: 18px;}
  .cp-ov-overview-diagram .item .icon {width: 130px; height: 130px; flex-shrink: 0;}

  .cp-ov-service-cards {grid-template-columns: repeat(1, 1fr);}
  .cp-ov-service-cards > li {border-radius: 15px; height: 280px; padding: 15px; text-align: left; font-size: 18px;}
  .cp-ov-service-cards.type2 > li .desc {font-size: 18px;}

  .bi-types-group {display: flex; flex-direction: column;}
  .bi-types-group .items {grid-template-columns: repeat(1, 1fr); gap: 10px;}
}



/* Service */
.diagram-box:has(.bnf-diagram) {padding-block: 30px; padding-inline: 50px;}
.bnf-diagram {max-width: calc(100% + 30px);}

.diagram-box:has(.svc-diagram-table-container) {padding: 34px 35px 34px 55px;}
.svc-diagram-table-container {display: flex;}
.svc-diagram-table {--theme: #7F8FA1; color: var(--theme); padding: 0 25px; border-radius: 15px; width: 100%;}
.svc-diagram-table .row {display: flex; gap: 8px;}
.svc-diagram-table .col {position: relative; padding: 20px 10px; width: 100%;}
.svc-diagram-table .col--tag {width: 66px; flex-shrink: 0;}
.svc-diagram-table .head .col {padding-bottom: 0;}
.svc-diagram-table .head .tit {display: flex; align-items: center; justify-content: center; padding: .3em 1em; border-radius: 100px; background: var(--theme); color: #fff; text-align: center; font-weight: 700;}
.svc-diagram-table .diagram .col {height: 435px; display: flex; align-items: center; justify-content: center;}
.svc-diagram-table .content .tag {font-size: 32px; font-weight: 700;}
.svc-diagram-table .content .col {border-block: 1px solid #AEAEAE; font-size: 17px; margin-top: -1px; min-height: 94px; display: flex; align-items: center; justify-content: flex-start;}
.svc-diagram-table .content .col--tag {justify-content: center;}
.svc-diagram-table .content .col .arw {position: absolute; top: 50%; left: -50px; transform: translate(0, -50%);}
.svc-diagram-table.before {padding-left: 0;}
.svc-diagram-table.after {--theme: var(--primary); width: 596px; flex-shrink: 0; background: #fff; box-shadow: 5px 5px 10px rgb(0,0,0,.15);}
.svc-diagram-table.after .col--tag {display: none;}
.svc-diagram-table.after .head .tit {box-shadow: 5px 5px 10px rgb(0,0,0,.15);}
.svc-diagram-table.after .content .col:not(.col--tag) {font-size: 20px;}
.svc-diagram-table.after .content .col:not(.col--tag):has(.arw) {padding-left: 40px;}
.svc-diagram-table.after .content .row:last-child .col {border-bottom: 0;}

.diagram-box:has(.svc-bf-af) {padding: 25px; padding-left: 0;}
.svc-bf-af {display: flex; gap: 10px;}
.svc-bf-af .card {width: 50%; padding: 18px 25px 0 25px; display: flex; flex-direction: column; border-radius: 14px; align-items: center;}
.svc-bf-af .card .tit {display: flex; align-items: center; justify-content: center; padding: .3em 1em; border-radius: 100px; background: var(--theme); color: #fff; text-align: center; font-weight: 700; position: relative; margin-bottom: 28px; width: 100%;}
.svc-bf-af .card .tit .arw {position: absolute; top: 50%; left: 100%; transform: translate(-8px, -50%);}
.svc-bf-af .card .desc {text-align: center; font-weight: 600; font-size: 19px; margin-bottom: 0.8em;}
.svc-bf-af .card .desc b {color: var(--theme); font-weight: 600;}
.svc-bf-af .card .visual {margin-top: auto;}
.svc-bf-af .card .visual.to-bottom {margin-bottom: -25px;}
.svc-bf-af .card.before {--theme: #7F8FA1;}
.svc-bf-af .card.before .desc {color: #7E808B;}
.svc-bf-af .card.after {--theme: var(--primary); background: #fff; box-shadow: 5px 5px 13px rgb(0,0,0,.15);}

.cmpt-network-effect.diagram-box:has(.svc-diagram-table-container) {padding-inline: 30px;}
.cmpt-network-effect .svc-diagram-table-container {gap: 30px;}
.cmpt-network-effect .svc-diagram-table {width: 50%;}
.cmpt-network-effect .svc-diagram-table .diagram .col {height: 595px;}
.cmpt-network-effect .svc-diagram-table.before {padding-right: 0;}
.cmpt-network-effect .svc-diagram-table.after {width: 62%;}

.cmpt-os-table {display: flex;}
.cmpt-os-table .group {position: relative; width: 100%;}
.cmpt-os-table .group :where(.head, .content) {padding-inline: 15px;}
.cmpt-os-table .group .head {padding-block: 20px 5px;}
.cmpt-os-table .group .head-tit {display: flex; align-items: center; justify-content: center; padding: .3em 1em; border-radius: 100px; border: 3px solid #000; background: #000; color: #fff; font-weight: 700; box-sizing: border-box; margin-block: 5px;}
.cmpt-os-table .group .content {display: flex; align-items: center; gap: 24px; height: 85px; border-bottom: 1px solid #C2C2C2;}
.cmpt-os-table .group .content .tit {font-weight: 700; line-height: 1.3; font-size: 1.2em; color: #000;}
.cmpt-os-table .group .content .tit small {display: inline-block; font-weight: 400; font-size: 0.7em;}

.cmpt-os-table .group-head {width: 265px; flex-shrink: 0; padding-right: 25px;}
.cmpt-os-table .group-head .head-tit {border-color: var(--primary); color: var(--primary); background: #fff;}

.cmpt-os-table .group-qp {width: 523px; flex-shrink: 0; z-index: 10; padding-inline: 14px; border-radius: 14px; background: #fff; box-shadow: 5px 5px 15px rgb(0,0,0,.15);}
.cmpt-os-table .group-qp .head-tit {font-size: 1.25em; background: var(--primary); border-color: var(--primary); margin-block: 0;}
.cmpt-os-table .group-qp .content {color: #000;}
.cmpt-os-table .group-qp .content:last-child {border: none;}

.cmpt-os-table .group-other {padding-inline: 25px; background: #F7F8FA; border-radius: 0 14px 14px 0;}
.cmpt-os-table .group-other .head-tit {background: #7F8FA1; border-color: #7F8FA1;}
.cmpt-os-table .group-other .content {color: #7F8FA1;}
.cmpt-os-table .group-other .content:last-child {border: none;}

@media screen and (max-width: 1399px) {
  .diagram-box:has(.svc-diagram-table-container) {padding: 30px!important;}
  .svc-diagram-table-container {flex-direction: column; gap: 30px;}
  .svc-diagram-table {width: 100%!important;}
  .svc-diagram-table :where(.head, .diagram) .col--tag {display: none!important;}
  .svc-diagram-table .diagram .col {height: auto!important;}
  .svc-diagram-table.before {padding-right: 0;}
  .svc-diagram-table.before .head .col {padding-top: 0;}
  .svc-diagram-table.after .col--tag {display: flex;}
  .svc-diagram-table .content .col {min-height: 0;}
  .svc-diagram-table .content .col .arw {display: none!important;}
  .svc-diagram-table.after .content .col:not(.col--tag) {padding-left: 10px; font-size: 18px;}

  .cmpt-os-table .group :where(.head, .content) {padding-inline: 10px;}
  .cmpt-os-table .group .head-tit {font-size: 0.9em; margin-block: 0;}
  .cmpt-os-table .group .content {font-size: 0.9em; gap: 14px; height: 75px;}
  .cmpt-os-table .group .content .icon {width: 20px;}
  .cmpt-os-table .group .content .tit {font-size: 1em;}
  .cmpt-os-table .group-head {width: 165px; padding-right: 15px;}
  .cmpt-os-table .group-qp {width: 100%; flex-shrink: 1;}

  .svc-bf-af .card .tit {margin-bottom: 15px;}
  .svc-bf-af .card .desc {font-size: 16px;}
}
@media screen and (max-width: 767px) {
  .diagram-box:has(.svc-diagram-table-container) {padding: 30px 20px!important;}
  .svc-diagram-table .col--tag {width: 40px;}
  .svc-diagram-table .content .tag {font-size: 24px;}
  .svc-diagram-table .content .col {font-size: 15px;}
  .svc-diagram-table.after .content .col:not(.col--tag) {font-size: 17px;}
  .svc-diagram-table.after {padding-inline: 20px;}

  .cmpt-os-table {min-width: 580px;}
  .cmpt-os-table .group .head {padding-inline: 0;}
  .cmpt-os-table .group-head {width: 122px;}

  .diagram-box:has(.svc-bf-af) {padding: 20px 10px;}
  .svc-bf-af {flex-direction: column; gap: 25px;}
  .svc-bf-af .card {width: 100%;}
  .svc-bf-af .card .tit .arw {display: none;}
  .svc-bf-af .card .desc {font-size: 14px;}
  .svc-bf-af .card.before {padding-top: 0;}
}



/* Location */
.loca-content .map-container {height: 445px;}
.loca-content-info {display: flex; justify-content: space-between; gap: 0 30px; padding-block: 30px; border-bottom: 1px solid #BFBFBF;}
.loca-content-info .addr {font-size: 20px; display: flex; gap: .7em; align-items: flex-start;}
.loca-content-info .addr .icon {flex-shrink: 0;}
.loca-content-info .addr span {line-height: 1.4;}
.loca-content-info .contact {display: flex; gap: 0 2em; font-size: 16px;}
.loca-content-info .contact .tag {font-weight: 700;}
@media (hover: hover) {}
@media screen and (max-width: 1399px) {
  .loca-content-info .addr {font-size: 18px;}
}
@media screen and (max-width: 767px) {
  .loca-content .map-container {height: 350px;}
  .loca-content-info {display: block; padding-block: 20px;}
  .loca-content-info .addr {font-size: 16px; gap: .5em;}
  .loca-content-info .addr .icon {width: 15px;}
  .loca-content-info .contact {margin-top: 1em; display: block; padding-left: 23px; line-height: 1.8;}
}



/* Recruit */
.rc-cards {display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;}
.rc-card {position: relative; overflow: hidden; border-radius: 40px; color: #fff; height: 460px; text-align: center; display: flex; flex-direction: column; justify-content: space-between; align-items: center; padding: 35px 15px;}
.rc-card .bg {position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; z-index: -1;}
.rc-card .tit {font-size: 40px; font-weight: 600; line-height: 1.3;}

@media (hover: hover) {}
@media screen and (max-width: 1399px) {
  .rc-card {border-radius: 15px; height: 350px;}
  .rc-card .tit {font-size: 24px;}
}
@media screen and (max-width: 767px) {
  .rc-cards {overflow: auto hidden; gap: 10px; width: calc(100% + 30px); margin-left: -15px; padding-inline: 15px;}
  .rc-card {min-width: 240px; height: 280px;}
}
@media screen and (max-width: 499px) {}



/* Contact us */
.visit-notice {display: none;}
.visit-notice.active {display: block;}
.visit-notice li {display: flex; gap: .5em; font-size: 16px;}
.visit-notice li::before {content: '※';}
.ql-form-foot:has(.visit-notice) {display: flex; align-items: flex-end; justify-content: space-between;}
.ql-form-foot:has(.visit-notice) button {margin-left: auto;}
@media (hover: hover) {}
@media screen and (max-width: 1399px) {}
@media screen and (max-width: 767px) {
  .ql-form-foot:has(.visit-notice) {flex-direction: column; padding-top: 20px; align-items: flex-start; gap: 30px;}
  .visit-notice li {font-size: 14px;}
}
@media screen and (max-width: 499px) {}



/* Event */
body:has(.event-2507) .header {position: sticky; background: white;}
.event-2507 .sp-section-head .heading1 {margin-bottom: 0.5em;}

.event-banner {display: block; width: 100%;}
.event-banner img {display: block; width: 100%;}

.event-survey-section {}
.event-survey-section:not(:first-of-type) {margin-top: 120px;}
.event-survey-section-head {display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; padding-bottom: 24px; margin-bottom: 40px; border-bottom: 2px solid #A7A7A7;}
.event-survey-section-title {font-size: 40px; font-weight: 700; line-height: 1.3;}
.event-survey-section-title b {color: black; font-weight: 700;}
.event-survey-section-body {}
.event-survey-article:not(:first-of-type) {margin-top: 50px; padding-top: 50px; border-top: 1px solid #DBDBDB;}
.event-survey-article-head {margin-bottom: 25px;}
.event-survey-article-title {font-size: 19px; font-weight: 700; color: black; line-height: 1.5;}
.event-survey-article .ql-inp .checkbox-group {gap: 20px 80px;}

.event-2507-content-1 .cards {display: grid; grid-template-columns: repeat(4, 1fr); gap: 29px;}
.event-2507-content-1 .cards > li {border-radius: 10px; overflow: hidden; background: white; box-shadow: 6px 6px 30px rgb(0,0,0,0.1);}
.event-2507-content-1 .cards > li > img {display: block; width: 100%;}

.event-2507-content-2 .heading1 img {display: inline-block; vertical-align: middle; width: 126px; margin-right: 0.2em; margin-top: -0.2em;}
.event-2507-content-2 .ly-divided-head {display: flex; flex-direction: column; gap: 20px;}
.event-2507-content-2 .ly-divided-head .group-1 {height: 50%;}
.event-2507-content-2 .ly-divided-head .title {font-size: 28px; font-weight: 700; margin-bottom: 1.25em; color: var(--theme); border-top: 3px solid var(--theme); padding-top: 0.5em;}
.event-2507-content-2 .ly-divided-head .title.gray {--theme: #7F8FA1;}
.event-2507-content-2 .ly-divided-head .title.blue {--theme: #127AF2;}
.event-2507-content-2 .cards {display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; padding-left: 45px;}
.event-2507-content-2 .cards > li {border-radius: 14px; overflow: hidden; box-shadow: 5px 5px 13px rgb(0,0,0,0.1);}
.event-2507-content-2 .cards > li > img {display: block;}

.event-2507-content-3 .sp-section-head .heading1 strong {color: #127AF2}
.event-2507-content-3 .sp-section-body {display: flex; gap: 40px;}
.event-2507-content-3 .sp-section-body .content {border-radius: 20px; box-shadow: 0px 5px 6px rgb(0,0,0,0.1); overflow: hidden;}

@media screen and (max-width: 1399px) {
  .event-survey-section:not(:first-of-type) {margin-top: 100px;}
  .event-survey-section-head {padding-bottom: 18px; margin-bottom: 34px;}
  .event-survey-section-title {font-size: 34px;}
  .event-survey-article:not(:first-of-type) {margin-top: 40px; padding-top: 40px;}
  .event-survey-article-head {margin-bottom: 15px;}
  .event-survey-article-title {font-size: 18px;}
  .event-survey-article .ql-inp .checkbox-group {flex-direction: column; gap: 5px;}

  .event-2507-content-1 .cards {gap: 10px;}

  .event-2507-content-2 .heading1 img {width: 90px;}
  .event-2507-content-2 .ly-divided-head {display: none;}
  .event-2507-content-2 .cards {padding-left: 0; gap: 20px;}

  .event-2507-content-3 .sp-section-body {gap: 20px;}
}

@media screen and (max-width: 1399px) and (min-width: 768px) {
  .event-survey .ql-form-table colgroup {display: none;}
  .event-survey .ql-form-table tbody tr {display: grid; grid-template-columns: 150px 1fr; width: 100%;}
  .event-survey .ql-form-table tbody .space {display: none;}
}

@media screen and (max-width: 767px) {
  .event-survey-section:not(:first-of-type) {margin-top: 80px;}
  .event-survey-section-head {padding-bottom: 15px; margin-bottom: 24px;}
  .event-survey-section-title {font-size: 24px;}
  .event-survey-article:not(:first-of-type) {margin-top: 30px; padding-top: 30px;}
  .event-survey-article-head {margin-bottom: 10px;}
  .event-survey-article-title {font-size: 16px;}
  .event-survey-article .ql-inp .checkbox-group {gap: 0px;}

  .event-2507-content-1 .cards {grid-template-columns: repeat(2, 1fr); gap: 5px;}

  .event-2507-content-2 .heading1 img {width: 70px;}
  .event-2507-content-2 .cards {gap: 5px;}

  .event-2507-content-3 .sp-section-body {gap: 10px;}
}
@media screen and (max-width: 499px) {
  .event-2507-content-3 .sp-section-body {flex-direction: column;}
  .event-2507-content-2 .cards {grid-template-columns: repeat(1, 1fr);}
}



/* Format */
@media (hover: hover) {}
@media screen and (max-width: 1399px) {}
@media screen and (max-width: 767px) {}
@media screen and (max-width: 499px) {}



