@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=Noto+Sans+KR:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard-dynamic-subset.css');
/* 태블릿 */
@media screen and (max-width: 1200px) {
  header {
    height: 70px;
    padding: 0 40px;
    box-sizing: border-box;
  }

  .h_logo {
    width: auto;
    margin-left: 0;
    flex: 1;
  }

  .h_logo img {
    height: 34px;
  }

  ul.gnb {
    width: 680px;
  }

  ul.gnb > li > a > p {
    font-size: 19px;
  }

  ul.gnb > li:hover p {
    font-size: 19px;
  }
}

/* 모바일 */
@media screen and (max-width: 768px) {
  html,
  body {
    overflow: hidden;
  }

  header {
    height: 64px;
    padding: 0 24px;
  }

  .h_logo {
    height: 36px;
  }

  .h_logo img {
    height: 30px;
  }

  ul.gnb {
    position: fixed;
    top: 64px;
    right: -100%;
    width: 100%;
    height: calc(100vh - 64px);
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(10px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 36px;
    transition: right 0.4s ease;
    z-index: 9998;
  }

  ul.gnb.open {
    right: 0;
  }

  ul.gnb > li > a > p {
    font-size: 24px;
    font-weight: 400;
  }

  ul.gnb > li:hover p,
  ul.gnb > li.active p {
    font-size: 24px;
    font-weight: 700;
    color: #00ada4;
  }

  .side_menu {
    display: flex;
    width: 34px;
    height: 34px;
    cursor: pointer;
    z-index: 9999;
  }

  .side_menu > i {
    font-size: 24px;
  }

  main {
    height: 100svh;
  }

  .main_background {
    height: 100svh;
  }

  .main_background > img {
    height: 100%;
    object-fit: cover;
  }
}

/* 작은 모바일 */
@media screen and (max-width: 480px) {
  header {
    height: 58px;
    padding: 0 18px;
  }

  .h_logo img {
    height: 26px;
  }

  ul.gnb {
    top: 58px;
    height: calc(100vh - 58px);
    gap: 30px;
  }

  ul.gnb > li > a > p {
    font-size: 21px;
  }

  ul.gnb > li:hover p,
  ul.gnb > li.active p {
    font-size: 21px;
  }

  .side_menu > i {
    font-size: 22px;
  }
}

/* main_box 반응형 */
@media screen and (max-width: 1200px) {
  .main_box {
    width: 46%;
    height: auto;
    margin-top: 40px;
  }

  .main_box_tit img {
    width: 100%;
  }

  .main_welcome_ment {
    height: 76px;
    margin-top: 90px;
  }

  .main_welcome_ment img {
    width: 82%;
  }

  .main_sub_logo {
    margin-top: 40px;
  }

  .main_sub_logo img {
    width: 160px;
  }
}

@media screen and (max-width: 768px) {
  main,
  .main_background {
    height: 100svh;
  }

  .main_box {
    width: 72%;
    height: auto;
    top: 52%;
    margin-top: 0;
  }

  .main_box_tit img {
    width: 100%;
  }

  .main_welcome_ment {
    height: 64px;
    margin-top: 70px;
  }

  .main_welcome_ment img {
    width: 84%;
  }

  .main_sub_logo {
    margin-top: 34px;
  }

  .main_sub_logo img {
    width: 130px;
  }
}

@media screen and (max-width: 480px) {
  .main_box {
    width: 82%;
    top: 53%;
  }

  .main_welcome_ment {
    height: 54px;
    margin-top: 54px;
  }

  .main_welcome_ment img {
    width: 88%;
  }

  .main_sub_logo {
    margin-top: 28px;
  }

  .main_sub_logo img {
    width: 105px;
  }
}

/* ----------------------------------------------------------- */
/* 소개부분 */
/* ----------------------------------------------------------- */
@media screen and (max-width: 1400px) {
  .itd_con,
  .mi_con {
    width: 84%;
  }

  .card_layout {
    grid-template-columns: 1fr 1fr;
  }

  .skill_card,
  .history_card,
  .instagram_card {
    grid-column: auto;
    grid-row: auto;
  }
}

@media screen and (max-width: 1024px) {
  #slogan {
    height: 500px;
  }

  .slogan_box {
    width: 70%;
    padding: 44px 30px;
  }

  .slogan_box > h2 {
    font-size: 36px;
  }

  .slogan_box > p {
    font-size: 18px;
  }

  #itd {
    padding: 70px 0 80px;
  }

  .card_layout {
    grid-template-columns: 1fr 1fr;
    gap: 22px;
  }

  .history_card {
    grid-column: span 2;
  }

  ul.pmh_txt > li {
    grid-template-columns: 120px 1fr 1fr 1.2fr;
    gap: 16px;
  }

  ul.pmh_txt > li > span,
  ul.pmh_txt > li > p,
  ul.pmh_txt > li > b,
  ul.pmh_txt > li > p.sub {
    font-size: 14px;
  }

  ul.ps_img img {
    width: 56px;
  }

  #my_identity {
    height: 330px;
  }

  ul.partners_slider > li {
    width: 180px;
  }
}

