@charset "UTF-8";

/*
    ============================================
    SE-Trade Theme - Combined Stylesheet
    1688구매대행 중국무역대행 SE무역
    ============================================
*/

/* ============ Font (Google Fonts Noto Sans KR) ============ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100;300;400;500;700;900&display=swap');

/* Font-family aliases (원본 호환) */
.NotoSansT, * { font-family: 'Noto Sans KR', sans-serif; }

/* ============ Base Reset ============ */
* { margin: 0; padding: 0; border: 0; }

a { text-decoration: none; color: #222222; }
a:visited { text-decoration: none; color: #222222; }
a:active { text-decoration: none; color: #222222; }
a:link { text-decoration: none; color: #222222; }

ul, ol, dl { list-style: none; }
table { border-collapse: collapse; }
:focus { outline: none; }

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.showBlockPc { display: block; }
.showInlineBlockPc { display: inline-block; }
.showInlinePc { display: inline; }
.showBlockM { display: none; }
.showInlineBlockM { display: none; }
.showInlineM { display: none; }


/* ============ Main Layout ============ */
.wrap { width: 100%; overflow: hidden; }
.hideContent { display: none; }

/* ============ Header ============ */
.headerWrap { width: 100%; position: fixed; top: 0; background-color: #fff; z-index: 100; box-shadow: 0 2px 8px rgba(0,0,0,.06); }
.header { display: flex; align-items: center; max-width: 1200px; height: 80px; margin: 0 auto; padding: 0 20px; gap: 8px; }
.header .logo { flex-shrink: 0; }
.header .logo img { height: 40px; width: auto; }
.header .gnb { flex: 1; display: flex; justify-content: center; }
.header .iconWrap { flex-shrink: 0; display: flex; align-items: center; gap: 6px; }
.header .iconWrap img { height: 28px; width: auto; }

/* ============ Quick Menu Cards ============ */
.qm-trade { padding: 40px 0 20px; margin-top: 124px; background: #f0f2f8; }
.qm-trade .qm-container { max-width: 1200px; margin: 0 auto; padding: 0 12px; }
.qm-trade .qm-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.qm-trade .qm-card { background: #fff; border-radius: 20px; overflow: hidden; border: 1px solid #bbb; transition: all .3s ease; }
.qm-trade .qm-card:hover { background: #c5d5f5; border-color: #293c84; }
.qm-trade .qm-img { position: relative; width: 100%; aspect-ratio: 4/3; overflow: hidden; border-radius: 20px; }
.qm-trade .qm-img a { display: block; width: 100%; height: 100%; }
.qm-trade .qm-img img { width: 100%; height: 100%; object-fit: cover; border: 3px solid #fff; border-radius: 20px; transition: border-color .3s; }
.qm-trade .qm-card:hover .qm-img img { border-color: #293c84; }
.qm-trade .qm-title { display: block; text-align: center; padding: 12px 8px 4px; font-size: 1.1rem; font-weight: 700; color: #1a1a1a; }
.qm-trade .qm-link { text-align: center; padding: 0 8px 16px; font-size: .95rem; line-height: 1.8; }
.qm-trade .qm-link a { color: #444; }
.qm-trade .qm-link a:hover { color: #293c84; font-weight: 700; }

/* ============ Live Review Ticker ============ */
.live-review-ticker { display: flex; align-items: center; background: #1a2a6c; overflow: hidden; height: 44px; position: fixed; top: 0; width: 100%; z-index: 101; }
.live-review-ticker + .headerWrap { top: 44px; }
.ticker-label { flex-shrink: 0; display: flex; align-items: center; gap: 6px; padding: 0 16px; font-size: 13px; font-weight: 700; color: #fff; background: #293c84; height: 100%; white-space: nowrap; z-index: 1; }
.ticker-dot { display: inline-block; width: 8px; height: 8px; background: #ff4444; border-radius: 50%; animation: tickerBlink 1.2s ease-in-out infinite; }
@keyframes tickerBlink { 0%, 100% { opacity: 1; } 50% { opacity: .3; } }
.ticker-wrap { flex: 1; overflow: hidden; height: 100%; }
.ticker-track { display: flex; align-items: center; height: 100%; animation: tickerScroll 30s linear infinite; white-space: nowrap; }
.ticker-track:hover { animation-play-state: paused; }
@keyframes tickerScroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
a.ticker-item, a.ticker-item:link, a.ticker-item:visited, a.ticker-item:active { display: inline-flex; align-items: center; gap: 8px; padding: 0 28px; height: 100%; color: #fff; font-size: 14px; white-space: nowrap; border-right: 1px solid rgba(255,255,255,.15); transition: color .2s; }
a.ticker-item:hover { color: #ffd700; }
.ticker-rating { color: #ffc107; font-size: 14px; letter-spacing: -1px; }
.ticker-title { font-weight: 600; }
.ticker-author { color: rgba(255,255,255,.7); font-size: 13px; }

/* ============ Navigation (GNB) ============ */
.gnb-menu { display: flex; gap: 0; }
.gnb-menu li a { display: block; padding: 8px 20px; font-size: 15px; font-weight: 500; color: #333; transition: color .2s; white-space: nowrap; }
.gnb-menu li a:hover { color: #293c84; font-weight: 700; }

.mobile-menu-toggle { display: none; background: none; cursor: pointer; width: 30px; height: 24px; position: relative; }
.mobile-menu-toggle span { display: block; width: 100%; height: 3px; background: #293c84; border-radius: 2px; position: absolute; left: 0; transition: all .3s; }
.mobile-menu-toggle span:nth-child(1) { top: 0; }
.mobile-menu-toggle span:nth-child(2) { top: 10px; }
.mobile-menu-toggle span:nth-child(3) { top: 20px; }

.mobile-menu-overlay { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,.5); z-index: 199; }
.mobile-menu-overlay.active { display: block; }

.mobile-menu { position: fixed; top: 0; right: -280px; width: 280px; height: 100%; background: #fff; z-index: 200; transition: right .3s ease; overflow-y: auto; }
.mobile-menu.active { right: 0; }
.mobile-menu-header { display: flex; align-items: center; justify-content: space-between; padding: 20px; border-bottom: 1px solid #e0e0e0; }
.mobile-menu-header img { height: 30px; }
.mobile-menu-close { background: none; font-size: 28px; cursor: pointer; color: #333; line-height: 1; }
.mobile-menu-list { padding: 10px 0; }
.mobile-menu-list li a { display: block; padding: 14px 24px; font-size: 16px; color: #333; border-bottom: 1px solid #f0f0f0; }
.mobile-menu-list li a:hover { background: #f5f7ff; color: #293c84; }
.mobile-menu-contact { padding: 20px 24px; border-top: 1px solid #e0e0e0; }
.mobile-menu-phone { display: block; text-align: center; padding: 12px; background: #293c84; color: #fff !important; border-radius: 8px; font-size: 18px; font-weight: 700; }

/* ============ Content ============ */
.content { width: 100%; height: 5833px; margin-top: 124px; background: url("../images/contentPc.png") center center no-repeat; }
.content_m { display: none; }

/* ============ Complete ============ */
.complete { width: 100%; height: 743px; background: url("../images/complete_pc.png") center center no-repeat; }
.complete_m { display: none; }

/* ============ Home Review Section ============ */
.home-review-section { padding: 48px 0; background: #f8f9fd; }
.home-review-container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.home-section-title { font-size: 24px; font-weight: 700; color: #222; text-align: center; margin-bottom: 28px; }
.home-review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 20px; }
.home-review-card { background: #fff; border: 1px solid #e0e0e0; border-radius: 12px; transition: box-shadow .3s, border-color .3s; }
.home-review-card:hover { box-shadow: 0 4px 16px rgba(41, 60, 132, .12); border-color: #293c84; }
.home-review-card a { display: block; padding: 20px; color: inherit; }
.home-review-card h3 { font-size: 15px; font-weight: 600; color: #222; margin: 8px 0; line-height: 1.4; }
.home-review-card p { font-size: 13px; color: #666; line-height: 1.6; margin-bottom: 12px; min-height: 40px; }
.home-card-rating .star { font-size: 14px; color: #ddd; }
.home-card-rating .star.filled { color: #ffc107; }
.home-card-meta { font-size: 12px; color: #999; display: flex; gap: 8px; }
.home-review-more { text-align: center; }
.home-review-more a { display: inline-block; padding: 10px 32px; border: 1px solid #293c84; border-radius: 50px; color: #293c84; font-weight: 600; font-size: 15px; transition: all .2s; }
.home-review-more a:hover { background: #293c84; color: #fff; }

/* ============ Footer ============ */
.footerWrap { width: 100%; background: #17265c; }
.copyWrap { display: flex; justify-content: center; align-items: center; max-width: 1200px; height: 142px; font-size: 18px; color: #e8e8e9; font-weight: 300; text-align: center; margin: 0 auto; }
.copyWrap .copy a { font-size: 18px; color: #ecf0f2; }
.copyWrap .copy span { font-size: 14px; font-weight: 400; }
.copy_m { display: none; }

/* ============ Fixed Form ============ */
.fixedForm { display: block; position: fixed; bottom: 0; width: 100%; display: none; z-index: 99; }
.fixedForm.on { display: block; }

.fixedForm .formWrap { max-width: 1200px; height: 122px; background: #293c84; margin: 0 auto; }
.fixedForm .formWrap .form { display: flex; justify-content: space-between; align-items: center; height: 100%; }
.formInputWrap { display: flex; align-items: center; }
.fixedForm .formWrap .form .formText { color: #ffffff; font-size: 24px; font-weight: 500; padding-left: 30px; }
.formInput { display: flex; color: #ffffff; }
.formInput input[type=text] { width: 180px; height: 45px; font-size: 18px; background: #6d7cc8; color: #ffffff; padding: 0 10px; box-sizing: border-box; border: none; }
.formInput .name { font-size: 18px; font-weight: 400; padding-right: 10px; padding-left: 40px; padding-top: 7px; }
.formInput .phone { font-size: 18px; font-weight: 400; padding-right: 10px; padding-left: 30px; padding-top: 7px; }
.agreeForm { padding-left: 40px; color: #d9dde3; font-size: 18px; font-weight: 300; }
.agreeForm input[type=checkbox] {
    width: 17px; height: 17px; margin-right: 8px;
}

.btnForm { display: flex; align-items: center; justify-content: center; width: 120px; height: 100%; font-size: 25px; font-weight: 700; color: #000000; background: #ffab9b; cursor: pointer; }
.btnForm .btnText { margin-bottom: 7px; }
.btnForm .icon { display: flex; align-items: center; justify-content: center; font-size: 20px; font-weight: 700; color: #ffffff; border-radius: 20px; padding: 5px 10px; background: #293c84; }
.btnForm .icon img { padding-left: 3px; }
.closeBtn { display: none; }

.clickFormWrap { display: none; }

/* ============ Bottom Fixed Buttons (mobile) ============ */
.bottomFixedButtons { display: none; }


/* ============ Privacy Popup ============ */
#privacyPopup { display: none; position: fixed; width: 100%; height: 100%; top: 0; left: 0; z-index: 2000; background-color: rgba(0,0,0,0.7); }
#privacyPopup .contWin { position: relative; width: 100%; max-width: 1100px; height: 90%; font-family: 'Noto Sans KR', sans-serif; padding: 30px; box-sizing: border-box; margin: 0 auto; margin-top: 50px; background-color: #ffffff; }
#privacyPopup .contWin .scrollWrap { height: calc(100% - 120px); overflow-y: auto; }
#privacyPopup .contWin .btnClosePopup { position: absolute; right: 0; top: -46px; cursor: pointer; }
#privacyPopup .contWin input[type=checkbox] { width: 18px; height: 18px; border: solid 1px #91989a; vertical-align: middle; margin-bottom: 3px; background-color: #ffffff; }
#privacyPopup .contWin .agreeAllCell { font-size: 14px; font-weight: 700; padding-bottom: 5px; }
#privacyPopup .contWin .agreeAllCell span { margin-right: 20px; }
#privacyPopup .contWin .popupTitle { font-size: 20px !important; color: #000000; font-weight: 700; text-align: center; margin-bottom: 20px; }
#privacyPopup .contWin .privacyInfoText { font-size: 12px; margin-bottom: 20px; }
#privacyPopup .contWin .agreeContWrap { border-top: solid 2px #6a6a6a; border-bottom: solid 1px #b3b3b3; padding: 15px 0; margin-bottom: 10px; }
#privacyPopup .contWin .agreeContWrap .agreeBox { margin-bottom: 20px; }
#privacyPopup .contWin .agreeContWrap .agreeBox:last-child { margin-bottom: 0; }
#privacyPopup .contWin .agreeContWrap .agreeBox .titleCell { font-size: 14px; font-weight: 500; margin-bottom: 5px; }
#privacyPopup .contWin .agreeContWrap .agreeBox .titleCell span { color: #31b9ff; }
#privacyPopup .contWin .agreeContWrap .agreeBox .titleCell span.checkCell { color: #333333; font-weight: normal; margin-left: 10px; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell { height: 50px; font-size: 12px; font-weight: 300; line-height: 20px; padding: 10px; letter-spacing: -1px; overflow-y: auto; border: solid 1px #cccccc; margin-bottom: 5px; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .bold { font-weight: 500; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .indent { display: inline-block; width: 15px; }
#privacyPopup .contWin .agreeContWrap .agreeBox .checkCell { font-size: 14px; }
#privacyPopup .contWin .btnConfirm { width: 100px; font-size: 18px; color: #ffffff; text-align: center; border-radius: 20px; margin: 0 auto; margin-top: 30px; padding: 5px 15px; cursor: pointer; background-color: #000000; }

#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable { width: 100%; font-size: 12px; border-collapse: collapse; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable th { font-weight: normal; padding: 5px 0; border: solid 1px #cccccc; background-color: #f0f0f0; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable th:nth-child(1) { width: 30%; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable th:nth-child(2) { width: 30%; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable th:nth-child(3) { width: 30%; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable th:nth-child(4) { width: 10%; }
#privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable td { padding: 5px 0; border: solid 1px #cccccc; text-align: center; }


/* ============ Responsive: Tablet (max-width: 1200px) ============ */
@media (max-width: 1200px) {
    .header { padding: 0 16px; }

    .qm-trade .qm-row { grid-template-columns: repeat(2, 1fr); }
    .home-review-grid { grid-template-columns: repeat(2, 1fr); }

    .gnb { display: none; }
    .mobile-menu-toggle { display: block; }

    .content { display: none; }
    .content_m { display: block; }
    .content_m img { width: 100%; }

    .complete { display: none; }
    .complete_m { display: block; }
    .complete_m img { width: 100%; }

    .footerWrap { width: 100%; background: #17265c; margin-bottom: 0; padding-bottom: 0; margin-top: -4px; }

    .copyWrap { display: flex; justify-content: center; align-items: center; max-width: 1200px; height: 180px; font-size: 12px; color: #e8e8e9; font-weight: 300; text-align: center; margin: 0 auto; }
    .copyWrap .copy a { font-size: 14px; color: #ecf0f2; }
    .copyWrap .copy span { font-size: 11px; font-weight: 400; }

    /* 개인정보취급방침 */
    .copy_pc { display: none; }
    .copy_m { display: block; padding-bottom: 10px; }

    .fixedForm { display: none; }

    /* 클릭하면 신청폼 뜨는 곳 */
    .clickFormWrap { display: block; }
    .clickForm { position: relative; }
    .clickForm .clickBar { display: none; position: fixed; bottom: 0; width: 100%;
        line-height: 105px; background: #293c84; margin-top: 20px; padding: 0 10px;
        box-sizing: border-box; }

    .clickForm .clickBar ul { display: flex; align-items: center; justify-content: space-around; }
    .clickForm .clickBar ul li { display: flex; align-items: center; font-size: 14px; color: #ffffff; font-weight: 700; padding-top: 10px; }
    .clickForm .clickBar ul li img { width: 27px; height: 27px; }

    .clickForm .clickBtn { display: none; position: fixed; bottom: 77px; left: 50%; transform: translatex(-50%); align-items: center; justify-content: center;
        width: 250px; height: 55px; font-weight: 700; font-size: 24px; margin: 0 auto; border-radius: 50px; cursor: pointer; }
    .clickForm .clickBtnText { align-items: center; justify-content: center; width: 50%; height: 100%; color: #222222; border-radius: 50px 0px 0 50px; background: #ffab9b; }
    .clickForm .clickBtnIcon { align-items: center; justify-content: center; width: 50%; height: 100%; color: #ffffff; border-radius: 0px 50px 50px 0px; background: #000000; }
    .clickForm .clickBtnIcon img { padding-left: 10px; width: 20px; }

    /* 고정 신청폼 */
    .fixedForm { display: none; position: fixed; bottom: 0px; width: 100%; }
    .fixedForm.on { display: block; }

    .fixedForm .formWrap { display: block; max-width: 1200px; height: 220px; }
    .fixedForm .formWrap .form { display: flex; justify-content: center; align-items: center; padding: 0px 0; margin-left: -26px; }

    .formInputWrap { display: block; }

    .fixedForm .formWrap .form .formText { display: none; }
    .formInput { display: flex; justify-content: space-between; align-items: center; color: #ffffff; padding: 8px 0; }
    .formInput input[type=text] { flex: 1; height: 40px; line-height: 30px; font-size: 16px; background: #6d7cc8; padding: 0 10px; box-sizing: border-box; }
    .formInput .name { width: 50px; font-size: 16px; font-weight: 400; padding-top: 7px; padding-right: 0px; }
    .formInput .phone { width: 50px; font-size: 16px; font-weight: 400; padding-top: 7px; }

    .agreeForm { display: flex; justify-content: center; font-size: 14px; padding-top: 7px; padding-left: 69px; }
    .agreeForm input[type=checkbox] { display: inline-block; width: 15px; height: 15px; margin-right: 3px; margin-top: 2px; }

    /* 신청폼 안에 버튼 */
    .btnForm { display: flex; justify-content: center; width: 95px; height: 95px; text-align: center;
        font-size: 20px; font-weight: 700; color: #000000; background: #ffab9b; cursor: pointer; margin-top: -28px; margin-right: 10px; margin-left: 10px; }
    .btnForm .btnText { margin-bottom: 7px; }
    .btnForm .icon { display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; color: #ffffff; border-radius: 20px; padding: 5px 10px; background: #293c84; }
    .btnForm .icon img { padding-left: 3px; }
    .closeBtn { display: none; }

    /* 닫기 버튼 */
    .closeBtn { display: block; position: absolute; top: -39px; right: 0; cursor: pointer; }
    .closeBtn img { width: 40px; }
}


/* ============ Responsive: Mobile (max-width: 768px) ============ */
@media (max-width: 768px) {
    .headerWrap { position: relative; }
    .header { padding: 0 10px; height: 60px; }
    .header .iconWrap .kakaoIcon,
    .header .iconWrap .telIcon { display: none; }
    .header .logo img { height: 32px; }
    .header .iconWrap img { height: 24px; }

    .live-review-ticker { height: 38px; }
    .live-review-ticker + .headerWrap { top: 38px; }
    .ticker-label { font-size: 12px; padding: 0 10px; }
    .ticker-item { font-size: 12px; padding: 0 16px; }
    .qm-trade { margin-top: 0; padding: 24px 0 10px; }
    .qm-trade .qm-row { grid-template-columns: 1fr; gap: 12px; }
    .qm-trade .qm-title { font-size: .95rem; }
    .qm-trade .qm-link { font-size: .85rem; }

    .gnb { display: none; }
    .mobile-menu-toggle { display: block; }

    .home-review-grid { grid-template-columns: 1fr; }
    .home-review-section { padding: 32px 0; }
    .home-section-title { font-size: 20px; margin-bottom: 16px; }

    .footerWrap { padding-bottom: 50px; }

    /* Bottom Fixed Buttons */
    .bottomFixedButtons { position: fixed; bottom: 0; display: flex; flex-direction: row; z-index: 98; }
    .bottomFixedButtons div { width: 50%; }
    .bottomFixedButtons div img { width: 100%; vertical-align: top; }

    /* PC/Mobile visibility */
    .showBlockPc { display: none; }
    .showInlineBlockPc { display: none; }
    .showInlinePc { display: none; }
    .showBlockM { display: block; }
    .showInlineBlockM { display: inline-block; }
    .showInlineM { display: inline; }

    /* Privacy Popup */
    #privacyPopup .contWin { position: relative; width: 90%; height: 85%; padding: 10px; margin-top: 40px; }
    #privacyPopup .contWin .scrollWrap { height: calc(100% - 90px); }
    #privacyPopup .contWin .btnClosePopup { width: 40px; height: 40px; right: 0; top: -41px; }
    #privacyPopup .contWin .agreeAllCell { font-size: 13px; }
    #privacyPopup .contWin .agreeAllCell span { margin-right: 10px; }
    #privacyPopup .contWin .popupTitle { font-size: 16px !important; margin-bottom: 10px; letter-spacing: -1px; }
    #privacyPopup .contWin .privacyInfoText { font-size: 11px; margin-bottom: 10px; line-height: 15px; }
    #privacyPopup .contWin .agreeContWrap { padding: 5px 0; margin-bottom: 5px; }
    #privacyPopup .contWin .agreeContWrap .agreeBox { margin-bottom: 10px; }
    #privacyPopup .contWin .agreeContWrap .agreeBox .titleCell { font-size: 12px; letter-spacing: -1px; }
    #privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell { height: 40px; font-size: 11px; padding: 5px; letter-spacing: -1px; }
    #privacyPopup .contWin .agreeContWrap .agreeBox .checkCell { font-size: 12px; line-height: 15px; }
    #privacyPopup .contWin .btnConfirm { font-size: 15px; margin-top: 10px; }
    #privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable { font-size: 11px; line-height: 16px; }
    #privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable th { padding: 3px 0; }
    #privacyPopup .contWin .agreeContWrap .agreeBox .agreeTextCell .infoTable td { padding: 3px 0; }
}


/* ============ Complete Page ============ */
.complete-page .footerWrap { margin-bottom: 0px; padding-bottom: 0px; }
