body { margin: 0; background: #fff; color: #222; }
body header { background: rgba(0,0,0,0.7); }

.eso-process-section {
    padding: clamp(0rem, 14vw, 21.6rem) clamp(2rem, 4vw, 6rem) clamp(6rem, 8vw, 10rem);
    min-height: 100vh;

}
.eso-process-inner { max-width: 920px; margin: 0 auto; }

.eso-process-heading {
    font-size: clamp(2.8rem, 3.5vw, 4.8rem);
    font-weight: 700;
    font-family: var(--font-ko);
    color: #111;
    text-align: center;
    margin: 0 0 clamp(4rem, 7vw, 12.6rem);
    letter-spacing: -0.03em;

}

/* 스텝 원형 */
.eso-process-steps { display: flex; justify-content: center; align-items: center; margin-bottom: clamp(6rem, 8vw, 10rem); }

.eso-process-step { margin-left: clamp(-2rem, -1.5vw, -1rem); }
.eso-process-step:first-child { margin-left: 0; }

.eso-process-circle {
    width: clamp(12rem, 16vw, 21.2rem);
    height: clamp(12rem, 16vw, 21.2rem);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.8;

}
.eso-process-circle-1 { background: linear-gradient(90deg, rgba(0,0,0,0.20) 0%, rgba(60,60,60,0.20) 23%, rgba(255,255,255,0.10) 100%); }
.eso-process-circle-2 { background: linear-gradient(90deg, rgba(0,0,0,0.40) 0%, rgba(60,60,60,0.40) 23%, rgba(255,255,255,0.20) 100%); }
.eso-process-circle-3 { background: linear-gradient(90deg, rgba(0,0,0,0.50) 0%, rgba(60,60,60,0.50) 23%, rgba(255,255,255,0.25) 100%); }
.eso-process-circle-4 { background: linear-gradient(90deg, #000 0%, #6D6D6D 100%); }

.eso-process-circle-label {
    font-size: clamp(1.3rem, 1.5vw, 2.4rem);
    font-weight: 700;
    color: #212121;
    font-family: var(--font-ko);
    letter-spacing: -0.03em;
    text-align: center;

}
.eso-process-circle-4 .eso-process-circle-label { color: #fff; }

/* 상세 설명 */
.eso-process-details { margin-bottom: clamp(4rem, 6vw, 8rem); }

.eso-process-detail {
    padding: clamp(3rem, 6vw, 9.8rem) 0;
    border-top: .5px solid #c8c8c8;

}
.eso-process-detail:first-child { border-top: 0; }
.eso-process-detail:last-child { border-bottom: .5px solid #ddd; }

.eso-process-detail-title {
    font-size: clamp(2rem, 2.03vw, 2.6rem);
    font-weight: 700;
    font-family: var(--font-ko);
    color: #000;
    margin: 0 0 clamp(1.6rem, 2.5vw, 3.6rem);
    letter-spacing: -0.03em;

}

.eso-process-detail-desc {
    font-size: clamp(1.3rem, 1.56vw, 2.4rem);
    font-weight: 400;
    font-family: var(--font-ko);
    color: #3C3C3C;
    line-height: 1.8;
    margin: 0;
    letter-spacing: -0.03em;

}

/* 유의사항 */
.eso-process-notice {
    background: #f5f5f5;
    border-radius: clamp(0.6rem, 0.8vw, 1rem);
    padding: clamp(2.4rem, 3vw, 5rem) clamp(2.4rem, 3.5vw, 5.6rem);
    margin-top: clamp(2rem, 4vw, 5rem);

}

.eso-process-notice-title { font-size: clamp(1.6rem, 1.56vw, 2rem); font-weight: 700; font-family: var(--font-ko); color: #3C3C3C; margin: 0 0 clamp(1.2rem, 1.5vw, 2rem); letter-spacing: -0.03em; }

.eso-process-notice-list { list-style: none; margin: 0; padding: 0; }
.eso-process-notice-list li {
    position: relative;
    padding-left: clamp(1.2rem, 1.2vw, 1.6rem);
    font-size: clamp(1.2rem, 1.25vw, 1.6rem);
    color: #6D6D6D;
    font-family: var(--font-ko);
    font-weight: 300;
    line-height: 1.8;
    letter-spacing: -0.03em;

}
.eso-process-notice-list li:last-child { margin-bottom: 0; }
.eso-process-notice-list li::before { content: ''; position: absolute; left: 0; top: clamp(0.7rem, 0.8vw, 0.9rem); width: 4px; height: 4px; background: #aaa; border-radius: 50%; }

@media all and (max-width: 1024px) {
  .eso-process-steps { flex-wrap: nowrap; justify-content: center; }
  .eso-process-circle {
        width: clamp(10rem, 11vw, 12rem);
        height: clamp(10rem, 11vw, 12rem);
    
    }
  .eso-process-circle-label { font-size: clamp(1rem, 2.8vw, 1.4rem); }
  .eso-process-step { margin-left: clamp(-1.5rem, -3vw, -1rem); }
  .eso-process-step:first-child { margin-left: 0; }
  .eso-process-detail-desc br { display: none; }
}