@media screen and (max-width: 768px) {
  html,
  body {
    height: auto;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
  }

  body {
    -webkit-overflow-scrolling: touch;
  }

  main {
    height: auto;
    overflow: visible;
  }

  #slogan {
    height: 390px;
  }

  .slogan_box {
    width: 84%;
    padding: 34px 22px;
  }

  .slogan_box > h2 {
    font-size: 28px;
  }

  .slogan_box > p {
    font-size: 15px;
    margin-top: 18px;
  }

  #itd {
    overflow: visible;
  }

  .itd_con,
  .mi_con {
    width: 90%;
  }

  .itd_box,
  .itd_main {
    overflow: visible;
  }

  .itd_tit > span,
  .mi_tit > span {
    font-size: 24px;
  }

  .card_layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 22px !important;
    width: 100% !important;
  }

  .intro_card,
  .information_card,
  .education_card,
  .history_card,
  .instagram_card,
  .skill_card {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: auto !important;
    grid-column: auto !important;
    grid-row: auto !important;
    box-sizing: border-box;
  }

  .information_card {
    order: 1;
  }

  .education_card {
    order: 2;
  }

  .skill_card {
    order: 3;
  }

  .history_card {
    order: 4;
  }

  .instagram_card {
    order: 5;
  }

  .intro_card {
    padding: 26px 22px;
    border-radius: 14px;
  }

  ul.infor_txt > li,
  ul.edu_mil_txt > li {
    grid-template-columns: 90px 1fr;
    gap: 14px;
  }

  ul.infor_txt > li > span,
  ul.infor_txt > li > p,
  ul.edu_mil_txt > li > p {
    font-size: 15px;
  }

  ul.pmh_txt > li {
    grid-template-columns: 1fr;
    gap: 5px;
    padding: 16px 0;
    margin-top: 0;
    border-bottom: 1px solid #eee;
  }

  ul.pmh_txt > li:last-child {
    border-bottom: 0;
  }

  .instagram_card > img {
    width: 130px;
  }

  ul.ps {
    gap: 30px;
  }

  ul.ps_img img {
    width: 52px;
  }

  #my_identity {
    height: 280px;
  }

  .partners_slider_wrap {
    height: 96px;
  }

  ul.partners_slider > li {
    width: 145px;
    margin-left: 16px;
  }
}

@media screen and (max-width: 480px) {
  #slogan {
    height: 340px;
  }

  .slogan_box {
    width: 88%;
    padding: 28px 18px;
  }

  .slogan_box > h2 {
    font-size: 23px;
  }

  .slogan_box > p {
    font-size: 14px;
  }

  #itd {
    padding: 54px 0 64px;
  }

  .itd_con,
  .mi_con {
    width: 92%;
  }

  .intro_card {
    padding: 24px 18px;
  }

  ul.infor_txt > li,
  ul.edu_mil_txt > li {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  ul.infor_txt > li > span,
  ul.edu_mil_txt > li > span {
    color: #00ada4;
  }

  ul.ps_img img {
    width: 48px;
  }

  .instagram_card > img {
    width: 118px;
  }

  #my_identity {
    height: 250px;
  }

  .partners_slider_wrap {
    height: 84px;
  }

  ul.partners_slider > li {
    width: 125px;
    margin-left: 14px;
  }
}

/* ----------------------------------------------------------- */
/* 브랜드디자인 */
/* ----------------------------------------------------------- */
/* ==============================
  BRAND 반응형
================================ */

@media screen and (max-width: 1400px) {
  #brand_category > ul {
    width: 70%;
  }

  ul.project_all_box > li > ul > li {
    width: calc((100% - 90px) / 4);
    height: 620px;
    margin-left: 30px;
  }

  .project_infor_txt,
  .project_infor_detail {
    width: 70%;
  }
}

