@charset "utf-8";

@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css");

#site {
    font-family: "Pretendard Variable", "notokr", sans-serif;
    padding-top: 0px;
  opacity: 0;
}
@media (max-width: 767px) {
    #site {
        padding-top: 66px;
    }
}

ol,
ul,
li {
    list-style: none;
    list-style-position: inside;
    margin: 0;
    padding: 0;
}

p,
.table {
    margin: 0;
}
a,
a:hover,
a:focus {
    text-decoration: none;
}

#site > .container:not(.agreement_container, .privacy_container, .mypage_container) {
    width: 100%;
    padding: 0;
}

:root {
    --page-point-color: #0c4ead;
        /* google-material-symbols */
    --page-grey-color: #ddd;
    --gms: "Material Symbols Outlined";
    --gms-grad-low: "GRAD" -25;
    --gms-grad-zero: "GRAD" 0;
    --gms-grad-high: "GRAD" 200;
    --gms-opsz: "opsz" 48;
    /* fill icon */
    --gms-100-fill: "FILL" 1, "wght" 100, var(--gms-opsz);
    --gms-200-fill: "FILL" 1, "wght" 200, var(--gms-opsz);
    --gms-300-fill: "FILL" 1, "wght" 300, var(--gms-opsz);
    --gms-400-fill: "FILL" 1, "wght" 400, var(--gms-opsz);
    --gms-500-fill: "FILL" 1, "wght" 500, var(--gms-opsz);
    --gms-600-fill: "FILL" 1, "wght" 600, var(--gms-opsz);
    --gms-700-fill: "FILL" 1, "wght" 700, var(--gms-opsz);
    /* outlined icon */
    --gms-100-out: "FILL" 0, "wght" 100, var(--gms-opsz);
    --gms-200-out: "FILL" 0, "wght" 200, var(--gms-opsz);
    --gms-300-out: "FILL" 0, "wght" 300, var(--gms-opsz);
    --gms-400-out: "FILL" 0, "wght" 400, var(--gms-opsz);
    --gms-500-out: "FILL" 0, "wght" 500, var(--gms-opsz);
    --gms-600-out: "FILL" 0, "wght" 600, var(--gms-opsz);
    --gms-700-out: "FILL" 0, "wght" 700, var(--gms-opsz);
}

@media (min-width: 1240px) {
    .container {
        width: 1230px;
    }
}

/* ------------ 접근성 ------------ */
.navbar .caret {
    display: none;
}
.clip {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    clip-path: polygon(0 0, 0 0, 0 0);
}

/* ------------ 상단 메뉴 ------------ */
.navbar-inverse {
    border-bottom: none;
    background-color: transparent;
    transition: all 0.3s ease;
}
.navbar-inverse > .container{
    display: flex;
    width: 100%;
    justify-content: space-between;
    align-items: center;
    padding: 0 100px;
}
.navbar-inverse > .container::before,
.navbar-inverse > .container::after{
    content: none;
}
.navbar.navbar-inverse.on {
    box-shadow: 0px 0 7px rgba(0, 0, 0, 0.09);
    border-bottom: 0;
    background-color: #fff;
    margin: 0;
}
.navbar-right {
    margin-right: 0;
}
.navbar-inverse .navbar-brand img {
    height: 38px;
    /* margin-top: -10px;
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1); */
}
.main_l,.main_w{opacity: 0;margin-top: -10px;}
.main_l.on,.main_w.on{opacity: 1;}
.main_w{margin-top: -38px;}
.navbar-inverse.on .navbar-brand img {
    filter: none;
}
.navbar-inverse .navbar-nav > li > a {
    padding: 36px 40px;
    font-size: 19px;
    font-weight: 500;
    color: #fff;
    letter-spacing: 0;
}
.navbar-inverse.on .navbar-nav > li > a {
    color: #222;
    font-weight: 700;
}
.navbar-inverse .navbar-nav > li > a:hover,
.navbar-inverse .navbar-nav > li > a:focus {
    background: transparent;
    color: var(--page-point-color);
}
.navbar-inverse .navbar-nav .dropdown.open .dropdown-toggle,
.navbar-inverse .navbar-nav .dropdown.open:hover .dropdown-toggle,
.navbar-inverse .navbar-nav .dropdown.open:focus .dropdown-toggle {
    background: none;
    color: var(--page-point-color);
}
.navbar > .container .navbar-brand {
    z-index: 9;
    position: relative;
    width: 260px;
}
.navbar-inverse .navbar-collapse {
    position: relative;
}
.link_icon{
    width: 235px;
    text-align: right;
}
.link_icon a{
    padding: 10px 40px;
    text-align: center;
    font-size: 16px;
    background: transparent;
    border: 1px solid rgb(255 255 255 / 70%);
    color: #fff;
    font-weight: 500;
    letter-spacing: -0.03em;
    transition: all 0.3s ease;
    border-radius: 50px;
}
.link_icon a:hover{
    background: #fff;
    color: var(--page-point-color);
}
.on .link_icon a {
    border: 1px solid var(--page-point-color);
    color: var(--page-point-color);
}
@media (max-width: 767px) {
    .navbar-right{margin: 0;}
    .navbar-inverse{background-color: #fff;}
    .navbar-inverse > .container{display: block;padding: 0 15px;}
    .main_l{opacity: 1;}
    .link_icon{
        right: 60px;
        width: inherit;
        position: absolute;
        top: 22px;
    }
    .link_icon a{
        border: 1px solid var(--page-point-color);
        color: var(--page-point-color);
        padding: 4px 15px;
        font-size: 13px;
    }
    .navbar-inverse .navbar-brand {
        padding: 5px 15px;
        margin: 8px 0;
    }
    .navbar-inverse .navbar-brand img {
        margin-top: 15px;
        height: 30px;
    }

    .navbar-inverse .navbar-nav > li > a {
        padding: 15px;
    }
    .navbar-inverse .navbar-nav > li > a,
    .navbar-inverse .navbar-nav > li > a:focus {
        font-size: 17px;
        color: #333;
    }
    .navbar-nav .open .dropdown-menu {
        background-color: var(--page-point-color);
        border-radius: 0;
    }
    .navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color: #fff;}
    .navbar-inverse .navbar-toggle {
        border: 0;
        padding: 18px 0;
    }
    .navbar-inverse .navbar-toggle .icon-bar {
        background-color: #333;
        transition: ease-in-out 0.15s all;
        opacity: 1;
        position: relative;
    }
    .navbar-inverse .navbar-toggle:hover,
    .navbar-inverse .navbar-toggle:focus {
        background: transparent;
    }
    .navbar-inverse .navbar-toggle:hover .icon-bar,
    .navbar-inverse .navbar-toggle:focus .icon-bar {
        background-color: #000;
    }
    .navbar-inverse .navbar-collapse,
    .navbar-inverse .navbar-form {
        border-color: transparent;
        overflow-x: hidden;
        padding: 0;
    }
    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(1) {
        transform: rotate(45deg);
        top: 6px;
    }
    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(2) {
        opacity: 0;
    }
    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(3) {
        transform: rotate(-45deg);
        top: -6px;
    }
}

@media (min-width: 768px) {
    .navbar-inverse .navbar-nav .dropdown-menu {
        left: 50%;
        right: auto;
        transform: translate(-50%, -12px);
        border-radius: 10px;
        border: 0;
        padding: 20px 20px;
        background: var(--page-point-color);
        -webkit-box-shadow: 0 4px 8px rgba(0, 0, 0, 0.125);
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.125);
        animation-fill-mode: both;
        animation-duration: 0.4s;
        animation-name: fadeIn;
    }
    .navbar-inverse .navbar-nav .dropdown-menu > li > a {
        padding: 6px 5px;
        text-align: center;
        font-size: 15px;
        color: rgba(255,255,255,0.8);
        background: transparent;
        transition: all 0.2s;
    }

.navbar-inverse .navbar-nav .dropdown-menu > li > a:hover {
    text-decoration: underline;
    text-underline-position: under;
    color: #fff;
}
    .navbar-inverse .navbar-nav .dropdown-menu > li > a:hover,
    .navbar-inverse .navbar-nav .dropdown-menu > li > a:focus {
        color: #fff;
        background: var(--page-point-color);
    }
}

