/* =========================
   기본
========================= */
*{
  box-sizing:border-box;
}

/* =========================
   큰 이미지 프레임
   PC 기준 배치 고정
========================= */
.frame_application{
  position:relative;
  width:100%;
  min-height:160vh;
  overflow:hidden;
  border-radius:0;
  box-shadow:none;
  isolation:isolate;
}

/* 배경 */
.application_bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  z-index:0;
}

/* =========================
   위에 겹치는 이미지
========================= */
.frame_overlay_application{
  position:relative;
  width:100%;
  min-height:100vh;
  z-index:2;
}

.frame_overlay_application img{
  position:absolute;
  height:auto;
  object-fit:contain;
  display:block;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:none;
  opacity:0.98;
  filter:brightness(0.97);
  transition:none !important;
}

/* 1번 이미지 = 타이틀 */
/* PC 원본 비율 유지 */
.application_title_img{
  left:0%;
  top:-30%;
  width:100%;
}

/* 2번 이미지 = 아이콘 */
/* PC 원본 비율 유지 */
.application_icon_img{
  left:20%;
  top:50%;
  width:clamp(260px, 22vw, 520px);
}

/* =========================
   상담 폼
   PC 원본 위치 유지
========================= */
.apply_form{
  position:absolute;
  left:60%;
  top:30%;
  transform:translateX(-50%);
  z-index:50;

  width:min(360px, 90vw);
  padding:18px 18px 22px;
  box-sizing:border-box;
}

/* 라벨 */
.f_label{
  display:block;
  font-size:14px;
  font-weight:800;
  color:#ffffff;
  margin:12px 6px 8px;
  letter-spacing:0.2px;
}

.req{
  color:#ff2b2b;
}

/* 입력 */
.f_input,
select{
  width:100%;
  height:48px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.95);
  outline:none;
  padding:0 16px;
  box-sizing:border-box;
  font-size:14px;
  background:rgba(255,255,255,.35);
  color:#000;
}

.f_input::placeholder{
  color:rgba(0,0,0,0.85);
}

/* select */
.select_wrap{
  position:relative;
}

.select_wrap select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  padding-right:44px;
}

.select_arrow{
  position:absolute;
  right:18px;
  top:50%;
  width:0;
  height:0;
  transform:translateY(-30%);
  border-left:6px solid transparent;
  border-right:6px solid transparent;
  border-top:7px solid rgba(255,255,255,.95);
  pointer-events:none;
}

/* 연락처 */
.tel_row{
  display:flex;
  align-items:center;
  gap:10px;
}

.tel_row .f_input{
  width:30%;
  flex:1;
  text-align:center;
  padding:0 10px;
}

.tel_dash{
  color:#fff;
  font-weight:900;
  opacity:.95;
}

/* 약관 */
.privacy_box{
  margin-top:6px;
  background:rgba(255,255,255,.35);
  border:2px solid rgba(255,255,255,.95);
  border-radius:14px;
  padding:12px;
  height:140px;
  overflow:auto;
  color:#000;
  font-size:13px;
  line-height:1.55;
}

.privacy_box hr{
  border:none;
  border-top:1px solid rgba(255,255,255,.6);
  margin:10px 0;
}

/* 체크 */
.check_row{
  display:flex;
  align-items:center;
  gap:10px;
  margin:14px 6px 0;
  color:#000;
  font-size:13px;
  font-weight:700;
}

.check_row input{
  width:18px;
  height:18px;
  accent-color:#ffffff;
}

/* 버튼 */
.apply_btn{
  width:100%;
  height:56px;
  border-radius:999px;
  border:none;
  margin-top:18px;
  background:#ffcf00;
  color:#111;
  font-weight:900;
  font-size:15px;
  letter-spacing:.2px;
  cursor:pointer;
}

.apply_btn:active{
  transform:translateY(1px);
}

/* =========================
   큰 노트북
   PC 비율 거의 그대로, 살짝 축소
========================= */
@media (max-width:1440px){
  .frame_application{
    min-height:155vh;
  }

  .application_title_img{
    top:-26%;
    width:100%;
  }

  .application_icon_img{
    left:19%;
    top:51%;
    width:clamp(240px, 21vw, 470px);
  }

  .apply_form{
    left:59%;
    top:31%;
    width:min(340px, 88vw);
  }
}

/* =========================
   일반 노트북
   PC 기준 유지 + 전체 조금 축소
========================= */
@media (max-width:1280px){
  .frame_application{
    min-height:148vh;
  }

  .application_title_img{
    top:-22%;
    width:104%;
    left:-2%;
  }

  .application_icon_img{
    left:18%;
    top:52%;
    width:clamp(220px, 20vw, 420px);
  }

  .apply_form{
    left:58%;
    top:32%;
    width:min(320px, 86vw);
    padding:16px 16px 20px;
  }

  .f_label{
    font-size:13px;
    margin:10px 6px 6px;
  }

  .f_input,
  select{
    height:44px;
    font-size:13px;
  }

  .apply_btn{
    height:52px;
    font-size:14px;
  }
}

/* =========================
   작은 노트북 / 태블릿 가로
   PC 구조 유지한 채 더 축소
========================= */
@media (max-width:1024px){
  .frame_application{
    min-height:138vh;
  }

  .frame_overlay_application{
    min-height:92vh;
  }

  .application_title_img{
    top:-16%;
    width:108%;
    left:-4%;
  }

  .application_icon_img{
    left:16%;
    top:54%;
    width:clamp(190px, 19vw, 340px);
  }

  .apply_form{
    left:58%;
    top:34%;
    width:min(300px, 84vw);
    padding:14px 14px 18px;
  }

  .privacy_box{
    height:125px;
    font-size:12px;
  }
}

/* =========================
   모바일
   PC 레이아웃 유지가 너무 어려운 구간이라
   비율 최대한 유지하며 아래로 자연스럽게 이동
========================= */
@media (max-width:767px){
  .frame_application{
    min-height:auto;
    padding-bottom:50px;
  }

  .frame_overlay_application{
    min-height:58vw;
  }

  .application_title_img{
    position:relative;
    left:auto;
    top:auto;
    width:100%;
    transform:none !important;
  }

  .application_icon_img{
    position:relative;
    left:auto;
    top:50%;
    display:none !important;
    width:min(56vw, 280px);
    margin:-6vw auto 0;
  }

  .apply_form{
    position:relative;
    left:auto;
    top:auto;
    transform:none;
    width:min(360px, 92vw);
    margin:24px auto 0;
    padding:16px 16px 20px;
  }

  .tel_row{
    gap:6px;
  }

  .tel_row .f_input{
    min-width:0;
    padding:0 6px;
    font-size:13px;
  }

  .f_input,
  select{
    height:44px;
    font-size:13px;
  }

  .apply_btn{
    height:50px;
    font-size:14px;
  }

  .privacy_box{
    height:120px;
    font-size:12px;
  }
}