@import url(https://fonts.googleapis.com/css?family=Lato:100,300,400,700,900,100italic,300italic,400italic,700italic,900italic);
@import url(https://fonts.googleapis.com/css2?family=EB+Garamond&display=swap);
@import url(https://fonts.googleapis.com/css2?family=EB+Garamond:wght@700&display=swap);

/* @font-face {
    font-family: 'AGaramondPro';
    src: url('/fonts/fonts/AGaramondPro-Bold.woff') format('woff');

    font-weight: normal;
    font-style: normal;
    font-display: swap;
  } */

body,
html {
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale;
    overflow-y: auto;
    overflow-x: hidden;
    /* font-family: 'AGaramondPro', 'Lato', sans-serif; */
    font-family: 'EB Garamond', 'Lato', sans-serif;
    color: #6f6f6f;
    background-color: #000000;
}




::-webkit-scrollbar {
    width: 2px;
}

/* for vertical scrollbars */
::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.1);
}

::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.5);
}

@media (min-width: 1200px) {
    .container {
        width: 1100px
    }

}




h1 {
    font-weight: 900;
    /* text-transform: uppercase; */
}

h1 small {
    text-transform: lowercase
}

h2 {
    line-height: 24px;
    font-weight: 300;
}

h5 {
    font-size: 16px
}

p {
    font-size: 14px
}

a {
    color: inherit;
    transition: all 0.5s;
}

a:hover,
a:focus {
    text-decoration: none;
    color: #09428d;
}

.highlight {
    letter-spacing: 0.02em; 
    color: #ffffff;
}

.clearfix:after {
    visibility: hidden;
    display: block;
    font-size: 0;
    content: " ";
    clear: both;
    height: 0;
}

.clearfix {
    display: inline-block
}

* html .clearfix {
    height: 1%
}

.clearfix {
    display: block
}

/* Navigation */
#tf-menu {
    margin-bottom: 0;
    /* background-color: #ffffff; */
    background-color: #000000;
    padding: 10px 0;
    height: auto;
    border-bottom: none;
    box-shadow: none;
    z-index: 2;
    /* 혹시 그림자도 있으면 이것도 제거 */
}

.navbar-brand img {
    height: 30px;
    width: auto;
}

.navbar-brand {
    padding: 12px 15px
}

.navbar-nav>li>a {
    font-size: 18px;
    font-weight: 00;
    border-bottom: 2px solid transparent;
    padding: 5px 5px;
    margin: 8px 10px;
    text-transform: uppercase;
    transition: all 0.5s;

}

.navbar-default .navbar-nav>li>a.active,
.navbar-default .navbar-nav>li>a:hover,
.navbar-default .navbar-nav>li>a:focus {
    color: #333;
    border-bottom: 4px solid #09428d;
}

.navbar-default .navbar-toggle {
    border-color: transparent
}

.navbar-default .navbar-toggle:hover,
.navbar-default .navbar-toggle:focus {
    background-color: transparent
}

.navbar-default .navbar-toggle:hover>.navbar-default .navbar-toggle .icon-bar,
.navbar-default .navbar-toggle:focus>.navbar-default .navbar-toggle .icon-bar {
    color: #09428d
}

/* Header Page */
#tf-header {
    padding: 20px 0;
    background: #09428d;
    margin-top: 70px;
    color: #ffffff;
}

#tf-header .breadcrumb {
    padding: 8px 15px;
    margin-bottom: 20px;
    list-style: none;
    background-color: transparent;
    border-radius: 4px;
    margin-left: -10px;
    margin-top: -10px;
}

#tf-header .breadcrumb>li+li:before {
    padding: 0 5px;
    color: #000000;
    content: "/\00a0";
}

#tf-header .breadcrumb>li a {
    color: #ffffff
}

.text_under {
    position: relative;
}

.text_under::after {
    content: "";
    width: 100%;
    height: 10px;
    background: #09428d;
    position: absolute;
    display: inline-block;
    left: 0;
    bottom: 1px;
    z-index: -1;
}




#tf-home {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
    color: #cfcfcf;
    z-index: 1;
}

#corp-intro {
    background-color: #fff;
    /* 필요 시 배경색 */
    padding: 40px 0;
}

#corp-intro .left-box {
    color: #ffffff;
}

.center-content {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    gap: 40px;
    flex-wrap: nowrap;
    /* 줄바꿈 없이 */
}

.left-text {
    flex: 1;
    /* 50% */
    padding: 20px;
}

.left-text h2 {
    font-size: 24px;
    font-weight: 400;
    line-height: 1.6;
    color: #111;
}

.left-text h2 strong {
    font-weight: 700;
}

.right-image {
    flex: 1;
    /* 50% */
    display: flex;
    justify-content: flex-end;
    /* 오른쪽 붙이기 */
    padding: 20px;
}

.right-image img {
    max-width: 100%;
    height: auto;
    display: block;
}



/* 🎥 배경 비디오 스타일 */
.bg-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1;
}

#tf-home .mobile_bg-video {
   z-index: 1;
} 

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3);
    /* 반투명 검은색 */
}