/* ------------ board ------------ */
.form-control {
    height: 42px;
    font-size: 14px;
    letter-spacing: -0.02em;
}

.btn {
    min-height: 42px;
    transition: all 0.25s ease;
    font-weight: 500;
    font-size: 15px;
}

.btn.btn-lg {
    border-radius: 100px;
    min-width: 180px !important;
    font-size: 16px;
}

#item_captcha  #captcha {
    height: 42px;
    vertical-align: bottom;
}

#item_captcha #captcha + br {
    display: none;
}

.board_wrapper .table.board_write_table tbody tr th {
    font-size: 16px;
    font-weight: 600;
    color: #222;
    letter-spacing: -0.03em;
    background: transparent;
    padding-top: 25px;
    padding-left: 20px;
}

.board_wrapper .table.board_write_table tbody tr th > span.required_text {
    color: red;
}

.board_wrapper .table.board_write_table :where(.input-group, .form-control) {
    width: 350px;
}

p.text-muted.form-caption {
    letter-spacing: -0.03em;
    font-size: 13px;
    color: #888;
}

.board_wrapper .table.board_write_table tbody tr :where(th, td) {
    padding: 20px 15px;
    border-color: #e3e3e3;
}

#wr_captcha {
    margin-top: 0 !important;
}

.checkbox.privacy_checkbox {
    margin-top: 6px !important;
    font-size: 14px;
}

.checkbox label, .radio label {
    font-size: 15px;
    letter-spacing: -0.03em;
}

.checkbox label a, .radio label a {
    font-weight: 500;
    color: var(--page-point-color);
}

/* ------------  슬라이드 ------------  */
.carousel-control.left,
.carousel-control.right {
    background-image: none;
}

.carousel-control.left .glyphicon::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: rotate(225deg);
}
.carousel-control.right .glyphicon::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
}
#mainCarousel .carousel-inner .item {
    height: 867px;
    /* height: calc(100vh - 96px); */
}
#mainCarousel .carousel-inner .item::before {
    content: "";
    width: 100%;
    height: 100%;
    background: #000;
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0.4;
}
.carousel-indicators {
    margin: 0;
    max-width: 100%;
    transform: translateX(-50%);
}
.carousel-indicators li {
    width: 60px;
    height: 5px;
    background-color: #fff;
    opacity: 0.3;
    margin: 0 7px 0 0;
    border-radius: 10px;
    transition: ease-in-out 0.15s all;
}
.carousel-indicators li.active {
    width: 60px;
    height: 5px;
    margin: 0 7px 0 0;
    opacity: 1;
}

.carousel-caption {
    color: #fff;
    text-shadow: none;
    text-align: center;
    top: 45%;
    bottom: inherit;
    transform: translateY(-50%);
}
.carousel-caption h1 {
    font-size: 58px;
    font-weight: 800;
    margin: 0px;
    margin-bottom: 40px;
}
.carousel-caption p {
    font-size: 20px;
    font-weight: 400;
    letter-spacing: 0;
}

/* ------------ footer ------------ */
#site footer {
    margin-top: 0px;
    background-color: #212121;
    color: #ccc;
}
#site footer .footer-info {
    padding: 30px 0;
}
#site footer .footer-info ul {
    position: relative;
    margin: 0;
    padding: 0;
}
#site footer .footer-info ul li:first-child {
    font-weight: 700;
    font-size: 15px;
    color: #ccc;
    margin-bottom: 5px;
}
#site footer .footer-info ul li {
    list-style: none;
    display: inline-block;
    font-size: 13.5px;
    margin-right: 15px;
    line-height: 21px;
}
#site footer .footer-info .info {
    flex-direction: column;
    padding: 0 15px;
}
#site footer .footer-info ul .copy {
    font-size: 11px;
    color: #777;
    letter-spacing: 0.08em;
}
#site footer .footer-info .row{
    display: flex;
    /* align-items: center; */
}
#site footer .footer-info .logo{
    width: 13%;
}
#site footer .footer-info .logo img{margin-top: 9px;}
#site footer .footer-info .col-md-3{
    padding-left: 30px;
}
#site footer .footer-info .col-md-3 p{
    font-size: 18px;
}
#site footer .footer-info .col-md-3 p strong{
    display: block;
    font-size: 24px;
}
@media (max-width: 767px) {
    #site footer .footer-info ul li,
    #site footer .footer-info ul li:first-child {
        font-size: 13px;
    }
    #site footer .footer-info .row{display: block;}
    #site footer .footer-info .logo{width: 100%;}
    #site footer .footer-info .logo > img {
        width: 25%;
        margin: 0 auto 20px;
    }
    #site footer .footer-info .col-md-3{
        padding-left: 15px;
        border-top: 1px solid #8181815c;
        padding-top: 20px;
        margin-top: 20px;
    }
    #site footer .footer-info .col-md-3 p{font-size: 16px;}
    #site footer .footer-info .col-md-3 p strong {font-size: 20px;}
}

/* ------------ sub 헤더 ------------ */
.sub_header {
    height: 440px;
    position: relative;
    color: #fff;
    text-align: center;
    background: #333 url("/public/img/sub/sub_header.jpg") no-repeat bottom center;
    background-size: cover;
}
[id^="company"] .sub_header{
    background: #333 url("/public/img/sub/sub_header01.jpg") no-repeat bottom center;
}
[id^="business"] .sub_header{
    background: #333 url("/public/img/sub/sub_header02.jpg") no-repeat bottom center;
}
[id^="newsroom"] .sub_header{
    background: #333 url("/public/img/sub/sub_header03.jpg") no-repeat bottom center;
}
.sub_header::before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: rgba(0,0,0,0.1);
}
.sub_header h2 {
    font-size: 60px;
    line-height: 1;
    margin: 120px 0 0;
    text-align: left;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.02em;
}
.sub_header .container {
    position: absolute;
    top: 60%;
    left: 50%;
    transform: translate(-50%, -50%);
}
@media (max-width: 767px) {
    .sub_header {
        height: 170px;
    }
    .sub_header .container{top: 50%; width: 100%;}
    .sub_header h2 {
        font-size: 35px;
        margin: 0;
        line-height: 1.2;
        text-align: center;
    }
}

/* ------------ 서브 메뉴 ------------ */
.sub_menu {
    position: relative;
    z-index: 10;
    border-bottom: 1px solid #dfdfdf;
}
.sub_menu ul {
    display: flex;
    justify-content: center;
    gap: 80px;
}
.sub_menu ul > li {
    /* width: 220px; */
}
.sub_menu ul > li > a {
    font-size: 18px;
    font-weight: 600;
    padding: 0 10px;
    color: #999;
    letter-spacing: 0;
    line-height: 72px;
    text-decoration: none;
    background: #fff;
    text-align: center;
    letter-spacing: -0.03em;
    transition: all 0.25s;
}
.sub_menu ul > li > a::after {
    content: "";
    bottom: -1px;
    left: 50%;
    width: 0;
    height: 3px;
    position: absolute;
    background: transparent;
    transform: translateX(-50%);
    transition: 0.3s;
}
.sub_menu ul > li.active > a::after,
.sub_menu ul > li:hover > a::after {
    width: 100%;
    background-color: #00b4eb;
}
.sub_menu .nav li.active a,
.sub_menu .nav li:hover a {
    background-color: #fff !important;
    font-weight: 700;
    color: #333;
}
@media (max-width: 767px) {
    .sub_menu {
        display: none;
    }
}

