/* ── 게시판 뷰 액션바: URL 복사 버튼 (pnv-icon-btn 36px 높이 통일) ── */
.pnv-action-btns .pnv-copy-btn{
    display:inline-flex; align-items:center; gap:5px;
    height:36px; padding:0 12px; border-radius:6px;
    border:1px solid #F2F2F2; background:#F2F2F2; color:#555;
    font-size:13px; font-weight:600; line-height:1; cursor:pointer;
    text-decoration:none; white-space:nowrap; box-sizing:border-box;
    transition:background .15s, border-color .15s;
}
.pnv-action-btns .pnv-copy-btn i{ font-size:13px; color:#8D8D8D; }
.pnv-action-btns .pnv-copy-btn:hover{ background:#fff; border-color:#8D8D8D; }
.pnv-action-btns .pnv-copy-btn:hover i{ color:#555; }
@media (max-width:480px){
    .pnv-action-btns .pnv-copy-btn{ padding:0 10px; font-size:12px; }
}

.board_top {position:relative;background-size: cover !important ; text-align: center; padding:100px 20px 300px}
.board_top * {color:#fff;}
.interior_washing {background: url('../img/board/interior_washing_top.png') no-repeat center center;}
.bidding_top {background: url('../img/board/bidding_top.png') no-repeat center center;}
.interior_application {background: url('../img/board/application_top.png') no-repeat center center;}

.board_top h4 {font-size: 13px; font-weight: 300; line-height: normal; padding-bottom:10px}
.board_top h3 {font-size: 30px; font-weight: 600; line-height: normal; }
.board_top h5 {font-size: 22px; font-weight: 500; line-height: 150%;  padding:100px 0px 15px}
.board_top h5 b{font-weight: 700;}
.board_top p {font-size: 15px; font-weight: 300; line-height: 150%; }

.interior_washing .ul_img {position: absolute; bottom: -200px; left: 50%; transform: translateX(-50%); width: 100%; max-width: 1400px; margin: 0 auto;}
.interior_washing .ul_img ul {display: flex;  gap: 20px;}
.interior_washing .ul_img ul li {width:33.3%}
.interior_washing .ul_img ul li img {width: 100%; height: auto;}

.interior_washing .ul_img .board_info {color: #555; text-align: center; font-size: 15px; font-weight: 300; padding-top: 10px;}


#page_title {display:flex; flex-direction: column; align-items: center;  justify-content: center; height:210px; background:#808080; background-size: cover !important;}
#page_title p {color: #FFF; font-size:13px; font-weight:300; text-align: center; padding-bottom:10px}
#page_title h3 {color: #FFF; font-size:30px; font-weight:600; text-align: center;}


#page_title.info_title {background:transparent}
#page_title.info_title p {color: #03240F}
#page_title.info_title h3 {color: #03240F}

#content {padding:40px; background:#fff; border-radius:10px; position: relative; top: -40px;}
#content iframe {border:0px; width:100%; height:80vh}


#privacy {font-size:15px; line-height: 150%; color:#222; font-weight:400; padding:20px 0px 100px;}
#privacy b {font-weight:600}


.tab_menu {display: flex; gap:10px; padding-bottom:20px; border-bottom: 1px solid #Ccc;}
.tab_menu li a {border-radius: 10px; border: 1px solid #CECECE; color:#03240F; font-size: 14px; font-weight: 500; padding: 10px; text-align: center; width: 210px; display: block; transition: all 0.5s;}
.tab_menu li a.on {color: #fff; background: #03240F; border: 1px solid #03240F;}
.tab_menu li a:hover {color: #fff; background: #03240F; border: 1px solid #03240F; }

@media (max-width: 1440px) {
    #privacy {padding:20px 20px 100px}
    .tab_menu {padding:0px 20px 20px}
     .tab_menu li a {width: 180px;}
}

@media (max-width:724px) {
    .tab_menu li a {font-size: 12px; font-weight: 500; padding: 10px 40px;  width:auto}
    #content {padding:40px 20px;}
}


.btn_write  {
    color: #333; 
font-size: 13px;
font-weight: 600;
display: flex;
    align-items: center;
    gap:10px;
    background: #fff;
    border: 1px solid #F28629;
    border-radius: 50px;
    padding:3px 10px 3px 5px
}
.btn_write span {display: flex;
width: 15px;
height: 15px;
padding: 10px;
flex-direction: column;
justify-content: center;
align-items: center;
gap: 10px;border-radius: 50px;
background: #F28629;
color: #fff;
text-align: center;
font-family: "Spoqa Han Sans Neo";
font-size: 10px;
font-weight: 400;
}
#quick{
  position: fixed;
  border-radius:10px;
  padding:15px 10px;
  text-align:center;
  z-index:90;
  filter: drop-shadow(0 4px 30px rgba(0, 0, 0, 0.05));
  background:#fff;

  right: 24px;   /* ✅ -55px 말고 보이게 */
  bottom: 30px;  /* ✅ bottom 기준 유지 */
}
#quick ul li:nth-child(2){padding:10px 0}
#quick ul li:nth-child(3){padding-bottom:10px}
#quick button{border:0; text-align:center;}

#quick.is-stop{
  position: absolute;
}

#top_btn:hover {}
.text-left {text-align: left !important;     align-items: flex-start !important; padding:0px 20px}
/* padding, margin */
.pt_10 {padding-top:10px}
.pt_20 {padding-top:20px}  
.pt_30 {padding-top:30px}    
.pt_40 {padding-top:40px}      
.pt_50 {padding-top:50px}
.pt_100 {padding-top:100px}
.pt_150 {padding-top:150px}
.pt_200 {padding-top:200px}
/* 글쓰기 */
.bo_w_wrap {border-radius: 10px; background: #FFF; box-shadow: 0 4px 30px 0 rgba(0, 0, 0, 0.05); padding:80px 15% ;}
.board_tit {color: #222; text-align: center; font-size: 22px; font-weight: 700;line-height: 170%; /* 37.4px */ padding-bottom: 100px;}
.write_div.write_div_two {display: flex;    justify-content: space-between}
.bo_w_sub_tit {color: #03240F;  font-family: "Spoqa Han Sans Neo";  font-size: 13px;  font-weight: 400;   line-height: 170%;}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   개비공 안내 페이지
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.iv-page { width: 100%; }
.iv-inner { max-width: 1400px; margin: 0 auto; padding: 0 20px; }

/* ── 1. Hero ── */
.iv-hero {
    background: url('../img/info/info_bg_01.png') no-repeat center ;
    background-size: 100% auto;
    text-align: center;
    padding: 60px 20px 0;
}
.iv-hero h2 {
    color: #222;
    font-size: 40px;
    font-weight: 700;
    line-height: 150%;
}
.iv-hero > .iv-inner > p {
    color: #000;
    font-size: 18px;
    font-weight: 400;
    line-height: 150%;
    padding-top: 20px;
}
.iv-hero-img {
    max-width: 780px;
    margin: 50px auto 150px;
}
.iv-hero-img img { width: 100%; height: auto; }

/* ── 2. 이런 원장님들을 위해 ── */
.iv-doctors {
    padding: 150px 20px;
    background-size: cover !important;
}
.iv-doctors h2 {
    color: #FFF;
    text-align: center;
    font-size: 25px;
    font-weight: 600;
    line-height: 150%;
    padding-bottom: 40px;
}
.iv-doctors-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 1400px;
    margin: 0 auto;
}
.iv-doctors-card {
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.18);
    padding: 40px 20px;
    text-align: center;
}
.iv-doctors-card h4 {
    color: #FFF;
    font-size: 20px;
    font-weight: 700;
    line-height: 150%;
    padding-bottom: 12px;
}
.iv-doctors-card p {
    color: #FFF;
    font-size: 16px;
    font-weight: 400;
    line-height: 150%;
}

/* ── 3. 취약한 지점 해결 ── */
.iv-solve {
    padding: 150px 20px;
    background: #F8F8F8;
}
.iv-solve > .iv-inner > h2 {
    color: #222;
    text-align: center;
    font-size: 30px;
    font-weight: 600;
    line-height: 150%;
    padding-bottom: 50px;
}
.iv-solve-wrap {
    display: flex;
    align-items: stretch;
    gap: 0;
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
}
.iv-solve-box {
    flex: 1;
    border-radius: 10px;
    padding: 50px 35px;
}
.iv-solve-box.left {
    background: #FFF;
}
.iv-solve-box.right {
    border: 2px solid #03240F;
    background: #03240F;
    color: #fff;
}
.iv-solve-box .iv-solve-icon {
    width: 80px;
    height: 80px;
    margin: 0px auto 20px;
    
    
}
.iv-solve-box .iv-solve-icon img { width: 100%; height: auto; }
.iv-solve-box h3 {
    color: #444;
    font-size: 26px;
    font-weight: 700;
    line-height: 150%;
    padding-bottom: 30px;
    text-align: center;
}
.iv-solve-box.right h3 { color: #fff;  
    text-align: center;}
.iv-solve-box ul {
    list-style: none;
    padding: 0;
}
.iv-solve-box ul li {
    text-align: center;
    font-size: 16px;
    font-weight: 400;
    line-height: 170%;
    padding: 3px 0;
}
.iv-solve-box ul li::before {
    content: '· ';
    font-weight: 700;
}
.iv-solve-box.right ul li::before {
    content: none;
}
.iv-solve-box.left ul li { color: #555; }
.iv-solve-box.right ul li { color: rgba(255,255,255,0.85); }

.iv-solve-arrow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0 24px;
    flex-shrink: 0;
}
.iv-solve-arrow-circle {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    font-size:18px;
}
.iv-solve-arrow-circle svg { width: 24px; height: 24px; }

/* ── 4. 핵심 서비스 아코디언 ── */
.iv-services {
    padding: 100px 20px;
}
.iv-services > .iv-inner > h2 {
    color: #222;
    text-align: center;
    font-size: 30px;
    font-weight: 600;
    line-height: 150%;
    padding-bottom: 50px;
}
.iv-accordion {
    max-width: 1400px;
    margin: 0 auto;
}
.iv-acc-item {
    border-top: 1px solid #CACACA;
}
.iv-acc-item:last-child {
    border-bottom: 1px solid #CACACA;
}
.iv-acc-header {
    display: grid;
    padding: 24px 10px;
    cursor: pointer;
    gap: 20px;
	align-items:center;
	    grid-template-columns: 60px 1fr 1fr 30px;
}
.iv-acc-num {
    color: #555;
    font-size: 34px;
    font-weight: 200;
    line-height: 150%;
    flex-shrink: 0;
    width: 60px;
}
.iv-acc-title {
    color: #222;
    font-size: 28px;
    font-weight: 700;
    line-height: 150%;
    flex: 1;
}
.iv-acc-thumb {
    width: 120px;
    height: 70px;
    border-radius: 8px;
    overflow: hidden;
    flex-shrink: 0;
    opacity: 1;
    
}

.iv-flex {display:flex; margin-left:50px;     flex-direction: column;
    justify-content: space-between;}

.iv-acc-thumb_img01 {background: url('../img/info/info_img_02.png') no-repeat; background-size:cover; width: 100%;}
.iv-acc-thumb_img02 {background: url('../img/info/info_img_03.png') no-repeat; background-size:cover; width: 100%;}
.iv-acc-thumb_img03 {background: url('../img/info/info_img_04.png') no-repeat; background-size:cover; width: 100%;}
.iv-acc-thumb_img04 {background: url('../img/info/info_img_05.png') no-repeat; background-size:cover; width: 100%;}
.iv-acc-thumb_img05 {background: url('../img/info/info_img_06.png') no-repeat; background-size:cover; width: 100%;}

.iv-acc-item.active .iv-acc-header {align-items: stretch;}

.iv-acc-thumb img { opacity: 0;}
.iv-acc-item.active .iv-acc-thumb { height:100%}
.iv-acc-item.active .iv-acc-thumb img {display:block;}
.iv-acc-item.active .iv-acc-thumb {display:block;    overflow: hidden; height:100%}
.iv-acc-item.active .iv-acc-thumb  img {opacity: 1; width: 100%; height: 100%; object-fit: cover; }
.iv-acc-thumb img { width: 50%; object-fit: cover; }
.iv-acc-toggle {
    flex-shrink: 0;
    display: flex;
    justify-content: center;
    width: 24px;
}
.iv-acc-toggle .icon-plus { display: block; }
.iv-acc-toggle .icon-minus { display: none; }
.iv-acc-item.active .iv-acc-toggle .icon-plus { display: none; }
.iv-acc-item.active .iv-acc-toggle .icon-minus { display: block; }

.iv-acc-body {
    max-height: 0;
    overflow: hidden;
/*   transition: max-height 0.45s ease, opacity 0.35s ease; */
    opacity: 0;
}
.iv-acc-item.active .iv-acc-body {
    max-height: 600px;
    opacity: 1;
}
.iv-acc-body-inner {
    display: flex;
    gap: 40px;
    padding-top: 50px;
}
.iv-acc-text {
    flex: 1;
    align-self: flex-end;
}
.iv-acc-text h4 {
    color: #222;
    font-size: 20px;
    font-weight: 600;
    line-height: 150%;
    padding-bottom: 12px;
}
.iv-acc-text p {
    color: #222;
    font-size: 16px;
    font-weight: 400;
    line-height: 150%;
}
.iv-acc-img {
    flex-shrink: 0;
    width: 45%;
    border-radius: 12px;
    overflow: hidden;
}
.iv-acc-img img { width: 100%; height: 100%; object-fit: cover; }

/* ── 5. 무엇이 다를까 ── */
.iv-diff {
    padding: 100px 20px;
    background: url('../img/info/info_bg_03.png') no-repeat center center;
    background-size: cover;
}
.iv-diff-wrap {
    display: flex;
    gap: 60px;
   /* align-items: center; */
}
.iv-diff-left {
    flex-shrink: 0;
    width: 240px;
}
.iv-diff-left h2 {
    color: #FFF;
    font-size: 30px;
    font-weight: 600;
    line-height: 150%;
}
.iv-diff-grid {
    flex: 1;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 50px;
}
.iv-diff-card {
/*    background: rgba(255,255,255,0.1);
    border-radius: 12px;
    padding: 28px 24px;
    border: 1px solid rgba(255,255,255,0.12); */
}
.iv-diff-card .quote {
    color: #FFF;
    font-size: 24px;
    font-weight: 700;
    line-height: 150%;
    padding-bottom: 4px;
}
.iv-diff-card h4 {
    color: #FFF;
    font-size: 24px;
    font-weight: 600;
    line-height: 150%;
    padding-bottom: 8px;
    display: inline-block;
}
.iv-diff-card p {
    color: #FFF;
    font-size: 17px;
    font-weight: 400;
    line-height: 150%;
    opacity: 0.8;
}

/* ── 6. 실제 사례 ── */
.iv-cases {
    padding: 100px 20px;
    background: #F7F8F7;
}
.iv-cases-wrap {
    display: flex;
    gap: 40px;
    align-items: flex-start;
}
.iv-cases-left {
    flex-shrink: 0;
    width: 420px;
    padding-top: 20px;
}
.iv-cases-left h2 {
    color: #222;
    font-size: 30px;
    font-weight: 600;
    line-height: 140%;
    padding-bottom: 20px;
}
.iv-cases-left > p {
    color: #222;
    font-size: 16px;
    font-weight: 400;
    line-height: 150%;
    padding-bottom: 24px;
}
.iv-cases-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 15px;
    border-radius: 80px;
    background: #DDD;
    color: #03240F;
    font-size: 15px;
    font-weight: 400;
    line-height: 170%;
    text-decoration: none;
    transition: background 0.2s;
}
.iv-cases-link:hover { background: #ccc; }

.iv-cases-right {
    flex: 1;
    display: flex;
    gap: 20px;
	    flex-direction: column;
}
.iv-case-card {
    flex: 1;
    border-radius: 10px;
    box-shadow: 0 4px 30px 0 rgba(0,0,0,0.05);
    overflow: hidden;
    display: flex;
    align-items: flex-end;
}
.iv-case-card.light { background: #FFF; margin-right: 50px;}
.iv-case-card.dark  { background: #03240F; margin-left: 50px;}
.iv-case-card.dark * { color: #fff; }

.iv-case-main {
    flex: 1;
    padding: 30px 28px;
}
.iv-case-main h4 {
    color: #000;
    font-size: 24px;
    font-weight: 700;
    line-height: 150%;
    padding-bottom: 14px;
}
.iv-case-card.dark .iv-case-main h4 { color: #fff; }
.iv-case-main .iv-case-problem {
    color: #000;
    font-size: 17px;
    font-weight: 400;
    line-height: 150%;
    padding-bottom: 16px;
}
.iv-case-card.dark .iv-case-problem { color: rgba(255,255,255,0.85); }
.iv-case-main .iv-case-solution {
    list-style: none;
    padding: 0;
}
.iv-case-main .iv-case-solution li {
    color: #222;
    font-size: 17px;
    font-weight: 300;
    line-height: 150%;
    padding: 2px 0;
}
.iv-case-card.dark .iv-case-solution li { color: rgba(255,255,255,0.75); }

.iv-case-result {
    flex-shrink: 0;
    width: 222px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 20px 30px;
	margin-bottom:20px;
}
.iv-case-card.light .iv-case-result {
    border-radius: 10px 0px 0px 10px;
    background: rgba(3, 36, 15, 0.20);
}
.iv-case-card.dark .iv-case-result {
    border-radius: 10px 0 0  10px;
    background: rgba(255, 255, 255, 0.20);
}
.iv-case-result span {
    color: #03240F;
    font-size: 15px;
    font-weight: 400;
    line-height: 130%;
    display: block;
    padding-bottom: 6px;
}
.iv-case-card.dark .iv-case-result span { color: rgba(255,255,255,0.9); }
.iv-case-result strong {
    color: #03240F;
    font-size: 20px;
    font-weight: 600;
    line-height: 130%;
}
.iv-case-card.dark .iv-case-result strong { color: #fff; }

/* ── 반응형 ── */
@media (max-width: 1200px) {
    .iv-doctors-grid { grid-template-columns: repeat(2, 1fr); }
    .iv-diff-grid { grid-template-columns: repeat(2, 1fr); }
    .iv-cases-wrap { flex-direction: column; }
    .iv-cases-left { width: 100%; }
    .iv-cases-right { width: 100%; }
}
@media (max-width: 768px) {
    #quick ul li:not(:last-child) {display:none !important}
    .iv-hero  {padding:0px 0px 0;}
    .iv-hero h2 { font-size: 24px; }
    .iv-hero > .iv-inner > p { font-size: 15px; word-break: keep-all;}
    .iv-doctors {padding:50px 0px;}
    .iv-doctors h2 { font-size: 24px; word-break: keep-all; }
    .iv-doctors-card h4 {font-size: 18px; word-break: keep-all;}
    .iv-doctors-card p { font-size: 14px; word-break: keep-all;}
    .iv-doctors-card p br{display:none;}
    .iv-doctors-grid { grid-template-columns: 1fr; }
    .iv-doctors-grid .none {display: none;}
    .iv-solve {padding:50px 0px}
    .iv-solve > .iv-inner > h2 {font-size: 24px; word-break: keep-all;}
    .iv-solve-box .iv-solve-icon {width: 50px; height: 50px;}
    .iv-solve-box h3 {font-size: 20px;   padding-bottom: 20px;}
    .iv-solve-box.left ul li {font-size: 14px;}
    .iv-solve-box.right {padding:50px 20px}
    .iv-solve-box ul li {font-size: 14px;}
    .iv-solve-wrap { flex-direction: column; }
    .iv-solve-arrow { transform:translate(-50%, -50%) rotate(90deg); padding: 16px 0; }
    .iv-services {padding:50px 0px}
    .iv-services > .iv-inner > h2 {font-size: 24px; word-break: keep-all;}
    /* 아코디언 비활성화 - 모두 펼침 */
    .iv-acc-header { display: flex; flex-direction: column; gap: 0; cursor: default; padding: 24px 0; }
    .iv-acc-toggle { display: none !important; }
    .iv-acc-num { font-size: 16px; width: auto; margin-bottom: 10px; ext-align: left;        width: 100%; }
    .iv-acc-item .iv-acc-thumb {
        width: 100%;
        height: 100%;
        border-radius: 8px;
    }
    .iv-acc-item .iv-acc-thumb img { opacity: 1 !important; display: block !important; width: 100%; height: 100%; object-fit: cover; }
    .iv-flex { margin-left: 0px; margin-top: 14px; }
    .iv-acc-title { font-size: 18px; }
    .iv-acc-body { max-height: none !important; opacity: 1 !important; overflow: visible; }
    .iv-acc-body-inner { padding-top: 12px; }
    .iv-acc-text h4 { font-size: 16px; }
    .iv-acc-text p { font-size: 14px; }
    .iv-acc-body-inner { flex-direction: column; }
    .iv-acc-text { padding-left: 0; }
    .iv-acc-img { width: 100%; }
    .iv-diff-wrap { flex-direction: column; gap:30px}
    .iv-diff-left { width: 100%; text-align: center; }
    .iv-diff-grid { grid-template-columns: 1fr; }
    .iv-cases-right { flex-direction: column; }
    .iv-case-card { flex-direction: column; }
    .iv-case-result { width: 100%; border-radius: 0 0 10px 10px !important; padding: 16px; flex-direction: row; gap: 8px; margin-bottom: 0px;}
    .iv-diff {padding:50px 0px}
    .iv-diff-left h2 { font-size: 24px; word-break: keep-all; }
    .iv-diff-card h4 {font-size: 18px;}
    .iv-diff-card p {font-size: 16px;}
    .iv-diff-grid {gap: 25px;}
    .iv-cases {padding:50px 0px}
    .iv-cases-left h2 { font-size: 24px; word-break: keep-all; }
    .iv-case-main h4 { font-size: 18px; word-break: keep-all;}
    .iv-case-main .iv-case-problem { font-size: 14px;  word-break: keep-all;}
    .iv-case-main .iv-case-solution li { font-size: 14px; word-break: keep-all;}
    .iv-case-card.light {margin-right: 0px;}
    .iv-case-result span {padding-bottom: 0px}
    .iv-case-result strong { font-size: 16px; }
    .iv-case-card.dark {margin-left: 0px;}

    .iv-case-main .iv-case-solution li {
    padding-left: 0.5em;
    text-indent: -0.5em
    }
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   비딩 Step 4 공간구성 및 동선
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.bw-group-title {
    font-size: 14px;
    font-weight: 600;
    color: #1a3a2a;
    padding: 20px 0 10px;
    border-bottom: 1px solid #e0e0e0;
    margin-bottom: 4px;
    margin-top: 8px;
}

.bw-space-grid {
    display: flex;
    flex-direction: column;
}
.bw-space-grid .bwf {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 16px;
    padding: 11px 0;
}
.bw-space-grid .bwf > label {
    min-width: 170px;
    flex-shrink: 0;
    font-size: 13px;
    color: #555;
    padding-top: 7px;
    line-height: 1.4;
}
.bw-space-grid .bwf > label small {
    display: block;
    color: #999;
    font-size: 11px;
    font-weight: 400;
    margin-top: 2px;
}
.bw-space-grid .bwf > label br {
    display: none;
}

/* 제안서 선정 상태 뱃지 */
.status-badge.badge-rejected {
    background: #f5e6e6;
    color: #c62828;
}
.status-badge.badge-selected {
    background: #03240F;
    color: #fff;
}
.status-badge.badge-final {
    background: #e67e22;
    color: #fff;
}

/* 파일 업로드 도움말 */
.bwf-help {
    font-size: 12px;
    color: #999;
    margin-top: 4px;
    line-height: 1.5;
}

/* view 그룹 타이틀 */
.bv-group-title {
    font-size: 14px;
    font-weight: 600;
    color: #1a3a2a;
    padding: 20px 0 10px;
    border-bottom: 1px solid #e0e0e0;
    margin-bottom: 4px;
    margin-top: 8px;
}

/* 기타 파일 추가 버튼 */
.btn-add-extra-file {
    background: #f5f7f5;
    border: 1px dashed #aaa;
    border-radius: 6px;
    padding: 8px 20px;
    font-size: 13px;
    color: #555;
    cursor: pointer;
    transition: background .2s, border-color .2s;
}
.btn-add-extra-file:hover {
    background: #e8ede8;
    border-color: #888;
}

@media (max-width: 768px) {
    .bw-space-grid .bwf {
        flex-direction: column;
        gap: 4px;
    }
    .bw-space-grid .bwf > label {
        min-width: auto;
        padding-top: 0;
    }
}


.mobile_menu {display:none}

@media (max-width: 1024px) {
    .mobile_menu {display:block}
    .mobile_menu  i {font-size: 22px;   cursor: pointer;}
}


.top_banner  { background-size: cover;}
.banner_100 {background: url(../img/top_banner_100.png) no-repeat center center !important;}
.banner_101 {background: url(../img/top_banner_101.png) no-repeat center center !important;}
.banner_102 {background: url(../img/top_banner_102.png) no-repeat center center !important;}
.banner_103 {background: url(../img/top_banner_103.png) no-repeat center center !important;}
.banner_104 {background: url(../img/top_banner_104.png) no-repeat center center !important;}
.banner_105 {background: url(../img/top_banner_105.png) no-repeat center center !important;}
.solution_top_bg {background: url(../img/solution/system_top_bg.png) no-repeat center center !important;}

/* ── 개원 서포트 시스템 (솔루션 리스트) ── */
.sol-list {
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px 20px 60px;
}


.sol-list-row {
    display: flex;
    align-items: center;
    gap: 50px;
    padding: 14px 0 50px;
    
    margin: 0 auto;
}

.sol-list-row .sol-item-row {width:33.3%}


.sol-list-row .sol-img {
    position: relative;
    display: flex;
    width: 100%;
    height: auto;
    justify-content: center;
    align-items: center;
    border-radius: 16px;
    overflow: hidden;
}


.sol-item {
    display: flex;
    align-items: center;
    gap: 50px;
    padding: 36px 0;
    border-bottom: 1px dashed #CACACA;
}


.sol-item:last-child { border-bottom: none; }
.sol-img {
    position: relative;
    display: flex;
    width: 572px;
    height: 280px;
    justify-content: center;
    align-items: center;
    border-radius: 16px;
    overflow: hidden;
}
.sol-img::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 35%;
    background: linear-gradient(to bottom, rgba(3,36,15,0) 0%, rgba(3,36,15,0.65) 100%);
    pointer-events: none;
}
.sol-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.sol-img-title {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 20px;
    white-space: nowrap;
    color: #fff;
    z-index: 1;
   
    font-size: 30px;
    font-style: normal;
    font-weight: 600;
    line-height: 150%; /* 45px */
    letter-spacing: -0.6px;
}
.sol-links {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.sol-link {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 18px;
    color: #444;
    text-decoration: none;

font-weight: 500;
line-height: 150%; /* 27px */
letter-spacing: -0.36px;
}
.sol-link:hover .sol-dot{ background: #03240F; }
.sol-dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #ccc;
    flex-shrink: 0;
    transition: background 0.15s;
}
.sol-dot::after {
    content: '';
    display: block;
    width: 8px;
    height: 8px;
    border-top: 2.5px solid #fff;
    border-right: 2.5px solid #fff;
    transform: rotate(45deg);
    margin-left: -2px;
}
.sol-link.active .sol-dot { background: #03240F; }


@media (max-width: 1440px) {
.sol-list-row {
    display: flex;
    align-items: center;
    gap: 50px;
    padding: 14px 20px 50px;
    
    margin: 0 auto;
}
.sol-img-title {font-size:26px}
.sol-list-row .sol-item-row {width:33.3%}
}

/* 반응형 - 태블릿 */
@media (max-width: 1024px) {
    .sol-list { padding: 30px 16px 50px; }
    .sol-item { gap: 30px; }
    .sol-img { width: 420px; height: 220px; }
    .sol-img-title { font-size: 24px; }
    .sol-link { font-size: 16px; }
    .sol-list-row  {        flex-wrap: wrap;}
    .sol-list-row .sol-item-row {width:100%}
    .sol-link {width:100%}
}
/* 반응형 - 모바일 */
@media (max-width: 768px) {
    .sol-list { padding: 20px 0px 40px; }
    .sol-item {
        flex-direction: column;
        gap: 16px;
        padding: 24px 0;
    }
    .sol-img {
        width: 100%;
        height: 200px;
    }
    .sol-img-title { font-size: 22px; bottom: 14px; }
    .sol-links {
        width: 100%;
        padding-left: 4px;
        gap: 10px;
    }
    .sol-link { font-size: 15px; }
    .sol-dot { width: 24px; height: 24px; }
    .sol-dot::after { width: 6px; height: 6px; border-width: 2px; }
}


/* iframe 로딩 스피너 */
.iframe-loader-wrap { position:relative; width:100%; min-height:600px; }
.iframe-loader-wrap iframe { width:100%; height:100%; min-height:600px; border:none; opacity:0; transition:opacity 0.4s ease; position:relative; z-index:1; }
.iframe-loader-wrap.loaded iframe { opacity:1; }
.iframe-loader { position:absolute; top:0; left:0; width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; z-index:0; }
.iframe-loader-wrap.loaded .iframe-loader { display:none; }
.iframe-spinner { width:40px; height:40px; animation:ifrSpin 0.8s linear infinite; }
.iframe-loader-text { font-size:14px; color:#888; margin:0; }
@keyframes ifrSpin { to { transform:rotate(360deg); } }

/* 링크 복사 버튼 */
.bvi-lc-btn { display:inline-flex; align-items:center; gap:4px; margin- top:10px; padding:3px 10px; background:#f0f4f1; border:1px solid #d0d9d3; border-radius:6px; font-size:12px; color:#03240F; cursor:pointer; vertical-align:middle; transition:background 0.2s; }
.bvi-lc-btn:hover { background:#dce8df; }
.bvi-lc-btn svg { width:13px; height:13px; }
.bvi-lc-btn.copied { background:#03240F; color:#fff; border-color:#03240F; }

/* ===================================================================
   인덱스 페이지 공통 CSS
   =================================================================== */

/* ── 파트너 배너 ── */
.index_partner {
    width: 100vw; position: relative; left: 50%; transform: translateX(-50%);
    border-radius: 16px; overflow: hidden; max-width: 1400px; margin: 40px auto;
}
.idx-partner-inner { padding: 80px 40px; text-align: center; /*background: rgba(0,0,0,0.35); */}
.idx-partner-title { font-size: 32px; font-weight: 700; color: #fff; margin: 0 0 16px; line-height: 1.3; }
.idx-partner-desc { font-size: 15px; font-weight: 400; color: rgba(255,255,255,0.85); margin: 0 0 30px; line-height: 1.7; }
.idx-partner-btn {
    display: inline-block; padding: 14px 50px;
    background: rgba(255,255,255,0.9); color: #222;
    font-size: 15px; font-weight: 600; border-radius: 30px;
    text-decoration: none; transition: background 0.2s, color 0.2s;
}
.idx-partner-btn:hover { background: #fff; color: #03240F; text-decoration: none; }

/* ── 3열 최신글 ── */
.lndex_3_latest {
    display: flex; gap: 30px; max-width: 1400px;
    margin: 40px auto; padding: 0 20px;
}
.lndex_3_latest > div { flex: 1; min-width: 0; }
.idx3-latest { width: 100%; }
.idx3-header {
    display: flex; align-items: center; justify-content: space-between;
    padding-bottom: 16px; border-bottom: 2px solid #222;
}
.idx3-title { font-size: 20px; font-weight: 700; color: #222; margin: 0; }
.idx3-more {
    display: inline-flex; padding: 4px 14px;
    border: 1px solid #ccc; border-radius: 20px;
    font-size: 12px; font-weight: 500; color: #555;
    text-decoration: none; transition: all 0.15s;
}
.idx3-more:hover { border-color: #03240F; color: #03240F; text-decoration: none; }
.idx3-list { list-style: none; margin: 0; padding: 0; }
.idx3-item {
    display: flex; align-items: flex-start; gap: 14px;
    padding: 16px 0; border-bottom: 1px solid #eee;
}
.idx3-item:last-child { border-bottom: none; }
.idx3-num {
    flex-shrink: 0; width: 28px; height: 28px;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid #03240F; border-radius: 50%;
    font-size: 13px; font-weight: 600; color: #03240F;
}
.idx3-info { flex: 1; min-width: 0; }
.idx3-subject {
    display: block; font-size: 15px; font-weight: 500; color: #222;
    text-decoration: none; line-height: 1.4;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-bottom: 4px;
}
.idx3-subject:hover { color: #03240F; text-decoration: underline; }
.idx3-meta { font-size: 13px; color: #999; font-weight: 400; }
.idx3-sep { margin: 0 6px; color: #ddd; }
.idx3-empty { padding: 40px 0; text-align: center; color: #bbb; font-size: 14px; }

/* ── 사이드 강의 ── */
.idx-side-lecture { padding: 24px; }
.idx-lecture-tags { display: flex; gap: 8px; margin-bottom: 10px; flex-wrap: wrap; }
.idx-tag-outline {
    display: inline-block; padding: 4px 12px; border-radius: 6px;
   color: #222; font-size: 12px; font-weight: 600; background: #fff;
}
.idx-tag-solid {
    display: inline-block; padding: 4px 12px; border-radius: 6px;
    background: #e53935; color: #fff; font-size: 12px; font-weight: 600; border: none;
}
.idx-lecture-date { font-size: 16px; font-weight: 700; color: #fff; margin: 0 0 6px; }
.idx-lecture-title { font-size: 18px; font-weight: 700; color: #fff; margin: 0 0 16px; line-height: 1.4; }
.idx-lecture-more {
    display: inline-block; padding: 10px 24px;
    background: rgba(0,0,0,0.06); color: #555;
    font-size: 13px; font-weight: 500; border-radius: 8px;
    text-decoration: none; transition: background 0.15s;
}
.idx-lecture-more:hover { background: rgba(0,0,0,0.1); color: #fff; text-decoration: none; }

/* ── 인덱스 반응형 ── */
@media (max-width: 1420px) {
    .index_partner { margin: 40px 20px; max-width: calc(100% - 40px); }
    .lndex_3_latest { padding: 0 20px; }
}
@media (max-width: 1024px) {
    .lndex_3_latest { flex-direction: column; gap: 30px; }
}
@media (max-width: 768px) {
    .idx-partner-inner { padding: 50px 24px; }
    .idx-partner-title { font-size: 22px; }
    .idx-partner-desc { font-size: 13px; }
    .idx-partner-btn { padding: 12px 36px; font-size: 14px; }
    .idx3-title { font-size: 17px; }
    .idx3-subject { font-size: 14px; }
    .idx3-meta { font-size: 12px; }
    .idx3-num { width: 24px; height: 24px; font-size: 12px; }
    .idx-lecture-title { font-size: 16px; }
}
@media (max-width: 480px) {
    .idx-partner-inner { padding: 40px 16px; }
    .idx-partner-title { font-size: 18px; }
}

/* ===== 인덱스 파트너 배너 ===== */
.index_partner {
    width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 16px;
    overflow: hidden;
    max-width: 1400px;
    margin: 40px auto;
}
.idx-partner-inner {
    padding: 80px 40px;
    text-align: center;
    word-break: keep-all;
    /*background: rgba(0,0,0,0.35); */
}
.idx-partner-title {
    font-size: 30px;
    font-weight: 700;
    color: #fff;
    margin: 0 0 16px;
    line-height: 1.3;
}
.idx-partner-desc {
    font-size: 17px;
    font-weight: 400;
    color: rgba(255,255,255,0.85);
    margin: 0 0 30px;
    line-height: 1.7;
}
.idx-partner-btn {
    display: inline-block;
    padding: 10px 50px;
    background: rgba(255,255,255,0.9);
    color: #222;
    font-size: 15px;
    font-weight: 600;
    border-radius: 10px;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}
.idx-partner-btn:hover {
    background: #fff;
    color: #03240F;
    text-decoration: none;
}

/* 반응형 */
@media (max-width: 1420px) {
    .index_partner {padding:40px 20px; width: calc(100% - 40px);     left: calc(50% - 20px); max-width: 100% }
}
@media (max-width: 768px) {
    .idx-partner-inner { padding: 20px 20px; }
    .idx-partner-title { font-size: 22px; }
    .idx-partner-desc { font-size: 13px; }
    .idx-partner-btn { padding: 10px 20px; font-size: 14px; }
}
@media (max-width: 480px) {
    
    .idx-partner-title { font-size: 18px; }
}

.idx-footer {padding-bottom: 50px;}


/* 유튜브 + 사이드 레이아웃 */
.idx-yt-row { display:flex; gap:30px; margin:80px auto 40px; max-width:1400px; padding:0 20px; }
.idx-yt-main { flex:1; min-width:0; }
.idx-yt-side { width:340px; flex-shrink:0; display:flex; flex-direction:column; gap:20px; }

/* 사이드 - 자료실 */
.idx-side-archive {}
.idx-side-title { font-size:20px; font-weight:700; color:#222; margin:0 0 18px; }
.idx-side-link {
    display:flex; align-items:center; gap:14px;
    padding:14px 16px; margin-bottom:10px;
    border-radius: 10px;
    background: #D8E4DC;
    text-decoration:none; color:#222;
    transition:background 0.2s;
}
.idx-side-link:last-of-type { margin-bottom:0; }
.idx-side-link:hover { background:#e6ece8; }
.idx-side-icon { width:36px; height:36px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.idx-side-icon img { width:28px; height:28px; object-fit:contain; }
.idx-side-link-text { flex:1; font-size:17px; font-weight:600; }
.idx-side-arrow { color:#999; font-size:16px; }

/* 사이드 - 강의 배너 */
.idx-side-lecture {
    padding:24px;
    border-radius: 10px;
    background: linear-gradient(292deg, #C2E59C 3.11%, #64B3F4 92.02%);
    color:#fff;
    flex:1;
    display:flex;
    flex-direction:column;
    justify-content:center;
}
.idx-lecture-tags { display:flex; gap:8px; margin-bottom:12px; }
.idx-tag-outline {
    display:inline-block; padding:5px 10px;
    border-radius:20px; background:#fff; 
    font-size:13px; font-weight:500; color:#222;
}
.idx-tag-solid {
    display:inline-block; padding:5px 10px;
    background: rgba(3, 36, 15, 0.60);
    border-radius:20px;
    font-size:13px; font-weight:600; color:#fff;
}
.idx-lecture-date { font-size:17px; font-weight:600; margin:0 0 10px; }
.idx-lecture-title { font-size:24px; font-weight:700; line-height:1.4; padding:10px 0px; border-bottom: 1px solid #E0E0E0; border-top: 1px solid #E0E0E0; margin-bottom:20px}

.idx-lecture-link {display:flex; gap:10px}

.idx-lecture-more {
    display:inline-block; padding:10px 20px;
    background:#fff; border-radius:10px;
    color:#222; font-size:15px; font-weight:500;
    text-decoration:none; transition:background 0.2s;
    align-self:flex-start; letter-spacing: -0.3px;
}
.idx-lecture-more:hover { background:rgba(0,0,0,1); color:#fff; }

/* 반응형 */
@media (max-width:1024px) {
    .idx-yt-row { flex-direction:column; min-height:auto; gap:20px; }
    .idx-yt-side { width:100%; flex-direction:row; }
    .idx-side-archive, .idx-side-lecture { flex:1; min-width:0; }
}
@media (max-width:768px) {
    .idx-yt-side { flex-direction:column; }
    .idx-lecture-more { font-size:12px; letter-spacing:-0.5px; }
    .idx-lecture-title { font-size:18px; }
}

/* ===================================================================
   결제 내역 (payment_history)
   =================================================================== */

/* 결제 요청 (pending) */
.ph-pending { background:#fff5f0; border:1px solid #ffcc80; border-radius:12px; padding:20px 24px; margin-bottom:20px; }
.ph-pending-title { font-size:16px; font-weight:700; color:#e65100; margin:0 0 14px; }
.ph-pending-item { display:flex; justify-content:space-between; align-items:center; padding:14px 18px; background:#fff; border-radius:8px; margin-bottom:8px; border:1px solid #eee; }
.ph-pending-info { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.ph-pending-amount { font-weight:700; font-size:15px; }
.ph-pending-type { font-size:13px; color:#888; }
.ph-pending-memo { font-size:12px; color:#999; }
.ph-pay-btn { padding:8px 20px; background:#03240F; color:#fff; border:none; border-radius:8px; font-size:13px; font-weight:600; cursor:pointer; flex-shrink:0; }
.ph-pay-btn:hover { background:#0a4a1f; }

/* 메인 카드 */
.ph-card { background:#fff; border-radius:12px; box-shadow:0 2px 10px rgba(0,0,0,.06); padding:24px; margin-bottom:30px; }
.ph-toolbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; flex-wrap:wrap; gap:10px; }
.ph-count { color:#888; font-size:13px; margin:0; }
.ph-search { display:flex; gap:6px; }
.ph-search-input { padding:6px 12px; border:1px solid #ddd; border-radius:6px; font-size:13px; width:200px; }
.ph-search-btn { padding:6px 14px; background:#03240F; color:#fff; border:none; border-radius:6px; font-size:13px; cursor:pointer; }
.ph-search-btn:hover { background:#0a4a1f; }

/* 테이블 */
.ph-table { width:100%; border-collapse:collapse; font-size:14px; }
.ph-th { padding:12px 10px; text-align:left; background:#f8f8f8; border-bottom:2px solid #03240F; font-weight:600; font-size:13px; white-space:nowrap; }
.ph-th-amount { text-align:right; }
.ph-th-method, .ph-th-status, .ph-th-date { text-align:center; }
.ph-row { border-bottom:1px solid #eee; }
.ph-td { padding:12px 10px; vertical-align:middle; }
.ph-empty { text-align:center; padding:40px; color:#999; }

/* 뱃지 */
.ph-badge { padding:3px 10px; border-radius:20px; font-size:12px; font-weight:600; white-space:nowrap; }
.ph-badge-bidding { background:#000; color:#fff; border:1px solid #000; }
.ph-badge-washing { background:#fff; color:#000; border:1px solid #000; }

/* 회원 */
.ph-td-mbid { font-size:13px; font-weight:600; }
.ph-td-mbname { font-size:13px; }

/* 주문번호 */
.ph-td-order { font-size:12px; color:#888; }

/* 금액 */
.ph-td-amount { text-align:right; font-weight:700; }

/* 결제수단 / 상태 / 날짜 */
.ph-td-method { text-align:center; }
.ph-td-status { text-align:center; }
.ph-td-date { text-align:center; font-size:13px; color:#666; }

/* 상태 색상 */
.ph-status { font-weight:600; }
.ph-status-paid { color:#2e7d32; }
.ph-status-deferred { color:#e67e22; }
.ph-status-refunded { color:#e74c3c; }

/* 페이지네이션 */
.ph-pagination { margin-top:20px; text-align:center; }
.ph-page-link { display:inline-block; padding:6px 12px; margin:0 2px; border-radius:6px; font-size:13px; background:#f0f0f0; color:#555; text-decoration:none; }
.ph-page-link.active { background:#03240F; color:#fff; }
.ph-page-link:hover { background:#ddd; text-decoration:none; }
.ph-page-link.active:hover { background:#03240F; }


.new_win .win_desc {background: #000 !important;}
.new_win .win_desc:after {
    background: #D6DAD7;
}

.empty_li {text-align: center !important;}

/* ── 결제 내역 반응형 ── */
@media (max-width:768px) {
    .ph-card { padding:16px; }
    .ph-search-input { width:140px; }

    /* 결제 요청 */
    .ph-pending { padding:16px; }
    .ph-pending-item { flex-direction:column; gap:12px; align-items:stretch; }
    .ph-pay-btn { width:100%; text-align:center; }

    /* 테이블 → 카드형 */
    .ph-table thead { display:none; }
    .ph-table, .ph-table tbody, .ph-table tr, .ph-table td { display:block; width:100%; }
    .ph-row { padding:16px 0; border-bottom:1px solid #eee; display:flex; flex-wrap:wrap; gap:4px 0; }
    .ph-td { padding:4px 0; border:none; }
    .ph-td::before { content:attr(data-label); display:inline-block; font-size:12px; color:#999; font-weight:400; min-width:70px; margin-right:8px; }

    /* 구분 뱃지: 전체 폭 */
    .ph-td[data-label="구분"] { width:100%; margin-bottom:6px; }
    .ph-td[data-label="구분"]::before { display:none; }

    /* 회원: 아이디+이름 한 줄 */
    .ph-td-mbid { width:auto; }
    .ph-td-mbid::before { content:'회원'; }
    .ph-td-mbname { width:auto; display:inline; margin-left:-4px; color:#888; }
    .ph-td-mbname::before { content:'('; min-width:auto; margin-right:0; font-size:13px; color:#888; }
    .ph-td-mbname::after { content:')'; }

    /* 금액+상태+결제수단: 한 줄에 나란히 */
    .ph-td-amount { width:auto; text-align:left; flex:1; }
    .ph-td-method { width:auto; text-align:left; flex:1; }
    .ph-td-status { width:auto; text-align:left; flex:1; }

    /* 주문번호+날짜: 한 줄 */
    .ph-td-order { width:50%; font-size:11px; }
    .ph-td-date { width:50%; text-align:left; font-size:11px; }

    /* 페이지네이션 */
    .ph-page-link { padding:5px 10px; font-size:12px; }
}


.parent {
  	width: calc(100% - 40px);
  	height: 50px;
  	position: relative;
  	box-shadow: 0px 6px 20px rgba(3, 36, 15, 0.07);
  	border-radius: 10px;
  	background-color: #fff;
  	display: flex;
    align-items: center;
    justify-content: space-between;  	
  	gap: 10px;
  	padding:10px 20px;
  	font-size: 16px;
  	color: #03240f;
    margin:20px 0px 20px 20px;
}
.parent .div {
  	position: relative;
  	letter-spacing: -0.02em;
  	line-height: 150%;
  	grid-column: 1;
  	grid-row: 1 / span 5;
  	height: 27px;
}
.parent .span {
  	font-weight: 500;
}
.parent .arrow-drop-down {
  	position: relative;
}
.vector-icon {
  	max-width: 100%;
  	overflow: hidden;
  	max-height: 100%;
}

#btnCalendarPopup .arrow-drop-down {
    transform: rotate(265deg);
}


.rm-select-bar{position:sticky;top:60px;z-index:100;display:flex;gap:0;background:#fff;border-bottom:1px solid #e0e0e0;padding:0}
.rm-select-wrap{flex:1;position:relative}
.rm-select-wrap+.rm-select-wrap{border-left:1px solid #e0e0e0}
.rm-select{width:100%;padding:14px 20px 14px 10px;border:none;background:#f8f8f8;font-size:14px;font-weight:600;color:#333;appearance:none;-webkit-appearance:none;cursor:pointer;outline:none}
.rm-select:disabled{color:#bbb;cursor:default}
.rm-select-wrap::after{content:'';position:absolute;right:10px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #666;pointer-events:none}
#btnCalendarPopup{cursor:pointer}
.cal-popup-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.45);z-index:99999;align-items:center;justify-content:center;padding:20px}
.cal-popup-overlay.active{display:flex}
.cal-popup{background:#fff;border-radius:12px;width:100%;max-width:380px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 30px rgba(0,0,0,.2);animation:calPopIn .25s ease}
@keyframes calPopIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.cal-popup-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid #eee}
.cal-popup-title{font-size:16px;font-weight:700;color:#333}
.cal-popup-close{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;line-height:1}
.cal-popup-close:hover{color:#333}
.cal-popup-body{padding:14px 18px 18px}
.cal-popup-body .aside-calendar-wrap{border:none;padding:0;margin-bottom:0}

/* ============ 메인 슬라이드 팝업 레이어 ============ */
#hd_pop h2{position:absolute}
.ive-pop-overlay{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);padding:20px;animation:ivePopFade .25s ease}
@keyframes ivePopFade{from{opacity:0}to{opacity:1}}
.ive-pop-modal{position:relative;width:100%;max-width:1000px;background:#fff;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.3);overflow:hidden;animation:ivePopUp .3s ease}
@keyframes ivePopUp{from{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

/* 슬라이드 뷰포트 / 트랙 */
.ive-pop-viewport{position:relative;overflow:hidden}
.ive-pop-track{display:flex;transition:transform .4s cubic-bezier(.4,0,.2,1);will-change:transform;cursor:grab}
.ive-pop-track:active{cursor:grabbing}
.ive-pop-slide{flex:0 0 100%;width:100%;min-width:100%}
.ive-pop-content{width:100%}
.ive-pop-content img{max-width:100%;height:auto;display:block;margin:0 auto}

/* 좌우 화살표 */
.ive-pop-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border:none;border-radius:50%;background:rgba(255,255,255,.85);color:#333;font-size:18px;line-height:1;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.15);transition:background .15s,transform .15s}
.ive-pop-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.06)}
.ive-pop-prev{left:14px}
.ive-pop-next{right:14px}

/* 슬라이드 점(dots) - 이미지 위에 겹침 */
.ive-pop-dots{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);z-index:5;display:flex;align-items:center;justify-content:center;gap:8px}
.ive-pop-dot{width:9px;height:9px;padding:0;border:none;border-radius:50%;background:rgba(0,0,0,.2);cursor:pointer;transition:background .2s,width .2s}
.ive-pop-dot.active{width:22px;border-radius:5px;background:#03240F}

/* 푸터 */
.ive-pop-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-top:1px solid #eee}
.ive-pop-footer button{background:none;border:none;cursor:pointer;font-size:15px;color:#666;padding:6px 4px}
.ive-pop-footer .ive-pop-close{font-weight:700;color:#222}
.ive-pop-footer button:hover{color:#000}

/* ===== 메인 개원 고민 섹션 ===== */
.idx-concern{max-width:1200px;margin:120px auto;padding:0 20px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.idx-concern-list{display:flex;flex-direction:column;gap:14px;}
.idx-concern-item{display:flex;align-items:center;gap:14px;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(90deg,#C2E59C,#64B3F4) border-box;border:2px solid transparent;border-radius:15px;padding:18px 22px;font-size:20px;font-weight:700;color:#333;box-shadow:0 6px 18px rgba(0,0,0,.04);transition:transform .2s, box-shadow .2s;}
.idx-concern-item:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.07);}
.idx-concern-check{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:#E8E8E8 ;color:#03240F;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;line-height:1;}
.idx-concern-text{padding-left:10px;}
.idx-concern-tag{margin:0 0 14px;font-size:17px;font-weight:700;letter-spacing:.02em;background:linear-gradient(0deg,#C2E59C,#64B3F4);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#64B3F4;display:inline-block;}
.idx-concern-title{margin:0 0 18px;font-size:45px;line-height:1.35;font-weight:600;color:#03240F;letter-spacing:-.02em;}
.idx-concern-desc{margin:0;font-size:18px;line-height:1.8;color:#222222;}
@media (max-width:1024px){
    .idx-concern{grid-template-columns:1fr;gap:32px;margin:40px auto;}
    .idx-concern-text{order:-1;padding-left:0;}
    .idx-concern-title{font-size:26px;}
}
@media (max-width:768px){
    .idx-concern{margin:28px auto;padding:0 16px;}
    .idx-concern-item{font-size:14px;padding:15px 16px;gap:10px;}
    .idx-concern-check{width:22px;height:22px;font-size:12px;}
    .idx-concern-title{font-size:22px;}
    .idx-concern-desc{font-size:14px;}
    .ib-item {flex-wrap: wrap;      height:auto !important;}
    .index_banner {  height:auto !important; padding:20px 10px !important;         font-size: 12px !important; }
    .index_banner img {display:block; margin-bottom:10px}
    .index_banner b {display:inline-block;}
}

/* 모바일 대응 */
@media (max-width:768px){
    .ive-pop-overlay{padding:12px}
    .ive-pop-modal{border-radius:14px}
    .ive-pop-arrow{width:34px;height:34px;font-size:15px}
    .ive-pop-prev{left:8px}
    .ive-pop-next{right:8px}
    .ive-pop-footer{padding:12px 16px}
    .ive-pop-footer button{font-size:14px}
}

/* ====================================================
   메인 랜딩 (How it works / 비딩 / 워싱)
   ==================================================== */
.lp-band{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);overflow-x:hidden;background: linear-gradient(180deg, rgba(216, 228, 220, 0.60) 0%, rgba(216, 228, 220, 0.00) 70%);}
.hiw, .midcta, .bidsec, .wshsec{background:transparent;}
.hiw-inner {max-width:1600px; margin:0 auto;padding:0 20px;}
.bidsec-inner, .wshsec-inner{max-width:1200px;margin:0 auto;padding:0 20px;}

/* 공통 라벨/타이틀/버튼 */
.lp-tag{margin:0 0 14px;font-size:17px;font-weight:600;letter-spacing:.04em;background:linear-gradient(#C2E59C,#64B3F4);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#64B3F4;display:inline-block;}
.lp-tit{margin:0 0 18px;font-size:45px;line-height:1.4;font-weight:600;color:#222;letter-spacing:-.02em;}
.lp-desc{margin:0 0 26px;font-size:18px;line-height:1.8;color:#222;}
.lp-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 26px;border-radius:999px;font-size:18px;font-weight:500;color:#fff;text-decoration:none;background:linear-gradient(90deg,#7ec98f,#64B3F4);box-shadow:0 8px 20px rgba(100,179,244,.3);transition:transform .2s,box-shadow .2s;}
.lp-btn b {font-weight:700}
.lp-btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(100,179,244,.4);color:#fff;}

/* ── How it works ── */
.hiw{padding:90px 0 70px;text-align:center;}
/* .hiw-tag → .lp-tag 로 통합 */
.hiw-title{margin:0 0 70px;font-size:45px;line-height:1.4;font-weight:600;color:#222;letter-spacing:-.02em;}
.hiw-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;position:relative;}
.hiw-steps::before{content:"";position:absolute;top:105px;left:10%;right:10%;height:1px;background:#cfe0d6;z-index:0;}
.hiw-step{position:relative;z-index:1;}
.hiw-ico{width:210px;height:210px;margin:0 auto 22px;border-radius:50%;box-shadow:0 10px 24px rgba(31,84,58,.08);display:flex;align-items:center;justify-content:center;color:#2f9e6a;}
.hiw-ico img {width:100%;}
.hiw-step h4{margin:0 0 10px;font-size:20px;font-weight:700;color:#03240F;}
.hiw-step p{margin:0;font-size:18px;line-height:1.65;color:#222222;}

/* ── 중간 CTA 배너 ── */
.midcta{background:transparent;text-align:center;padding:30px 20px 60px;}
.midcta-pill{display:inline-block;max-width:1200px;width:100%;background:#03240F;color:#fff;border-radius:999px;padding:10px 20px;font-size:26px;font-weight:600;letter-spacing:-.01em;box-shadow:0 14px 30px rgba(3,36,15,.18);}
.midcta-sub{margin:22px 0 0;font-size:18px;color:#222;line-height:1.7;}

/* ── 비딩 / 워싱 공통 2단 ── */
.bidsec{padding:250px 0px 100px;}
.wshsec{padding:100px 0px 250px;}
.bidsec-inner{display:grid;grid-template-columns:0.7fr 1fr;gap:200px;align-items:center;position:relative;}
.wshsec-inner{display:grid;grid-template-columns:1fr 0.7fr;gap:70px;align-items:center;position:relative;}
/* 카드 뒤 장식 원 (카드 중앙 배치, 반응형) */
.bidsec-card, .wshsec-card{position:relative;}
.bidsec-card::before, .wshsec-card::before{
    content:"";position:absolute;z-index:-1;pointer-events:none;
    width:clamp(320px,48vw,686px);height:clamp(320px,48vw,686px);
    border-radius:50%;
    background:linear-gradient(180deg,#D8E4DC 0%,rgba(216,228,220,0) 70%);
    top:50%;left:50%;transform:translate(-50%,-50%);
}
.bidsec-inner .lp-text, .wshsec-inner .lp-text{position:relative;z-index:1;}

/* 흐름 리스트 (비딩 카드 / 워싱 항목 공통) */
.lp-flow{list-style:none;margin:0;padding:0;}
.lp-flow li{display:flex;gap:20px;padding:20px 0;}
.lp-flow li:first-child{border-top:0;padding-top:0;}
.lp-no{flex:0 0 auto;width:32px;height:32px;border-radius: 10px; background: linear-gradient(292deg, #C2E59C 3.11%, #64B3F4 92.02%), #E8E8E8;;color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;}
.lp-flow-txt b{display:block;font-size:18px;font-weight:700;color:#222;margin-bottom:4px;}
.lp-flow-txt p{margin:0;font-size:14px;line-height:1.6;color:#333; word-break: keep-all;}


.lp-flow-txt2 b{display:block;font-size:20px;font-weight:700;color:#222;margin-bottom:4px;}
.lp-flow-txt2  p{margin:0;font-size:18px;line-height:1.6;color:#333; word-break: keep-all;}

/* 비딩 카드 */
.bidsec-card{padding:36px 34px; border-radius: 15px;
background: linear-gradient(180deg, #FFF 80%, rgba(255, 255, 255, 0.00) 100%);
box-shadow: 0 -10px 30px 0 rgba(3, 36, 15, 0.03);}
.bidsec-card-title{margin:0 0 22px;font-size:22px;font-weight:700;color:#222;text-align:center;  padding-bottom:10px;  border-bottom:1px solid rgba(204, 204, 204, 1);}

/* 워싱 항목 리스트 */
.wshsec-list{list-style:none;margin:0 0 30px;padding:0;}
.wshsec-list li{display:flex;gap:14px;padding:16px 0;}
.wshsec-ico{flex:0 0 auto;width:34px;height:34px;border-radius:10px;background:#eef6f1;color:#2f9e6a;display:flex;align-items:center;justify-content:center;}
.wshsec-ico svg{width:20px;height:20px;}

/* 워싱 분석 카드 */
.wshsec-card{padding:30px 30px 34px; border-radius: 15px;
background: linear-gradient(180deg, #FFF 80%, rgba(255, 255, 255, 0.00) 100%);
box-shadow: 0 -10px 30px 0 rgba(3, 36, 15, 0.03);}
.wshsec-card-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:18px;border-bottom:1px solid rgba(204, 204, 204, 1);margin-bottom:8px;}
.wshsec-card-head b{font-size: 22px; font-weight:700; color:#222;}
.wshsec-card-head span{font-size:16px;    background: linear-gradient(#C2E59C, #64B3F4);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: #64B3F4;
    display: inline-block;
}
.wshsec-rows{list-style:none;margin:0 0 20px;padding:0;}
.wshsec-rows li{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid rgba(204, 204, 204, 1);font-size:16px;color:#03240F;}
.wshsec-rows li b{font-weight:700;color:#222; font-size:17px}
.wshsec-rows li.cut{color:#e8893f;}
.wshsec-rows li.cut span{text-decoration:line-through;color:#e8893f;}
.wshsec-rows li.cut b{text-decoration:line-through;color:#848484;}
.wshsec-final{text-align:center;padding:20px;}
.wshsec-final-label{margin:0 0 8px;font-size:18px;font-weight:700;color:#03240F;}
.wshsec-final-amt{display:inline-block;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(rgba(194, 229, 156, 1),rgba(100, 179, 244, 1)) border-box;border:2px solid transparent;border-radius:999px;padding:4px 100px;font-size:28px;font-weight:800;color:#222;}
.wshsec-final-amt span{font-size:15px;font-weight:700;}
.wshsec-save{margin:12px 0 0;font-size:12px;color:#555;}

/* ── 반응형 ── */
@media (max-width:1280px){
    .hiw-inner, .bidsec-inner, .wshsec-inner{padding:0 24px;}
    .hiw-steps{gap:14px;}
    .hiw-steps::before{left:8%;right:8%;}
    .hiw-ico{width:104px;height:104px;}
    .hiw-ico svg{width:44px;height:44px;}
    .hiw-step h4{font-size:16px;}
    .bidsec-inner{grid-template-columns:0.85fr 1fr;gap:70px;}
    .wshsec-inner{gap:50px;}
    .hiw-title{font-size:32px;}
    .lp-tit{font-size:30px;}
}
@media (max-width:1024px){
    .hiw{padding:60px 0 50px;}
    .hiw-inner{max-width:720px;}
    .hiw-title{margin-bottom:50px;font-size:28px;}
    .hiw-steps{grid-template-columns:repeat(3,1fr);gap:34px 16px;}
    .hiw-steps::before{display:none;}
    .hiw-ico{width:100px;height:100px;}
    .bidsec-inner, .wshsec-inner{grid-template-columns:1fr;gap:36px;}
    .wshsec .lp-text{order:-1;}
    .lp-tit, .midcta-pill{font-size:20px;}
}
@media (max-width:768px){
    .hiw-inner, .bidsec-inner, .wshsec-inner{padding:0 20px;}
    .hiw{padding:46px 0 36px;}
    .hiw-title{font-size:23px;margin-bottom:36px;}
    .hiw-steps{grid-template-columns:repeat(2,1fr);gap:26px 14px;}
    .hiw-ico{width:84px;height:84px;margin-bottom:14px;}
    .hiw-ico svg{width:38px;height:38px;}
    .hiw-step h4{font-size:15px;}
    .hiw-step p{font-size:13px;}
    .midcta{padding:20px 16px 44px;}
    .midcta-pill{font-size:15px;padding:18px 22px;}
    .bidsec{padding:20px 0 40px;}
    .wshsec{padding:40px 0 60px;}
    .bidsec-card, .wshsec-card{padding:26px 20px;}
    .lp-tit{font-size:21px;}
    .lp-desc{font-size:14px;}
    .midcta-sub{font-size:14px;}
    .lp-flow-txt b, .lp-flow-txt2 b{font-size:16px;}
    .lp-flow-txt p, .lp-flow-txt2 p{font-size:14px;}
    .bidsec-card-title{font-size:18px;}
    .wshsec-card-head b{font-size:17px;}
    .wshsec-rows li{font-size:14px;}
    .wshsec-rows li b{font-size:15px;}
    .wshsec-final-label{font-size:15px;}
    .wshsec-final-amt{font-size:20px; padding:5px 30px; width:80%; margin:0 auto}
    .bidsec-card::before, .wshsec-card::before{width:80vw;height:80vw;max-width:440px;max-height:440px;}
}
@media (max-width:480px){
    .hiw-steps{grid-template-columns:1fr;gap:22px;}
    .hiw-step{display:flex;align-items:center;gap:16px;text-align:left;}
    .hiw-ico{width:64px;height:64px;margin:0;flex:0 0 auto;}
    .hiw-step h4{margin-bottom:4px;}
    /*.hiw-step p br{display:none;}*/
}

/* ====================================================
   Real Reviews (메인 후기 캐러셀)
   ==================================================== */
.rr-section{
    width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
    background:#03240f;padding:150px 0 ;overflow:hidden;
}
.rr-inner{max-width:1400px;margin:0 auto;padding:0 20px;text-align:center;}
/* .rr-tag → .lp-tag 로 통합 */
.rr-title{margin:0 0 40px;font-size:45px;font-weight:700;color:#fff;letter-spacing:-.02em;}

/* 캐러셀 */
/* 풀폭 무한 캐러셀: 가운데 카드 밝게 + 양옆 카드 dim */
.rr-latest{
    position:relative;overflow:hidden;
    width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);
    --rr-cw:min(1400px, 100vw - 40px);          /* 가운데 콘텐츠 폭 */
    --rr-gut:calc((100vw - var(--rr-cw)) / 2);   /* 양옆 여백(peek 영역) */
}
.rr-track{
    display:flex;gap:24px;padding:6px 0 14px;
    will-change:transform;transition:transform .55s ease;
}
.rr-card{
    position:relative;
    flex:0 0 calc((var(--rr-cw) - 48px)/3);
    background:#fff;border-radius:18px;padding:26px 26px 22px;text-align:left;
    text-decoration:none;color:#222;box-shadow:0 14px 34px rgba(0,0,0,.22);
    display:flex;flex-direction:column;transition:transform .25s;
}
/* 가운데(밝은) 외의 카드 어둡게 처리 */
.rr-card::after{
    content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
    background:rgba(7,28,16,.62);opacity:0;transition:opacity .45s;
}
.rr-card.rr-dim::after{opacity:1;}
.rr-card:not(.rr-dim):hover{transform:translateY(-4px);}
.rr-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px; padding-bottom:18px; border-bottom: 1px solid #CCC;}
.rr-card-badge{display:inline-block;background:rgba(223, 242, 216, 1);color:#03240F;font-weight:600;font-size:17px;padding:5px 15px;border-radius:999px;white-space:nowrap;}
.rr-card-cat{font-size:17px;color:#555;font-weight:600;white-space:nowrap; }
.rr-card-rows{margin-bottom:10px;}
.rr-card-row{display:flex;align-items:center;justify-content:space-between;font-size:17px;color:#222;padding:10px 0px; font-weight: 400;}
.rr-card-row b{font-size:24px;font-weight:700;color:#03240F;}
.rr-card-arrow{display:flex;justify-content:center;color:#b9c4bd;margin:2px 0;}
.rr-card-arrow svg{width:22px;height:22px;}
.rr-card-save{
    display:flex;align-items:center;justify-content:space-between;
    background:linear-gradient(90deg,#C2E59C,#64B3F4);border-radius:12px;padding:14px 18px;margin-top:auto;
}
.rr-card-save span{font-size:18px;font-weight:700;color:#fff;}
.rr-card-save b{font-size:35px;font-weight:700;color:#fff;}
.rr-card-caption{margin:16px 0 0;font-size:15px;font-weight:600;color:#e8893f;text-align:center;}
.rr-empty{flex:1;text-align:center;color:#cfe0d6;padding:40px;}

/* 화살표 */
.rr-nav{
    position:absolute;top:50%;transform:translateY(-50%);z-index:5;
    width:44px;height:44px;border-radius:50%;border:0;cursor:pointer;
    background:#fff;color:#0d2a18;box-shadow:0 6px 18px rgba(0,0,0,.25);
    display:flex;align-items:center;justify-content:center;transition:opacity .2s;
}
.rr-nav svg{width:22px;height:22px;}
.rr-nav{z-index:6;}
.rr-prev{left:calc(var(--rr-gut) - 100px);}
.rr-next{right:calc(var(--rr-gut) - 100px);}
.rr-nav-off{opacity:0;pointer-events:none;}

/* 하단 알약 + 주석 */
.rr-bottom-pill{
    max-width:1200px;margin:48px auto 0;
    padding:10px 20px;color:#eaf3ee;font-size:18px;font-weight:500;
    border-radius: 50px;
    background: #021709;
    box-shadow: 0 4px 30px 0 rgba(3, 36, 15, 0.05);
}
.rr-note{margin:15px 0 0;font-size:15px;color:#fff;}
br.pc {display:none}
/* 반응형 */

@media (max-width:1650px){
.rr-prev{left:calc(var(--rr-gut) - 10px);}
.rr-next{right:calc(var(--rr-gut) - 10px);}

}

@media (max-width:1024px){
    .rr-latest{--rr-cw:calc(100vw - 40px);}
    .rr-section{padding:60px 0 70px;}
    .rr-title{font-size:30px;margin-bottom:36px;}
    .rr-card{flex:0 0 calc((var(--rr-cw) - 24px)/2);}   /* 2개 + 양옆 peek */
    .rr-latest::before, .rr-latest::after{width:48px;}
    .rr-prev{left:6px;}
    .rr-next{right:6px;}
}
@media (max-width:768px){
    .rr-latest{--rr-cw:calc(100vw - 32px);}
    .rr-section{padding:46px 0 54px;}
    .rr-inner{padding:0 16px;}
    .rr-title{font-size:23px;margin-bottom:28px;}
    .rr-track{gap:16px;}
    .rr-card{flex:0 0 calc(var(--rr-cw) - 56px);padding:22px 20px 18px;}  /* 1개 + 옆 peek */
    .rr-card-badge{font-size:14px;}
    .rr-card-cat{font-size:13px;}
    .rr-card-row{font-size:14px;}
    .rr-card-row b{font-size:18px;}
    .rr-card-save span{font-size:14px;}
    .rr-card-save b{font-size:20px;}
    .rr-card-caption{font-size:13px;}
    .rr-latest::before, .rr-latest::after{width:36px;}
    .rr-nav{width:38px;height:38px;}
    .rr-prev{left:4px;}
    .rr-next{right:4px;}
    .rr-bottom-pill{font-size:14px;padding:5px 10px;margin-top:20px;}
    .rr-note {font-size:12px}
     br.pc {display:block}
     br.none {display:none}
}

/* ====================================================
   개원 준비, 혼자 하지 마세요 (Partners 카드 캐러셀)
   ==================================================== */
.idxp{
    width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);
    background: linear-gradient(180deg, rgba(216, 228, 220, 0.50) 0%, rgba(216, 228, 220, 0.00) 70%);
    padding:150px 0 100px;overflow:hidden;
}
.idxp-inner{max-width:1280px;margin:0 auto;padding:0 20px;text-align:center;}
/* .idxp-tag → .lp-tag 로 통합 */
.idxp-title{margin:0 0 0px;font-size:45px;font-weight:600;color:#111;letter-spacing:-.02em;}
.idxp-desc{margin:0 0 44px;font-size:18px;line-height:1.7;color:#222;}

.idxp-carousel{position:relative;}
.idxp-viewport{overflow:hidden; height:660px}
.idxp-track{
    display:flex;gap:30px;align-items:flex-start;
    padding:6px 0 60px;
    will-change:transform;transition:transform .55s ease;
}
/* 현재 가운데 카드만 아래로 내려오는 스태거 (3개 노출 시) */
.idxp-card.idxp-mid{margin-top:50px;}
.idxp-card{
    flex:0 0 calc((100% - 60px)/3);
    overflow:hidden;text-align:left;
    text-decoration:none;color:#222;
    transition:transform .2s, box-shadow .2s, margin-top .45s ease;display:flex;flex-direction:column;

    border-radius: 20px;
    background: #FFF;
    box-shadow: 0 4px 30px 0 rgba(3, 36, 15, 0.08);
}
.idxp-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(31,84,58,.16);}
.idxp-card-img{position:relative;aspect-ratio:16/11;background:#eef2f0;overflow:hidden;}
.idxp-card-img img{width:100%;height:100%;object-fit:cover;display:block;}
.idxp-card-go{
    position:absolute;right:16px;bottom:16px;width:40px;height:40px;border-radius:50%;
    background: linear-gradient(292deg, #92CDA5 3.11%, #5FAFE8 92.02%), #03240F;;color:#fff;
    display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(100,179,244,.4);
}
.idxp-card-go svg{width:20px;height:20px;}
.idxp-card-body{padding:22px 24px 26px;}
.idxp-card-label{display:inline-block;margin-bottom:8px;font-size:17px;font-weight:600;background:linear-gradient(rgba(194, 229, 156, 1),rgba(100, 179, 244, 1));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#64B3F4;}
.idxp-card-title{margin:0 0 12px;font-size:26px;font-weight:700;color:#222;}
.idxp-card-text{margin:0;font-size:17px;line-height:1.7;color:#222;}

/* 화살표 */
.idxp-nav{
    position:absolute;top:50%;transform:translateY(-50%);z-index:5;
    width:44px;height:44px;border-radius:50%;border:0;cursor:pointer;
    background:#fff;color:#1c2b22;box-shadow:0 6px 18px rgba(0,0,0,.12);
    display:flex;align-items:center;justify-content:center;transition:opacity .2s;
}
.idxp-nav svg{width:22px;height:22px;}
.idxp-prev{left:-100px;}
.idxp-next{right:-100px;}
.idxp-nav-off{opacity:0;pointer-events:none;}


@media (max-width:1450px){
.idxp-prev{left:5px;}
.idxp-next{right:5px;}

}

@media (max-width:1024px){
    .idxp{padding:60px 0 70px;}
    .idxp-title{font-size:30px;}
    .idxp-card{flex-basis:calc((100% - 30px)/2);}
    .idxp-card:nth-child(2){margin-top:0;}   /* 3개 노출 아닐 땐 스태거 해제 */
    .idxp-track{padding-bottom:40px;}
    .idxp-viewport{height:auto}
}
@media (max-width:768px){
    .idxp{padding:46px 0 54px;}
    .idxp-inner{padding:0 16px;}
    .idxp-title{font-size:23px;}
    .idxp-desc{font-size:14px;margin-bottom:28px;}
    .idxp-track{gap:16px;padding-bottom:30px;}
    .idxp-card{flex-basis:calc(100% - 70px);}  /* 모바일: 1개 + 양옆 peek */
    .idxp-card:nth-child(2){margin-top:0;}
    .idxp-card-label{font-size:14px;}
    .idxp-card-title{font-size:20px;}
    .idxp-card-text{font-size:14px;}
    .idxp-card-body{padding:18px 20px 22px;}
    .idxp-nav{width:38px;height:38px;}
}