#tf-home .overlay {
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.73) 17%, rgba(0, 0, 0, 0.66) 35%, rgba(0, 0, 0, 0.55) 62%, rgba(0, 0, 0, 0.4) 100%);
    /* FF3.6+ */
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(0, 0, 0, 0.8)), color-stop(17%, rgba(0, 0, 0, 0.73)), color-stop(35%, rgba(0, 0, 0, 0.66)), color-stop(62%, rgba(0, 0, 0, 0.55)), color-stop(100%, rgba(0, 0, 0, 0.4)));
    /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.73) 17%, rgba(0, 0, 0, 0.66) 35%, rgba(0, 0, 0, 0.55) 62%, rgba(0, 0, 0, 0.4) 100%);
    /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.73) 17%, rgba(0, 0, 0, 0.66) 35%, rgba(0, 0, 0, 0.55) 62%, rgba(0, 0, 0, 0.4) 100%);
    /* Opera 11.10+ */
    background: -ms-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.73) 17%, rgba(0, 0, 0, 0.66) 35%, rgba(0, 0, 0, 0.55) 62%, rgba(0, 0, 0, 0.4) 100%);
    /* IE10+ */
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.73) 17%, rgba(0, 0, 0, 0.66) 35%, rgba(0, 0, 0, 0.55) 62%, rgba(0, 0, 0, 0.4) 100%);
    /* W3C */
    padding: 20% 0;
    background-attachment: fixed;
}

#tf-home h1 {
    color: #09428d
}

.content-heading p.lead {
    margin-bottom: 80px
}

a.goto-btn {
    font-size: 18px;
    font-weight: 700;
    border-bottom: 2px solid transparent;
    padding: 10px 0;
    transition: all 0.5s;
}

a.goto-btn:hover {
    color: #ffffff;
    border-bottom: 2px solid #09428d;
}

.mouse {
    width: 27px;
    height: 43px;
    background-image: url(https://www.movvcorp.com/images/scroll.png);
    position: absolute;
    bottom: 50px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 500;
    animation-name: up_down;
    animation-duration: 1s;
    animation-iteration-count: infinite;
    animation-direction: alternate;
    animation-timing-function: linear;
}

@keyframes up_down {
    0% {
        bottom: 50px;
    }

    100% {
        bottom: 75px;
        ;
    }
}


/* Home Section Style 2 - With Video*/
#tf-home.video .overlay {
    padding: 0;
    padding-top: 10%;
}

.img-wrapper {
    position: relative
}

.img-wrapper img.img-responsive {
    margin: 0 auto !important
}

.img-wrapper i.fa {
    position: absolute;
    z-index: 10;
    top: 50%;
    font-size: 25px;
    background: rgba(32, 22, 22, 0.29);
    padding: 18px 23px;
    height: 60px;
    width: 60px;
    text-align: center;
    border-radius: 50%;
    color: #ffffff;
    margin-left: -30px;
    transition: all 0.3s;
}

.img-wrapper i.fa:hover {
    background: #09428d
}

/* Home Section Style 3 - Slider*/
#tf-home.slider {
    background: none
}

#tf-home.slider .overlay {
    padding: 0
}

.carousel-caption {
    position: absolute;
    right: 15%;
    top: 28%;
    bottom: auto;
    left: 15%;
    z-index: 10;
    padding-top: 20px;
    padding-bottom: 0;
    color: #fff;
    text-align: center;
    text-shadow: none;
}

.carousel-indicators li {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin: 1px;
    text-indent: -999px;
    cursor: pointer;
    background-color: rgba(0, 0, 0, 0);
    border: 1px solid #fff;
    border-radius: 10px;
}

.carousel-indicators {
    position: absolute;
    bottom: 60px;
    left: 50%;
    z-index: 15;
    width: 60%;
    padding-left: 0;
    margin-left: -30%;
    text-align: center;
    list-style: none;
}

.carousel-indicators .active {
    width: 14px;
    height: 14px;
    margin: 0;
    background-color: #E5B112;
}

.carousel-fade .carousel-inner .item {
    opacity: 0;
    transition-property: opacity;
}

.carousel-fade .carousel-inner .active {
    opacity: 1
}

.carousel-fade .carousel-inner .active.left,
.carousel-fade .carousel-inner .active.right {
    left: 0;
    opacity: 0;
    z-index: 1;
}

.carousel-fade .carousel-inner .next.left,
.carousel-fade .carousel-inner .prev.right {
    opacity: 1
}

.carousel-fade .carousel-control {
    z-index: 2
}

/* Home Section Style 4 - App Header Style*/
#tf-home.app .overlay {
    padding: 10% 0 5% 0
}

#tf-home.app {
    background: url(../img/bg/02.jpg);
}

a.goto-btn {
    margin-right: 30px
}

.ipad-wrapper .app-wrap {
    position: relative;
    width: 395px;
}

.app-wrap {
    position: absolute;
    background: url(../img/header4.png);
    width: 395px;
    height: 540px;
    background-repeat: no-repeat;
    z-index: 2;
    left: 5%;
}

#owl-demo .item img {
    position: relative;
    width: 305px;
    height: auto;
    left: 12%;
    margin-top: 46px;
    z-index: -1;
}