/* ------------ 공통 ------------  */
.content {
    padding: 60px 0 100px;
}
.content + .content {
    padding-top: 30px;
}
.content:last-child {
    padding-bottom: 150px;
}
.content_box {
    padding-bottom: 100px;
}
.content_box:last-child {
    padding-bottom: 0;
}
.page_tit {
    position: relative;
    margin: 110px 0 0;
    text-align: center;
}
.page_tit h3 {
    margin: 0 0 0;
    font-size: 38px;
    font-weight: 700;
    color: #1f1f1f;
    letter-spacing: -0.025em;
}
.sub_tit {
    position: relative;
    padding-top: 20px;
}
.sub_tit h4 {
    font-size: 30px;
    font-weight: 680;
    margin-top: 0;
    margin-bottom: 40px;
    letter-spacing: -0.035em;
    text-align: center;
    color: #222;
}

.sub_tit h4::after {
    content: '';
    background: #00408c;
    display: block;
}
.sub_tit::before {
    content: "";
    width: 7px;
    height: 7px;
    background-color: #145cc3;
    left: 0;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(calc(-50% - 5px));
    border-radius: 50%;
    box-shadow: 11px 0 0 #00b4eb;
}
.content_box h5 {
    padding-left: 12px;
    line-height: 1.5em;
    position: relative;
    font-size: 20px;
    font-weight: 600;
    margin: 0 0 20px;
    letter-spacing: -0.035em;
    color: var(--page-point-color);
}
.content_box h5::before {
    content: "";
    top: 13px;
    left: 1px;
    width: 5px;
    height: 5px;
    position: absolute;
    background: var(--page-point-color);
    border-radius: 50%;
}
.category {
    margin-top: 50px;
}
.category .nav {
    display: flex;
    justify-content: center;
    border-radius: 50px;
    width: max-content;
    background: #f3f3f3;
    margin: 0 auto;
}
.category .nav li {
    width: 180px;
    margin: 0;
    text-align: center;
}
.category .nav li.active a {
    color: #fff !important;
    background: var(--page-point-color);
}
.category .nav li a {
    font-size: 17px;
    font-weight: 500;
    padding: 18px 0;
    color: #777;
    letter-spacing: -0.03em;
    border-radius: 100px;
}

.category .nav li a:hover {
    color: #555;
}
.list-dot > li {
    padding-left: 12px;
    font-size: 16px;
    line-height: 1.5em;
    position: relative;
}
.list-dot > li::before {
    content: "";
    top: 10px;
    left: 1px;
    width: 5px;
    height: 5px;
    position: absolute;
    background: #777;
    border-radius: 50%;
}
.list-dash > li {
    padding-left: 14px;
    font-size: 16px;
    line-height: 1.5em;
    position: relative;
    letter-spacing: -0.035em;
}

.list-dash > li + li {
    margin-top: 2px;
}
.list-dash > li::before {
    content: "";
    top: 10px;
    left: 1px;
    width: 5px;
    height: 2px;
    position: absolute;
    background: #666;
    border-radius: 20px;
}
.list-num,
.list-num-basic {
    counter-reset: number 0;
}
.list-num > li,
.list-num-basic > li {
    padding-left: 28px;
    font-size: 16px;
    line-height: 1.8em;
    position: relative;
    list-style: none;
}
.list-num > li::before {
    counter-increment: number 1;
    content: counter(number);
    top: 5px;
    left: 1px;
    font-size: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    background: var(--page-point-color);
    color: #fff;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    font-weight: 700;
    padding-top: 1px;
}
.list-num-basic > li::before {
    counter-increment: number 1;
    content: counter(number) "";
    top: 5px;
    left: 1px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    color: #fff;
    width: 18px;
    height: 18px;
    background: var(--page-point-color);
    border-radius: 50%;
    font-size: 12px;
    font-weight: 600;
    padding-top: 1px;
}
.list-star > li {
    padding-left: 12px;
    font-size: 16px;
    line-height: 1.5em;
    position: relative;
}
.list-star > li::before {
    content: "*";
    top: 3px;
    left: 0px;
    position: absolute;
    border-radius: 50%;
}
.tb_style_1 {
    border-top: 2px solid var(--page-point-color);
    width: 100%;
    border-left: 2px solid #fff;
    border-right: 2px solid #fff;
}

table.tb_style_1.mro_table {
    border-top: 2px solid #888;
}

.tb_style_1 .tr_bg {
    background: #f4f9ff;
}
.tb_style_1 tr {
    border-bottom: 1px solid #e3e3e3;
}
.tb_style_1 tr :is(th, td) {
    font-size: 16px;
    padding: 15px 10px;
    color: #333;
    font-weight: 400;
    border-left: 1px solid #e3e3e3;
    white-space: nowrap;
    text-align: center;
    line-height: 1.5;
    letter-spacing: -0.03em;
}

.mro_table.tb_style_1 tr :is(th, td) {
    color: #555;
    padding: 10px;
}

.mro_table.tb_style_1 tr :is(th) {
    background: #f6f6f6;
    color: #555;
    border-bottom-color: #aaa;
}
.tb_style_1 tr :is(th) {
    background: #f4f9ff;
    color: var(--page-point-color);
    font-weight: 600;
    padding: 15px 0;
    font-size: 17px;
    border-bottom: 1px solid var(--page-point-color);
}
.tb_style_1 tr :is(th, td):last-child {
    border-right: 1px solid #ddd;
}
.tb_style_1 tbody tr :is(th) {
    background: #fafafa;
    font-weight: 500;
    color: #333;
}
/* login */
.member_wrapper {
    padding-top: 170px;
    padding-bottom: 260px;
}
/* board, form */
input + #list_btn {
    display: none;
}
.board_wrapper {
    margin-top: 0;
}
.btn.btn-primary {
    background-color: var(--page-point-color);
    border: 1px solid var(--page-point-color);
}
.btn.btn-primary:hover,
.btn.btn-primary:focus {
    background-color: var(--page-point-color);
}
.table_default {
    border-top: 2px solid #333;
}
.table.table_default tr th,
.table.table_default tr td {
    padding: 20px 5px;
    border-color: #e3e3e3;
}
.table.table_default thead th {
    background: #fff;
    border-bottom: 1px solid #ddd;
    font-weight: 600 !important;
    font-size: 16px;
    letter-spacing: -0.02em;
    padding: 21px 0;
    color: #222;
}
.table.table_default tr td {
    color: #777;
    letter-spacing: -0.03em;
}
.table.table_default tr .num {
    font-weight: normal;
}

.table.table_default tbody .subject a {
    font-size: 16px;
    letter-spacing: -0.03em;
    color: #333;
}
.table.table_default tbody .subject a:hover {
    text-decoration: underline;
}
.table.table_default colgroup .hits_col {
    width: 80px;
}
:where(.table_video, .table_blog2, .table_pd, .table_blog, .table_default, .board_pd_view .pd_title_wrap) .badge {
    padding: 4px 7px;
    background: #4a93f1;
    vertical-align: middle;
}
.board_data_view {
    border-top: 2px solid #333;
    border-bottom: 1px solid #ccc;
}
.board_data_view .header_wrap .title {
    font-size: 22px;
    font-weight: 600;
    color: #222;
    letter-spacing: -0.015em;
}
.board_data_view .header_wrap {
    text-align: left;
    border-bottom: 1px solid #e3e3e3;
    padding: 30px 15px;
}
.contents_inner p {
    font-size: 17px;
}
@media (max-width: 767px) {
    .page_tit{margin: 80px 0 0;}
    .page_tit h3 {font-size: 30px;}

    .sub_tit h4{font-size: 28px;}

    .board_wrapper .table colgroup,
    .board_wrapper .table tr .num,
    .board_wrapper .table tr .hits {
        display: none;
    }
    .board_wrapper .table.table_default tr th,
    .board_wrapper .table.table_default tr td {
        padding: 10px;
        font-size: 12px;
    }
    .board_wrapper .table.board_write_table :where(.input-group, .form-control) {
        width: 100%;
    }
    .table.table_default tbody .subject a {
        font-size: 15px;
    }
    .board_wrapper .table .subject {
        width: 45%;
    }
    .board_write_table #captcha {
        margin-bottom: 10px;
        height: inherit;
    }

    .member_wrapper {
        padding-top: 100px;
        padding-bottom: 200px;
    }
    .member_wrapper .login_extra ul {
        display: flex;
        flex-direction: column;
        gap: 7px;
    }
    .member_wrapper .login_extra ul li + li::before {
        content: none;
    }
}

