.logo {
    margin: 0 auto 32px;
    width: 206px;
}

.copyright .logo {
    margin: 0 0 10px;
    width: 94px;
}

.logo > img {
    display: block;
    width: 100%;
    height: auto;
}

.logo-lp {
    margin: 0 auto 24px;
    width: 74px;
}

.logo-lp > img {
    display: block;
    width: 100%;
    height: auto;
}

.copyright-text {
    color: #171717;
    font-size: 8px;
    font-weight: 400;
    line-height: 120%;
    text-align: right;
}

.landing-text {
    color: #171717;
    font-size: 14px;
    font-weight: 400;
    line-height: 120%;
    letter-spacing: 0.36px;
}

.text-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    color: #171717;
    font-size: 12px;
    font-weight: 400;
    line-height: 24px;

    cursor: pointer;
}

.box-btn {
    padding: 0 22px;
    min-width: 52px;
    height: 50px;
    border-radius: 5px;
    background: #F2F2E8;

    font-size: 14px;
    font-weight: 400;
    line-height: 50px;
    letter-spacing: 0.42px;

    text-align: center;
}

@media (max-width: 1024px) {
    .box-btn {
        min-width: 50px;
        height: 45px;
        line-height: 45px;
    }
}

.stage-text-box {
    border-radius: 5px;
    background: #F2F2E8;

    color: #171717;
    font-size: 12px;
    font-weight: 400;
    line-height: 24px;
}

.stage-text-box-inner {
    position: relative;
    width: 100%;
    height: 100%;
}

.stage-header {
    position: fixed;
    z-index: 99;
    top: 0;
    left: 0;
    width: 100%;
}

.stage-header-inner {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 34px 30px 0;
    width: 100%;
}

@media (max-width: 1024px) {
    .stage-header-inner {
        padding: 12px 20px 0;
    }
}

.util-list {
    display: flex;
    gap: 15px;
}

.stage-title {
    position: absolute;
    top: 34px;
    left: 50%;
    transform: translate(-50%, 0);
    width: 375px;
    height: 30px;
    text-align: center;
}

@media (max-width: 1024px) {
    .stage-title {
        position: absolute;
        top: calc(36px + 12px);
        left: 50%;
        transform: translate(-50%, 0);
        width: calc(100% - 40px);
    }
}

.stage-title span {
    font-family: 'Suisse Int\'l Mono';
    line-height: 30px;
    font-size: 12px;
    font-weight: 400;
}

.copyright {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

@media (max-width: 1024px) {
    .stage-footer-inner {
        padding: 0;
    }

    .copyright {
        display: none !important;
    }
}

.stage-info {
    position: absolute;
    top: 72px;
    left: 50%;
    transform: translate(-50%, 0);
    padding: 0 30px;
    width: fit-content;
    min-width: 375px;
    height: 50px;
    text-align: center;
}

.stage-info span {
    font-size: 14px;
    letter-spacing: 0.42px;
    line-height: 50px;
}

@media (max-width: 1024px) {
    .stage-info {
        position: absolute;
        bottom: initial;
        top: calc(36px + 12px + 30px + 8px);
        left: 50%;
        transform: translate(-50%, 0);
        padding: 0 30px;
        width: calc(100% - 40px);
        min-width: auto;
        height: 45px;
        text-align: center;
    }

    .stage-info span {
        line-height: 45px;
        font-size: 13.5px;
        letter-spacing: 0.38px;
    }
}

/* 모바일 녹화 진행바 (클립 길이 기준 / 끝에서 자동 추출) */
#mux-progress {
    position: fixed;
    left: 50%;
    bottom: 90px;
    transform: translateX(-50%);
    z-index: 60;
    width: 240px;
    max-width: calc(100% - 40px);
    display: none;
    text-align: center;
    pointer-events: none;
}

#mux-progress.show {
    display: block;
}

#mux-progress .mux-track {
    height: 6px;
    border-radius: 3px;
    background: rgba(0, 0, 0, 0.12);
    overflow: hidden;
}

#mux-progress .mux-fill {
    height: 100%;
    width: 0;
    background: #3931ac;
    border-radius: 3px;
    transition: width 0.1s linear;
}

#mux-progress .mux-time {
    margin-top: 8px;
    font-family: 'Suisse Int\'l Mono';
    font-size: 12px;
    color: #171717;
}

.console-log-wrapper {
    position: fixed;
    top: calc(58px + 20px);
    left: 34px;
}

.console-log-list {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-height: 226px;
}

.console-log-item:nth-child(2) {
    opacity: 0.6 !important;
}

.console-log-item:nth-child(3) {
    opacity: 0.2 !important;
}

@media (max-width: 1024px) {
    .console-log-wrapper {
        position: fixed;
        bottom: initial;
        top: 142px;
        left: 20px;
    }

    .console-log-list {
        min-height: auto;
    }

    .console-log-item:nth-child(1) {
        opacity: 0.9 !important;
    }

    .console-log-item:nth-child(2) {
        opacity: 0.45 !important;
    }
}

.console-log-item {
    width: fit-content;
    height: 42px;
    padding: 0 14px;
    border-radius: 3px;
    background: #C7E2FF;
    animation: log-pop 0.45s cubic-bezier(.34, 1.6, .64, 1) both;
}