.app .content-heading.text-left {
    padding: 15% 0
}

#tf-home.app .owl-theme .owl-controls .owl-page span {
    width: 15px;
    height: 15px;
    margin: 5px;
    background: #ffffff !important;
    border: 2px solid transparent;
    opacity: 1;
}

#tf-home.app .owl-theme .owl-controls {
    margin-top: 60px;
    text-align: center;
}

#tf-home.app .owl-theme .owl-controls .owl-page.active span,
#tf-home.app .owl-theme .owl-controls.clickable .owl-page:hover span {
    border: 2px solid #09428d
}

/* Home Parallax Effect */
.bcg {
    background-position: center center;
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-size: cover;
    height: 100%;
    width: 100%;
}

#tf-home.parallax .bcg {
    background-image: url('../img/bg/slider03.jpg');
}

.parallax .content-heading {
    padding: 20% 0;
    text-align: center;
}

/* Intro Section */
#tf-intro {
    background-color: #ffffff;
    padding: 5% 0;
    color: black;
    text-align: center;
}

#tf-intro img.intro-logo {
    margin: 0 auto;
    margin-bottom: 30px;
}

/* Service Section */
#tf-services {
    background-color: #000000;
    width: 100%;
    padding: 80px 0;
}

#tf-services #corp-intro {
    background-color: #000000;
}

#corp-intro h2 {
    font-size: 22px;
    line-height: 1.7;
    font-weight: 500;
}

#corp-intro .row {
    display: flex;
    align-items: center;
}

#corp-intro img {
    max-width: 100%;
    height: auto;
}

.big-print {
    width: 100%;
}
.detail_small_section{
    height: 350px;
}
.service_section{
    background-color: #000000;
}

.section-header {
    padding: 20px 0;
    text-align: center;
}

.section-header h2 {
    font-size: 70px;
}

.section-body{
    font-size: 22px;
    line-height: 5vb;
    padding: 20px 0;
    text-align: center;
    color: #ffffff;
}

.fancy {
    line-height: 0.5;
    text-align: center;
    margin-bottom: 40px;
    margin-top: 20px;
}

.fancy span {
    display: inline-block;
    position: relative;
}

.fancy span:before,
.fancy span:after {
    content: "";
    position: absolute;
    height: 5px;
    border-bottom: 1px solid #f1f1f1;
    top: 15px;
    width: 400px;
}

.fancy span:before {
    right: 100%;
    margin-right: 10px;
}

.fancy span:after {
    left: 100%;
    margin-left: 10px;
}

/* service lists */
.service {
    margin-bottom: 20px
}

.service .media-right i.fa {
    text-align: center;
    font-size: 30px;
    background-color: #09428d;
    color: #ffffff;
    padding: 25px 0;
    border-radius: 50px;
    border-top-left-radius: 0;
    margin: 0 10px;
    margin-right: 20px;
    width: 82px;
    height: 80px;
    transition: background-color 0.5s;
}

.service .media-left i.fa {
    text-align: center;
    font-size: 30px;
    background-color: #09428d;
    color: #ffffff;
    padding: 25px 0;
    border-radius: 50px;
    border-top-right-radius: 0;
    margin: 0 10px;
    margin-left: 20px;
    width: 82px;
    height: 80px;
    transition: background-color 0.5s;
}

.process:hover i.fa,
.service:hover i.fa {
    background-color: #333333
}

h4.media-heading {
    margin-top: 0;
    margin-bottom: 5px;
    font-size: 16px;
    font-weight: 400;
    text-transform: uppercase;
    color: #333;
    line-height: 20px;
}


/* Our Work 모바일 대응 */
@media (max-width: 768px) {
    #corp-intro .row {
        flex-direction: column-reverse;
        /* 모바일에서는 이미지가 먼저 나오고 텍스트가 뒤로 */
    }

    .right-image img {
        width: 100%;
        height: auto;
    }

    .left-box {
        /* position: absolute; */
        /* 텍스트를 이미지 위에 덮어 씌움 */
        /* top: 45%;
        transform: translate(-50%, -50%); */
        padding: 20px;
        /* background: rgba(255, 255, 255, 0.8); */
        /* 살짝 투명한 흰 배경 */
        border-radius: 10px;
        /* z-index: 2; */
        width: 80%;
        /* 텍스트 박스 폭 제한 */
        text-align: center;
        
    }
    .section-body{
        width: 80%;
        font-size: 18px;
        margin: auto;
        
    }
    .highlight{
       line-height: 0.8;
       font-size: 50px;
    }
}


/* About Us */
#tf-about {
    padding: 20px 0;
    position: relative;
    z-index: 1;
}

#tf-about .container_ex .wrap .rolling-list .desc img {
    width: 100%;
    height: 100%;
    text-align: center;
}

.gray-bg {
    background-color: #f3f3f3
}

.navy-bg {
    background-color: #1D2088
}

.img-wrap .profile-img {
    position: relative;
    margin-bottom: 40px;
}

.profile-img .social {
    position: absolute;
    z-index: 1;
    bottom: -10px;
    left: 50px;
}