/* ------------ main ------------ */
.video-section{
    display: flex;
    position: relative;
}
.video-section::before {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: #000;
    opacity: 0.45;
}
.video-section video{    
    height: 100vh;
    object-fit: fill;
}
.slide_as{
    position: absolute;
    transform: translateX(-50%);
    left: 50%;
    bottom: 75px;
    display: grid;
    grid-template-columns: 200px 1000px;
    align-items: center;
}
.slide_as::after,.slide_as::before{
    content:none;
}
.slide_as .down_area{margin-right: 40px;}
.slide_as .down_area a{
    border: 1px solid #dddddd8f;
    width: 150px;
    margin: 20px auto 0;
    backdrop-filter: blur(10px);
    padding: 8px 0;
    color: #fff;
    font-size: 13px;
}
.slide_as .down_area a:hover{
    background: var(--page-point-color);
    border-color: var(--page-point-color);
}
.slide_as .down_area a span{font-size: 20px;}
.slide_as h4{
    color: #fff;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
    margin: 0;
}
.slide_as h4 small{
    display: block;
    color: #fff;
    margin-top: 5px;
}
.main_license_item{
    background: #ffffffa6;
    margin: 0 2px;
    padding: 10px 44px;
}
.main_license_item img{
    width: 70px;
    margin: 0 auto;
}
.main_license_item .tit{
    font-weight: 700;
    font-size: 21px;
    text-align: center;
}
.main_license_item .tit small{
    display: block;
    font-size: 15px;
}
#main_license_slider .slick-prev::before{
    content:"\e5cb";
    font-family: var(--gms);
}
#main_license_slider .slick-next::before{
content:"\e5cc";
font-family: var(--gms);
padding-left: 1px;
}
#main_license_slider .slick-prev::before, 
#main_license_slider .slick-next::before{
    background: #0000008a;
    color: #fff;
    border-radius: 50%;
    display: block;
}
.main_section {
    padding: 160px 0;
}
.main_page_tit {
    margin-bottom: 80px;
}
.main_page_tit h3 {
    margin: 0;
    font-size: 65px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: -0.03em;
    line-height: 1;
    color: #111;
}
.main_page_tit p {
    font-size: 20px;
}

.main_section#se01 {
    background: url('/public/img/main/se01_bg.jpg') no-repeat center / cover;
}

#se01 .main_page_tit h3{
    color: #fff;
}

#se01 .main_page_tit {display: flex;gap: 40px;align-items: center;margin-bottom: 80px;}

#se01 .main_page_tit p {
    color: #fff;
    letter-spacing: -0.03em;
    line-height: 1.4;
}
.main_bs_items {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}
.main_bs_item {
    height: 400px;
    position: relative;
    /* display: flex; */
    /* align-items: flex-end; */
    overflow: hidden;
    text-align: center;
    color: #fff;
    box-shadow: 5px 5px 20px rgba(0,0,0,0.3);
    flex-flow: column;
}
.main_bs_item .txt_area::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: top center;
    transition: transform calc(0.7s * 1.5) cubic-bezier(0.19, 1, 0.22, 1);
}
.main_bs_item .txt_area::after {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    opacity: 0;
    background: rgb(0 57 137 / 80%);
    transition: all 0.7s cubic-bezier(0.19, 1, 0.22, 1);
    backdrop-filter: blur(10px);
}

.main_bs_item:hover .txt_area::after {opacity: 1;}
.main_bs_item:nth-child(1) .txt_area::before {
    background-image: url(/public/img/main/mbs01.jpg);
}
.main_bs_item:nth-child(2) .txt_area::before {
    background-image: url(/public/img/main/mbs02.jpg);
}
.main_bs_item:nth-child(3) .txt_area::before {
    background-image: url(/public/img/main/mbs03.jpg);
}
.main_bs_item:nth-child(4) .txt_area::before {
    background-image: url(/public/img/main/mbs04.jpg);
}
.main_bs_item .txt_area {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 300px;
    z-index: 1;
    transition: all 0.7s cubic-bezier(0.19, 1, 0.22, 1);
    overflow: hidden;
}
.main_bs_item:hover .txt_area {
    opacity: 1;
}
.main_bs_item .txt_area .sub_area {
    opacity: 0;
    transition: 0.7s cubic-bezier(0.19, 1, 0.22, 1);
    z-index: 1;
    /* transform: translateY(calc(100% - 20rem)); */
    width: 100%;
    color: #fff;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-flow: column;
    padding-top: 40px;
}
.main_bs_item:hover .txt_area .sub_area {
    opacity: 1;
    transform: translateY(-30px);
}
.main_bs_item  .tit {
    font-size: 23px;
    font-weight: 700;
    margin-bottom: 0;
    height: 100px;
    color: #222;
    letter-spacing: -0.035em;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}
.main_bs_item .txt_area p {
    line-height: 1.8;
    margin-bottom: 24px;
    font-size: 16px;
    letter-spacing: -0.03em;
}
.m_link_btn {
    color: #333;
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 14px;
    width: 160px;
    justify-content: center;
    padding: 14px 0;
    border-radius: 50px;
    transition: all 0.3s;
    font-weight: 500;
    letter-spacing: -0.015em;
    color: #fff;
    margin: 0 auto;
    border: 1px solid #fff;
}

.m_link_btn span {
    font-size: 20px;
}
.m_link_btn:hover {
    background: #fff;
    color: #333;
}
#se02 {
    background: url('/public/img/main/se02_bg.jpg') no-repeat center / cover;
    padding: 160px 0 130px;
}
#se02 .col-md-8{padding-right: 15px;min-height: 480px;}

#se02 .col-md-8 .txt_area {
    box-shadow: 5px 5px 20px rgba(0,0,0,0.08);
    background: #fff;
    padding: 35px;
}
#se02 .col-md-8 .txt_area .tit {
    display: flex;
    justify-content: space-between;
    font-size: 30px;
    font-weight: 600;
    margin: 0;
    letter-spacing: -0.035em;
    color: #222;
    gap: 30px;
}
#se02 .col-md-8 .txt_area .tit .m_link_btn {
    border: 1px solid #e3e3e3;
    background: #fff;
    color: #333;
    margin-right: 0;
}