@media screen and (max-width: 1024px) {
  #brand_category {
    top: 70px;
    height: 86px;
  }

  #brand_category > ul {
    width: 86%;
    gap: 12px;
  }

  #brand_category > ul > li {
    width: auto;
    flex: 1;
  }

  #brand_category > ul > li > a > span {
    font-size: 15px;
  }

  #project_all {
    margin-top: 156px;
  }

  ul.project_all_box {
    width: 90%;
    margin-top: 70px;
    margin-bottom: 80px;
  }

  ul.project_all_box > li {
    margin-top: 0;
  }

  ul.project_all_box > li > ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 28px;
    margin-top: 28px;
  }

  ul.project_all_box > li:first-child > ul {
    margin-top: 0;
  }

  ul.project_all_box > li > ul > li {
    width: 100%;
    height: 520px;
    margin-left: 0;
    border-radius: 16px;
  }

  .project_infor {
    height: 76px;
  }

  .project_infor_txt,
  .project_infor_detail {
    width: 76%;
  }

  .project_infor_txt > span,
  .project_infor_txt > p {
    font-size: 16px;
  }

  .project_infor_detail > h3 {
    font-size: 17px;
  }

  .detail_more_btn > a > button {
    height: 46px;
  }

  .detail_more_btn > a > button > p {
    font-size: 16px;
  }

  .top_move_btn {
    width: 64px;
    height: 64px;
    bottom: 60px;
  }

  .top_move_btn > a > span {
    font-size: 16px;
  }
}

@media screen and (max-width: 768px) {
  html,
  body {
    height: auto;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
  }

  main {
    height: auto;
    overflow: visible;
  }

  #brand_category {
    top: 64px;
    height: auto;
    padding: 16px 0;
    overflow-x: auto;
    justify-content: flex-start;
  }

  #brand_category::-webkit-scrollbar {
    display: none;
  }

  #brand_category > ul {
    width: max-content;
    min-width: 100%;
    padding: 0 20px;
    box-sizing: border-box;
    gap: 10px;
    justify-content: flex-start;
  }

  #brand_category > ul > li {
    width: auto;
    min-width: 104px;
    height: 38px;
    flex: none;
    border-radius: 50px;
  }

  #brand_category > ul > li > a > span {
    font-size: 14px;
    white-space: nowrap;
  }

  #project_all {
    margin-top: 135px;
    align-items: flex-start;
  }

  ul.project_all_box {
    width: 90%;
    margin-top: 44px;
    margin-bottom: 70px;
  }

  ul.project_all_box > li > ul {
    grid-template-columns: 1fr;
    gap: 24px;
    margin-top: 24px;
  }

  ul.project_all_box > li > ul > li {
    height: 460px;
    border-radius: 18px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
  }

  .project_infor {
    height: auto;
    min-height: 92px;
    padding: 18px 0;
    box-sizing: border-box;
  }

  .project_infor_txt {
    width: 82%;
  }

  .project_infor_txt > span,
  .project_infor_txt > p {
    font-size: 16px;
  }

  .project_infor_detail {
    width: 82%;
    height: auto;
  }

  .project_infor_detail > h3 {
    font-size: 18px;
  }

  .project_infor_detail_txt > span,
  .project_infor_detail_txt > p {
    font-size: 14px;
  }

  .detail_more_btn {
    margin-top: 28px;
  }

  .detail_more_btn > a > button {
    height: 44px;
  }

  .detail_more_btn > a > button > p {
    font-size: 15px;
  }

  .top_move_btn {
    width: 54px;
    height: 54px;
    right: 16px;
    bottom: 24px;
    border-radius: 50%;
  }

  .top_move_btn > a > span {
    font-size: 13px;
  }
}