.about-right-content {
    padding: 40px 0
}

.about-left-content {
    padding-bottom: 60px
}

.about-left-content h2,
.about-left-content h2 small {
    color: #333
}

/* .about-left-content h2 small {
    font-weight: 300
}

ul.social li a.fa {
    background: #FFCC32;
    width: 50px;
    height: 50px;
    padding: 15px;
    text-align: center;
    margin-right: -5px;
    font-size: 20px;
    color: #ffffff;
    margin-bottom: 0;
}

ul.social li a.fa:hover {
    background-color: #333333
} */

.partner-logos {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
    padding: 40px 0;
}

.partner-logos img {
    max-width: 180px;
    height: auto;
    padding: 10px 20px;
    border: 1px solid #eee;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    transition: transform 0.2s ease;
}

.partner-logos img:hover {
    transform: scale(1.05);
}

.logo-title {
    text-align: center;
    font-size: 1.6rem;
    font-weight: bold;
    margin-bottom: 30px;
}

/* Skills Progress Bar */
.progress {
    height: 12px;
    margin-bottom: 20px;
    overflow: hidden;
    background-color: #999999;
    border-radius: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.progress-bar {
    float: left;
    width: 0;
    height: 100%;
    font-size: 12px;
    line-height: 20px;
    color: #fff;
    text-align: center;
    background-color: #FFCC32;
    -webkit-box-shadow: none;
    box-shadow: none;
    -webkit-transition: width .6s ease;
    -o-transition: width .6s ease;
    transition: width .6s ease;
}

.skills {
    margin-top: 30px;
    padding: 20px 0;
}

.skillset p {
    font-size: 13px;
    margin-bottom: 5px;
}

/* Counter */
#tf-counter {
    border-top: 1px solid #D1D1D1;
    border-bottom: 1px solid #D1D1D1;
}

.facts {
    padding: 0
}

.facts .count-box {
    position: relative
}

.count-box {
    -webkit-backface-visibility: hidden;
    border-left: 1px solid #d3d3d3;
    padding: 40px 0;
    margin: 0;
    overflow: hidden;
    transition: all 0.5s;
    transform: translateX(0px) translateY(0%);
    -webkit-transform: translateX(0px) translateY(0%);
    -moz-transform: translateX(0px) translateY(0%);
    -ms-transform: translateX(0px) translateY(0%);
    -o-transform: translateX(0px) translateY(0%);
}

/*.count-box .hover-bg{ 
  position: absolute;
  display: block;
  background-color: #FFCC32;
  width: 100%;
  height: 100%;
  z-index: -1;
  transition: all 0.5s;
  transform: translateX(0px) translateY(150px);
  -webkit-transform: translateX(0px) translateY(150px);
  -ms-transform: translateX(0px) translateY(150px);
    -o-transform: translateX(0px) translateY(150px);
    opacity: 0;
}
.count-box:hover .hover-bg{
  background: #FFCC32;
  color: #fff !important;
  transform: translateX(0px) translateY(-40px);
    -webkit-transform: translateX(0px) translateY(-40px);
    -moz-transform: translateX(0px) translateY(-40px);
    -ms-transform: translateX(0px) translateY(-40px);
    -o-transform: translateX(0px) translateY(-40px);
    opacity: 1;
}*/
.count-box:hover,
.count-box:hover>i.fa {
    color: #ffffff
}

.count-box:hover {
    -webkit-backface-visibility: hidden;
    background-color: #e5b112;
}

.counter i.fa {
    font-size: 40px;
    color: #09428d;
}

.count-box.last {
    border-right: 1px solid #d3d3d3
}

/* Portfolio / Works Sections */
#loadMoreBtn {
    padding: 10px 20px;
    background-color: #09428d;
    color: white;
    font-size: 16px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
}

#loadMoreBtn:hover {
    background-color: #0056b3;
}


#itemsWork {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 1080px;  
    margin: 0 auto;
    gap: 10px;
}

#itemsWork>div {
    display: block;
  
}
.box{
    margin: 10px;
}
@media (max-width: 768px) {
    #itemsWork {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        max-width: none;  
        margin: 0 auto;
        gap: 10px;
    }
    #itemsWork>div {
        width: 100%;           /* 한 줄에 하나씩 */
        justify-content: center;  /* 내부 박스를 수평 중앙 정렬 */
    }
    .box{
        margin: 0 auto;  /* box 자체를 중앙에 배치 */

    }
    .container-fluid{
        padding: 0;
    }
    .box img {
        display: block;
        margin: 0 auto;
        padding: 10px;
    }
    .hover-text {
        margin: 0 auto;
    }
    .text_under::after{
        display: none;
    }
    #tf-home .mobile_bg-video {
        object-fit: contain; 
    } 
    #tf-home{
        margin-top: 150px;
        height: 700px;
    }

}


.hover-bg .hover-text {
    position: absolute;
    display: block;
    bottom: 0;
    width: 100%;
    height: 25%;
    padding: 20px;
    color: #ffffff;
    transition: all 0.8s;
    -webkit-transition: all 08s;
    -moz-transition: all 0.8s;
    -o-transition: all 0.8s;
}

