/*
 * Generator V3 Hero Final
 * 기존 누적 히어로 스타일을 마지막 단계에서 완전히 재설정
 */

/* 페이지 배경은 밝게 고정 */
html body.lm-v3-inner.page-generator {
    background: #edf3f9 !important;
}

/* 히어로 자체가 파란 배경을 담당 */
html body.lm-v3-inner.page-generator .generator-hero {
    display: block !important;
    position: relative !important;

    width: 100% !important;
    height: auto !important;
    min-height: 340px !important;

    margin: 0 !important;
    padding: 38px 0 !important;

    border: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;

    background:
        radial-gradient(
            circle at 72% 35%,
            rgba(61, 143, 230, .18),
            transparent 28%
        ),
        linear-gradient(
            110deg,
            #0c3d6d 0%,
            #15568f 56%,
            #164f83 100%
        ) !important;

    box-shadow: none !important;
}

/* 기존 장식 제거 */
html body.lm-v3-inner.page-generator .generator-hero::before,
html body.lm-v3-inner.page-generator .generator-hero::after {
    display: none !important;
    content: none !important;
}

/* 정확히 본문과 같은 1180px 중심축 */
html body.lm-v3-inner.page-generator
.generator-hero > .wrap.gen-hero-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 700px) 320px !important;
    justify-content: space-between !important;
    align-items: center !important;

    width: min(1180px, calc(100% - 40px)) !important;
    max-width: 1180px !important;
    min-height: 264px !important;

    margin: 0 auto !important;
    padding: 0 !important;
    gap: 60px !important;

    transform: none !important;
    left: auto !important;
    right: auto !important;

    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

/* 왼쪽 콘텐츠 */
html body.lm-v3-inner.page-generator
.generator-hero .gen-hero-grid > div:first-child {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;

    width: 100% !important;
    max-width: 700px !important;

    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
}

html body.lm-v3-inner.page-generator .gen-label {
    align-self: flex-start !important;
    margin: 0 !important;
}

/* 제목 */
html body.lm-v3-inner.page-generator .generator-hero h1 {
    width: 100% !important;
    max-width: 680px !important;

    margin: 17px 0 13px !important;
    padding: 0 !important;

    color: #fff !important;
    font-size: 51px !important;
    line-height: 1.09 !important;
    letter-spacing: -.055em !important;

    text-align: left !important;
    word-break: keep-all !important;
}

/* 설명 */
html body.lm-v3-inner.page-generator .generator-hero p {
    width: 100% !important;
    max-width: 680px !important;

    margin: 0 !important;
    padding: 0 !important;

    color: #c8d9e9 !important;
    font-size: 15px !important;
    line-height: 1.65 !important;
    font-weight: 750 !important;

    text-align: left !important;
}

/* 버튼은 반드시 파란 영역 내부 */
html body.lm-v3-inner.page-generator .gen-actions {
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;

    width: auto !important;
    margin: 23px 0 0 !important;
    padding: 0 !important;
    gap: 10px !important;
}

html body.lm-v3-inner.page-generator .gen-actions .gen-btn {
    min-width: 145px !important;
    min-height: 44px !important;
    margin: 0 !important;
}

/* 오른쪽 회원 상태카드 */
html body.lm-v3-inner.page-generator .gen-status-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;

    justify-self: end !important;
    align-self: center !important;

    width: 320px !important;
    min-width: 320px !important;
    max-width: 320px !important;
    height: 170px !important;
    min-height: 170px !important;

    margin: 0 !important;
    padding: 24px !important;

    border: 1px solid rgba(255,255,255,.21) !important;
    border-radius: 19px !important;

    color: #fff !important;
    text-align: center !important;

    background:
        linear-gradient(
            145deg,
            rgba(70,145,221,.92),
            rgba(23,78,133,.94)
        ) !important;

    box-shadow:
        0 18px 38px rgba(0,28,62,.22),
        inset 0 1px 0 rgba(255,255,255,.13) !important;

    backdrop-filter: none !important;
    overflow: hidden !important;
    transform: none !important;
}

html body.lm-v3-inner.page-generator .gen-status-card::before,
html body.lm-v3-inner.page-generator .gen-status-card::after {
    display: none !important;
    content: none !important;
}

html body.lm-v3-inner.page-generator .gen-status-card strong {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;

    color: #ffd365 !important;
    font-size: 25px !important;
    line-height: 1.2 !important;
    text-align: center !important;
}