#se02 .col-md-8 .txt_area .tit .m_link_btn:hover {
    background: var(--page-point-color);
    border-color: var(--page-point-color);
    color: #fff;
}
#se02 .col-md-8 .txt_area p {
    font-size: 16px;
    line-height: 1.6;
    margin: 20px 0 44px;
    letter-spacing: -0.035em;
}
#se02 .board_widget > div {
    background: #fff;
    padding: 35px 35px;
    min-height: 480px;
    box-shadow: 5px 5px 20px rgba(0,0,0,0.08);
}
.board_widget .page-header {
    margin-block: 0 20px;
    color: #222;
    border-bottom: 2px solid #333333;
    padding-bottom: 20px;
}
.board_widget .page-header h4 {
    color: inherit;
    display: inline-block;
    font-weight: 700 !important;
    font-size: clamp(20px, 3vw, 22px);
    letter-spacing: -0.03em;
    margin: 0;
}
.board_widget .page-header i::before {
    position: relative;
    display: block;
    content: "\e145" !important;
    translate: 5px 2px;
    font-family: "Material Symbols Outlined";
    font-variation-settings: "FILL" 0, "wght" 300, "opsz" 48;
    font-size: 27px;
    font-weight: 500;
    color: inherit;
}
.board_widget .type_list li {
    padding: 0;
    display: flex;
    flex-direction: column;
}
.board_widget .type_list li + li{
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid #e3e3e3;
}
.board_widget .type_list a:hover {
    text-decoration: underline;
}
.board_widget .type_list :where(li, a) {
    line-height: 1;
    font-size: 16px;
    color: #222;
    width: 100%;
    text-align: left;
    letter-spacing: -0.04em;
}
.board_widget .type_list .info {
    width: 100%;
    float: none !important;
    text-align: left;
    margin-top: 10px;
}
.type_list .info span{margin: 0;font-size: 13px;letter-spacing: 0;}
.board_widget .type_list .info span:not(.regdate) {
    display: none;
}
#se03{
    padding: 50px 0;
    background: #f7f7f7;
}
#se03 .inner{
    display: grid;
    grid-template-columns: 300px 1fr;
    align-items: center;
}
#se03 .txt_area h4{
    letter-spacing: -0.035em;
    color: #222;
    font-size: 30px;
    font-weight: 600;
}
#se03 .txt_area p{
    font-size: 16px;
    line-height: 1.6;
    margin: 20px 0 15px;
    letter-spacing: -0.035em;
}
#se03 .txt_area .num{
    font-weight: 700;
    font-size: 18px;
    margin: 0;
}
#se03 .txt_area .num strong{
    color: var(--page-point-color);
    margin-left: 10px;
    font-size: 28px;
}
#se03 .img_area{position: relative;}
#se03 .img_area:hover .overlay_box {
    opacity: 1;
}
.overlay_box {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    background: rgba(0, 0, 0, 0.5);
    transition: all 0.3s ease;
    z-index: 90;
    transition: 0.3s;
    opacity: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.overlay_box a{
    color: #fff;
    border: 1px solid #fff;
    padding: 10px 0;
    width: 190px;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}
.overlay_box a span{
    --wght: 100;
    font-size: 29px;
}
.last_link{
    padding: 15px 0;
}
.last_link .inner{
    display: flex;
    gap: 20px;
}
.last_link p{
    display: flex;
    align-items: center;
    font-size: 16px;
    font-weight: 700;
}
.last_link p span{
    margin-top: -3px;
}
.last_link ul{
    display: flex;
    gap: 30px;
}
.last_link ul li a{
    font-size: 16px;
    font-weight: 400;
    position: relative;
    color: #333;
    font-weight: 700;
}
.last_link ul li a::before {
    content: '';
    display: block;
    position: absolute;
    width: 1px;
    height: 12px;
    background: #ddd;
    right: -16px;
    top: 50%;
    transform: translateY(-50%);
}
.last_link ul li:last-child a::before{
    content:none;
}

/* ------------ company01 ------------  */
.greet {
    margin-top: 60px;
}
.greet .img_area {
    padding-right: 60px;
}
.greet .txt_area > p {
    font-size: 24px;
    margin-bottom: 40px;
    margin-top: 0;
    font-weight: 500;
    letter-spacing: -0.04em;
    line-height: 1.6;
}

.greet .txt_area > p strong {
    color: var(--page-point-color);
}
.greet .txt_area ul {border-top: 2px solid #333;border-bottom: 1px solid #ddd;padding: 50px 10px;}
.greet .txt_area ul li {
    display: flex;
    align-items: center;
    /* gap: 20px; */
    font-size: 16px;
    letter-spacing: -0.03em;
    color: #555;
}
.greet .txt_area ul li + li {
    margin-top: 15px;
}
.greet .txt_area ul .tit {
    position: relative;
    /* display: inline-block; */
    width: 100px;
    font-weight: 600;
    color: #222;
    /* border-top: 1px solid; */
    /* padding-top: 10px; */
    /* margin-top: -1px; */
    line-height: 1;
}
.greet .txt_area ul .tit::before {
    content: "";
    width: 5px;
    height: 5px;
    background: var(--page-point-color);
    border-radius: 50%;
}

/* ------------ company02 ------------  */
.list_mission {
    display: flex;
    justify-content: center;
    margin-top: 48px;
}
.list_mission li {
    box-shadow: 7px 15px 30px rgba(0, 0, 0, 0.032);
    border-radius: 50%;
    width: 310px;
    /* height: 230px; */
    aspect-ratio: 1;
    text-align: center;
    display: flex;
    justify-content: center;
    flex-direction: column;
    border: 20px solid #1d499e;
    margin: 0 -10px;
    mix-blend-mode: multiply;
    color: #333;
    background: #fff;
    /* box-shadow: 0 15px 30px rgba(0,0,0,0.15); */
}
.list_mission li .tit {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 16px;
    letter-spacing: -0.02em;
    color: #222;
}

.list_mission li:nth-child(2) {
    border-color: #1d82c9;
}

.list_mission li:nth-child(3) {
    border-color: #17baef;
}
.list_mission li p {
    font-size: 17px;
    letter-spacing: -0.03em;
    font-weight: 500;
    color: #555;
}
.history_items {
    position: relative;
}
.history_items::before {
    /* content: ""; */
    display: block;
    width: 1px;
    background: #ddd;
    position: absolute;
    left: 197px;
    height: 100%;
}
.history_item {
    display: grid;
    grid-template-columns: 23% auto;
    position: relative;
    gap: 30px;
    max-width: 1000px;
    margin: 10px auto 0;
}

.history_item ul {
    border-top: 1px solid #ccc;
    padding: 30px 45px;
}
.history_item .year {
    position: relative;
    line-height: 1;
    color: var(--page-point-color);
    letter-spacing: -0.015em;
    font-weight: 700;
    font-size: 40px;
    margin: 0;
    border-top: 1px solid;
    padding-top: 25px;
}
.history_item .year::before {
    /* content: ""; */
    display: block;
    position: absolute;
    width: 50px;
    height: 1px;
    left: 133px;
    top: 17px;
    border: 1px dashed #ddd;
}
.history_item .year::after {
    z-index: 10;
    /* content: ""; */
    display: block;
    box-sizing: content-box;
    width: 7px;
    height: 7px;
    background-color: var(--page-point-color);
    border: 7px solid #d6e2f1;
    position: absolute;
    border-radius: 50%;
    right: 54px;
    top: 8px;
}
.history_item ul li {
    display: flex;
    gap: 40px;
    font-weight: 400;
    line-height: 1.85;
    color: #777;
    font-size: 16px;
    position: relative;
    letter-spacing: -0.035em;
}

.history_item ul li + li {
    margin-top: 20px;
}
.history_item ul li .date {
    font-weight: 700;
    color: #444;
    margin-top: -1px;
    font-size: 17px;
    min-width: 25px;
}

/* ------------ company03 ------------ */
.list_license {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
.list_license li > .img_box {background: #f6f6f6;padding: 40px;}

.list_license li > .img_box  img {
    box-shadow: 0 0 30px rgba(0,0,0,0.08);
    padding: 5px;
    background: #fff;
}
.list_license li > .tit{
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 19px;
    font-weight: 700;
    gap: 5px;
    margin-bottom: 10px;
}
.list_license li > .tit img{
    width: 60px;
}
.down_area a{
    border: 2px solid #ddd;
    border-radius: 50px;
    padding: 10px 0;
    font-weight: 700;
    width: 230px;
    margin: 50px auto 0;
    box-shadow: 0px;
    color: #444;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    gap: 10px;
    transition: all 0.5s;
}
.down_area a:hover{
    box-shadow: 0 0rem 1rem rgba(14, 17, 31, .16);
}

/* ------------ company04 ------------ */
.map .detail {
    display: flex;
    justify-content: space-between;
    margin-top: 30px;
}
.map .detail > div {
    display: flex;
    gap: 40px;
}
.map .detail .tit {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.8;
    color: var(--page-point-color);
}
.map .detail .info {
    display: flex;
    gap: 10px;
    font-weight: 500;
    letter-spacing: -0.03em;
}
.map .detail p {
    font-size: 19px;
}
.map .detail > .info {
    width: 60%;
}
.map .detail > .info span {
    background: var(--page-point-color);
    border-radius: 50%;
    text-align: center;
    font-size: 17px;
    color: #ffff;
    padding: 6px 0 0;
    width: 28px;
    height: 28px;
}

/* ------------ public01 ------------ */
#public01 .table-responsive {
    margin-bottom: 60px;
}
.ex_area {
    text-align: center;
    padding: 40px;
    background: #eef5fd;
}
.ex_area .tit {
    font-weight: 600;
    font-size: 24px;
    letter-spacing: -0.032em;
}
.ex_area .result {
    font-weight: 600;
    font-size: 24px;
    background: #0e55a9;
    color: #fff;
    padding: 14px;
    border-radius: 12px;
    letter-spacing: -0.03em;
}
.plus_items {
    display: flex;
    gap: 20px;
}
.plus_item {
    position: relative;
    flex: 1;
    padding: 30px 0;
    margin: 30px 0 35px;
    background: #fff;
    font-size: 17px;
    border-radius: 12px;
    font-weight: 500;
    color: #555;
    letter-spacing: -0.03em;
    box-shadow: 5px 5px 20px rgb(0 44 113 / 10%);
}
.plus_item::before {
    content: "\e145";
    font-family: "Material Symbols Outlined";
    transform: translateY(-50%);
    top: 50%;
    right: -27px;
    position: absolute;
    border-radius: 50%;
    color: #fff;
    font-weight: 600;
    font-size: 23px;
    background: #175fb5;
    width: 30px;
    height: 30px;
    z-index: 1;
}
.plus_item:last-child:before {
    content: none;
}
.about_items{
    margin-bottom: 60px;
}
.about_item{
    font-size: 17px;
    text-align: center;
    margin-top: 50px;
}
.about_item .tit{
    display: inline-block;
    border: 2px solid #ddd;
    border-radius: 50px;
    padding: 10px 0;
    font-weight: 700;
    width: 165px;
    text-align: center;
    margin-bottom: 20px;
    /* box-shadow: 0 0rem 1rem rgba(14, 17, 31, .16); */
}

/* ------------ business01 ------------ */
.bs_items {
    display: grid;
    gap: 20px;
}
.bs_item {
    padding: 40px 40px 50px;
    background: #f6f6f6;
    display: flex;
    gap: 40px;
    align-items: center;
    justify-content: center;
}
.bs_item span {
    color: var(--page-point-color);
    width: 110px;
    aspect-ratio: 1;
    font-size: 55px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-variation-settings: var(--gms-200-out);
    background: #fff;
    box-shadow: 0px 0px 15px rgba(0,0,0,0.025);
}
.bs_item .txt_area {
    width: 70%;
}
.bs_item .txt_area > .tit {
    font-size: 22px;
    font-weight: 700;
    color: #111;
    margin: 0px 0 15px;
    letter-spacing: -0.03em;
}
.bs_item .txt_area > .tit + p {
    font-size: 17px;
    color: #555;
    letter-spacing: -0.035em;
    word-break: keep-all;
    line-height: 1.55;
}
.link_area{
    color: var(--page-point-color);
    font-weight: 600;
    font-size: 17px;
    letter-spacing: -0.035em;
    line-height: 1.55;
    margin-top: 5px;
    display: flex;
    gap: 5px;
}
.link_area p{
    display: flex;
}
.link_area p::after{
    content: '\e941';
    font-family: var(--gms);
    color: inherit;
    font-size: 17px;
}
.link_area a{
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--page-point-color);
    margin-top: -2px;
}
.link_area a:hover{
    text-decoration: underline;
}

/* ------------ business02 ------------ */
.intro_txt {
    font-size: 22px;
    margin: 0 auto 100px;
    text-align: center;
    font-weight: 500;
    word-break: keep-all;
    letter-spacing: -0.035em;
    line-height: 1.6;
    /* color: #222; */
    /* max-width: 60%; */
}

.intro_txt strong {
    margin-right: 20px;
}
.detail_area > p {
    font-size: 18px;
    margin: -10px auto 50px;
    letter-spacing: -0.035em;
    word-break: keep-all;
    text-align: center;
    color: #555;
    line-height: 1.6;
    font-weight: 500;
    max-width: 800px;
}
.mro_area {
    display: flex;
    gap: 30px;
}
.mro_area > div {
    flex: 1;
}
.table_box .tit {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 0;
    text-align: center;
    background: #888;
    color: #fff;
    padding: 12px;
    border-right: 2px solid #fff;
}
.spec_box {
    border: 1px solid var(--page-point-color);
    box-shadow: 5px 5px 20px rgba(0,0,0,0.1);
    text-align: center;
}
.spec_box .tit {
    background: var(--page-point-color);
    color: #fff;
    font-size: 24px;
    font-weight: 600;
    padding: 32px 0;
    text-align: center;
    letter-spacing: -0.05em;
}
.spec_box .tit span {
    margin-left: 5px;
    /* display: block; */
    text-decoration: underline;
    text-underline-position: under;
    text-decoration-thickness: 1px;
    color: #fffc76;
    letter-spacing: 0;
}
.spec_box ul {
    text-align: center;
    width: max-content;
    margin: 49px auto 0px;
}
.spec_box ul li {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: -0.03em;
    flex: 1;
    word-break: keep-all;
    position: relative;
    display: flex;
    align-items: center;
    padding-left: 34px;
}

.spec_box ul li::before {
    content: '\e5ca';
    font-family: var(--gms);
    font-variation-settings: var(--gms-grad-high);
    border-radius: 3px;
    position: absolute;
    left: 0;
    top: -4px;
    color: #ff4040;
    font-size: 24px;
}
.spec_box ul li + li {
    margin-top: 15px;
}
.service_area {
    display: grid;
    /* grid-template-columns: 67% 1fr; */
    gap: 40px;
}

.service_area .img_area img {
    max-width: 940px;
}
.detail_area .img_area {
    /* border: 1px solid #ddd; */
    /* padding: 50px 10px; */
}

.detail_area .img_area img {
    /* max-width: 1000px; */
}
.effect_items {
    display: flex;
    justify-content: center;
    /* background: #f6f6f6; */
    gap: 30px;
} 
.effect_item {/* display: flex; *//* align-items: center; */gap: 40px;max-width: 450px;min-width: 450px;border: 1px solid #a2a2c1;}
.effect_item:first-child {
    margin-bottom: 0;
}
.effect_item .tit {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 0;
    letter-spacing: -0.03em;
    position: relative;
    padding-left: 0;
    background: #474ca9;
    text-align: center;
    word-break: keep-all;
    color: #fff;
    line-height: 1.4;
    align-items: center;
    justify-content: center;
    display: flex;
    /* width: 140px; */
    /* aspect-ratio: 1; */
    /* flex-flow: column; */
    /* border-radius: 20px; */
    padding: 10px;
}
.effect_item > ul {
    /* margin-top: 10px; */
    /* padding-left: 20px; */
    padding: 28px;
}
.effect_item > ul li {
    color: var(--page-point-color);
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.03em;
}

.effect_item > ul li ul {
    margin-top: 5px;
}
.effect_item > ul > li + li {
    margin-top: 20px;
}
.effect_item ul li .list-dash li {
    font-weight: 400;
    color: #555;
    font-size: 16px;
}
.value_items {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}
.value_item {
    flex: 1 0 23%;
    text-align: center;
    padding: 55px 30px 50px;
    background: #f6f6f6;
}
.value_item > .tit {
    display: flex;
    font-size: 22px;
    font-weight: 700;
    color: #111;
    margin: 0px 0 20px;
    letter-spacing: -0.03em;
    flex-flow: column-reverse;
    align-items: center;
    gap: 35px;
}
.value_item > .tit span {color: var(--page-point-color);width: 110px;aspect-ratio: 1;font-size: 65px;border-radius: 50%;display: flex;justify-content: center;align-items: center;font-variation-settings: var(--gms-200-out);background: #fff;box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.025);}
.value_item .txt_area {
    font-size: 15px;
    letter-spacing: -0.03em;
    color: #555;
    word-break: keep-all;
    line-height: 1.5;
}
.value_item .txt_area strong {
    display: block;
    margin-bottom: 20px;
    color: var(--page-point-color);
    line-height: 1.4;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.035em;
}
.list_cus {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}
.list_cus li {
    /* border: 1px solid #ddd; */
    padding: 10px 50px;
    display: flex;
    align-items: center;
}
.list_cus li img {
    max-height: 72px;
}

/* ------------ business03_01 ------------ */
.list-num.ex_list {
    display: flex;
    gap: 10px 40px;
    justify-content: center;
    flex-flow: column;
    width: max-content;
    margin: 0 auto;
}

.list-num.ex_list li {
    font-weight: 500;
    letter-spacing: -0.03em;
    font-size: 17px;
}
.ex_items {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
    margin-top: 60px;
}
.ex_item p {
    font-size: 16px;
    text-align: center;
    margin-top: 13px;
    font-weight: 600;
    letter-spacing: -0.03em;
}
.list_pro {
    display: flex;
    gap: 40px;
    margin-top: 60px;
}
.list_pro li {
    flex: 1;
    border-radius: 20px;
    background: #f6f6f6;
    position: relative;
}
.list_pro li .txt_area {
    position: relative;
    text-align: center;
    display: flex;
    align-items: center;
    border-radius: 50px;
    flex-flow: column;
    margin-top: -24px;
}
.list_pro li::before {
    content: "\e5e1";
    font-family: "Material Symbols Outlined";
    transform: translateY(-50%);
    top: 50%;
    right: -35px;
    position: absolute;
    color: #c2c9d3;
    font-weight: 500;
    font-size: 25px;
}

.list_pro li:last-child::before {
    content: none;
}
.list_pro li:last-child .txt_area::before {
    content: none;
}
.list_pro li .txt_area span {
    font-weight: 600;
    font-size: 22px;
    background: var(--page-point-color);
    color: #fff;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 7px 15px 30px rgba(0, 0, 0, 0.032);
    margin-bottom: 20px;
    border: 6px solid #fff;
}
.list_pro li .txt_area p {
    font-weight: 600;
    font-size: 18px;
    color: var(--page-point-color);
}
.list_pro li .txt_area small {
    font-size: 13px;
}
.list_pro li .tit {
    text-align: center;
    margin-top: 10px;
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.035em;
    padding-bottom: 35px;
}

/* ------------ business03_02 ------------ */
.work_area {
    background: #f7f7f7;
    padding: 40px;
    text-align: center;
}
.work_area > .tit {
    color: var(--page-point-color);
    font-size: 20px;
    font-weight: 600;
    margin: -10px auto 30px;
}
.work_items {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}
.work_item {
    flex: 1;
    background: #fff;
    width: 100%;
    box-shadow: 5px 5px 20px rgba(0,0,0,0.1);
}
.work_item > .tit {
    background: var(--page-point-color);
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    padding: 15px;
    letter-spacing: -0.03em;
}
.work_item .txt_area {
    font-size: 16px;
    padding: 0 30px;
    min-height: 108px;
    display: flex;
    align-items: center;
    letter-spacing: -0.03em;
    color: #555;
    line-height: 1.6;
    word-break: keep-all;
}
.work_item .img_area {
    display: flex;
    gap: 10px;
    border: 0;
    padding: 0px 30px 30px;
}

/* ------------ business04 ------------ */
.system {
    margin: -40px 0 100px;
}
.system > .tit {
    font-size: 24px;
    font-weight: 500;
    text-align: center;
    color: #2d3081;
    letter-spacing: -0.02em;
    border: 1px solid;
    border-radius: 50px;
    padding: 7px 30px;
    margin: 0 auto 40px;
    width: max-content;
}
.system > img {
}
.site_txt {
    display: grid;
    gap: 55px;
    grid-template-columns: 350px 1fr;
    border: 8px solid #f2f2f2;
    padding: 40px 120px 40px 40px;
    align-items: center;
    position: relative;
    color: #555;
}

.site_txt .img_box {
    background: #fff;
    text-align: center;
}
.link_btn {
    background: #fff;
    padding: 8px 20px;
    margin-top: 10px;
    display: inline-flex;
    color: var(--page-point-color);
    transition: all 0.25s ease;
    border: 1px solid var(--page-point-color);
    justify-content: space-between;
    gap: 9px;
    align-items: center;
    border-radius: 112px;
    align-items: center;
}

.link_btn::after {
    content: '\f8ce';
    font-family: var(--gms);
    color: inherit;
    font-size: 16px;
    line-height: 1;
}
.link_btn:hover {
    background: var(--page-point-color);
    color: #fff;
    border-color: var(--page-point-color);
}
.site_txt ul > li {
    font-size: 16px;
    letter-spacing: -0.03em;
    word-break: keep-all;
    padding-left: 20px;
}
.site_txt ul > li + li {
    margin-top: 35px;
}
.site_txt ul > li .tit {
    /* color: var(--page-point-color); */
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 8px;
    letter-spacing: -0.03em;
    position: relative;
    padding-left: 0;
    color: #222;
}

.site_txt ul > li .tit::before {
    content: '\e5ca';
    font-family: var(--gms);
    font-variation-settings: var(--gms-grad-high);
    border-radius: 3px;
    position: absolute;
    left: -30px;
    top: -4px;
    color: #ff4040;
    /* transform: rotate(45deg); */
    font-size: 24px;
}

/* ------------ newsroom01 ------------ */
#newsroom01 .con01 .list-dash {
    margin: -20px auto 0;
    background: #f6f6f6;
    padding: 30px 40px;
}
#newsroom01 .detail_area .img_area {
    margin-top: 60px;
}
#newsroom01 .detail_area .img_area img {
    max-width: 800px;
}
.newsroom_contact {
    padding: 30px 80px;
    background: #f6f6f6;
    display: flex;
    gap: 50px;
    width: 100%;
    justify-content: center;
}
.newsroom_contact p {
    font-size: 18px;
    letter-spacing: -0.01em;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 13px;
}
.newsroom_contact span.material-symbols-outlined {
    width: 30px;
    aspect-ratio: 1;
    border-radius: 50%;
    background: var(--page-point-color);
    color: #fff;
    text-align: center;
    font-size: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* ------------ floating ------------ */
#floating {
    top: 440px;
    right: 20px;
    width: 254px;
    height: 499px;
    overflow: hidden;
    z-index: 9999;
    position: fixed;
}
#floating .inner {
    display: grid;
    grid-template-columns: 35px 1fr;
    transition: all 0.3s;
}
#floating.on .inner {
    margin-left: 130px;
}
#floating .arrow_area {
    border: 1px solid #e5e5e5;
    border-right: 0;
    height: 75px;
    background: #f5f5f5;
    display: flex;
    align-items: center;
    justify-content: center;cursor: pointer;
}
#floating .arrow_area span {
    color: #8f8f8f;
    font-size: 20px;
    font-variation-settings: var(--gms-400-out);
    transition: all 0.3s;
}
#floating.on .arrow_area span {
    transform: rotate(180deg);
}
#floating ul li {
    border: 1px solid #e5e5e5;
    margin-bottom: -1px;
    padding: 10px 18px;
    background: #fff;
}
#floating ul li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
#floating.on ul li a {
    justify-content: center;
}
#floating ul li a img {
    width: 18px;
}
#floating ul li a span {
    color: var(--page-point-color);
    font-size: 16px;
    font-weight: 600;
    width: 92px;
    opacity: 1;
    transition: all 0.3s;
}
#floating.on ul li a span {
    opacity: 0;
    display: none;
}
#floating ul li a .material-symbols-outlined {
    transform: rotate(45deg);
    color: #aeaeae;
    width: auto;
    font-size: 32px;
    font-variation-settings: var(--gms-200-out);
}
#floating ul .cs_area {
    background: #f5f5f5;
    padding: 19px 15px;
}
#floating.on ul .cs_area {
    padding: 13px 18px;
    background: #fff;
}
#floating ul .cs_area a {
    opacity: 0;
    pointer-events: none;
}
#floating.on ul .cs_area a {
    opacity: 1;
    pointer-events: painted;
}
#floating ul .cs_area .cs_box {
    margin-top: -20px;
}
#floating.on ul .cs_area .cs_box {
    display: none;
}
#floating ul .cs_area .cs_box b {
    color: #403f3f;
    font-size: 14px;
    font-weight: 900;
    letter-spacing: -0.3px;
}
#floating ul .cs_area .cs_box p {
    color: var(--page-point-color);
    margin: 10px 0;
    font-size: 23px;
    font-weight: 800;
}
#floating ul .cs_area .cs_box p small {
    display: block;
    font-size: 15px;
}
#floating ul .cs_area .cs_box span {
    color: #666;
}
#floating ul .scroll_top {
    text-align: center;
    font-size: 16px;
    font-weight: 600;
    background: var(--page-point-color);
    color: #fff;
    border: 1px solid var(--page-point-color);
    cursor: pointer;
}
@media (max-width: 767px) {
    .video-section{flex-direction: column;}
    .video-section video{
        height: 450px;
        object-fit: cover;
    }
    .carousel-caption {
        right: 20%;
        left: 20%;
        top: 23%;
    }
    .carousel-caption h1 {
        font-size: 20px;
        margin-bottom: 15px;
    }
    .carousel-caption p {
        font-size: 13px;
    }
    .carousel-control {
        font-size: 14px;
    }
    .carousel-indicators li,
    .carousel-indicators li.active {
        width: 8px;
        height: 8px;
    }
    .carousel-indicators {
        bottom: 30px;
    }
    .slide_as {
        position: initial;
        transform: none;
        display: block;
        padding: 20px 40px 40px;
        z-index: 99;
        margin-top: -262px;
    }
    .slide_as .down_area{margin: 0 0 20px;}
    .slide_as h4{    font-size: 17px;}
    .slide_as .down_area a {
        width: 130px;
        padding: 8px 0;
        font-size: 11px;
    }
    .slide_as .down_area a span {
        font-size: 15px;
    }
    .main_license_item{    padding: 10px 4px;}
    .main_license_item img{width: 30px;}
    .main_license_item .tit{font-size: 17px;}
    .main_license_item .tit small{font-size: 12px;}

    .main_section {
        padding: 140px 0;
    }
    .main_page_tit h3{text-align: center;font-size: 45px;}
    #se01 .main_page_tit {flex-direction: column;}
    #se01 .main_page_tit p{text-align: center;}
    .main_bs_items {grid-template-columns: repeat(1, 1fr);}
    .main_bs_item .tit {font-size: 21px;    height: 70px;}
    .main_bs_item .txt_area {height: 100%;}
    #se02 .col-md-8 .txt_area .tit{    flex-direction: column; gap: 10px;}
    #se02 .col-md-8 .txt_area .tit .m_link_btn{margin: 0;}
    .m_link_btn{padding: 10px 0;}
    #se02 .col-md-8 {padding-bottom: 20px;}
    #se03 .inner {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .last_link .inner{
        gap: 20px;
        flex-direction: column;
    }
    .last_link ul {
        gap: 10px 30px;
        flex-wrap: wrap;
    }

    .greet .img_area{padding-right: 15px;padding-bottom: 30px;}
    .greet .txt_area > p {font-size: 20px;}
    .greet .txt_area ul{padding: 30px 10px;}
    .greet .txt_area ul li{display: grid;grid-template-columns: 100px 1fr;}

    .list_mission{flex-direction: column;align-items: center;}
    .list_mission li{margin: -10px 0;}
    .history_item{grid-template-columns: 1fr;}
    .history_item .year{padding: 25px 10px 0;}
    .history_item ul{padding: 20px 10px;}

    .list_license{grid-template-columns: repeat(2, 1fr);}
    .list_license li > .tit img {width: 40px;}
    .list_license li > .tit {font-size: 17px;}
    .list_license li > .img_box {padding: 20px;}

    .map .detail {flex-direction: column;gap: 10px;}
    .map .detail p {font-size: 17px;}
    .map .detail > .info {
        width: 100%;
        display: grid;
        grid-template-columns: 28px 1fr;
    }
    .map .detail > div {
        gap: 0px;
        flex-direction: column;}

    .intro_txt {font-size: 19px;margin: 0 auto 80px;}
    .about_item {font-size: 16px;}    
    .about_item .tit {width: 145px;font-size: 16px;}

    .plus_items{
        margin: 25px 0;
        flex-direction: column;
    }
    .plus_item {
        padding: 25px 0;
        font-size: 16px;
        margin: 0;
    }
    .plus_item::before {
        right: inherit;
        left: 50%;
        top: inherit;
        bottom: -26px;
        transform: translateX(-50%);
    }
    .ex_area .tit, .ex_area .result{font-size: 18px;}

    .bs_item{
        padding: 30px 30px 40px;
        gap: 30px;
        flex-direction: column;
    }
    .bs_item .txt_area {width: 100%;}
    .bs_item .txt_area > .tit {font-size: 20px;}
    .bs_item .txt_area > .tit + p {font-size: 16px;}
    .link_area {font-size: 15px;}

    .detail_area > p {font-size: 17px;}
    .mro_area,.effect_items {gap: 20px;flex-direction: column;}
    .table_box .tit,table.tb_style_1.mro_table, .talbe_box .table-responsive{border: none;}
    .spec_box .tit{padding: 25px 0;font-size: 20px;}
    .spec_box ul {margin: 35px auto;}
    .spec_box ul li{font-size: 18px;}
    .service_area .img_area img{max-width: 100%;}
    .effect_item{max-width: 100%;min-width: 100%;}
    .effect_item .tit {font-size: 17px;}
    .effect_item > ul li {font-size: 16px;}
    .effect_item ul li .list-dash li{    font-size: 15px;}
    .list_cus{
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
    .list_cus li {padding: 10px 10px;}

    .category .nav{width: 100%;}
    .category .nav li a{font-size: 15px;padding: 13px 0;}
    .list-num.ex_list{width: 100%;}
    .ex_items{grid-template-columns: repeat(2, 1fr);gap: 30px;}
    .list_pro{gap: 60px;flex-direction: column;}
    .list_pro li::before{
        right: inherit;
        left: 50%;
        top: inherit;
        bottom: -38px;
        transform: translateX(-50%) rotate(90deg);
    }
    .list_pro li .txt_area p{font-size: 17px;}
    .list_pro li .tit {font-size: 20px;}

    .work_area {padding: 30px;}
    .work_item .txt_area{min-height: max-content;padding: 20px 30px;}
    .work_item .img_area {flex-direction: column;}

    .system > .tit {font-size: 20px;}
    .value_items{flex-direction: column;}

    .site_txt{grid-template-columns: 1fr;padding: 30px;}

    #newsroom01 .detail_area .img_area img {max-width: 100%;}
    .newsroom_contact {padding: 20px;gap: 20px;flex-direction: column;}
    .newsroom_contact p{flex-wrap: wrap;}

    #floating{
        transform: scale(0.7);
        top: inherit;
        bottom: -60px;
        right: -20px;
    }
    #floating.on {
        bottom: -210px;
    }
}