.hover-bg .hover-text.on {
    opacity: 1
}

.hover-bg .hover-text.off {
    transition: all 0.3s;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    -o-transition: all 0.3s;
    -webkit-transform: translateX(100%) translateY(-90%);
    transform: translateX(100%) translateY(-90%);
    opacity: 1;
    background: rgba(0, 0, 0, 0.70);
}

.hover-bg:hover .hover-text.off {
    -webkit-transform: translateX(0%) translateY(-90%);
    transform: translateX(0%) translateY(-90%);
    opacity: 1;
}

.nav.nav-pills>li>a {
    position: relative;
    display: block;
    background-color: #ffffff;
    padding: 25px;
    border-bottom: 3px solid #cccccc;
    text-transform: uppercase;
    margin-bottom: 5px;
}

.nav.nav-pills>li>a small {
    text-transform: lowercase;
    font-style: italic;
}

.nav.nav-pills>li>a:hover,
.nav-pills>li.active>a,
.nav-pills>li.active>a:hover,
.nav-pills>li.active>a:focus {
    color: #fff;
    background-color: #09428d;
    padding: 25px;
    border-bottom: 3px solid black;
}

.nav-pills>li>a {
    border-radius: 4px
}

ul.features li span.fa {
    font-size: 35px;
    vertical-align: middle;
    margin-right: 20px;
    float: left;
    clear: both;
    margin-top: 5px;
}

/* Portfolio or works blocks */
#tf-works {
    background-color: #000000;
    padding: 60px 0
}

ul.cat {
    margin: 30px 0
}

ul.cat li a {
    background: inherit;
    border: 1px solid;
    padding: 5px 10px;
    border-radius: 3px;
}

ul.cat li a:hover,
ul.cat li a:focus,
ul.cat li a.active {
    background: #f1f1f1;
    border: 1px solid;
    padding: 5px 10px;
    border-radius: 3px;
    color: inherit;
}

.nopadding {
    padding:0;
}

.box a {
    margin: 2px
}

.box .hover-bg {
    position: relative;
    overflow: hidden;
}

.box .hover-bg .hover-text {
    height: 100%;
    bottom: 0;
    -webkit-transform: translateX(0%) translateY(0%);
    transform: translateX(0%) translateY(0%);
    background: transparent;
}

.box:hover .hover-bg .hover-text {
    background-color: rgba(1, 1, 1, 0.5)
}

.box .hover-bg:hover .hover-text.off {
    -webkit-transform: translateX(0%) translateY(0%);
    transform: translateX(0%) translateY(0%);
    opacity: 1;
}

.box .hover-text i.fa {
    font-size: 20px;
    background: #09428d;
    padding: 13px;
    position: relative;
    top: 40%;
    border-radius: 50%;
    width: 45px;
    height: 45px;
    transition: all 0.5s;
}

.box .hover-text i.fa:hover {
    background: #333333
}

.box .hover-text i.fa.fa-expand {
    border-top-right-radius: 0;
    -webkit-transform: translateX(-400%) translateY(0%);
    transform: translateX(-400%) translateY(0%);
    opacity: 0;
    transition: all 0.5s;
}

.box:hover .hover-text i.fa.fa-expand {
    -webkit-transform: translateX(0%) translateY(0%);
    transform: translateX(0%) translateY(0%);
    opacity: 1;
}

.box .hover-text i.fa.fa-chain {
    border-top-left-radius: 0;
    -webkit-transform: translateX(400%) translateY(0%);
    transform: translateX(400%) translateY(0%);
    opacity: 0;
    transition: all 0.5s;
}

.box:hover .hover-text i.fa.fa-chain {
    -webkit-transform: translateX(0%) translateY(0%);
    transform: translateX(0%) translateY(0%);
    opacity: 1;
}



/* Isotope Filter */
.isotope-item {
    z-index: 2
}

.isotope-hidden.isotope-item {
    z-index: 1
}

.isotope,
.isotope .isotope-item {
    /* change duration value to whatever you like */
    -webkit-transition-duration: 0.8s;
    -moz-transition-duration: 0.8s;
    transition-duration: 0.8s;
}

.isotope-item {
    margin-right: -1px;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.isotope {
    -webkit-transition-property: height, width;
    -moz-transition-property: height, width;
    transition-property: height, width;
}

.isotope .isotope-item {
    -webkit-transition-property: -webkit-transform, opacity;
    -moz-transition-property: -moz-transform, opacity;
    transition-property: transform, opacity;
}

.nivo-lightbox-theme-default .nivo-lightbox-title {
    font-size: 14px;
    background: #f1f1f1;
    border: 1px solid #333;
    letter-spacing: 2px;
    color: #333;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding: 10px 35px;
    border-radius: 2px;
}

.nivo-lightbox-theme-default.nivo-lightbox-overlay {
    background: #ffffff !important;
    background: rgba(255, 255, 255, 1) !important;
}

.nivo-lightbox-theme-default .nivo-lightbox-nav,
.nivo-lightbox-theme-default .nivo-lightbox-close {
    opacity: 1
}

.nivo-lightbox-error {
    color: #C59A6D !important;
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0) !important;
}