html body.lm-v3-inner.page-generator .gen-status-card span {
    display: block !important;
    width: 100% !important;
    margin: 14px 0 0 !important;

    color: #fff !important;
    font-size: 14px !important;
    line-height: 1.35 !important;
    text-align: center !important;
}

html body.lm-v3-inner.page-generator .gen-status-card em {
    display: block !important;
    width: 100% !important;
    margin: 10px 0 0 !important;

    color: #d9e7f4 !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
    font-style: normal !important;
    text-align: center !important;
}

/* 본문도 히어로와 같은 중심축 */
html body.lm-v3-inner.page-generator .gen-layout,
html body.lm-v3-inner.page-generator .result-card {
    width: min(1180px, calc(100% - 40px)) !important;
    max-width: 1180px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

html body.lm-v3-inner.page-generator .gen-layout {
    margin-top: 34px !important;
}

/* 태블릿 */
@media (max-width: 980px) {
    html body.lm-v3-inner.page-generator .generator-hero {
        min-height: auto !important;
    }

    html body.lm-v3-inner.page-generator
    .generator-hero > .wrap.gen-hero-grid {
        grid-template-columns: 1fr !important;
        gap: 25px !important;
    }

    html body.lm-v3-inner.page-generator
    .generator-hero .gen-hero-grid > div:first-child {
        align-items: center !important;
        max-width: none !important;
        text-align: center !important;
    }

    html body.lm-v3-inner.page-generator .gen-label {
        align-self: center !important;
    }

    html body.lm-v3-inner.page-generator .generator-hero h1,
    html body.lm-v3-inner.page-generator .generator-hero p {
        margin-left: auto !important;
        margin-right: auto !important;
        text-align: center !important;
    }

    html body.lm-v3-inner.page-generator .gen-actions {
        justify-content: center !important;
    }

    html body.lm-v3-inner.page-generator .gen-status-card {
        justify-self: center !important;
        width: min(100%, 430px) !important;
        min-width: 0 !important;
        max-width: 430px !important;
    }
}

/* 모바일 */
@media (max-width: 600px) {
    html body.lm-v3-inner.page-generator .generator-hero {
        padding: 27px 0 !important;
    }

    html body.lm-v3-inner.page-generator
    .generator-hero > .wrap.gen-hero-grid,
    html body.lm-v3-inner.page-generator .gen-layout,
    html body.lm-v3-inner.page-generator .result-card {
        width: calc(100% - 28px) !important;
    }

    html body.lm-v3-inner.page-generator .generator-hero h1 {
        font-size: 37px !important;
    }

    html body.lm-v3-inner.page-generator .gen-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        width: min(100%, 390px) !important;
    }

    html body.lm-v3-inner.page-generator .gen-actions .gen-btn {
        min-width: 0 !important;
    }

    html body.lm-v3-inner.page-generator .gen-status-card {
        width: 100% !important;
        height: auto !important;
        min-height: 155px !important;
    }
}

@media (max-width: 430px) {
    html body.lm-v3-inner.page-generator .generator-hero h1 {
        font-size: 33px !important;
    }

    html body.lm-v3-inner.page-generator .gen-actions {
        grid-template-columns: 1fr !important;
    }
}

/* Generator full-width hero correction */

html,
body {
    overflow-x: hidden;
}

html body.lm-v3-inner.page-generator .generator-hero {
    width: 100vw !important;
    max-width: none !important;

    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;

    background:
        radial-gradient(
            circle at 68% 38%,
            rgba(73, 151, 235, .18),
            transparent 30%
        ),
        linear-gradient(
            110deg,
            #0c3d6d 0%,
            #15568f 58%,
            #164f83 100%
        ) !important;
}

html body.lm-v3-inner.page-generator
.generator-hero > .wrap.gen-hero-grid {
    grid-template-columns: minmax(0, 680px) 320px !important;
    justify-content: space-between !important;

    width: min(1180px, calc(100% - 40px)) !important;
    max-width: 1180px !important;

    margin-left: auto !important;
    margin-right: auto !important;

    gap: 80px !important;
}

html body.lm-v3-inner.page-generator
.generator-hero .gen-hero-grid > div:first-child {
    max-width: 680px !important;
}

html body.lm-v3-inner.page-generator .gen-status-card {
    justify-self: end !important;
}

@media (max-width: 980px) {
    html body.lm-v3-inner.page-generator
    .generator-hero > .wrap.gen-hero-grid {
        grid-template-columns: 1fr !important;
        gap: 24px !important;
    }

    html body.lm-v3-inner.page-generator .gen-status-card {
        justify-self: center !important;
    }
}