@media screen and (max-width: 480px) {
  #brand_category {
    top: 58px;
    padding: 14px 0;
  }

  #brand_category > ul {
    padding: 0 16px;
  }

  #brand_category > ul > li {
    min-width: 94px;
    height: 36px;
  }

  #brand_category > ul > li > a > span {
    font-size: 13px;
  }

  #project_all {
    margin-top: 122px;
  }

  ul.project_all_box {
    width: 92%;
    margin-top: 34px;
    margin-bottom: 60px;
  }

  ul.project_all_box > li > ul {
    gap: 20px;
    margin-top: 20px;
  }

  ul.project_all_box > li > ul > li {
    height: 390px;
    border-radius: 14px;
  }

  .project_infor {
    min-height: 82px;
    padding: 15px 0;
  }

  .project_infor_txt,
  .project_infor_detail {
    width: 84%;
  }

  .project_infor_txt > span,
  .project_infor_txt > p {
    font-size: 14px;
  }

  .project_infor_detail > h3 {
    font-size: 16px;
  }

  .detail_more_btn {
    margin-top: 24px;
  }

  .detail_more_btn > a > button {
    height: 42px;
  }

  .top_move_btn {
    width: 48px;
    height: 48px;
  }

  .top_move_btn > a > span {
    font-size: 12px;
  }
}

/* ==============================
  BRAND DETAIL 반응형
================================ */

@media screen and (max-width: 1400px) {
  #side_infor {
    width: 34%;
  }

  .blank {
    width: 34%;
  }

  #project_detail_img {
    width: 64%;
  }

  .side_infor_tit > b {
    font-size: 22px;
  }

  .side_infor_txt > span,
  .side_infor_txt > p,
  ul.side_infor_form_box > li > span,
  ul.side_infor_form_box > li > p {
    font-size: 17px;
    line-height: 34px;
  }

  #project_detail_img > ul > li {
    height: 760px;
  }

  #project_detail_img > ul > li img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

@media screen and (max-width: 1024px) {
  main {
    display: block;
  }

  #side_infor {
    width: 100%;
    height: auto;
    position: relative;
    padding: 130px 0 60px;
    box-sizing: border-box;
    border-bottom: 1px solid #eee;
  }

  .side_infor_box {
    width: 84%;
    margin-top: 0;
  }

  .side_infor_tit > b {
    font-size: 28px;
  }

  .side_infor_txt {
    margin-top: 18px;
  }

  .side_infor_txt > span,
  .side_infor_txt > p {
    font-size: 19px;
  }

  .side_infor_form {
    margin-top: 44px;
    padding: 28px 0;
    border-radius: 16px;
  }

  ul.side_infor_form_box > li > span {
    font-size: 19px;
  }

  ul.side_infor_form_box > li > p {
    font-size: 17px;
    line-height: 32px;
  }

  .blank {
    display: none;
  }

  #project_detail_img {
    width: 100%;
  }

  #project_detail_img > ul {
    width: 84%;
    margin: 0 auto;
  }

  #project_detail_img > ul > li {
    height: auto;
    margin-top: 32px;
    border-radius: 18px;
  }

  #project_detail_img > ul > li:first-child {
    margin-top: 60px !important;
  }

  #project_detail_img > ul > li img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
  }

  .back_move_btn,
  .top_move_btn {
    width: 64px;
    height: 64px;
    right: 18px;
  }

  .top_move_btn {
    bottom: 50px;
  }

  .back_move_btn {
    bottom: 124px;
  }

  .back_move_btn > a > span,
  .top_move_btn > a > span {
    font-size: 15px;
  }
}

@media screen and (max-width: 768px) {
  html,
  body {
    height: auto;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
  }

  body {
    -webkit-overflow-scrolling: touch;
  }

  main {
    height: auto;
    overflow: visible;
  }

  #side_infor {
    padding: 104px 0 46px;
  }

  .side_infor_box {
    width: 88%;
  }

  .side_infor_tit > b {
    font-size: 23px;
    line-height: 145%;
  }

  .side_infor_txt {
    height: auto;
    margin-top: 16px;
  }

  .side_infor_txt > span,
  .side_infor_txt > p {
    font-size: 16px;
    line-height: 150%;
  }

  .side_infor_form {
    margin-top: 34px;
    padding: 24px 0;
    border-color: #e5e5e5;
    border-radius: 14px;
  }

  ul.side_infor_form_box {
    width: 84%;
  }

  ul.side_infor_form_box > li > span {
    font-size: 17px;
    line-height: 150%;
  }

  ul.side_infor_form_box > li > p {
    font-size: 15px;
    line-height: 180%;
    word-break: keep-all;
  }

  #project_detail_img > ul {
    width: 88%;
  }

  #project_detail_img > ul > li {
    margin-top: 24px;
    border-radius: 14px;
  }

  #project_detail_img > ul > li:first-child {
    margin-top: 42px !important;
  }

  .back_move_btn,
  .top_move_btn {
    width: 54px;
    height: 54px;
    right: 16px;
    border-radius: 50%;
  }

  .top_move_btn {
    bottom: 24px;
  }

  .back_move_btn {
    bottom: 86px;
  }

  .back_move_btn > a > span,
  .top_move_btn > a > span {
    font-size: 12px;
  }
}

