/* color */
.cfff {color: #fff;}
.caaa{color: #aaa;}
.cbbb{color: #bbb;}
.cccc{color: #ccc;}
.cddd{color: #ddd;}
.ceee{color: #eee;}
.c000 {color: #000;}
.c111 {color: #111;}
.c222 {color: #222;}
.c333 {color: #333;}
.c444 {color: #444;}
.c555 {color: #555;}
.c666 {color: #666;}
.c777 {color: #777;}
.c888 {color: #888;}
.c999 {color: #999;}

.c919191 {color: #919191;}
.c707070 {color: #707070;}
.c767676 {color: #767676;}
.c656565 {color: #656565;}
.c6B6B6B {color: #6B6B6B;}
.c5A5A5A {color: #5A5A5A;}
.c404040 {color: #404040;}
.c464646 {color: #464646;}
.c0C6EAC {color: #0C6EAC;}
.c17BDFF {color: #17BDFF;}
.cE7F8FF {color: #E7F8FF;}
.c00A550 {color: #00A550;}
.c0F8944 {color: #0F8944;}
.c36AC37 {color: #36AC37;}
.cFF6E6E {color: #FF6E6E;}


/* background-color */
.bfff {background-color: #fff;}
.bfafafa {background-color: #fafafa;}
.baaa {background-color: #aaa;}
.bbbb {background-color: #bbb;}
.bccc {background-color: #ccc;}
.bddd {background-color: #ddd;}
.beee {background-color: #eee;}
.b000 {background-color: #000;}
.b111 {background-color: #111;}
.b222 {background-color: #222;}
.b333 {background-color: #333;}
.b444 {background-color: #444;}
.b555 {background-color: #555;}
.b666 {background-color: #666;}
.b777 {background-color: #777;}
.b888 {background-color: #888;}
.b999 {background-color: #999;}

.bEBEBEB {background-color: #EBEBEB;}
.bF4F4F4 {background-color: #F4F4F4;}
.bFFFCF2 {background-color: #FFFCF2;}
.bFFF3D3 {background-color: #FFF3D3;}
.bFFE396 {background-color: #FFE396;}
.bFCB713 {background-color: #FCB713;}
.b0C6EAC {background-color: #0C6EAC;}
.b17BDFF {background-color: #17BDFF;}
.bE7F8FF {background-color: #E7F8FF;}
.bDAF0C4 {background-color: #DAF0C4;}
.b00A550 {background-color: #00A550;}
.b0F8944 {background-color: #0F8944;}
.b36AC37 {background-color: #36AC37;}
.bFF6E6E {background-color: #FF6E6E;}



/* gradient */
.gr-1 {background: linear-gradient(180deg, #FFFFFF 0%, #A2DBFF 100%);}


/* ------------------------------------------------------------------------------- */


/* 컴포넌트 */

.wrap {
    width: 100%;
    max-width: 101rem;
    padding: 0 4rem;
    margin: 0 auto;
}

section {
    overflow: hidden;
}

/* section 공통 패딩 */
.section {
    padding: 16rem 0;
    overflow: hidden;
}

/* title 공통 */
.title-area {
    margin-bottom: 6rem;
}
.title-area .title {
    height: 4rem;
}
.title-area .title img {
    height: 100%;
    width: auto;
}
h1.title {
    font-size: 4.4rem;
    font-weight: 900;
    line-height: 1.4;
    letter-spacing: -0.03em;
}
.title-area .sub-title {
    font-weight: 500;
    font-size: 2.2rem;
    line-height: 1.6;
    letter-spacing: -0.02em;
    margin-top: 4rem;
}

.flex-center {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* .border-dashed {
    background-image: url("data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' rx='40' ry='40' stroke='%23333' stroke-width='4' stroke-dasharray='6%2c 14' stroke-dashoffset='0' stroke-linecap='square'/%3e%3c/svg%3e");
} */

.obj-fit {
    object-fit: cover;
    height: 100%;
    width: 100%;
}

.shadow-1::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    left: -.2rem;
    top: 1rem;
    border-radius: 1.6rem;
    background-color: #bfbfbf;
    border: .2rem solid #000;
    z-index: -1;
}
.shadow-1::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    left: -.2rem;
    top: -.2rem;
    border-radius: 1.6rem;
    background-color: #fff;
    border: .2rem solid #000;
    z-index: -1;
}

.notice-list li {
    position: relative;
    display: flex;
    color: #464646;
}
.notice-list li::before {
    position: relative;
    margin-right: .8rem;
    content: '';
    background: url(../img/list-icon.svg)no-repeat center/cover;
    min-width: 1.2rem;
    height: 1.2rem;
    top: .8rem;
    left: 0;
}

.dot-list li {
    position: relative;
    display: flex;
    /* align-items: center; */
}
.dot-list li::before {
    position: relative;
    content: '';
    min-width: .4rem;
    height: .4rem;
    border-radius: 50%;
    background-color: #000;
    display: inline-block;
    margin-right: .8rem;
    top: 1.6rem;
}

i {
    display: block;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

dialog {
    border: none;
    border-radius: 8px;
    padding: 1rem 2rem;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}

dialog::backdrop {
    background: rgba(0,0,0,0.4);
}

br.mb-ver {
    display: none;
}
br.pc-ver {
    display: block;
}
br.pad-ver {
        display: none;
    }
@media (max-width: 1279px) {

    .title-area .title {
        height: 3rem;
    }
    .title-area .sub-title {
        font-weight: 500;
        font-size: 1.8rem;
    }
    .section {
        padding: 10rem 0;
    }
    .dot-list li::before {
        top: 1rem;
    }
    br.pad-ver {
        display: block;
    }
    .shadow-1::before {
        top: .6rem;
        border-radius: 1.2rem;
    }
    .shadow-1::after {
        border-radius: 1.2rem;
    }
    .notice-list li {
        font-size: 1.4rem;
    }
    .notice-list li::before {
        min-width: .8rem;
        height: .8rem;
        top: .7rem;
        margin-right: .6rem;
    }
}

@media (max-width: 768px) {
    br.mb-ver {
        display: block;
    }
    br.mb-ver-none {
        display: none;
    }
    br.pc-ver {
    display: none;
    }
    h1.title {
        font-size: 2.8rem;
    }
    .wrap {
        padding: 0 2rem;
    }
    .dot-list li::before {
        top: .9rem;
    }
}

/* @media (max-width: 389px) {
    .wrap {
        padding: 0 2rem;
    }
} */

.scroll-y {
    overflow-x: hidden;
    overflow-y: auto;
}
.scroll-y::-webkit-scrollbar {
    width: .375rem;
    height: .375rem;
    background-color: transparent;
}
.scroll-y::-webkit-scrollbar-track {
    background-color: transparent;
}
.scroll-y::-webkit-scrollbar-thumb {
    background-color: #D8DCE2;
}
.scroll-y::-webkit-scrollbar-button {
    width: 0;
    height: 0;
}

/* 모달 공통 */
.modal-area {
    background: rgb(0, 0, 0, 50%);
    width: 100%;
    height: 100%;
    display: none;
    word-break: keep-all;
    z-index: 500;
    top: 0;
    left: 0;
}
.modal-area.active {
    display: block;
}
.modal-area .modal {
    display: none;
}
.modal-area .modal.active {
    display: block;
}
.modal-area .close-btn {
    top: 2.2rem;
    right: 2.4rem;
    cursor: pointer;
    z-index: 10;
}
/* .modal-area .close-btn:hover {
    content: url(../img/ico_close-hover.svg);
} */
/* .modal-area .modal {
    padding: 48px 40px;
    border-radius: 2.0rem;
    z-index: 1;
} */


/* ------------------------------------------------------------------------------- */


/* 애니메이션 */
@keyframes bounce1 {
    0%,100% {
        transform: translate(0,-15%);
    }
    50% {
        transform: translate(0, 0%);
    }
}

.bounce1 {
    animation-name: bounce1;
    animation-duration: 2.5s;
    /* animation-delay: 0.2s; */
    animation-iteration-count: infinite;
}

@keyframes bounce2 {
    0%,100% {
        transform: translate(0,-7.5%);
    }
    50% {
        transform: translate(0, 0%);
    }
}

.bounce2 {
    animation-name: bounce2;
    animation-duration: 2.5s;
    /* animation-delay: 0.2s; */
    animation-iteration-count: infinite;
}

@keyframes add-chart1 {
	100% {
        transform: translateY(0px);
        opacity:1;
    }
}

@keyframes moving1 {
    0%, 100% {
        transform: translate(10px,-10px);
    }
    50% {
        transform: translate(0,0);
    }
}
.moving1 {
    -webkit-animation-name: moving1;
    animation-name: moving1;
    animation-duration: 2.5s;
    animation-iteration-count: infinite;
}

@keyframes moving2 {
    0%, 100% {
        transform: translate(-10px,-10px);
    }
    50% {
        transform: translate(0,0);
    }
}
.moving2 {
    -webkit-animation-name: moving2;
    animation-name: moving2;
    animation-duration: 2.5s;
    animation-iteration-count: infinite;
}

@keyframes add-round {
	0% {
        transform: scale(0.5);
        opacity: 0;
    }
    100% {
        transform: scale(1);
        opacity: 0.4;
    }
}
.add-round {
    animation: add-round 0.5s 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) alternate infinite;
}

@keyframes fade1 {
	0% {
        opacity: .3;
    }
    40%, 60% {
        opacity: 1;
    }
    100% {
        opacity: .3;
    }
}

.fade1 {
   -webkit-animation-name: fade1;
    animation-name: fade1;
    animation-duration: 5s;
    animation-iteration-count: infinite;
}

@keyframes fade2 {
	0% {
        opacity: 0;
    }
    30%, 70% {
        opacity: .3;
    }
    100% {
        opacity: 0;
    }
}

.fade2 {
   -webkit-animation-name: fade2;
    animation-name: fade2;
    animation-duration: 4s;
    animation-iteration-count: infinite;
}

@keyframes fade3 {
	0% {
        opacity: 0;
    }
    30%, 70% {
        opacity: .5;
    }
    100% {
        opacity: 0;
    }
}

.fade3 {
   -webkit-animation-name: fade3;
    animation-name: fade3;
    animation-duration: 4s;
    animation-iteration-count: infinite;
    animation-delay: .5s;
}


@keyframes scale {
    0% {
        opacity: 0;
        -webkit-transform: scale(0);
        transform: scale(0);
    }
    100% {
        opacity: 1;
        -webkit-transform: scale(1);
        transform: scale(1);
    }
}
.scale {
    -webkit-animation-name: scale;
    animation-name: scale;
}

@keyframes scale1 {
    0%, 100% {
        opacity: 0;
        -webkit-transform: scale(0);
        transform: scale(0);
    }
    50% {
        opacity: 1;
        -webkit-transform: scale(1);
        transform: scale(1);
    }
}
.scale1 {
    -webkit-animation-name: scale1;
    animation-name: scale1;
    animation-iteration-count: infinite;
    animation-duration: 4s;
}

@keyframes scale2 {
    0% {
        opacity: 0;
        -webkit-transform: scale(.4);
        transform: scale(.4);
    }
    100% {
        opacity: 1;
        -webkit-transform: scale(1);
        transform: scale(1);
    }
}
.scale2 {
    -webkit-animation-name: scale2;
    animation-name: scale2;
}

@keyframes sticker1 {
    0% {
        transform: matrix3d(1, 0, 1.6, 0.005, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        opacity: 1;
    }
    50% {
        transform: matrix3d(1, 0, 1.6, -0.005, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}
.sticker1 {
    animation: sticker1 2s cubic-bezier(0.68, -0.6, 0.32, 1.6) alternate infinite;
    opacity: 0;
}

@keyframes sticker1-2 {
    0% {
        transform: matrix3d(1, 0, 1.3, 0.003, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1) rotate(10deg);
        opacity: 1;
    }
    50% {
        transform: matrix3d(1, 0, 1.3, -0.003, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1) rotate(-10deg);
        opacity: 1;
    }
    100% {
        transform: none;
        opacity: 1;
    }
}

.sticker1-2 {
    animation: sticker1-2 2s cubic-bezier(0.68, -0.6, 0.32, 1.6) alternate infinite;
    opacity: 0;
}

@keyframes sticker2 {
    0% {
        transform: scale(0.5);
        opacity: 1;
    }
    50% {
        transform: scale(1.1);
        opacity: 1;
    }
}
.sticker2 {
    animation: sticker2 1.3s cubic-bezier(0.32, 0, 0.67, 0) alternate infinite;
    opacity: 0;
}

@keyframes zoom1 {
    0% {
        transform: scale(1);
    }
    100% {
        transform: scale(1.05);
    }
}
.zoom1 {
    animation: zoom1 1s cubic-bezier(0.68, -0.6, 0.32, 1.6) alternate infinite;
}

@keyframes zoom2 {
    0% {
        transform: scale(.8);
    }
    100% {
        transform: scale(1.05);
    }
}
.zoom2 {
    animation: zoom2 1s cubic-bezier(0.68, -0.6, 0.32, 1.6) alternate infinite;
}

@keyframes zoom3 {
    0% {
        transform: scale(.94);
    }
    100% {
        transform: scale(1);
    }
}
.zoom3 {
    animation: zoom3 1.2s cubic-bezier(0.68, -0.6, 0.32, 1.6) alternate infinite;
}

@keyframes zoomOutBounce {
    0% {
        transform: scale(.7) translateY(40px);
        opacity: 0;
    }
    50% {
        transform: scale(1.08) translateY(-10px);
        opacity: 1;
    }
    70% {
        transform: scale(.97) translateY(5px);
    }
    85% {
        transform: scale(1.02) translateY(-3px);
    }
    100% {
        transform: scale(1) translateY(0);
    }
}
.zoomOutBounce {
    animation: zoomOutBounce 1s linear;
}

@keyframes rotate1 {
    0% {
        transform: rotate(0deg);
    }
    10% {
        transform: rotate(15deg);
    }
    20% {
        transform: rotate(-5deg);
    }
    30% {
        transform: rotate(15deg);
    }
    40% {
        transform: rotate(-5deg);
    }
    50% {
        transform: rotate(0deg);
    }
}
.rotate1 {
    animation-name: rotate1;
    animation-duration: 2s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}

@keyframes rotate2 {
    0% {
        transform: rotate(0deg);
    }
    10% {
        transform: rotate(5deg);
    }
    20% {
        transform: rotate(-5deg);
    }
    30% {
        transform: rotate(5deg);
    }
    40% {
        transform: rotate(-5deg);
    }
    50% {
        transform: rotate(0deg);
    }
}
.rotate2 {
    animation-name: rotate2;
    animation-duration: 2s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}

@keyframes jump1 {
    0%, 50%, 100% {
        transform: translateY(14px);
    }
    60% {
        transform: translateY(0);
    }
    70% {
        transform: translateY(6px);
    }
    80% {
        transform: translateY(0);
    }
}
.jump1 {
    animation-name: jump1;
    animation-duration: 2.4s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}

@keyframes swing2 {
    0% {
        transform: rotate(0deg);
    }
    20% {
        transform: rotate(6deg);
    }
    40% {
        transform: rotate(-6deg);
    }
    60% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(0deg);
    }
}
.swing2 {
    animation-name: swing2;
    animation-duration: 3s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}

@keyframes float-y {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-10px); }
}
.float-y  { 
    animation: float-y 2.4s ease-in-out infinite;
}

@keyframes float-y-slow {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}
.float-y-slow  { 
    animation: float-y-slow 3.8s ease-in-out infinite 0.5s;
}

@keyframes drive {
  0%, 100% { transform: translateX(0); }
  40%       { transform: translateX(6px); }
  60%       { transform: translateX(6px); }
}
.drive  { 
    animation: drive 2.4s ease-in-out infinite;
}

@keyframes drive2 {
  0%, 100% { transform: translateX(0); }
  40%       { transform: translateX(12px); }
  60%       { transform: translateX(12px); }
}
.drive2  { 
    animation: drive2 2.4s ease-in-out infinite;
}

@keyframes conveyor {
  0%   { transform: translateX(0) rotate(-1deg); }
  50%  { transform: translateX(-4px) rotate(1deg); }
  100% { transform: translateX(0) rotate(-1deg); }
}
.conveyor  { 
    animation: conveyor 2.0s ease-in-out infinite;
}

@keyframes arm-swing {
  0%, 100% { transform: rotate(0deg); transform-origin: bottom center; }
  40%       { transform: rotate(-8deg); transform-origin: bottom center; }
  60%       { transform: rotate(8deg); transform-origin: bottom center; }
}
.arm-swing  { 
    animation: arm-swing 2.8s ease-in-out infinite;
}

@keyframes doc-hover {
  0%, 100% { transform: translateY(0) rotate(-3deg); }
  50%       { transform: translateY(-6px) rotate(2deg); }
}
.doc-hover  { 
    animation: doc-hover 3.2s ease-in-out infinite;
}

@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.spin-slow  { 
    animation: spin-slow 6.0s linear infinite reverse;
}
.spin-slow-r  { 
    animation: spin-slow 6.0s linear infinite;
}

@keyframes twinkle {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.4; transform: scale(0.7); }
}
.twinkle  { 
    animation: twinkle 3.6s ease-in-out infinite 0.8s;
}

@keyframes bob {
  0%, 100% { transform: translate(0,0) scale(0.9) rotate(0deg); }
  50%       { transform: translate(-10px,-10px) scale(1.05) rotate(10deg); }
}
.bob  { 
    animation: bob 2.8s ease-in-out infinite;
}