@keyframes log-pop {
    from {
        opacity: 0;
        transform: scale(0.5);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.console-log-item > span {
    font-family: 'Suisse Int\'l Mono';
    font-size: 14px;
    font-weight: 400;
    line-height: 42px;
}

@media (max-width: 1024px) {
    .console-log-item {
        width: fit-content;
        height: 30px;
        animation: log-pop 0.45s cubic-bezier(.34, 1.6, .64, 1) both;
    }

    .console-log-item > span {
        font-size: 12px;
        font-weight: 400;
        line-height: 30px;
    }
}

.layer-popup {
    display: none;
    position: fixed;
    z-index: 10000;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    min-width: 375px;
    min-height: 310px;
}

.layer-popup-inner {
    position: relative;
    padding: 34px 20px 24px;
    width: 100%;
    height: 100%;
    background: #F2F2E8;
    border-radius: 5px;
}

@media (max-width: 1024px) {
    .layer-popup {
        display: none;
        position: fixed;
        z-index: 10000;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        min-width: auto;
        width: calc(100% - 40px);
        min-height: 310px;
    }

    .layer-popup-inner {
        padding: 34px 10px 22px;
    }
}

.lp-text-box {
    display: none;
    text-align: center;
}

.lp-text-box > strong {
    display: block;
    margin-bottom: 20px;
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: 160%;
}

.lp-text-box > p {
    font-size: 12px;
    font-weight: 400;
    line-height: 160%;
}

.lp-text-box > p > strong {
    font-weight: 500;
}

.lp-close-btn {
    margin: 20px auto 0;
    width: fit-content;
}

.layer-popup.open {
    display: block;
    animation: lp-pop 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes lp-pop {
    from {
        opacity: 0;
        transform: translate(-50%, -50%) scale(0.8);
    }
    to {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1);
    }
}

.layer-popup.closing {
    display: block;
    pointer-events: none;
    animation: lp-pop-out 0.2s ease-in both;
}

@keyframes lp-pop-out {
    from {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1);
    }
    to {
        opacity: 0;
        transform: translate(-50%, -50%) scale(0.8);
    }
}

.lp-text-box.show {
    display: block;
}

.layer-popup-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    backdrop-filter: blur(50px);
    -webkit-backdrop-filter: blur(50px);
}

.layer-popup-backdrop.open {
    display: block;
}

.layer-popup-backdrop.no-blur {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.stage-select-guide.stage-text-box {
    position: fixed;
    z-index: 10;
    bottom: 34px;
    left: 50%;
    min-width: 375px;
    height: 50px;
    background: #171717;
    text-align: center;
    color: #FFFDFB;
    font-size: 14px;
    font-weight: 400;
    line-height: 150%;
    letter-spacing: 0.42px;

    cursor: pointer;
    /* 기본: 숨김 (프리뷰 전). 센터에 오면 .show로 뿅 등장 */
    opacity: 0;
    transform: translateX(-50%) scale(0.5);
    pointer-events: none;
    transition: opacity 0.3s ease, transform 0.45s cubic-bezier(.34, 1.6, .64, 1);
}

.stage-select-guide.stage-text-box.show {
    opacity: 1;
    transform: translateX(-50%) scale(1);
    pointer-events: auto;
}

.stage-select-guide.stage-text-box span {
    line-height: 50px;
}

@media (max-width: 1024px) {
    .stage-select-guide.stage-text-box {
        min-width: calc(100% - 40px);
        bottom: 25px;
        height: 45px;
    }

    .stage-select-guide.stage-text-box span {
        line-height: 45px;
    }
}

#btn-download {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: #F2F2E8;
    color: #171717;
}

#btn-presave {
    padding: 0 30px;
    background: #171717;
    color: #F2F2E8;
}

#btn-share {
    max-width: 52px;
    padding: 0;
    background-image: url("data:image/svg+xml,%3Csvg width='18' height='15' viewBox='0 0 18 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M11.6734 5.53397V2.33281L16.4504 7.5L11.6734 12.6672V9.46603H10.3607C7.00296 9.46603 4.15698 10.1353 1.74343 12.0132C2.17524 10.5717 2.86205 9.22906 3.84091 8.15275C5.23522 6.61963 7.30246 5.53397 10.3607 5.53397H11.6734ZM9.04795 10.8157C5.83251 11.015 3.30119 12.0029 1.18774 14.3112C0.749563 14.7897 -0.0818481 14.5044 0.00651932 13.862C0.656185 9.13932 3.53898 4.22328 10.3607 4.22328V0.656664C10.3607 0.0600965 11.094 -0.226203 11.4993 0.212157L17.8259 7.05549C18.058 7.30653 18.058 7.69347 17.8259 7.94451L11.4993 14.7878C11.094 15.2262 10.3607 14.9399 10.3607 14.3433V10.7767C9.91071 10.7767 9.47334 10.7893 9.04795 10.8157Z' fill='%23171717'/%3E%3C/svg%3E%0A");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 18px 15px;
}

#btn-x {
    padding: 0;
    background-image: url("data:image/svg+xml,%3Csvg width='16' height='14' viewBox='0 0 16 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.6009 0H15.0544L9.69434 5.93026L16 14H11.0627L7.19566 9.10574L2.77087 14H0.31595L6.04904 7.65692L0 0H5.06262L8.55811 4.47354L12.6009 0ZM11.7399 12.5785H13.0993L4.32392 1.34687H2.86506L11.7399 12.5785Z' fill='black'/%3E%3C/svg%3E%0A");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 16px 14px;
}

@media (max-width: 1024px) {
    #btn-presave {
        padding: 0 20px;
    }

    #btn-share,
    #btn-x {
        max-width: 50px;
    }
}