@media screen and (max-width: 480px) {
  #side_infor {
    padding: 88px 0 38px;
  }

  .side_infor_box {
    width: 90%;
  }

  .side_infor_tit > b {
    font-size: 20px;
  }

  .side_infor_txt > span,
  .side_infor_txt > p {
    font-size: 15px;
  }

  .side_infor_form {
    margin-top: 28px;
    padding: 20px 0;
  }

  ul.side_infor_form_box > li > span {
    font-size: 16px;
  }

  ul.side_infor_form_box > li > p {
    font-size: 14px;
    line-height: 175%;
  }

  #project_detail_img > ul {
    width: 90%;
  }

  #project_detail_img > ul > li:first-child {
    margin-top: 34px !important;
  }

  .back_move_btn,
  .top_move_btn {
    width: 48px;
    height: 48px;
  }

  .top_move_btn {
    bottom: 20px;
  }

  .back_move_btn {
    bottom: 76px;
  }

  .back_move_btn > a > span,
  .top_move_btn > a > span {
    font-size: 11px;
  }
}

/* ==============================
  BRAND DETAIL ETC 반응형
================================ */

@media screen and (max-width: 1400px) {
  .concept_section {
    width: 34%;
    margin-left: 50px;
    margin-right: 50px;
  }

  #project_detail_img {
    width: 62%;
  }

  .side_infor_tit > b {
    font-size: 22px;
  }

  .side_infor_txt > span,
  .side_infor_txt > p,
  ul.side_infor_form_box > li > span,
  ul.side_infor_form_box > li > p {
    font-size: 17px;
    line-height: 34px;
  }

  #project_detail_img > ul > li {
    height: 760px;
  }

  #project_detail_img > ul > li img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

@media screen and (max-width: 1024px) {
  .bd_etc_section {
    display: block;
  }

  .concept_section {
    width: 84%;
    height: auto;
    margin: 0 auto;
    display: block;
    padding-top: 130px;
  }

  .side_infor {
    width: 100%;
    min-height: auto;
    margin-top: 0 !important;
    padding: 0 0 60px;
    border-bottom: 1px solid #eee;
  }

  .side_infor_box {
    width: 100%;
    margin-top: 0;
  }

  .side_infor_tit > b {
    font-size: 28px;
  }

  .side_infor_txt {
    height: auto;
    margin-top: 16px;
  }

  .side_infor_txt > span,
  .side_infor_txt > p {
    font-size: 19px;
  }

  .side_infor_form {
    margin-top: 38px;
    padding: 28px 0;
    border-radius: 16px;
  }

  ul.side_infor_form_box > li > span {
    font-size: 19px;
  }

  ul.side_infor_form_box > li > p {
    font-size: 17px;
    line-height: 32px;
    word-break: keep-all;
  }

  #project_detail_img {
    width: 84%;
    margin: 0 auto;
  }

  #project_detail_img > ul > li {
    height: auto;
    margin-top: 32px;
    border-radius: 18px;
  }

  #project_detail_img > ul > li:first-child {
    margin-top: 60px !important;
  }

  #project_detail_img > ul > li img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
  }

  .back_move_btn,
  .top_move_btn {
    width: 64px;
    height: 64px;
    right: 18px;
  }

  .top_move_btn {
    bottom: 50px;
  }

  .back_move_btn {
    bottom: 124px;
  }

  .back_move_btn > a > span,
  .top_move_btn > a > span {
    font-size: 15px;
  }
}