.nivo-lightbox-theme-default .nivo-lightbox-image img {
    background: #fff;
    -webkit-box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.4);
    -moz-box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.4);
    box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.4);
    border-top: 4px solid #09428d;
}

/* Single Portfolio Detail */
#work-detail-one,
#work-detail-two,
#work-detail-three {
    padding: 60px 0
}

.work-detail .dl-horizontal dt {
    text-align: left;
    margin-bottom: 10px;
}

.work-related-thumb {
    margin-bottom: 30px
}

.work-related-thumb .img-thumbnail {
    display: inline-block;
    max-width: 100%;
    height: auto;
    padding: 0;
    line-height: 1.42857143;
    background-color: transparent;
    border: 1px solid transparent;
    border-radius: 0;
    -webkit-transition: all .2s ease-in-out;
    -o-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
}

.work-related-thumb .img-thumbnail:hover {
    opacity: 0.8
}

/* Process Section */
#tf-process {
    padding: 100px 0 400px 0;
}

.process i.fa {
    text-align: center;
    font-size: 30px;
    background-color: #09428d;
    color: #ffffff;
    padding: 25px 0;
    border: 4px solid #ffffff;
    border-radius: 50px;
    border-top-left-radius: 0;
    margin: 0 10px;
    margin-right: 20px;
    width: 92px;
    height: 90px;
    transition: background-color 0.5s;
}

#tf-process .gray-bg {
    position: relative
}

.gray-bg .vline {
    position: absolute;
    height: 100%;
    padding: 5px;
    border-left: 3px solid #ffffff;
    left: 20%;
}

#process {
    padding: 60px 0 20px 0
}

.process {
    margin-bottom: 40px
}

/* Pricing Section */
#tf-pricing {
    padding: 60px 0
}

.price h1 {
    font-size: 50px
}

.price {
    text-align: center
}

.price.panel-default {
    border-color: #333
}

.price.panel-default>.panel-heading {
    font-size: 20px;
    text-transform: uppercase;
    font-weight: 600;
    color: #FFF;
    background-color: #333333;
    border-color: inherit;
}

.price .panel-heading {
    padding: 30px 15px
}

.price .panel-body {
    border-bottom: 1px solid
}

.price ul.list-unstyled {
    padding: 20px
}

.price ul.list-unstyled li {
    padding: 10px 0
}

.price ul.list-unstyled li small {
    margin-top: -10px
}

/* Featured */
.price.featured {
    -moz-box-shadow: 0 0 6px 2px rgba(0, 0, 0, 0.31);
    -webkit-box-shadow: 0 0 6px 2px rgba(0, 0, 0, 0.31);
    box-shadow: 0 0 6px 2px rgba(0, 0, 0, 0.31);
}

.price.featured.panel-default {
    border-color: #09428d;
    background-color: #ffffff;
    margin-top: -20px;
    position: relative;
    z-index: 1;
    margin-left: -5px;
    margin-right: -5px;
}

.price.featured.panel-default {
    border-color: #09428d
}

.price.featured.panel-default>.panel-heading {
    background-color: #09428d
}

.featured .panel-body {
    margin-top: 20px
}

.featured .panel-body,
.featured.panel-default>.panel-heading {
    border-color: #09428d
}

.featured .tf-btn {
    margin-top: 20px
}

.btn:focus,
.btn:active:focus,
.btn.active:focus,
.btn.focus,
.btn:active.focus,
.btn.active.focus {
    outline: 0;
    outline: 0;
    outline-offset: 0;
}

.btn:active,
.btn.active {
    background-image: none;
    outline: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.tf-btn {
    font-size: 12px;
    word-spacing: 2px;
    font-weight: 700;
    padding: 10px 20px;
    background-color: #333333;
    text-transform: uppercase;
    border-color: #333333;
    transition: all 0.5s;
}

.tf-btn:focus,
.tf-btn:hover {
    background-color: #333333;
    border-color: #09428d;
}

.color {
    background-color: #09428d;
    border-color: #09428d;
}

#business-main{
    padding: 200px 0;

}
@media (max-width: 768px) {
    #business-main{
        padding: 50px 0;
    
    }
    #tf-process{
        padding: 50px 0;
    }

    #tf-process .section-body{
        line-height: 3.5vb;
    }
}


.color:focus,
.color:hover {
    border-color: #333333;
    background-color: #09428d;
}

/* Blog Section */
#tf-blog,
#blog-post {
    padding: 60px 0
}

#blog-post a.btn {
    margin: auto 0
}

.post-wrap {
    position: relative
}

.media.post {
    background: #fff;
    padding: 10px;
}

.post-wrap {
    position: relative;
    margin-bottom: 30px;
    transition: all 0.5s;
}

.post-meta {
    border-top: 1px solid #ebebeb;
    background-color: #ffffff;
    padding: 5px 10px;
    height: auto;
    position: relative;
    min-height: 35px;
}

ul.metas li:after {
    content: ' / ';
    margin-right: 3px;
    margin-left: 3px;
}

ul.metas li:last-child:after {
    content: ' '
}

ul.metas li a {
    color: #e5b112
}

