/* 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;}
.c838383 {color : #838383}

/* 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;}


/* point color */
.c60CAFF {color: #60CAFF;}
.c0072FD {color: #0072FD;}
.cF8B500 {color: #F8B500;}
.c5472FF {color: #5472FF;}
.c7FBF26 {color: #7FBF26;}
.cE6428F {color: #E6428F;}
.c00B7D5 {color: #00B7D5;}

.b171717 {background-color: #171717;}
.b60CAFF {background-color: #60CAFF;}
.b0072FD {background-color: #0072FD;}

/* gradient */
.text-gr-1 {
    background: linear-gradient(90deg, #FFFFFF 0%, #60CAFF 100%);
    color: transparent;
    -webkit-background-clip: text;
    display: inline-block;
}
.text-gr-11 {
    background: linear-gradient(90deg, #FFFFFF 0%, rgba(96, 202, 255, 1) 50%,rgba(96, 202, 255, 0) 100%);
    color: transparent;
    -webkit-background-clip: text;
    display: inline-block;
}
.text-gr-2 {
    background: linear-gradient(97.91deg, #0072FD 17.18%, #00FBFF 112.34%);
    color: transparent;
    -webkit-background-clip: text;
    display: inline-block;
}
.text-gr-3 {
    background: linear-gradient(90deg,rgba(0, 75, 250, 0.3) 0%, rgba(85, 176, 255, 0.7) 50%, rgba(0, 75, 250, 0.3) 100%);
    color: transparent;
    -webkit-background-clip: text;
    display: inline-block;
}
.gr-1 {
    background: linear-gradient(180deg, #0072FD -46.85%, #000000 23.23%);
}


/* ------------------------------------------------------------------------------- */


/* 컴포넌트 */

.wrap {
    max-width: 108rem;
    padding: 0 4rem;
    margin: 0 auto;
}

section {
    overflow: hidden;
}

/* section 공통 패딩 */
.section {
    padding: 16rem 0;
}

/* title 공통 */
.title-box {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 2.5rem;
}
.title-box p,
.title-box p span {
    font-weight: 500;
    font-size: 2.4rem;
    line-height: 1.5;
    letter-spacing: -0.03em;
    text-align: center;
    color: #aaa;
}
h1.title {
    font-size: 5.5rem;
    font-weight: 800;
    line-height: 1.28;
    letter-spacing: -0.03em;
    text-align: center;
}

.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");
}

.dot-list li {
    position: relative;
    display: flex;
    align-items: center;
}
.dot-list li::before {
    position: relative;
    content: '';
    width: .4rem;
    height: .4rem;
    border-radius: 50%;
    background-color: #000;
    display: inline-block;
    margin-right: .8rem;
}

i {
    display: block;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

/* :root {
    --global--size: clamp(2rem, 4vw, 5rem);
    --anim--hover-time: 400ms;
    --anim--hover-ease: cubic-bezier(0.25, 1, 0.5, 1);
}
@property --angle-1 {
    syntax: "<angle>";
    inherits: false;
    initial-value: -75deg;
}
@property --angle-2 {
    syntax: "<angle>";
    inherits: false;
    initial-value: -45deg;
}
.alarm__wrap .button-wrap {
    position: relative;
    z-index: 100;
    width: max-content;
    margin: 0 auto;
    border-radius: 100vw;
    background: rgba(0, 0, 0, 0);
    pointer-events: none;
    transition: all var(--anim--hover-time) var(--anim--hover-ease);
}
.alarm__wrap button {
    --border-width: clamp(1px, 0.0625em, 4px);
    all: unset;
    cursor: pointer;
    position: relative;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    pointer-events: auto;
    z-index: 3;
    background: linear-gradient(-75deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.05));
    border-radius: 999vw;
    box-shadow: inset 0 .125em .125em rgba(0, 0, 0, .05), inset 0 -0.125em .125em rgba(255, 255, 255, .5), 0 .25em .125em -0.125em rgba(0, 0, 0, .2), 0 0 .1em .25em inset rgba(255, 255, 255, .2), 0 0 0 0 #fff;
    backdrop-filter: blur(clamp(1px, 0.125em, 4px));
    -webkit-backdrop-filter: blur(clamp(1px, 0.125em, 4px));
    -moz-backdrop-filter: blur(clamp(1px, 0.125em, 4px));
    -ms-backdrop-filter: blur(clamp(1px, 0.125em, 4px));
    transition: all var(--anim--hover-time) var(--anim--hover-ease);
}
.alarm__wrap button::after {
    content: "";
    position: absolute;
    z-index: 1;
    inset: 0;
    border-radius: 999vw;
    width: calc(100% + var(--border-width));
    height: calc(100% + var(--border-width));
    top: calc(0% - var(--border-width) / 2);
    left: calc(0% - var(--border-width) / 2);
    padding: var(--border-width);
    box-sizing: border-box;
    background: conic-gradient(from var(--angle-1) at 50% 50%, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0) 5% 40%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0) 60% 95%, rgba(0, 0, 0, 0.5)), linear-gradient(180deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.5));
    mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    mask-composite: exclude;
    transition: all var(--anim--hover-time) var(--anim--hover-ease), --angle-1 500ms ease;
    box-shadow: inset 0 0 0 calc(var(--border-width) / 2) rgba(255, 255, 255, .5);
}
.alarm__wrap button span {
    position: relative;
    display: inline-flex;
    gap: 7px;
    align-items: center;
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    font-size: 1.2rem;
    font-weight: 700;
    color: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-shadow: 0em .25em .05em rgba(0, 0, 0, .1);
    transition: all var(--anim--hover-time) var(--anim--hover-ease);
    padding-inline: 1.5em;
    padding-block: .875em;
}
.alarm__wrap button:hover {
    transform: scale(0.975);
    backdrop-filter: blur(0.01em);
    -webkit-backdrop-filter: blur(0.01em);
    -moz-backdrop-filter: blur(0.01em);
    -ms-backdrop-filter: blur(0.01em);
    box-shadow: inset 0 .125em .125em rgba(0, 0, 0, .05), inset 0 -0.125em .125em rgba(255, 255, 255, .5), 0 .15em .05em -0.1em rgba(0, 0, 0, .25), 0 0 .05em .1em inset rgba(255, 255, 255, .5), 0 0 0 0 #fff;
}
.alarm__wrap button:hover span {
    text-shadow: .025em .025em .025em rgba(0, 0, 0, .12);
}
.alarm__wrap button:hover::after {
    --angle-1: -115deg;
} */

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.mb-none-ver {
    display: block;
}
br.tb-ver {
    display: none;
}

@media (max-width: 1279px) {

    h1.title {
        font-size: 4rem;
    }
    .title-box p, .title-box p span {
        font-size: 2rem;
    }
    .section {
        padding: 10rem 0;
    }
    .title-box {
        margin-bottom: 4.8rem;
    }
    br.tb-ver {
        display: block;
    }

}

@media (max-width: 799px) {
    br.mb-ver {
        display: block;
    }
    br.tb-ver {
        display: none;
    }
    br.mb-none-ver {
        display: none;
    }
    .title-box {
        gap: 1.8rem;
    }
    h1.title {
        font-size: 2.8rem;
    }
    .title-box p, .title-box p span {
        font-size: 1.4rem;
    }
    .wrap {
        padding: 0 2rem;
    }
}


/* ------------------------------------------------------------------------------- */


/* 애니메이션 */
@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 add-chart1 {
	100% {
        transform: translateY(0px);
        opacity:1;
    }
}

.moving1 {
    -webkit-animation-name: moving1;
    animation-name: moving1;
}
@keyframes moving1 {
    0% {
        opacity: 0;
        transform: translate(-20px,-20px);
    }
    100% {
        opacity: 1;
        transform: translate(0,0);
    }
}

.moving2 {
    -webkit-animation-name: moving2;
    animation-name: moving2;
    animation-duration: 1.7s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-out;
}
@keyframes moving2 {
    0%,30%,60%, 100% {
        transform: translateY(0);
    }
    15%, 45% {
        transform: translateY(-10px);
    }
    
}

@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: 0;
    }
    10% {
        opacity: 1;
    }
    90% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

@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 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, 2, 0.004, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        opacity: 1;
    }
    50% {
        transform: matrix3d(1, 0, 2, -0.004, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}
.sticker1 {
    /* animation: sticker09 2s 0.5s cubic-bezier(0.68, -0.6, 0.32, 1.6) alternate infinite; */
    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, 0.0015, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        opacity: 1;
    }
    50% {
        transform: matrix3d(1, 0, 1, -0.0015, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        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 rotate1 {
    0% {
        transform: rotate(0deg) translateY(-50%);
    }
    10% {
        transform: rotate(10deg) translateY(-50%);
    }
    20% {
        transform: rotate(-5deg) translateY(-50%);
    }
    30% {
        transform: rotate(10deg) translateY(-50%);
    }
    40% {
        transform: rotate(-5deg) translateY(-50%);
    }
    50% {
        transform: rotate(0deg) translateY(-50%);
    }
}
.rotate1 {
    animation-name: rotate1;
    animation-duration: 2s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}

@keyframes rotate2 {
    0% {
        transform: rotate(0deg) translateY(-50%);
    }
    10% {
        transform: rotate(-5deg) translateY(-50%);
    }
    20% {
        transform: rotate(10deg) translateY(-50%);
    }
    30% {
        transform: rotate(-5deg) translateY(-50%);
    }
    40% {
        transform: rotate(10deg) translateY(-50%);
    }
    50% {
        transform: rotate(0deg) translateY(-50%);
    }
}
.rotate2 {
    animation-name: rotate2;
    animation-duration: 2s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}

.opacity1 {
    animation: opacity1 2s infinite;
    opacity: 0;
}
@keyframes opacity1 {
    0%,100% {
        opacity: 1;
    }
    50% {
        opacity: 0;
    }
}

.opacity2 {
    animation: opacity1 4s infinite;
    opacity: 0;
}

@keyframes opacity2 {
    0%,100% {
        opacity: 1;
    }
    50% {
        opacity: 0;
    }
}

.light1 {
    animation: light1 2s ease-in-out .5s 1 forwards;
    opacity: 0;
}
@keyframes light1 {
    0% {
      opacity: 0;
    }
    10% {
      opacity: 1;
    }
    20% {
      opacity: 0;
    }
    30% {
      opacity: 1;
    }
    40% {
      opacity: 0;
    }
    90%,100% {
      opacity: 1;
    }
  }

@keyframes moveGradient {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}




  .mb-ver { display: none; }
  @media (max-width: 799px) {
    .mb-ver { display: block; }
  }