@media screen and (max-width: 768px) {
  html,
  body {
    height: auto;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
  }

  body {
    -webkit-overflow-scrolling: touch;
  }

  main {
    height: auto;
    overflow: visible;
  }

  .concept_section {
    width: 88%;
    padding-top: 104px;
  }

  .side_infor {
    padding-bottom: 46px;
  }

  .side_infor_tit > b {
    font-size: 23px;
    line-height: 145%;
  }

  .side_infor_txt > span,
  .side_infor_txt > p {
    font-size: 16px;
    line-height: 150%;
  }

  .side_infor_form {
    margin-top: 30px;
    padding: 24px 0;
    border-color: #e5e5e5;
    border-radius: 14px;
  }

  ul.side_infor_form_box {
    width: 84%;
  }

  ul.side_infor_form_box > li > span {
    font-size: 17px;
    line-height: 150%;
  }

  ul.side_infor_form_box > li > p {
    font-size: 15px;
    line-height: 180%;
  }

  #project_detail_img {
    width: 88%;
  }

  #project_detail_img > ul > li {
    margin-top: 24px;
    border-radius: 14px;
  }

  #project_detail_img > ul > li:first-child {
    margin-top: 42px !important;
  }

  .back_move_btn,
  .top_move_btn {
    width: 54px;
    height: 54px;
    right: 16px;
    border-radius: 50%;
  }

  .top_move_btn {
    bottom: 24px;
  }

  .back_move_btn {
    bottom: 86px;
  }

  .back_move_btn > a > span,
  .top_move_btn > a > span {
    font-size: 12px;
  }
}

@media screen and (max-width: 480px) {
  .concept_section {
    width: 90%;
    padding-top: 88px;
  }

  .side_infor {
    padding-bottom: 38px;
  }

  .side_infor_tit > b {
    font-size: 20px;
  }

  .side_infor_txt > span,
  .side_infor_txt > p {
    font-size: 15px;
  }

  .side_infor_form {
    margin-top: 26px;
    padding: 20px 0;
  }

  ul.side_infor_form_box > li > span {
    font-size: 16px;
  }

  ul.side_infor_form_box > li > p {
    font-size: 14px;
    line-height: 175%;
  }

  #project_detail_img {
    width: 90%;
  }

  #project_detail_img > ul > li:first-child {
    margin-top: 34px !important;
  }

  .back_move_btn,
  .top_move_btn {
    width: 48px;
    height: 48px;
  }

  .top_move_btn {
    bottom: 20px;
  }

  .back_move_btn {
    bottom: 76px;
  }

  .back_move_btn > a > span,
  .top_move_btn > a > span {
    font-size: 11px;
  }
}

@media screen and (max-width: 1024px) {
  .etc_detail_list {
    padding: 120px 0 80px;
  }

  .etc_detail_item {
    width: 84%;
    display: block;
    margin-top: 80px;
  }

  .etc_detail_item:first-child {
    margin-top: 0;
  }

  .etc_detail_item .side_infor {
    width: 100%;
    position: static;
  }

  .etc_detail_item .side_infor_tit > b {
    font-size: 28px;
  }

  .etc_detail_item .side_infor_form {
    margin-top: 36px;
    border-radius: 16px;
  }

  .etc_detail_item .side_infor_form_box > li > p {
    font-size: 17px;
    line-height: 180%;
  }

  .etc_detail_item .project_detail_img {
    width: 100%;
    margin-top: 32px;
    border-radius: 18px;
  }
}

@media screen and (max-width: 768px) {
  .etc_detail_list {
    padding: 100px 0 70px;
  }

  .etc_detail_item {
    width: 88%;
    margin-top: 68px;
  }

  .etc_detail_item .side_infor_tit > b {
    font-size: 23px;
  }

  .etc_detail_item .side_infor_txt > span,
  .etc_detail_item .side_infor_txt > p {
    font-size: 16px;
  }

  .etc_detail_item .side_infor_form {
    margin-top: 28px;
    padding: 22px 0;
    border-color: #e5e5e5;
    border-radius: 14px;
  }

  .etc_detail_item .side_infor_form_box > li > span {
    font-size: 17px;
  }

  .etc_detail_item .side_infor_form_box > li > p {
    font-size: 15px;
    line-height: 180%;
  }

  .etc_detail_item .project_detail_img {
    margin-top: 24px;
    border-radius: 14px;
  }
}

/* ==============================
  CHARACTER 반응형
================================ */

@media screen and (max-width: 1400px) {
  #banner > img {
    width: 82%;
  }

  .instaqr_pdf {
    width: 60%;
  }
}

@media screen and (max-width: 1024px) {
  #banner {
    height: auto;
    min-height: 100vh;
    padding-bottom: 80px;
  }

  #banner > img {
    width: 86%;
    margin-top: 120px;
  }

  .instaqr_pdf {
    width: 76%;
    height: auto;
    margin-top: 70px;
    gap: 40px;
  }

  .instaqr {
    width: 160px;
  }

  .portfolio_pdf_download {
    width: calc(100% - 200px);
  }

  .instaqr > span,
  .portfolio_pdf_download > span {
    font-size: 26px;
  }

  .portfolio_pdf_download > a {
    margin-top: 36px;
  }
}

