/* === 스텝폼 + CTA 모달 + 하단 고정 바 공통 스타일 === */

/* 스텝폼 컨테이너 */
.stepform{padding:32px 24px;background:#fff}
.stepform-title{font-size:20px;font-weight:700;color:var(--color-main);margin-bottom:20px;text-align:center}

/* 프로그레스 바 */
.sf-progress{display:flex;gap:4px;margin-bottom:24px}
.sf-progress-bar{flex:1;height:4px;background:#eee;border-radius:2px;transition:background .3s}
.sf-progress-bar.active{background:var(--color-main)}

/* 스텝 공통 */
.sf-step{display:none}
.sf-step.active{display:block}
.sf-step-label{font-size:11px;color:#aaa;text-transform:uppercase;margin-bottom:4px;font-weight:600}
.sf-step-title{font-size:17px;font-weight:700;color:var(--color-main);margin-bottom:16px}

/* 칩 버튼 (서비스 선택) */
.sf-chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.sf-chip{padding:12px 18px;border-radius:10px;border:2px solid #eee;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;background:#fff;color:#555;text-align:center;flex:1;min-width:calc(50% - 5px)}
.sf-chip.selected{border-color:var(--color-main);background:var(--color-main);color:#fff}
.sf-chip:active{transform:scale(.97)}

/* 입력 필드 */
.sf-field{margin-bottom:14px}
.sf-field label{display:block;font-size:13px;font-weight:600;color:#555;margin-bottom:5px}
.sf-field label .req{color:#c0392b;margin-left:2px}
.sf-input{width:100%;padding:14px 16px;border:2px solid #eee;border-radius:10px;font-size:15px;font-family:inherit;outline:none;transition:border-color .2s;-webkit-appearance:none}
.sf-input:focus{border-color:var(--color-main)}
.sf-input::placeholder{color:#ccc}

/* 선택 그룹 (라디오 대체) */
.sf-options{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.sf-option{padding:10px 14px;border-radius:8px;border:2px solid #eee;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;color:#666}
.sf-option.selected{border-color:var(--color-main);background:rgba(27,42,74,.06);color:var(--color-main);font-weight:700}

/* 체크박스 그룹 */
.sf-checks{display:flex;flex-wrap:wrap;gap:8px}
.sf-check{padding:10px 14px;border-radius:8px;border:2px solid #eee;font-size:13px;cursor:pointer;transition:all .2s;color:#666}
.sf-check.checked{border-color:var(--color-main);background:rgba(27,42,74,.06);color:var(--color-main)}

/* 버튼 */
.sf-btns{display:flex;gap:10px;margin-top:20px}
.sf-btn-prev{flex:0 0 auto;padding:14px 20px;border-radius:10px;border:2px solid #ddd;background:#fff;font-size:15px;font-weight:600;cursor:pointer;color:#888}
.sf-btn-next{flex:1;padding:14px;border-radius:10px;border:none;background:var(--color-main);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:opacity .2s}
.sf-btn-next:disabled{opacity:.4;cursor:not-allowed}
.sf-btn-submit{flex:1;padding:16px;border-radius:10px;border:none;background:var(--color-cta);color:var(--color-cta-text);font-size:17px;font-weight:700;cursor:pointer}

/* 동의 체크박스 */
.sf-consent{display:flex;align-items:flex-start;gap:8px;margin:16px 0;font-size:12px;color:#888;line-height:1.5}
.sf-consent input{margin-top:3px;width:18px;height:18px;accent-color:var(--color-main)}

/* 완료 화면 */
.sf-done{text-align:center;padding:40px 0}
.sf-done-icon{font-size:48px;margin-bottom:16px}
.sf-done-title{font-size:22px;font-weight:700;color:var(--color-main);margin-bottom:8px}
.sf-done-sub{font-size:14px;color:#888;line-height:1.6;margin-bottom:24px}
.sf-done-info{background:var(--color-bg);border-radius:12px;padding:16px;font-size:13px;color:#555;line-height:1.8}

/* 텍스트 영역 */
.sf-textarea{width:100%;padding:14px 16px;border:2px solid #eee;border-radius:10px;font-size:14px;font-family:inherit;outline:none;resize:vertical;min-height:80px;transition:border-color .2s}
.sf-textarea:focus{border-color:var(--color-main)}

/* === CTA 모달 === */
.cta-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;align-items:center;justify-content:center}
.cta-modal-overlay.show{display:flex}
.cta-modal{background:#fff;border-radius:16px;padding:24px;width:calc(100% - 48px);max-width:400px;position:relative;animation:modalIn .25s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.cta-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:#f0f0f0;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#888}
.cta-modal-title{font-size:18px;font-weight:700;color:var(--color-main);margin-bottom:16px;text-align:center}
.cta-modal-btn{display:flex;align-items:center;gap:12px;padding:16px;border-radius:12px;border:2px solid #eee;margin-bottom:10px;cursor:pointer;transition:all .2s;text-decoration:none;color:inherit}
.cta-modal-btn:hover,.cta-modal-btn:active{border-color:var(--color-main);background:rgba(27,42,74,.03)}
.cta-modal-btn-icon{font-size:24px;min-width:36px;text-align:center}
.cta-modal-btn-text{flex:1}
.cta-modal-btn-text strong{display:block;font-size:15px;font-weight:700;color:#333;margin-bottom:2px}
.cta-modal-btn-text span{font-size:12px;color:#999}

/* === 하단 고정 바 (3버튼) === */
.sticky-bar-3{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:768px;display:flex;z-index:100;background:var(--color-main);padding:8px;gap:4px}
.sticky-bar-3 a{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:14px 0;border-radius:8px;font-size:13px;font-weight:700;text-decoration:none;text-align:center;transition:opacity .2s}
.sticky-bar-3 a:active{opacity:.8}
.sticky-bar-3 .sb-phone{background:transparent;border:1.5px solid rgba(255,255,255,.35);color:#fff}
.sticky-bar-3 .sb-kakao{background:#FEE500;color:#3C1E1E}
.sticky-bar-3 .sb-form{background:var(--color-cta);color:var(--color-cta-text)}

/* === 홈페이지 바로가기 === */
.homepage-link{text-align:center;padding:20px 24px 32px;font-size:13px}
.homepage-link a{color:#aaa;text-decoration:underline;text-underline-offset:3px}
.homepage-link a:hover{color:#888}