.meta-detail {
    background: #f4f4f4;
    border-radius: 3px;
    padding: 2px;
}

/* Contact Section */
/*********************************
/* Map Section
**********************************/
#tf-contact {
    border-bottom: none;
    box-shadow: none;
    background-color: #000000;
    padding: 60px 0
}

#map {
    position: relative;
    width: 100%;
    height: 400px;
}

.contact-detail {
    text-align: center;
    margin: 60px 0;
}

.contact-detail i.fa {
    text-align: center;
    font-size: 30px;
    background-color: #09428d;
    color: #ffffff;
    padding: 25px 0;
    border-radius: 50px;
    border-top-left-radius: 0;
    margin: 0 10px;
    margin-right: 20px;
    width: 82px;
    height: 80px;
    transition: background-color 0.5s;
}

.contact-detail:hover i.fa {
    background-color: #333333
}

form#contact-form {
    padding: 40px 0
}

.contact form#contact-form {
    padding: 0
}

.form-control:focus {
    border-color: inherit;
    outline: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.form-control {
    display: block;
    width: 100%;
    height: 44px;
    padding: 10px 12px;
    font-size: 14px;
    line-height: 1.42857143;
    color: #555;
    background-color: #fff;
    background-image: none;
    border: 1px solid #ccc;
    border-radius: 4px;
    -webkit-box-shadow: none;
    box-shadow: none;
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
}

p.help-block.text-danger ul li {
    display: block;
    margin-left: -20px;
    color: #09428d;
}

#success .alert-danger {
    color: #09428d;
    background-color: #FDFDFD;
    border-color: #09428d;
    margin-bottom: 10px;
}

/* Footer */
#tf-footer {
    justify-content: center;
    margin: 0 auto;
    padding: 3% 0 2% 0;
    color: #ffffff;
}

#tf-footer .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto;
}

ul.social li a i {
    font-size: 18px;
    background: transparent;
    width: 32px;
    height: 32px;
    padding: 7px 0;
    text-align: center;
    border-radius: 50%;
    border-top-left-radius: 0;
    border: 1px solid transparent;
    color: #ffffff;
    transition: all 0.5s;
}

ul.social li a i:hover {
    border-color: #ffffff
}

/* Blog Page */
.blog .media.post {
    background: #fff;
    padding: 10px;
    border: 1px solid #E9E9E9;
    border-bottom-color: transparent;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
}

.blog .post-meta {
    border-top: 1px solid #ebebeb;
    background-color: #ffffff;
    padding: 5px 10px;
    height: auto;
    position: relative;
    min-height: 35px;
    border: 1px solid #ebebeb;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
}

.pagination>li>a,
.pagination>li>span {
    position: relative;
    float: left;
    padding: 6px 12px;
    margin-left: 0;
    line-height: 1.42857143;
    color: #FFFFFF;
    text-decoration: none;
    background-color: #09428d;
    border: 1px solid #09428d;
    margin: 3px 3px;
    font-weight: 700;
    text-transform: uppercase;
    border-radius: 5px;
}

.pagination>li>a.active,
.pagination>li>a:hover,
.pagination>li>span:hover,
.pagination>li>a:focus,
.pagination>li>span:focus {
    color: #FFFFFF;
    background-color: #ddab15;
    border-color: #ddab15;
}


/* footer 모바일 대응 */
@media (max-width: 768px) {
    #tf-footer{
        justify-content: center;
        width: 100%;
        margin: 0 auto;
    }

    #tf-footer .container {
        flex-direction: column;
        align-items: center;
        text-align: center;
        
    }

    #tf-footer .container>div {
        width: 100%;
        margin-bottom: 15px;

    }

    #tf-footer img {
        margin-bottom: 10px;
    }

    #tf-footer p {
        font-size: 13px;
        line-height: 1.5;
    }
}

/* Sidebar */
.widget {
    margin-bottom: 40px;
    padding: 0 20px;
}

.comment h4,
.widget h4,
h4.text-uppercase {
    font-weight: 300;
    color: #09428d;
}

.comment h4 span.comments {
    color: #333333
}

/* Search */
button.btn.btn-default {
    padding: 11px 15px;
    color: #ffffff;
    background: #09428d;
}

/* Categories and Archive Widget */
ul.bullet-lists {
    margin-top: 20px
}

ul.list-unstyled.bullet-lists li span.fa.fa-circle {
    font-size: 8px;
    vertical-align: middle;
    margin-right: 10px;
    color: #09428d;
}

ul.list-unstyled.bullet-lists li {
    padding: 5px 0
}

ul.list-unstyled.bullet-lists li:hover {
    color: #09428d
}

/* Post Tab */
.post-tab .nav-tabs>li>a {
    margin-right: -1px;
    line-height: 1.42857143;
    border: 1px solid #ddd;
    border-radius: 0px 0px 0 0;
}

.post-tab .list-group-item:first-child {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    margin-top: -1px;
}

.post-tab .nav-tabs>li>a:hover,
.post-tab .nav-tabs>li>a:focus {
    color: #FFF;
    background-color: #FC3;
    border: 1px solid #ddd;
    border-bottom-color: transparent;
}