@media screen and (max-width: 768px) {
  html,
  body {
    height: auto;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
  }

  main {
    height: auto;
    overflow: visible;
  }

  #banner {
    padding-bottom: 70px;
  }

  #banner > img {
    width: 90%;
    margin-top: 100px;
  }

  .instaqr_pdf {
    width: 88%;
    flex-direction: column;
    margin-top: 50px;
    gap: 44px;
  }

  .instaqr,
  .portfolio_pdf_download {
    width: 100%;
  }

  .instaqr > span,
  .portfolio_pdf_download > span {
    font-size: 24px;
  }

  .instaqr > img {
    width: 130px;
  }

  .portfolio_pdf_download > a {
    height: 72px;
    margin-top: 22px;
  }

  .refer_r_pdf_txt {
    width: auto;
  }

  .refer_r_pdf_txt > img {
    width: 34px;
    height: auto;
  }

  .refer_r_pdf_txt > p {
    font-size: 16px;
    margin-left: 20px;
  }
}

@media screen and (max-width: 480px) {
  #banner > img {
    width: 92%;
    margin-top: 88px;
  }

  .instaqr_pdf {
    width: 90%;
    margin-top: 40px;
    gap: 38px;
  }

  .instaqr > span,
  .portfolio_pdf_download > span {
    font-size: 21px;
  }

  .instaqr > p {
    font-size: 15px;
  }

  .instaqr > img {
    width: 115px;
  }

  .portfolio_pdf_download > a {
    height: 66px;
  }

  .refer_r_pdf_txt > img {
    width: 30px;
  }

  .refer_r_pdf_txt > p {
    font-size: 14px;
    margin-left: 14px;
  }
}

/* ==============================
  UX/UI 반응형
================================ */

@media screen and (max-width: 1400px) {
  #uxui_category > ul {
    width: 48%;
  }

  ul.project_all_box > li > ul > li {
    width: calc((100% - 90px) / 4);
    height: 620px;
    margin-left: 30px;
  }

  .project_infor_txt,
  .project_infor_detail {
    width: 70%;
  }
}

@media screen and (max-width: 1024px) {
  #uxui_category {
    top: 70px;
    height: 86px;
  }

  #uxui_category > ul {
    width: 60%;
    gap: 12px;
  }

  #uxui_category > ul > li {
    width: auto;
    flex: 1;
  }

  #uxui_category > ul > li > a > span {
    font-size: 15px;
  }

  #project_all {
    margin-top: 156px;
  }

  ul.project_all_box {
    width: 90%;
    margin-top: 70px;
    margin-bottom: 80px;
  }

  ul.project_all_box > li > ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 28px;
  }

  ul.project_all_box > li > ul > li {
    width: 100%;
    height: 520px;
    margin-left: 0;
    border-radius: 16px;
  }

  .project_infor {
    height: 76px;
  }

  .project_infor_txt,
  .project_infor_detail {
    width: 76%;
  }

  .project_infor_txt > span,
  .project_infor_txt > p {
    font-size: 16px;
  }

  .project_infor_detail > h3 {
    font-size: 17px;
  }

  .detail_more_btn > a > button {
    height: 46px;
  }

  .detail_more_btn > a > button > p {
    font-size: 16px;
  }

  .top_move_btn {
    width: 64px;
    height: 64px;
    bottom: 60px;
  }

  .top_move_btn > a > span {
    font-size: 16px;
  }
}

