@charset "utf-8";

/* am.bohumclick 통합 CSS */

/* Fonts */

@import url(https://fonts.googleapis.com/earlyaccess/nanumgothic.css);
@import url(//cdn.rawgit.com/hiun/NanumSquare/master/nanumsquare.css);
@import url(//fonts.googleapis.com/earlyaccess/notosanskr.css);

@font-face {
  font-family: 'Cafe24Ohsquare';
  src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/Cafe24Ohsquare.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

/* Base */

* { margin: 0; padding: 0; }
ul, ol, li { list-style: none; }
a { text-decoration: none; color: inherit; cursor: pointer; }
img { vertical-align: middle; border: 0; }

.clearfix:after { content: ''; display: block; clear: both; }

.w100 { width: 100%; margin: 0 auto; float: left; }
.w1100 { width: 1100px; margin: 0 auto; }

.font_i { font-style: italic; }
.font_b { font-weight: bold; }

.color_g { color: #6a6a6a; }
.color_green { color: #63980a; }
.color_b { color: #0b8fd1; }
.color_y { color: #FF0; }
.color_r { color: #ff0e0e; }

.bg_lb { background-color: #6ab8df; }
.bg_db { background-color: #2d2d2d; }

.popup_layer { position: absolute; display: none; }

/* Header */

.top_logo { float: left; margin: 20px 0; width: 55%; line-height: 70px; }
.logo_txt { padding-left: 2%; font-family: 'Cafe24Ohsquare', '돋움'; font-size: 42px; line-height: 70px; letter-spacing: -2px; color: #000; }
.top_award { float: left; }
.top_tel { float: right; margin-top: 20px; width: 45%; }

.tel_mobile_btns { display: none; }

/* Main visual */

:is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper,
.main_visual_3th, .main_visual_dis, .main_visual_mu, .main_visual_adult) {
  height: 836px;
  background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/bg.png);
  background-repeat: no-repeat;
  background-position: center;
}

:is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper, .main_visual_3th, .main_visual_dis) { background-color: #edf1f4; }
:is(.main_visual_mu, .main_visual_adult) { background-color: #49b556; }

.visual_txt1 { font-size: 28px; letter-spacing: -3px; }
.visual_txt2 { font-size: 70px; letter-spacing: -2px; line-height: 130%; font-family: 'Cafe24Ohsquare', '돋움'; }

.visual_img { background: url(https://cancerok.speedgabia.com/cencerdirect/images/main_visual_.png) center no-repeat; height: 174px; padding-top: 60px; }
.main_txt1 { padding-left: 53%; padding-top: 90px; font-family: 'Cafe24Ohsquare', '돋움'; font-size: 42px; line-height: 50px; letter-spacing: -2px; color: #2d2d2d; }
.main_txt2 { padding-left: 53%; font-family: 'Nanum Square', '돋움'; font-size: 28px; line-height: 60px; letter-spacing: -2px; color: #2d2d2d; }

/* Title text */

.title_txt1  { color: #ffffff; font-size: 32px; line-height: 130%; font-family: 'Cafe24Ohsquare', '돋움'; text-shadow: 2px 2px 2px #000; letter-spacing: -1px; }
.title_txt1_ { font-size: 20px; letter-spacing: -1.5px; }
.title_txt2  { font-size: 45px; line-height: 130%; font-family: 'Cafe24Ohsquare', '돋움'; padding-top: 50px; letter-spacing: -1px; }
.title_txt3  { font-size: 50px; color: #ee0061; }
.title_txt3_ { font-size: 45px; color: #ee0061; }
.title_txt4  { text-align: center; }
.title_txt5  { color: #ffffff; font-size: 42px; line-height: 130%; font-family: 'Cafe24Ohsquare', '돋움'; letter-spacing: -2px; text-align: left; }
.title_txt5_ { color: #ffffff; font-size: 26px; line-height: 130%; letter-spacing: -1px; text-align: left; }

.txt { width: 25%; font-size: 20px; letter-spacing: -1.5px; text-align: center; float: left; }

/* Form - PC */

:is(.form_insu_am, .form_insu_chia, .form_insu_drive, .form_insu_oper,
.form_insu_3th, .form_insu_dis, .form_insu_mu, .form_insu_adult) {
  height: 560px;
  border: 3px solid #000;
  border-radius: 30px 0 0 30px;
}

.form_insu_am    { background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/form_bg_am.png); }
.form_insu_chia  { background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/form_bg_chia.png); }
.form_insu_drive { background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/form_bg_drive.png); }
.form_insu_oper  { background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/form_bg_oper.png); }
.form_insu_3th   { background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/form_bg_3th.png); }
.form_insu_dis   { background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/form_bg_dis.png); }
.form_insu_mu    { background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/form_bg_mu.png); }
.form_insu_adult { background-image: url(https://cancerok.speedgabia.com/cencerdirect/images/form_bg_adult.png); }

.form_l { width: 364px; float: left; padding: 20px 40px; }
.form_r { width: 656px; float: right; }

.f_box  { border: #000 solid 2px; width: 95%; height: 50px; font-size: 16px; margin-bottom: 10px; padding-left: 10px; }
.f_box2 { border: #000 solid 2px; width: 65%; height: 50px; font-size: 16px; margin-bottom: 10px; padding-left: 10px; margin-right: 1%; float: left; }
.f_box2_{ border: #000 solid 2px; width: 60%; height: 50px; font-size: 16px; margin-bottom: 10px; padding-left: 10px; margin-right: 1%; float: left; }
.f_box3 { border: #000 solid 2px; width: 30%; height: 54px; font-size: 16px; margin-bottom: 10px; padding-left: 10px; margin-right: 1%; float: left; }
.f_box4 { border: #000 solid 2px; width: 20%; height: 50px; font-size: 16px; margin-bottom: 10px; padding-left: 10px; margin-right: 1%; float: left; }
.f_box5 { width: 60px; height: 24px; background-color: #373737; color: #fff; font-size: 15px; text-align: center; padding: 16px 2px; float: left; }
.f_ok   { border: #000 solid 2px; background-color: #ee0061; color: #fff; width: 100%; height: 70px; font-size: 24px; font-weight: bold; margin-bottom: 10px; letter-spacing: -1px; }

.f_rbox   { width: 49.8%; height: 121.5px; float: left; padding-top: 17px; border-bottom: 2px solid #000; border-right: 2px solid #000; }
.f_rbox_  { width: 49.8%; height: 124px;   float: left; padding-top: 15px; border-right: 2px solid #000; }
.f_rbox_r { width: 49.8%; height: 121.5px; float: left; padding-top: 17px; border-bottom: 2px solid #000; }
.f_rbox_r_{ width: 49.8%; height: 124px;   float: left; padding-top: 15px; }

.box_m    { width: 51px; height: 24px; background-color: #000;    color: #fff; font-size: 15px; text-align: center; padding: 17px 0 13px 0; float: left; }
.box_m_on { width: 51px; height: 24px; background-color: #275cab; color: #fff; font-size: 15px; font-weight: 500; text-align: center; padding: 17px 0 13px 0; float: left; }
.box_w    { width: 51px; height: 24px; background-color: #000;    color: #fff; font-size: 15px; text-align: center; padding: 17px 0 13px 0; float: left; margin-left: 3px; }
.box_w_on { width: 51px; height: 24px; background-color: #275cab; color: #fff; font-size: 15px; font-weight: 500; text-align: center; padding: 17px 0 13px 0; float: left; margin-left: 3px; }
.box_m a, .box_w a, .box_m_on a, .box_w_on a { text-decoration: none; color: #fff; }

.view_txt { font-size: 14px; line-height: 35px; color: #000; }
.view_bt a { background-color: #275cab; padding: 4px 10px; font-size: 14px; line-height: 33px; color: #fff; }

/* Form fixes */
.form_l li.agree_line p.w100.agree_box { float: none; display: flex; align-items: center; justify-content: flex-start; gap: 6px; width: 100%; margin: 12px 0 12px; padding: 0; line-height: 24px; text-align: left; box-sizing: border-box; }
.form_l li.agree_line p.agree_box input#agree { flex: 0 0 auto; display: block; margin: 0; vertical-align: middle; accent-color: #275cab; }
.form_l li.agree_line p.agree_box .view_txt { display: inline-flex; align-items: center; height: 24px; margin: 0; line-height: 24px; vertical-align: middle; white-space: nowrap; }
.form_l li.agree_line p.agree_box .view_bt { display: inline-flex; align-items: center; justify-content: center; height: 22px; margin: 0; padding: 0; vertical-align: middle; }
.form_l li.agree_line p.agree_box .view_bt a { display: inline-flex; align-items: center; justify-content: center; height: 22px; padding: 2px 8px; margin: 0; line-height: 1; border-radius: 6px; }
.form_l .f_box5, .form_l .f_box5 a, .form_l .f_ok, .form_l .f_ok span { cursor: pointer; }
.form_l .f_box5 { display: flex; align-items: center; justify-content: center; user-select: none; }
.form_l .f_box5 a { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; color: #fff; text-decoration: none; }
.form_l .f_ok { cursor: pointer; user-select: none; transition: filter 0.15s ease, transform 0.15s ease; }
.form_l .f_box5:hover, .form_l .f_ok:hover { filter: brightness(1.08); }
.form_l .f_box5:active, .form_l .f_ok:active { transform: translateY(1px); }
.form_l .f_ok span { pointer-events: none; }
.form_l .box_m, .form_l .box_w, .form_l .box_m_on, .form_l .box_w_on { cursor: pointer; user-select: none; }
.form_l .box_m, .form_l .box_w { background: #000; color: #fff; }
.form_l .box_m_on, .form_l .box_w_on { background: #275cab; color: #fff; font-weight: 500; }


.form_bt   { width: 20%; height: 70px; float: right; padding-top: 10px; background-color: #ff4c5d; border-radius: 10px; box-shadow: 0 8px 0 #a2323d; text-align: center; }
.form_bt a { display: block; line-height: 30px; font-family: 'Nanum Square', '돋움'; font-size: 24px; letter-spacing: -1px; color: #fff; font-weight: 600; }

.list     { height: 560px; border: 3px solid #000; border-radius: 30px; margin-bottom: 40px; }
.list_top { height: 65px; border-radius: 25px 25px 0 0; background-color: #2f66d0; color: #fff; font-family: 'Cafe24Ohsquare', '돋움'; font-size: 42px; padding-top: 23px; }

/* Bottom visual */

:is(.visual_am, .visual_chia, .visual_drive, .visual_oper,
.visual_3th, .visual_dis, .visual_mu, .visual_adult) {
  position: relative;
  display: flex;
  align-items: center;
  width: 1100px;
  height: 344px;
  background: url(https://cancerok.speedgabia.com/cencerdirect/images/main_banner.png) no-repeat center;
  text-align: left;
}

.banner_txt_inner { padding: 106px 40px 30px 66px; text-align: left; }

.blue_banner_wrap { width: 100%; overflow: hidden; }

/* Spacing */

.pd_t30b10 { padding: 30px 0 10px 0; }
.pd_tb30   { padding: 30px 24px; }
.pd_tb40   { padding: 40px 24px; }
.pd_tb50   { padding: 50px 24px; }
.pd_t50    { padding-top: 50px; }
.pd_b30    { padding-bottom: 30px; }
.pd_b40    { padding-bottom: 40px; }
.pd_b50    { padding-bottom: 50px; }
.pd_b60    { padding-bottom: 60px; }
.pd_t20b50 { padding: 20px 0 50px 0; }
.mg_t50    { margin-top: 50px; }

/* Product list */

.list_1 { padding-bottom: 60px; }
.list_title { height: 60px; margin-bottom: 10px; font-family: 'Nanum Square'; font-size: 27px; color: #2d2d2d; text-align: center; line-height: 60px; letter-spacing: -1px; }
.list_1_title_1 { width: 35%; float: left; }
.list_1_title_2 { width: 35%; float: right; }
.list_1 ul li { border-top: 1px solid #cccccc; height: 70px; }
.list_1 ul li:last-child { border-bottom: 1px solid #cccccc; }
.list_img { width: 100%; margin-bottom: 15px; }
.list_bt  { width: 35%; float: left; font-family: 'Nanum Square'; font-size: 20px; color: #2d2d2d; text-align: center; line-height: 35px; letter-spacing: -1px; margin-left: 5%; }
.list_bt_ { width: 100%; font-family: 'Nanum Square'; font-size: 12px; color: #2d2d2d; text-align: center; line-height: 15px; letter-spacing: -1px; margin-top: 65px; }
.list_bt2 { width: 10%; float: left; height: 100%; font-family: 'Nanum Square'; font-size: 20px; color: #2d2d2d; text-align: center; line-height: 35px; letter-spacing: -1px; }
.list_bt_txt { width: 46%; color: #ff0e0e; font-size: 28px; font-family: 'Nanum Square'; font-weight: bold; background-color: #f3f2f8; text-align: center; line-height: 35px; float: left; }
.list_bt_on_1 { width: 27%; float: left; height: 50px; padding: 10px 5%; }
.list_bt_on_1 a { display: block; line-height: 50px; background-color: #0094e0; box-shadow: 0 3px 0 #115476; border-radius: 5px; font-family: 'Nanum Square'; font-size: 24px; color: #fff; text-align: center; letter-spacing: -1px; }
.list_bt_on_2 { width: 27%; float: left; height: 50px; padding: 10px 5%; }
.list_bt_on_2 a { display: block; line-height: 50px; background-color: #7fb62d; box-shadow: 0 3px 0 #44601a; border-radius: 5px; font-family: 'Nanum Square'; font-size: 24px; color: #fff; text-align: center; letter-spacing: -1px; }

/* Footer */

.footer  { width: 100%; height: 220px; float: none; }
.footer_ { width: 1100px; height: 140px; margin: 0 auto; padding-top: 40px; font-family: 'Nanum Square'; }
.info    { font-family: 'Nanum Square'; font-size: 16px; color: #000; line-height: 26px; }
.info_   { font-family: 'Nanum Square'; font-size: 16px; color: #b6b6b6; line-height: 26px; letter-spacing: -0.5px; }
.info_top{ font-size: 20px; line-height: 30px; color: #b6b6b6; padding-bottom: 10px; font-weight: bold; }

/* Display control */

.new_section,
.news_section,
.news_board,
.car_board:not(.quick_check),
.car_board.clearfix:not(.quick_check),
section.new_section,
section.news_section { display: none; }

section.quick_check.car_board { display: block; }

/* Quick check */

.quick_check {
  clear: both;
  width: 100%;
  padding: 64px 24px;
  background: #fff;
  box-sizing: border-box;
}

.quick_check_inner {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0;
  text-align: center;
  box-sizing: border-box;
}

.quick_check .visual_txt_5 {
  margin: 0 0 34px;
  padding-top: 0;
  font-family: 'Cafe24Ohsquare', 'Nanum Square', 'Noto Sans KR', 'Malgun Gothic', sans-serif;
  font-size: 40px;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: -1.5px;
  text-align: center;
  color: #ee0061;
}

.quick_check .visual_txt_5 i { color: #ee0061; font-style: italic; }
.quick_check .visual_txt_5 span { color: #111; }

.quick_check_grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}

.quick_check_card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  min-height: 210px;
  padding: 24px 16px 26px;
  border: 1px solid #cfcfcf;
  border-radius: 14px;
  background: #fff;
  color: #222;
  font-family: 'Nanum Square', 'Noto Sans KR', 'Malgun Gothic', sans-serif;
  font-size: 22px;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -1px;
  text-align: center;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.07);
  box-sizing: border-box;
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.quick_check_card img {
  display: block;
  width: 100%;
  max-width: 240px;
  aspect-ratio: 16 / 9;
  height: auto;
  margin: 0 auto;
  object-fit: cover;
  object-position: center center;
  border-radius: 14px;
}

.quick_check_card span {
  display: block;
  width: 100%;
  color: #111;
  font-size: 22px;
  font-weight: 800;
  line-height: 1.35;
  text-align: center;
  white-space: nowrap;
}

.quick_check_card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.12);
}

/* Award */

.award_section {
  clear: both;
  width: 100%;
  padding: 64px 20px 90px;
  background: linear-gradient(180deg, #ffffff 0%, #f6f9ff 100%);
  box-sizing: border-box;
  text-align: center;
}

.award_inner {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
  box-sizing: border-box;
}

.award_title {
  margin: 0 0 34px;
  color: #202020;
  font-family: 'Nanum Square', 'Noto Sans KR', 'Malgun Gothic', sans-serif;
  font-size: 36px;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -2px;
  text-align: center;
}

.award_title span { color: #154594; }
.award_title i { color: #ff5a3d; font-style: normal; }

.award_list {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  list-style: none;
  align-items: stretch;
  box-sizing: border-box;
}

.award_item,
.award_section .award_list > li {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  margin: 0;
  padding: 0;
  border-radius: 0 0 10px 10px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(21, 69, 148, 0.08);
  overflow: hidden;
  box-sizing: border-box;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.award_item:hover,
.award_section .award_list > li:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 34px rgba(21, 69, 148, 0.16);
}

.award_item img,
.award_section .award_list > li img {
  display: block;
  width: 100%;
  max-width: 198px;
  height: auto;
  margin: 0 auto;
}

/* PC 1025+ */

@media (min-width: 1025px) {

  /* blue banner */
  .blue_banner_wrap {
    width: 100%;
    background-color: #2c72ba;
    overflow: hidden;
  }

  .blue_banner_wrap .visual_am, .blue_banner_wrap .visual_chia,
  .blue_banner_wrap .visual_drive, .blue_banner_wrap .visual_oper,
  .blue_banner_wrap .visual_3th, .blue_banner_wrap .visual_dis,
  .blue_banner_wrap .visual_mu, .blue_banner_wrap .visual_adult {
    width: 1100px;
    max-width: 1100px;
    height: 344px;
    margin: 0 auto;
    float: none;
    display: block;
    background-position: center center;
    background-repeat: no-repeat;
    text-align: left;
  }

  /* header */
  .header_wrap {
    width: 100%;
    height: 120px;
    overflow: hidden;
    background: #fff;
    box-sizing: border-box;
	border-bottom: 3px #275cab solid;
  }

  .header_wrap .header_inner,
  .header_wrap .w1100 {
    position: relative;
    display: block;
    width: 1100px;
    max-width: 1100px;
    height: 120px;
    min-height: 120px;
    margin: 0 auto;
    padding: 0;
    box-sizing: border-box;
  }

  .header_wrap .top_logo {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    float: none;
    width: auto;
    margin: 0;
    padding: 0;
    line-height: 1;
  }

  .header_wrap .top_logo a {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    color: inherit;
    text-decoration: none;
    white-space: nowrap;
    line-height: 1;
  }

  .header_wrap .header_top_text {
    display: block;
    margin: 0 0 4px 61px;
    padding: 0;
    color: #000;
    font-size: 17px;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.5px;
    white-space: nowrap;
  }

  .header_wrap .logo_line {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
  }

  .header_wrap .top_logo img {
    width: auto;
    height: auto;
    max-width: none;
    max-height: none;
    margin: 0 10px 0 0;
    vertical-align: middle;
  }

  .header_wrap .top_logo .logo_txt {
    display: inline-block;
    margin: 0;
    padding: 0;
    color: #000;
    font-family: 'Cafe24Ohsquare', '돋움';
    font-size: 42px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: -2px;
    white-space: nowrap;
    vertical-align: middle;
  }

  .header_wrap .top_tel {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    float: none;
    width: auto;
    margin: 0;
    padding: 0;
    line-height: 1;
    text-align: right;
    white-space: nowrap;
  }

  .header_wrap .top_tel .tel_pc_text {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    color: inherit;
    text-decoration: none;
    white-space: nowrap;
    line-height: 1;
  }

  .header_wrap .top_tel img {
    width: auto;
    height: auto;
    max-width: none;
    max-height: none;
    margin: 0 8px 0 0;
    vertical-align: middle;
  }

  .header_wrap .top_tel .logo_txt {
    display: inline-block;
    margin: 0;
    padding: 0;
    color: #000;
    font-family: 'Cafe24Ohsquare', '돋움';
    font-size: 42px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: -2px;
    white-space: nowrap;
    vertical-align: middle;
  }

  .header_wrap .top_tel .tel_mobile_btns { display: none; }


  /* form - PC */
  :is(#frm_estimate, #frm_sec) .form_l {
    width: 444px;
    height: 560px;
    padding: 20px 40px;
    box-sizing: border-box;
  }

  :is(#frm_estimate, #frm_sec) .form_l ul {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }

  :is(#frm_estimate, #frm_sec) .form_l li {
    width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }

  :is(#frm_estimate, #frm_sec) .form_l .pd_t30b10 {
    padding: 30px 0 4px;
    margin: 0;
  }

  :is(#frm_estimate, #frm_sec) .form_l .pd_t30b10 p {
    margin: 0;
    padding: 0;
    text-align: center;
  }

  :is(#frm_estimate, #frm_sec) .form_l .pd_t30b10 img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 0 auto;
  }

  :is(#frm_estimate, #frm_sec) .form_l ul > li.name_birth_row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 10px 4px;
    width: 100%;
    box-sizing: border-box;
  }

  :is(#frm_estimate, #frm_sec) .form_l ul > li.name_birth_row > span[style*="display:none"] {
    display: none;
  }

  :is(#frm_estimate, #frm_sec) .form_l ul > li.name_birth_row .f_box {
    flex: 0 0 100%;
    width: 100%;
  }

  :is(#frm_estimate, #frm_sec) .form_l ul > li.name_birth_row .f_box2 {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
  }

  :is(#frm_estimate, #frm_sec) .form_l ul > li:nth-child(3),
  :is(#frm_estimate, #frm_sec) .form_l ul > li#mobile_check_id {
    display: flex !important;
    align-items: stretch;
    gap: 4px;
    width: 100%;
    box-sizing: border-box;
    flex-wrap: nowrap;
  }

  :is(#frm_estimate, #frm_sec) .form_l ul > li#mobile_check_id[style*="display:none"],
  :is(#frm_estimate, #frm_sec) .form_l ul > li#mobile_check_id[style*="display: none"] {
    display: none !important;
  }

  :is(#frm_estimate, #frm_sec) .form_l :is(.f_box, .f_box2, .f_box2_, .f_box3, .f_box4) {
    float: none;
    height: 54px;
    margin: 0;
    padding: 0 10px;
    border: 2px solid #000;
    border-radius: 0;
    background: #fff;
    color: #333;
    font-size: 16px;
    line-height: 50px;
    box-sizing: border-box;
    outline: none;
  }

  :is(#frm_estimate, #frm_sec) .form_l .f_box3 {
    flex: 0 0 104px;
    width: 104px;
    min-width: 0;
  }

  :is(#frm_estimate, #frm_sec) .form_l .f_box4 {
    flex: 1 1 0;
    width: auto;
    min-width: 0;
  }

  :is(#frm_estimate, #frm_sec) .form_l .f_box2_ {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
  }

  :is(#frm_estimate, #frm_sec) .form_l :is(.box_m, .box_m_on, .box_w, .box_w_on) {
    float: none;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 51px;
    width: 51px;
    height: 54px;
    margin: 0;
    padding: 0;
    font-size: 15px;
    line-height: 1;
    text-align: center;
    box-sizing: border-box;
    cursor: pointer;
    user-select: none;
  }

  :is(#frm_estimate, #frm_sec) .form_l :is(.box_m, .box_w) {
    background: #373737;
    color: #fff;
  }

  :is(#frm_estimate, #frm_sec) .form_l :is(.box_m_on, .box_w_on) {
    background: #275cab;
    color: #fff;
    font-weight: 500;
  }

  :is(#frm_estimate, #frm_sec) .form_l .f_box5 {
    float: none;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 60px;
    width: 60px;
    height: 54px;
    margin: 0 !important;
    padding: 0 2px;
    background: #373737;
    color: #fff;
    font-size: 15px;
    line-height: 1;
    text-align: center;
    box-sizing: border-box;
    cursor: pointer;
    user-select: none;
  }

  :is(#frm_estimate, #frm_sec) .form_l .f_box5 a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: #fff;
    text-decoration: none;
  }

  :is(#frm_estimate, #frm_sec) .form_l ul > li#mobile_check_id .f_box5 + .f_box5 {
    margin-left: 0 !important;
  }

  :is(#frm_estimate, #frm_sec) .form_l li.agree_line p.w100.agree_box {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    margin: 0 0 2px;
    padding: 0;
    line-height: 24px;
    box-sizing: border-box;
  }

  :is(#frm_estimate, #frm_sec) .form_l .f_ok {
    display: block;
    width: 100%;
    height: 66px;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    line-height: 1.2;
  }

}

/* Tablet 769-1024 */

@media (min-width: 769px) and (max-width: 1024px) {

  .header_wrap .w1100,
  .header_wrap .header_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    width: 100%;
    max-width: 100%;
    min-height: 58px;
    padding: 0 18px;
    box-sizing: border-box;
  }

  .header_wrap .top_logo {
    flex: 1 1 auto;
    max-width: calc(100% - 270px);
    min-width: 0;
  }

  .header_wrap .top_logo a {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    white-space: nowrap;
    line-height: 1;
    text-decoration: none;
  }

  .header_wrap .header_top_text {
    display: block;
    margin: 0 0 3px 34px;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.5px;
    white-space: nowrap;
  }

  .header_wrap .logo_line { display: inline-flex; align-items: center; white-space: nowrap; }

  .header_wrap .top_logo img { max-height: 28px; width: auto; margin: 0 4px 0 0; }

  .header_wrap .top_logo .logo_txt {
    font-size: 24px;
    line-height: 1;
    letter-spacing: -1.6px;
    white-space: nowrap;
  }

  .header_wrap .top_tel {
    flex: 0 0 auto;
    min-width: 250px;
    text-align: right;
    white-space: nowrap;
  }

  .header_wrap .top_tel .tel_pc_text {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    white-space: nowrap;
    text-decoration: none;
  }

  .header_wrap .top_tel .tel_pc_text img { max-height: 34px; width: auto; margin: 0 6px 0 0; }

  .header_wrap .top_tel .logo_txt {
    font-size: 30px;
    line-height: 1;
    letter-spacing: -1.5px;
    white-space: nowrap;
  }

  .header_wrap .top_tel .tel_mobile_btns { display: none; }
}

/* <=1024 */

@media (max-width: 1024px) {

  html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }

  body { min-width: 0; overflow-x: hidden; word-break: keep-all; }

  *, *::before, *::after { box-sizing: border-box; }

  img { max-width: 100%; height: auto; }

  .w1100, .footer_, .f_info, .f_info_box, .f_info_box2,
  :is(.visual_am, .visual_chia, .visual_drive, .visual_oper,
  .visual_3th, .visual_dis, .visual_mu, .visual_adult) {
    width: 100%;
    max-width: 100%;
  }

  /* header */
  .header_wrap { width: 100%; overflow: hidden; box-sizing: border-box; }

  .header_wrap .w1100,
  .header_wrap .header_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    width: 100%;
    max-width: 100%;
    min-height: 84px;
    padding: 0 24px;
    box-sizing: border-box;
	border-bottom: 3px #275cab solid;
  }

  .header_top_text { display: none; }

  .top_logo, .top_tel { float: none; margin: 0; padding: 0; box-sizing: border-box; }

  .top_logo {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
    max-width: calc(100% - 96px);
    text-align: left;
  }

  .top_tel {
    flex: 0 0 auto;
    width: auto;
    min-width: 88px;
    text-align: right;
    white-space: nowrap;
  }

  .top_logo a, .top_tel a { display: inline-flex; align-items: center; white-space: nowrap; text-decoration: none; }

  .top_logo img { flex: 0 0 auto; width: auto; max-width: none; max-height: 34px; margin: 0 5px 0 0; vertical-align: middle; }

  .top_logo .logo_txt {
    display: inline-block;
    max-width: 100%;
    margin: 0;
    padding: 0;
    font-size: 28px;
    line-height: 1;
    letter-spacing: -2px;
    white-space: nowrap;
    vertical-align: middle;
  }

  .top_tel .tel_pc_text,
  .top_tel > a { display: none; }

  .top_tel .tel_mobile_btns { display: inline-flex; align-items: center; justify-content: flex-end; gap: 4px; }
  .top_tel .tel_mobile_btns a { display: block; line-height: 0; }
  .top_tel .tel_mobile_btns img { display: block; width: auto; height: 35px; margin: 0; }

  /* main visual */
  :is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper,
  .main_visual_3th, .main_visual_dis, .main_visual_mu, .main_visual_adult) {
    height: auto;
    min-height: 0;
    padding-bottom: 0;
    background-size: cover;
    background-position: center top;
  }

  .visual_img { width: 100%; height: 130px; padding: 0; background-size: auto 100%; background-position: center bottom; background-repeat: no-repeat; }

  :is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper,
  .main_visual_3th, .main_visual_dis, .main_visual_mu, .main_visual_adult) .visual_img img {
    width: 340px;
    max-width: 60vw;
    height: auto;
  }

  /* form wrapper */
  :is(.form_insu_am, .form_insu_chia, .form_insu_drive, .form_insu_oper,
  .form_insu_3th, .form_insu_dis, .form_insu_mu, .form_insu_adult) {
    display: block;
    width: 90%;
    max-width: 760px;
    height: auto;
    min-height: 0;
    margin: 0 auto;
    padding-left: 0;
    padding-right: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    overflow: visible;
    box-sizing: border-box;
  }

  :is(.form_insu_am, .form_insu_chia, .form_insu_drive, .form_insu_oper,
  .form_insu_3th, .form_insu_dis, .form_insu_mu, .form_insu_adult) .form_l {
    float: none;
    display: block;
    width: 100%;
    max-width: 760px;
    height: auto;
    min-height: 0;
    margin: 0 auto 18px;
    padding: 36px 28px;
    border: 3px solid #111;
    border-radius: 18px;
    box-sizing: border-box;
    overflow: hidden;
  }

  /* 사이트별 배경색만 변경 */
  .form_insu_am .form_l    { background: #73ACD8; }
  .form_insu_chia .form_l  { background: #73D1D8; }
  .form_insu_drive .form_l { background: #BD73D8; }
  .form_insu_oper .form_l  { background: #7773D8; }
  .form_insu_3th .form_l   { background: #D873AA; }
  .form_insu_dis .form_l   { background: #D8BA73; }
  .form_insu_mu .form_l    { background: #7ECD81; }
  .form_insu_adult .form_l { background: #AFCD7E; }


  /* ul: flex 세로 방향 (name_birth_row가 전체 너비 사용) */
  .form_l ul { display: flex; flex-direction: column; gap: 8px; width: 100%; margin: 0; padding: 0; list-style: none; box-sizing: border-box; }
  .form_l li { margin: 0; padding: 0; list-style: none; box-sizing: border-box; width: 100%; }

  /* 이름+생년월일+남여 한 행 */
  .form_l ul > li.name_birth_row {
    display: flex;
    align-items: stretch;
    gap: 8px;
    grid-column: unset;
  }
  .form_l ul > li.name_birth_row > span[style*="display:none"] { display: none; }

  /* 전화번호 행 (li:3으로 당겨짐) */
  .form_l ul > li:nth-child(3) { display: flex; align-items: stretch; gap: 8px; }

  /* 인증번호 행 (li:4로 당겨짐) */
  .form_l ul > li:nth-child(4) { display: flex; align-items: stretch; gap: 8px; }

  /* 인증번호 확인/재전송 행 */
  .form_l ul > li#mobile_check_id {
    display: flex !important;
    align-items: stretch;
    gap: 8px;
    width: 100%;
    box-sizing: border-box;
    flex-wrap: nowrap;
  }
  .form_l ul > li#mobile_check_id[style*="display:none"],
  .form_l ul > li#mobile_check_id[style*="display: none"] {
    display: none !important;
  }
  .form_l ul > li#mobile_check_id .f_box2_ {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
    margin: 0;
  }
  .form_l ul > li#mobile_check_id .f_box5 {
    flex: 0 0 128px;
    width: 128px;
    margin: 0 !important;
  }
  .form_l ul > li#mobile_check_id .f_box5 + .f_box5 {
    margin-left: 0 !important;
  }

  .form_l .box_m, .form_l .box_m_on,
  .form_l .box_w, .form_l .box_w_on { margin-left: 0; }

  .form_l .pd_t30b10 { margin: 0 0 6px; padding: 0; }
  .form_l .pd_t30b10 p { margin: 0; padding: 0; text-align: left; }
  .form_l .pd_t30b10 img { display: block; width: 420px; max-width: 62%; height: auto; margin: 0; }

  .form_l .f_box, .form_l .f_box2, .form_l .f_box2_,
  .form_l .f_box3, .form_l .f_box4 {
    float: none;
    height: 52px;
    padding: 0 10px;
    border: 2px solid #111;
    border-radius: 8px;
    line-height: 46px;
    outline: none;
    box-sizing: border-box;
  }

  /* 이름: flex:1 */
  .form_l .f_box { display: block; flex: 1 1 auto; width: auto; min-width: 0; margin: 0; }

  /* 생년월일: flex:1 */
  .form_l .f_box2 { flex: 1 1 auto; width: auto; min-width: 0; margin: 0; font-size: 15px; padding: 0 8px; }

  .form_l .f_box2_, .form_l .f_box4 { flex: 1 1 auto; width: auto; min-width: 0; margin: 0; }
  .form_l .f_box3 { flex: 0 0 20%; min-width: 0; margin: 0; height: 52px; line-height: 46px; }

  .form_l .box_m, .form_l .box_m_on, .form_l .box_w, .form_l .box_w_on {
    float: none;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 60px;
    width: 60px;
    height: 52px;
    padding: 0;
    border: 0;
    border-radius: 8px;
    font-size: 20px;
    line-height: 1;
    text-align: center;
    box-sizing: border-box;
    cursor: pointer;
    user-select: none;
  }

  .form_l .box_m, .form_l .box_w { background: #373737; color: #fff; }
  .form_l .box_m_on, .form_l .box_w_on { background: #275cab; color: #fff; font-weight: 500; }

  .form_l .f_box5 {
    float: none;
    flex: 0 0 128px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 128px;
    height: 52px;
    min-width: 0;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 8px;
    background: #373737;
    color: #fff;
    font-size: 18px;
    line-height: 1;
    text-align: center;
    box-sizing: border-box;
  }

  .form_l .f_box5 a { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; color: #fff; text-decoration: none; }

  .form_l p.w100 { float: none; display: flex; align-items: center; justify-content: flex-start; width: 100%; margin: 0 0 16px; padding: 0; line-height: 1.2; }

  .form_l #agree { flex: 0 0 24px; width: 24px; height: 24px; margin: 0 6px 0 0; }

  .form_l .view_txt { display: inline-block; margin: 0 6px 0 0; color: #1d3a4e; font-size: 14px; line-height: 24px; }

  .form_l .view_bt,
  .form_l .view_bt a { display: inline-flex; align-items: center; justify-content: center; height: 22px; padding: 0 4px; color: #fff; font-size: 12px; line-height: 1; text-decoration: none; }

  .form_l .f_ok {
    display: block;
    width: 100%;
    height: 70px;
    margin: 0;
    padding: 0;
    border: 3px solid #111;
    border-radius: 8px;
    background: #f20063;
    box-shadow: none;
    color: #fff;
    font-size: 28px;
    line-height: 64px;
    letter-spacing: -1.5px;
    text-align: center;
  }

  .form_r {
    float: none;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    width: 100%;
    max-width: 760px;
    margin: 0 auto;
    padding: 0 0 34px;
    background: transparent;
    box-sizing: border-box;
  }

  .form_r .f_rbox, .form_r .f_rbox_, .form_r .f_rbox_r, .form_r .f_rbox_r_ {
    float: none;
    width: 100%;
    height: 190px;
    min-height: 190px;
    margin: 0;
    padding: 36px 12px 16px;
    border: 1px solid #bdbdbd;
    border-radius: 16px;
    background: #fff;
    text-align: center;
    overflow: hidden;
    box-sizing: border-box;
  }

  .form_r img { max-width: 58%; max-height: 42px; object-fit: contain; }
  .form_r p { max-width: 100%; line-height: 1.35; }

  .form_r .pay, .form_r .pay_1, .form_r .pay_2, .form_r .pay_3,
  .form_r .pay_4, .form_r .pay_5, .form_r .pay_6, .form_r .pay_7,
  .form_r .pay_8, .form_r .pay_9, .form_r .pay_10, .form_r .pay_11 {
    font-size: 25px;
    line-height: 1.2;
  }

  /* quick_check */
  .quick_check { padding: 58px 52px 62px; }
  .quick_check_inner { max-width: 760px; }
  .quick_check .visual_txt_5 { margin-bottom: 30px; font-size: 36px; }
  .quick_check_grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
  .quick_check_card { min-height: 205px; padding: 24px 16px; }
  .quick_check_card img { max-width: 260px; aspect-ratio: 16 / 9; height: auto; object-fit: cover; object-position: center center; border-radius: 10px; }
  .quick_check_card span { font-size: 21px; }

  /* blue banner */
  .banner_txt_inner { padding: 30px 30px; }
  .title_txt5  { font-size: 32px; padding-left: 0; letter-spacing: -1px; }
  .title_txt5_ { font-size: 20px; padding-left: 0; letter-spacing: -0.5px; }

  :is(.visual_am, .visual_chia, .visual_drive, .visual_oper,
  .visual_3th, .visual_dis, .visual_mu, .visual_adult) {
    height: 220px;
    background-size: cover;
    background-position: center;
  }

  /* award */
  .award_section { padding: 54px 18px 76px; }
  .award_list { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; max-width: 680px; }

  /* footer */
  .f_info_box_, .f_info_box2, .footer { clear: both; }

  .f_info_box { width: 100%; margin: 0 auto; padding: 36px 24px; border: 0; background: #2b2b2b; color: #fff; }
  .f_info_box_title, .f_info_box_content { color: #fff; }

  .f_info_box2 { width: 100%; max-width: 100%; margin: 0; padding: 32px 24px; border: 0; background: #fff; }
  .f_info_box2_content { float: none; display: inline-block; width: auto; margin: 0 14px 8px 0; line-height: 1.5; }

  .footer  { width: 100%; height: auto; background: #f2f2f2; }
  .footer_ { height: auto; padding: 28px 24px 40px; }
}

/* <=768 */

@media (max-width: 768px) {

  /* header */
  .header_wrap { height: auto; min-height: 56px; background: #fff; }

  .header_wrap .w1100,
  .header_wrap .header_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 84px;
    padding: 0 16px;
    box-sizing: border-box;
  }

  .header_wrap .top_logo { flex: 1 1 auto; max-width: calc(100% - 118px); min-width: 0; }

  .header_wrap .top_logo a { display: inline-flex; flex-direction: column; align-items: flex-start; justify-content: center; line-height: 1; white-space: nowrap; }

  .header_wrap .header_top_text {
    display: block;
    margin: 0 0 3px 34px;
    padding: 0;
    color: #000;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.5px;
    white-space: nowrap;
  }

  .header_wrap .logo_line { display: inline-flex; align-items: center; white-space: nowrap; }
  .header_wrap .top_logo img { max-height: 27px; width: auto; margin: 0 4px 0 0; }
  .header_wrap .top_logo .logo_txt { font-size: 24px; line-height: 1; letter-spacing: -1.6px; white-space: nowrap; }

  .header_wrap .top_tel { flex: 0 0 auto; min-width: 108px; text-align: right; }

  .header_wrap .top_tel .tel_pc_text,
  .header_wrap .top_tel > a.tel_pc_text { display: none; }

  .header_wrap .top_tel .tel_mobile_btns { display: inline-flex; align-items: center; justify-content: flex-end; gap: 4px; }
  .header_wrap .top_tel .tel_mobile_btns a { display: block; line-height: 0; }
  .header_wrap .top_tel .tel_mobile_btns img { display: block; width: auto; height: 45px; margin: 0; }

  /* main visual */
  :is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper,
  .main_visual_3th, .main_visual_dis, .main_visual_mu, .main_visual_adult) {
    padding-bottom: 18px;
    overflow: visible;
  }

  :is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper,
  .main_visual_3th, .main_visual_dis, .main_visual_mu, .main_visual_adult) .visual_img {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    width: 100%;
    height: 118px;
    margin: 0 auto -2px;
    padding: 0;
    overflow: hidden;
    background-size: contain;
    background-position: center bottom;
    background-repeat: no-repeat;
  }

  :is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper,
  .main_visual_3th, .main_visual_dis, .main_visual_mu, .main_visual_adult) .visual_img img {
    display: block;
    width: 260px;
    max-width: 100%;
    height: auto;
    margin: 14px auto;
    object-fit: contain;
  }

  /* form */
  :is(.form_insu_am, .form_insu_chia, .form_insu_drive, .form_insu_oper,
  .form_insu_3th, .form_insu_dis, .form_insu_mu, .form_insu_adult) {
    width: calc(100% - 32px);
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
    padding: 0 0 18px;
  }

  :is(.form_insu_am, .form_insu_chia, .form_insu_drive, .form_insu_oper,
  .form_insu_3th, .form_insu_dis, .form_insu_mu, .form_insu_adult) .form_l {
    width: 100%;
    max-width: 560px;
    margin: 0 auto 14px;
    padding: 22px 14px 18px;
    border-radius: 22px;
  }

  .form_l .pd_t30b10 { margin-bottom: 14px; }
  .form_l .pd_t30b10 p { text-align: center; }
  .form_l .pd_t30b10 img { width: 310px; max-width: 82vw; }

  .form_l ul { gap: 6px; }

  .form_l .f_box, .form_l .f_box2, .form_l .f_box2_,
  .form_l .f_box3, .form_l .f_box4 {
    height: 42px;
    padding: 0 6px;
    border-width: 2px;
    border-radius: 8px;
    font-size: 14px;
    line-height: 38px;
  }

  .form_l .f_box3 { height: 42px; line-height: 38px; }
  .form_l .f_box2 { font-size: 13px; padding: 0 4px; }
  .form_l .f_box { margin: 0; }
  .form_l ul > li.name_birth_row { gap: 8px; }
  .form_l ul > li:nth-child(3) { gap: 8px; align-items: stretch; }
  .form_l ul > li#mobile_check_id {
    display: flex !important;
    align-items: stretch;
    gap: 8px;
    flex-wrap: nowrap;
  }
  .form_l ul > li#mobile_check_id[style*="display:none"],
  .form_l ul > li#mobile_check_id[style*="display: none"] {
    display: none !important;
  }
  .form_l ul > li#mobile_check_id .f_box2_ {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
    margin: 0;
  }
  .form_l ul > li#mobile_check_id .f_box5 {
    flex: 0 0 90px;
    width: 90px;
    margin: 0 !important;
  }

  .form_l .box_m, .form_l .box_m_on,
  .form_l .box_w, .form_l .box_w_on { margin-left: 0; }

  .form_l .box_m, .form_l .box_m_on, .form_l .box_w, .form_l .box_w_on {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 41px;
    width: 41px;
    height: 42px;
    border-radius: 8px;
    font-size: 14px;
    line-height: 1;
  }

  .form_l .f_box5 { flex: 0 0 90px; width: 90px; height: 42px; border-radius: 8px; font-size: 14px; line-height: 1; }
  .form_l p.w100 { margin-bottom: 10px; }
  .form_l #agree { flex-basis: 18px; width: 18px; height: 18px; margin-right: 4px; }
  .form_l .view_txt { margin-right: 4px; font-size: 10px; line-height: 18px; white-space: nowrap; }
  .form_l .view_bt,
  .form_l .view_bt a { height: 18px; padding: 0 4px; font-size: 10px; }

  .form_l .f_ok { height: 50px; border-width: 2px; border-radius: 8px; font-size: 22px; line-height: 46px; }

  .form_r {
    grid-template-columns: 1fr;
    gap: 8px;
    width: 100%;
    max-width: 560px;
    padding: 0 0 24px;
    background: transparent;
  }

  .form_r .f_rbox, .form_r .f_rbox_, .form_r .f_rbox_r, .form_r .f_rbox_r_ {
    height: auto;
    min-height: 135px;
    padding: 14px 8px 12px;
    border-radius: 9px;
  }

  .form_r img { max-width: 70%; max-height: 34px; }
  .form_r p { font-size: 11px; line-height: 1.35; }

  .form_r .pay, .form_r .pay_1, .form_r .pay_2, .form_r .pay_3,
  .form_r .pay_4, .form_r .pay_5, .form_r .pay_6, .form_r .pay_7,
  .form_r .pay_8, .form_r .pay_9, .form_r .pay_10, .form_r .pay_11 { font-size: 18px; }

  /* quick_check */
  .quick_check { padding: 46px 16px 50px; }
  .quick_check_inner { max-width: 560px; }

  .quick_check .visual_txt_5 { margin-bottom: 24px; font-size: 26px; line-height: 1.3; letter-spacing: -1px; }

  .quick_check_grid { grid-template-columns: 1fr; gap: 8px; }

  .quick_check_card { min-height: 165px; padding: 18px 12px 20px; border-radius: 12px; box-shadow: none; }
  .quick_check_card:hover { transform: none; box-shadow: none; }
  .quick_check_card img { max-width: 260px; aspect-ratio: 16 / 9; height: auto; object-fit: cover; object-position: center center; border-radius: 10px; }
  .quick_check_card span { font-size: 22px; }

  /* blue banner */
  .banner_txt_inner { padding: 22px 18px; }
  .title_txt5  { font-size: 22px; line-height: 1.3; }
  .title_txt5_ { font-size: 16px; line-height: 1.5; }

  :is(.visual_am, .visual_chia, .visual_drive, .visual_oper,
  .visual_3th, .visual_dis, .visual_mu, .visual_adult) {
    height: auto;
    min-height: 180px;
    background-size: cover;
    background-position: center right;
  }

  /* award */
  .award_section { padding: 42px 12px 62px; }
  .award_title { margin-bottom: 24px; font-size: 28px; line-height: 1.32; letter-spacing: -1.5px; }
  .award_list { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; max-width: 430px; }
  .award_item { border-radius: 0 0 8px 8px; }
  .award_item:hover, .award_section .award_list > li:hover { transform: none; }

  /* footer */
  .f_info_box { padding: 30px 14px; }
  .f_info_box_title { font-size: 16px; }
  .f_info_box_content { font-size: 15px; line-height: 1.65; }
  .f_info_box2 { padding: 28px 14px; }
  .f_info_box2_title { font-size: 15px; }
  .f_info_box2_content { font-size: 15px; margin-right: 10px; }
  .footer_ { padding: 24px 14px 34px; }
  .info, .info_ { font-size: 15px; line-height: 1.55; }
}

/* <=430 */

@media (max-width: 430px) {

  /* header */
  .header_wrap { min-height: 50px; }
  .header_wrap .w1100,
  .header_wrap .header_inner { min-height: 64px; padding: 0 8px; }
  .header_wrap .top_logo { max-width: calc(100% - 98px); }
  .header_wrap .header_top_text { margin: 0 0 2px 28px; font-size: 10px; }
  .header_wrap .top_logo img { max-height: 24px; margin-right: 3px; }
  .header_wrap .top_logo .logo_txt { font-size: 20px; letter-spacing: -1px; }
  .header_wrap .top_tel { min-width: 92px; }
  .header_wrap .top_tel .tel_mobile_btns img { height: 36px; }

  /* main visual */
  :is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper,
  .main_visual_3th, .main_visual_dis, .main_visual_mu, .main_visual_adult) .visual_img {
  
    height: 82px;
    margin: 0 auto -1px;
  }

  :is(.main_visual_am, .main_visual_chia, .main_visual_drive, .main_visual_oper,
  .main_visual_3th, .main_visual_dis, .main_visual_mu, .main_visual_adult) .visual_img img {
    width: 200px;
    max-width: 100%;
  }

  /* form */
  :is(.form_insu_am, .form_insu_chia, .form_insu_drive, .form_insu_oper,
  .form_insu_3th, .form_insu_dis, .form_insu_mu, .form_insu_adult) {
    width: calc(100% - 20px);
    max-width: 560px;
    padding: 0 0 18px;
  }

  :is(.form_insu_am, .form_insu_chia, .form_insu_drive, .form_insu_oper,
  .form_insu_3th, .form_insu_dis, .form_insu_mu, .form_insu_adult) .form_l {
    width: 100%;
    padding: 18px 10px 16px;
    border-radius: 18px;
  }

  .form_l .pd_t30b10 img { width: 260px; max-width: 84vw; }

  .form_l .f_box, .form_l .f_box2, .form_l .f_box2_,
  .form_l .f_box3, .form_l .f_box4 { height: 38px; font-size: 13px; line-height: 34px; margin: 0; }

  .form_l .box_m, .form_l .box_m_on, .form_l .box_w, .form_l .box_w_on {
    flex: 0 0 41px;
    width: 41px;
    height: 38px;
    font-size: 13px;
    line-height: 1;
  }

  .form_l .f_box5 { flex: 0 0 90px; width: 90px; height: 38px; font-size: 13px; line-height: 1; }
  .form_l ul > li#mobile_check_id {
    gap: 6px;
    flex-wrap: nowrap;
  }
  .form_l ul > li#mobile_check_id .f_box5 {
    flex: 0 0 74px;
    width: 74px;
    margin: 0 !important;
  }
  .form_l ul > li#mobile_check_id .f_box2_ {
    min-width: 0;
    font-size: 13px;
  }
  .form_l .f_ok   { height: 46px; font-size: 20px; line-height: 42px; }

  .form_r { width: 100%; }
  .form_r .f_rbox, .form_r .f_rbox_, .form_r .f_rbox_r, .form_r .f_rbox_r_ { min-height: 126px; padding: 12px 6px 9px; }

  /* quick_check */
  .quick_check { padding: 40px 10px 44px; }
  .quick_check .visual_txt_5 { font-size: 22px; }
  .quick_check_card { min-height: 155px; }
  .quick_check_card img { max-width: 220px; aspect-ratio: 16 / 9; height: auto; object-fit: cover; object-position: center center; }
  .quick_check_card span { font-size: 18px; }

  /* award */
  .award_list { grid-template-columns: repeat(2, minmax(0, 1fr)); max-width: 430px; }
}

/* Showcase */

#showcase {
  clear: both;
  width: 100%;
  padding: 70px 20px;
  background: #fff;
  box-sizing: border-box;
}

#showcase .container {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}

#showcase .section-head {
  width: 100%;
  margin: 0 0 34px;
  padding: 0;
  text-align: left;
}

#showcase .section-head h2 {
  margin: 0;
  color: #111;
  font-family: 'Nanum Square', 'Noto Sans KR', 'Malgun Gothic', sans-serif;
  font-size: 36px;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -1.2px;
  text-align: center;
}

#showcase .media-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}

#showcase .media-link {
  display: block;
  width: 100%;
  color: inherit;
  text-decoration: none;
}

#showcase .media {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
  height: 280px;
  margin: 0;
  padding: 30px 24px 26px;
  border: 1px solid #d8d8d8;
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(21, 69, 148, 0.08);
  background: #fff;
  box-sizing: border-box;
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
  #showcase .media:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 18px rgba(0, 0, 0, 0.08);
    border-color: var(--brand-2, #275cab);
  }
}

@media (hover: none) and (pointer: coarse) {
  #showcase .media:active {
    transform: translateY(-1px);
    box-shadow: 0 8px 14px rgba(0, 0, 0, 0.07);
    border-color: var(--brand-2, #275cab);
  }
}

#showcase .media img {
  display: block;
  width: 74px;
  height: 74px;
  max-width: 74px;
  min-width: 74px;
  margin: 0 auto 20px;
  object-fit: contain;
}

#showcase .media figcaption {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

#showcase .media-title {
  display: -webkit-box;
  width: 100%;
  max-height: 65px;
  margin: 0 0 10px;
  overflow: hidden;
  color: #222;
  font-family: 'Nanum Square', 'Noto Sans KR', 'Malgun Gothic', sans-serif;
  font-size: 24px;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -0.8px;
  text-align: left;
  text-overflow: ellipsis;
  word-break: keep-all;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

#showcase .media-desc {
  display: -webkit-box;
  width: 100%;
  max-height: 53px;
  margin: 0;
  overflow: hidden;
  color: #586374;
  font-family: 'Nanum Square', 'Noto Sans KR', 'Malgun Gothic', sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: -0.3px;
  text-align: left;
  text-overflow: ellipsis;
  word-break: keep-all;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

@media (max-width: 1024px) {
  #showcase {
    padding: 58px 0 62px;
  }

  #showcase .container {
    width: 90%;
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
  }

  #showcase .section-head {
    margin-bottom: 28px;
  }

  #showcase .section-head h2 {
    font-size: 28px;
  }

  #showcase .media-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  #showcase .media {
    height: 270px;
    padding: 26px 20px 24px;
  }

  #showcase .media img {
    margin-bottom: 18px;
  }
}

@media (max-width: 768px) {
  #showcase {
    padding: 48px 16px 56px;
  }

  #showcase .container {
    width: 100%;
    max-width: 560px;
  }

  #showcase .section-head {
    margin-bottom: 22px;
  }

  #showcase .section-head h2 {
    font-size: 22px;
    line-height: 1.35;
    letter-spacing: -0.8px;
  }

  #showcase .media-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  #showcase .media {
    height: 230px;
    padding: 22px 18px;
    border-radius: 10px;
  }

  #showcase .media img {
    margin-bottom: 14px;
  }
}

@media (max-width: 480px) {
  #showcase {
    padding: 42px 0 48px;
  }

  #showcase .container {
    width: 94%;
    max-width: 560px;
  }

  #showcase .section-head {
    margin-bottom: 18px;
  }

  #showcase .section-head h2 {
    font-size: 20px;
  }

  #showcase .media-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  #showcase .media {
    height: 230px;
    padding: 22px 18px;
  }
}
/* END showcase */

/* ===========================
   패밀리사이트 반응형 수정
   - 기존 클래스명 그대로 사용
   - PC: 1150px 중앙 정렬
   - 태블릿/모바일: 자동 줄바꿈
=========================== */

.f_info_box2 {
  width: 100%;
  max-width: 1150px;
  height: auto;
  min-height: 0;
  margin: 6px auto 0;
  padding: 24px 24px;
  background-color: #fff;
  box-sizing: border-box;
  text-align: left;
  overflow: visible;

  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0 18px;
}

.f_info_box2_title {
  flex: 0 0 100%;
  width: 100%;
  margin: 0 0 8px;
  padding: 10px 0 10px 0px;
  box-sizing: border-box;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.4;
  color: #2d2d2d;
}

.f_info_box2_content {
  float: none;
  display: inline-flex;
  align-items: center;
  width: auto;
  margin: 0 0 8px;
  padding: 0;
  box-sizing: border-box;
  font-size: 16px;
  line-height: 1.55;
  letter-spacing: -1px;
  color: #000;
  white-space: nowrap;
}

.f_info_box2_content a {
  display: inline-block;
  color: #000;
  text-decoration: none;
}

.f_info_box2_content a:hover {
  text-decoration: underline;
}

.footer {
  clear: both;
}

/* 태블릿 */
@media (max-width: 1024px) {
  .f_info_box2 {
    max-width: calc(100% - 32px);
    padding: 24px 16px;
    gap: 0 14px;
  }

  .f_info_box2_content {
    line-height: 1.55;
  }
}

/* 모바일 */
@media (max-width: 768px) {
  .f_info_box2 {
    max-width: none;
    width: 100%;
    margin-top: 0;
    padding: 22px 14px;
    gap: 0 10px;
  }

  .f_info_box2_title {
    padding-left: 0;
    font-size: 15px;
    line-height: 1.4;
  }

  .f_info_box2_content {
    font-size: 15px;
    line-height: 1.55;
    letter-spacing: -0.8px;
    white-space: normal;
    word-break: keep-all;
  }

  .footer_ {
    width: 100%;
    height: auto;
    padding: 24px 14px 34px;
    box-sizing: border-box;
  }

  .info {
    font-size: 15px;
    line-height: 1.6;
    word-break: keep-all;
  }

  .info span {
    display: block;
    margin-bottom: 4px;
    font-size: 15px;
    line-height: 1.5;
  }
}

/* 소형 모바일 */
@media (max-width: 430px) {
  .f_info_box2 {
    padding: 20px 12px;
    gap: 0 8px;
  }

  .f_info_box2_content {
    font-size: 15px;
    line-height: 1.55;
    margin-bottom: 6px;
  }

  .footer_ {
    padding: 22px 12px 32px;
  }

  .info {
    font-size: 15px;
    line-height: 1.6;
  }
}

/* =========================================================
   w1100 pd_b60 영역 반응형 보정
   - 기존 HTML 수정 없음
   - PC 디자인 유지
========================================================= */

.w1100.pd_b60 {
  width: 1100px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 60px;
  text-align: center;
  box-sizing: border-box;
}

.w1100.pd_b60 .title_txt2 {
  margin: 0;
  padding-top: 50px;
  font-size: 45px;
  line-height: 1.3;
  letter-spacing: -1px;
  word-break: keep-all;
}

.w1100.pd_b60 .title_txt3 {
  font-size: 50px;
  color: #ee0061;
}

.w1100.pd_b60 .pd_tb20 {
  margin: 0;
  padding: 20px 0;
  text-align: center;
}

.w1100.pd_b60 .pd_tb20 img {
  display: block;
  width: 100%;
  max-width: 1100px;
  height: auto;
  margin: 0 auto;
}

.w1100.pd_b60 > .txt {
  float: left;
  width: 25%;
  margin: 0;
  padding: 0 8px;
  box-sizing: border-box;
  font-size: 20px;
  line-height: 1.45;
  letter-spacing: -1.5px;
  text-align: center;
  word-break: keep-all;
}

.w1100.pd_b60::after {
  content: "";
  display: block;
  clear: both;
}

/* 태블릿 */
@media (max-width: 1024px) {
  .w1100.pd_b60 {
    width: 90%;
    max-width: 760px;
    padding-bottom: 52px;
  }

  .w1100.pd_b60 .title_txt2 {
    padding-top: 44px;
    font-size: 36px;
    line-height: 1.35;
    letter-spacing: -1px;
  }

  .w1100.pd_b60 .title_txt3 {
    font-size: 40px;
  }

  .w1100.pd_b60 .pd_tb20 {
    padding: 20px 0 14px;
  }

  .w1100.pd_b60 > .txt {
    width: 25%;
    padding: 0 6px;
    font-size: 18px;
    line-height: 1.45;
    letter-spacing: -1px;
  }
}

/* 모바일 */
@media (max-width: 768px) {
  .w1100.pd_b60 {
    width: calc(100% - 32px);
    max-width: 560px;
    padding-bottom: 44px;
  }

  .w1100.pd_b60 .title_txt2 {
    padding-top: 38px;
    font-size: 26px;
    line-height: 1.35;
    letter-spacing: -1px;
  }

  .w1100.pd_b60 .title_txt3 {
    font-size: 30px;
  }

  .w1100.pd_b60 .pd_tb20 {
    padding: 18px 0 14px;
  }

  .w1100.pd_b60 > .txt {
    width: 50%;
    min-height: 46px;
    margin-bottom: 2px;
    padding: 10px 6px;
    border-radius: 10px;
    background: #f7f7f7;
    font-size: 17px;
    line-height: 1.35;
    letter-spacing: -0.8px;
    box-sizing: border-box;
    border: 2px solid #fff;
  }
}

/* 소형 모바일 */
@media (max-width: 430px) {
  .w1100.pd_b60 {
    width: calc(100% - 20px);
    padding-bottom: 38px;
  }

  .w1100.pd_b60 .title_txt2 {
    font-size: 22px;
  }

  .w1100.pd_b60 .title_txt3 {
    font-size: 25px;
  }

  .w1100.pd_b60 > .txt {
    float: none;
    width: 100%;
    min-height: 0;
    padding: 10px 8px;
    font-size: 16px;
  }
}


/* ===========================
   조재필 추가 2026-05-29
=========================== */
/* 배경 */
#layer_bg {
    display: none;
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0,0,0,0.5);
    z-index: 1000;
}

/* 팝업 */
#result_popup {
    display: none;
    position: fixed;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-width: 800px;
    max-height: 90vh;
    background: #fff;
    border-radius: 4px;
    z-index: 9999;
    overflow: hidden;
}

/* 헤더 */
.layer_header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid #ddd;
    background: #f5f5f5;
}

.layer_title {
    font-size: 16px;
    font-weight: bold;
    color: #222;
}

.layer_close {
    background: none;
    border: none;
    font-size: 18px;
    cursor: pointer;
    color: #888;
}

/* 본문 */
.layer_body {
    padding: 0;
    overflow-y: auto;
    max-height: calc(90vh - 50px);
}

/* iframe */
#layer_iframe {
    width: 100%;
    height: 70vh;
    border: none;
    display: block;
}

/* 모바일 */
@media (max-width: 480px) {
    #result_popup {
        width: 95%;
    }
    #layer_iframe {
        height: 60vh;
    }
}