/* Tags */
ul.list-inline.bullet-lists li a {
    color: inherit
}

ul.list-inline.bullet-lists li {
    background: #F8F8F8;
    padding: 5px 10px;
    margin-bottom: 5px;
    margin-right: 2px;
    border: 1px solid #F4F4F4;
    border-radius: 3px;
    transition: all 0.3s;
}

ul.list-inline.bullet-lists li:hover {
    background: #09428d
}

/* Single Blog Post */
.blog-post .post-wrap img,
.work-detail img.featured {
    margin: 20px 0
}

ul.meta-tags li a {
    font-style: italic
}

ul.meta-tags li:after {
    content: ','
}

ul.meta-tags li:last-child:after {
    content: ' '
}

/* Author Box */
.media.post-author {
    background: #09428d;
    padding: 20px;
    margin-top: -1px;
}

.media.post-author a {
    content: inherit
}

.blog-post .post-wrap {
    padding: 20px;
    margin-bottom: 0;
    border: 1px solid #DDDDDD;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
}

/* Comment */
.media.comment-block {
    border: 1px solid #DDD;
    padding: 20px;
}

.comment {
    margin-top: 40px
}

.comment form {
    margin-top: -30px
}

.comment input,
.comment textarea {
    margin-bottom: 15px
}

#business-part {
    position: relative;
    overflow: hidden;
    background: #b3b3b3;
    /* 밝은 배경 */
}

.wave-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 300px;
    overflow: hidden;
    z-index: 0;
}

.wave {
    position: absolute;
    width: 200%;
    height: 100%;
    animation: waveMove 8s linear infinite;
}

.wave path {
    fill: #b3b3b3;
    /* 파도 몸통 색 */
    stroke: white;
    /* 테두리선 */
    stroke-width: 1px;
    /* 하얀 선 두께 */
    opacity: 0.8;
}

@keyframes waveMove {
    0% {
      transform: translateX(-25%);
    }
    100% {
      transform: translateX(-75%);
    }
  }

.background-video {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    transform: translate(-50%, -50%);
    object-fit: cover;
    z-index: 1;
    opacity: 0.6;
    /* 필요하면 더 투명도 조정 가능 */
}

.wrap {
    display: flex;
    justify-content: center;
    /* 가로 가운데 (필요 시) */
    align-items: center;
    /* 세로 가운데 ✨ */
    overflow: hidden;
    height: 100px;
}

.wrap .rolling-list ul {
    display: flex;
}

.wrap .rolling-list ul li {
    width: 200px;
    height: 100px;
    box-sizing: border-box;
    border-radius: 20px;
    margin: 0 16px;
    padding: 23px 15px;
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.wrap .rolling-list ul li {
    /* background-color: #9a9a9a; */
}

/* 
  .wrap .rolling-list ul li:nth-child(1) { 
	  background-color: #F8E1E3;
  }
  .wrap .rolling-list ul li:nth-child(2) { 
	  background-color: #FFEAB5; 
  }
  .wrap .rolling-list ul li:nth-child(3) { 
	  background-color: #D3E7DC;
  }
  .wrap .rolling-list ul li:nth-child(4) { 
	  background-color: #A6C1E8;
  } */
.wrap .rolling-list ul li:nth-child(even) {
    /* background-color: #5a6cc7; */
}

.wrap .rolling-list ul li .image-wrap {
    padding-right: 32px;
    width: 30px;
    flex-shrink: 0;
}

.wrap .rolling-list ul li .image-wrap>img {
    width: 100%;
}

.wrap .rolling-list ul li .desc {
    font-family: 'BMJUA';
}

.wrap .rolling-list ul li .desc strong {
    display: block;
    font-size: 9px;
    margin-bottom: 5px;
}

.wrap .rolling-list ul li .desc span {
    font-size: 9px;
    line-height: 1.2;
}

.rolling-list.original {
    animation: rollingleft1 100s linear infinite;
}

.rolling-list.clone {
    animation: rollingleft2 100s linear infinite;
}

@keyframes rollingleft1 {
    0% {
        transform: translateX(0);
    }

    50% {
        transform: translateX(-100%);
    }

    50.01% {
        transform: translateX(100%);
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes rollingleft2 {
    0% {
        transition: translateX(0);
    }

    100% {
        transform: translateX(-200%);
    }
}

.circle-img {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    margin: auto;
}

.image-set {
    text-align: center;
}

.caption {
    margin-top: 10px;
    font-size: 16px;
    color: #333;
}

/* 데스크탑용: 가로 정렬 */
@media (min-width: 768px) {
    .image-wrapper .swiper-wrapper {
        display: flex;
        justify-content: center;
        gap: 20px;
    }

    .image-wrapper .swiper-slide {
        flex-shrink: 0;
        width: auto !important;
    }

    .swiper {
        overflow: visible !important;
    }
}


.swiper-button-next,
.swiper-button-prev {
    color: #666;
}

/* 데스크탑에서는 화살표 숨기기 */
@media (min-width: 768px) {

    .swiper-button-next,
    .swiper-button-prev {
        display: none;
    }
}