@media screen and (max-width: 768px) {
  html,
  body {
    height: auto;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
  }

  main {
    height: auto;
    overflow: visible;
  }

  #uxui_category {
    top: 64px;
    height: auto;
    padding: 16px 0;
    overflow-x: auto;
    justify-content: flex-start;
  }

  #uxui_category::-webkit-scrollbar {
    display: none;
  }

  #uxui_category > ul {
    width: max-content;
    min-width: 100%;
    padding: 0 20px;
    box-sizing: border-box;
    gap: 10px;
    justify-content: flex-start;
  }

  #uxui_category > ul > li {
    width: auto;
    min-width: 104px;
    height: 38px;
    flex: none;
    border-radius: 50px;
  }

  #uxui_category > ul > li > a > span {
    font-size: 14px;
    white-space: nowrap;
  }

  #project_all {
    margin-top: 135px;
    align-items: flex-start;
  }

  ul.project_all_box {
    width: 90%;
    margin-top: 44px;
    margin-bottom: 70px;
  }

  ul.project_all_box > li > ul {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  ul.project_all_box > li > ul > li {
    height: 460px;
    border-radius: 18px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
  }

  .project_infor {
    height: auto;
    min-height: 92px;
    padding: 18px 0;
    box-sizing: border-box;
  }

  .project_infor_txt {
    width: 82%;
  }

  .project_infor_txt > span,
  .project_infor_txt > p {
    font-size: 16px;
  }

  .project_infor_detail {
    width: 82%;
    height: auto;
  }

  .project_infor_detail > h3 {
    font-size: 18px;
  }

  .project_infor_detail_txt > span,
  .project_infor_detail_txt > p {
    font-size: 14px;
  }

  .detail_more_btn {
    margin-top: 28px;
  }

  .detail_more_btn > a > button {
    height: 44px;
  }

  .detail_more_btn > a > button > p {
    font-size: 15px;
  }

  .top_move_btn {
    width: 54px;
    height: 54px;
    right: 16px;
    bottom: 24px;
    border-radius: 50%;
  }

  .top_move_btn > a > span {
    font-size: 13px;
  }
}

@media screen and (max-width: 480px) {
  #uxui_category {
    top: 58px;
    padding: 14px 0;
  }

  #uxui_category > ul {
    padding: 0 16px;
  }

  #uxui_category > ul > li {
    min-width: 94px;
    height: 36px;
  }

  #uxui_category > ul > li > a > span {
    font-size: 13px;
  }

  #project_all {
    margin-top: 122px;
  }

  ul.project_all_box {
    width: 92%;
    margin-top: 34px;
    margin-bottom: 60px;
  }

  ul.project_all_box > li > ul {
    gap: 20px;
  }

  ul.project_all_box > li > ul > li {
    height: 390px;
    border-radius: 14px;
  }

  .project_infor {
    min-height: 82px;
    padding: 15px 0;
  }

  .project_infor_txt,
  .project_infor_detail {
    width: 84%;
  }

  .project_infor_txt > span,
  .project_infor_txt > p {
    font-size: 14px;
  }

  .project_infor_detail > h3 {
    font-size: 16px;
  }

  .detail_more_btn {
    margin-top: 24px;
  }

  .detail_more_btn > a > button {
    height: 42px;
  }

  .top_move_btn {
    width: 48px;
    height: 48px;
  }

  .top_move_btn > a > span {
    font-size: 12px;
  }
}

/* ==============================
  HOME 메인 슬라이더 복구
================================ */

@media screen and (max-width: 768px) {
  html,
  body.home_page {
    height: 100%;
    overflow: hidden;
  }

  body.home_page #mainSlider {
    height: 100svh !important;
    overflow: hidden !important;
  }

  body.home_page #mainSlider .main_background {
    height: 100svh !important;
  }

  body.home_page #mainSlider .main_background > img {
    height: 100% !important;
    object-fit: cover;
  }
}
/* ==============================
  모바일 전체 스크롤 + 좌우 10px 여백
================================ */

@media screen and (max-width: 768px) {
  html,
  body {
    width: 100%;
    height: auto !important;
    min-height: 100%;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  body {
    -webkit-overflow-scrolling: touch;
  }

  main {
    width: 100%;
    height: auto !important;
    min-height: auto !important;
    overflow: visible !important;
  }

  .wrap {
    width: 100%;
    min-height: 100%;
    overflow: visible !important;
  }

  section {
    box-sizing: border-box;
  }

  /* 모바일 좌우 여백 10px */
  #itd,
  #project_all,
  #project_detail_img,
  #banner,
  .etc_detail_list {
    padding-left: 10px !important;
    padding-right: 10px !important;
    box-sizing: border-box;
  }

  .itd_con,
  .mi_con,
  ul.project_all_box,
  #project_detail_img > ul,
  .side_infor_box,
  .concept_section,
  .etc_detail_item,
  .instaqr_pdf {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }
}

@media screen and (max-width: 768px) {
  body.home_page {
    height: 100svh !important;
    overflow: hidden !important;
  }

  body.home_page main,
  body.home_page #mainSlider {
    height: 100svh !important;
    overflow: hidden !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}