#leel-grid .plan-item[data-has="1"]{background:#fff}
#leel-grid .plan-item:not([data-has]){background:#d9d9d9;color:#111827}
#leel-grid .plan-item[data-has="1"]{background:#fff !important;color:inherit}
#leel-grid .plan-item:not([data-has]){
  background:#d9d9d9 !important;
  background-color:#d9d9d9 !important;
  background-image:none !important;
  box-shadow: inset 0 0 0 9999px #d9d9d9 !important; /* 강제 채움: 첨부 회색 */
  color:#111827;
  border-color:#d9d9d9
}
/* REMIAN: 기본은 항상 흰색 (이미지 있음) */
#remian-grid .plan-item{background:#fff !important;color:inherit;border-color:#cbd5e1;box-shadow:none !important}
/* REMIAN: 표시 이미지가 없는 코드 회색 처리 */
#remian-grid .plan-item[data-plan^="118"],
#remian-grid .plan-item[data-plan^="129"],
#remian-grid .plan-item[data-plan^="157"]{
  background:#d9d9d9 !important;
  background-image:none !important;
  box-shadow: inset 0 0 0 9999px #d9d9d9 !important;
  color:#111827;
  border-color:#d9d9d9
}
.plan-grid .plan-item.is-disabled{background:#f3f4f6 !important;color:#111827}
:root{--brand:#0f1b2d;--brand2:#1e2a44;--accent:#1f5eff;--paper:#ffffff;--muted:#6b7280;--bg:#0b1220}
*{box-sizing:border-box}
body{margin:0;font-family:'Pretendard',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;line-height:1.6;color:#0b1220;background:#fff}
.snap-section, main{position:relative}
html,body{height:100%}
body{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
.bg-full{position:relative}
.bg-layer{position:fixed;inset:0;background:none;z-index:-1;display:none} /* 메인 배경 흰색 유지 */
.container{max-width:1536px;margin:0 auto;padding:0 20px}
.container.narrow{max-width:1296px}
.site-header{background:#fff;border-bottom:2px solid #03c75a;padding:22px 0}
.site-header .brand{font-weight:700;color:var(--brand);text-decoration:none;display:inline-flex;align-items:center;gap:8px;font-size:1.5em}
.site-header .brand img{height:33px;display:block}
.site-header .nav{display:flex;gap:14px;float:right}
.site-header .nav a{color:#4a5568;text-decoration:none}
@media (max-width: 768px){
  .site-header .brand{font-size:1.2em}
}
.site-footer{border-top:1px solid #e5e8ef;margin-top:40px;padding:24px 0;color:#6b7280}
.tail-lines{font-size:14px;line-height:1.8;color:#374151;background:#f3f4f6;border-radius:12px;padding:16px}
.tail-lines strong{display:block;margin-top:8px;color:#374151}
.tail-lines a{color:#374151;text-decoration:underline}

.hero{display:none}
.alp-hero{position:relative;color:#fff;background:transparent;padding:calc(96px + 1cm) 0 calc(40px + 2cm);overflow:hidden}
.alp-hero:before{content:"";position:absolute;inset:0;background:rgba(15,27,45,.5)}
.alp-hero__inner{position:relative;z-index:1;max-width:1536px;margin:0 auto;padding:0 20px}
.alp-hero .eyebrow{letter-spacing:.06em;color:#cbd5e1;margin:0 0 6px}
.alp-hero .title{font-size:36px;line-height:1.3;margin:0}
/* 메인 히어로는 요청에 따라 20% 축소 및 박스화 */
.home-main .alp-hero{background:#fff;color:#0b1220;border:2px solid #111827;border-radius:12px;padding:16px;margin:16px auto;position:relative;max-width:1296px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.home-main .alp-hero:before{display:none}
.home-main .alp-hero .title{font-size:22px;font-weight:500;font-style:normal}
.home-main .alp-hero .hero-greet{font-size:inherit}
.alp-hero .title strong{color:#9cc5ff}
.alp-hero .title .text-blue{color:#9cc5ff}
/* 모바일/앱 브라우저에서도 히어로 내 파란색을 동일하게 고정 */
.alp-hero .title a.text-blue,
.alp-hero .title a.text-blue:visited{color:#9cc5ff}
.alp-hero .cta-row{margin-top:18px;display:flex;flex-direction:column;align-items:center;gap:12px}
.hero-phones{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px;justify-content:center}
.phone-chip{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.14);color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.35)}
.phone-chip:hover{background:rgba(255,255,255,.2)}
.alp-hero .stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:28px 0 0;padding:0;list-style:none}
.alp-hero .stats li{background:rgba(15,27,45,.55);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:14px;display:flex;gap:10px;align-items:center}
.alp-hero .stats b{font-size:28px}
.alp-hero .stats span{opacity:.9}
.btn{display:inline-block;background:var(--accent);color:#fff;padding:12px 16px;border-radius:10px;text-decoration:none;border:0;cursor:pointer}
.btn.primary{background:#2d5bff}
.btn.call{background:#03c75a;color:#fff}
.btn.call:hover{filter:brightness(0.98)}
.btn.kakao{background:#ffd83d;color:#111827}
.btn.kakao:hover{filter:brightness(0.98)}
.btn.naver{background:#2db400;color:#fff;display:block;width:100%;text-align:center;margin-top:8px}
.info-card .btn.kakao{display:block;width:100%;text-align:center}
.btn.ghost{background:transparent;color:#2d5bff;border:1px solid #bcd0ff}
.btn-secondary{background:#64748b}
.alert{padding:12px 14px;border-radius:8px;margin:12px 0}
.alert.success{background:#ecfdf5;color:#065f46}
.alert.error{background:#fef2f2;color:#991b1b}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.card{display:block;border:1px solid #e5e8ef;border-radius:10px;overflow:hidden;color:inherit;text-decoration:none;background:#fff}
.card img{width:100%;height:160px;object-fit:cover;background:#f4f6fa}
.card .card-body{padding:10px}
.card .price{color:#0ea5e9;font-weight:700}
.card .addr{color:#6b7280}

.filters{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0}
.filters input,.filters select{padding:8px;border:1px solid #e5e8ef;border-radius:8px}

.detail header{margin:10px 0}
.detail .meta{display:flex;flex-wrap:wrap;gap:10px;color:#6b7280}
.detail .gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;margin:10px 0}
.detail .gallery img{width:100%;height:200px;object-fit:cover;border-radius:6px}
.detail pre{white-space:pre-wrap;background:#f8fafc;padding:12px;border-radius:8px}

.contact-form,.admin-form{display:grid;gap:12px;max-width:1440px}
.contact-form input,.contact-form textarea,.admin-form input,.admin-form textarea,.admin-form select{padding:10px;border:1px solid #e5e8ef;border-radius:8px}
.row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}

/* Alpaca-like landing sections */
.alp-services{padding:28px 0}
.alp-services .eyebrow{color:#6b7280;margin-bottom:16px}
.alp-services .cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
@media (min-width: 1280px){
  .alp-services .cards{grid-template-columns:repeat(4,minmax(0,1fr))}
}
.alp-services .svc{display:block;border:1px solid #e5e8ef;border-radius:14px;padding:18px;text-decoration:none;color:inherit;background:#ffd83d;transition:transform .2s ease, box-shadow .2s ease}
.alp-services .svc:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.06)}
.alp-services .svc .kicker{display:inline-block;font-size:12px;letter-spacing:.08em;color:#6b7280;margin-bottom:6px}
.alp-services .svc h3{margin:6px 0}
.alp-services .svc p{color:#6b7280;margin:0}
/* '서비스 안내' 텍스트 숨김 */
.alp-services .eyebrow{display:none}

.plan-grid{display:none;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin:10px 0}
.plan-grid .plan-item{padding:10px;border:1px solid #cbd5e1;background:#fff;border-radius:8px;cursor:pointer;-webkit-appearance:none;appearance:none}
.plan-grid .plan-item[data-plan^="118"],
.plan-grid .plan-item[data-plan^="129"],
.plan-grid .plan-item[data-plan^="157"]{background:#f3f4f6}
.plan-detail{display:none}
.plan-detail-inner{display:none}

/* modal */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.5);z-index:50}
.modal .modal-card{background:#fff;border-radius:12px;max-width:420px;width:90%;padding:16px;box-shadow:0 10px 24px rgba(0,0,0,.2)}
.modal .modal-card h3{margin:0 0 8px;color:#111827}
.modal .modal-card p{margin:0 0 12px;color:#374151}
.modal .modal-card .actions{display:flex;justify-content:flex-end;gap:8px}
.modal .modal-card .btn{padding:8px 14px;border-radius:8px;background:#2d5bff;color:#fff}

.alp-newsletter{padding:48px 0}
.alp-newsletter .container{display:flex;align-items:center;justify-content:space-between}
.alp-newsletter .container h3{margin:0}
.alp-newsletter .btn{margin-left:16px}

/* info blocks & link chips */
.info-section{padding:40px 0}
.naver-banner + .container{margin-top:0}
.info-section.pad-extra{padding-top:calc(40px + 2cm);padding-bottom:calc(40px + 2cm)}
.info-section .lead{font-size:20px;line-height:1.6;margin:0 0 14px}
.naver-banner .banner-img{width:100%;height:auto;display:block;border-radius:12px}
.white-box{background:#ffffff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;color:#111827;line-height:1.6;display:flex;gap:8px;align-items:flex-start}
.white-box .ico{width:18px;height:18px;flex:0 0 18px;fill:#0ea5e9;margin-top:3px}
.emph-red{color:#dc2626;font-weight:600}
.text-blue{color:#2563eb}

/* Gwangjun list - make the more button match container width like white-box */
.gwangjun-list .more-wrap{margin:12px 0 24px}
.gwangjun-list .more-wrap .more-btn{display:block!important;width:100%!important;text-align:center;padding:12px 16px!important;border-radius:12px!important}

/* Luxury announcement section */
.announcement-section{padding:28px 0;margin-top:2cm}
.announcement-card{
  background:#f5f6f8;
  color:#111827;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:18px 18px;
  box-shadow:none;
  backdrop-filter:none
}
.announcement-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;justify-content:flex-start}
.announcement-head .ico{width:20px;height:20px;fill:#03c75a}
.announcement-head span{font-weight:700;letter-spacing:.02em;color:#111827}
.announcement-body{color:#374151}
.announcement-body ul{margin:6px 0 0 18px;padding:0}
.announcement-body li{margin:4px 0}
/* rows inside announcement body */
.announcement-body .item{margin:6px 0}

/* blinking effect for announcement title */
@keyframes blink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0.25; }
}
.announcement-head.blink{animation: blink 1s infinite}

/* link button inside announcement */
.announcement-body .btn-more{display:inline-block;margin-left:12px;padding:6px 10px;border-radius:8px;border:0;color:#ffe38a;text-decoration:none}
.announcement-body .btn-more:hover{background:rgba(212,175,55,.14)}
.announcement-body .btn-more.is-disabled{opacity:.55;pointer-events:none;cursor:default;text-decoration:none}
.info-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.info-card{border:1px solid #e5e8ef;border-radius:14px;background:rgba(243,244,246,.5);padding:16px}
.info-card h4{margin:0 0 8px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.chip{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;border:1px solid #bcd0ff;background:rgba(255,255,255,.92);color:#1f5eff;text-decoration:underline}
.chip.kakao{background:#ffd83d;color:#111827;border-color:#e9c633}
.chip.tel{background:#03c75a;color:#fff;border-color:#03c75a;text-decoration:none}
/* stretch phone chips to full width and use blue like primary */
.info-card .chip.tel{background:#2d5bff;border-color:#2d5bff;color:#fff;display:block;width:100%;text-align:center;flex:1 1 100%;display:flex;align-items:center;gap:10px;justify-content:center}
.info-card .chip.tel .ico{width:18px;height:18px;flex:0 0 auto}
.note{background:rgba(243,244,246,.5);border:1px solid #e5e7eb;border-radius:10px;padding:12px;color:#374151}
.blog-links{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.blog-links a.official{background:#2db400;color:#fff;border-color:#2db400;grid-column:1 / -1}
.blog-links a.official span{color:#fff}
.blog-links a.official span{position:relative;display:inline-block}
.blog-links a.official span .char{opacity:0;display:inline-block;animation:ob-appear .5s ease forwards;font-style:normal}
/* BLOG 1/2/3 작은 박스 */
.blog-links a:not(.official){padding:8px 10px}
.blog-links a:not(.official) img{width:22px;height:22px}
.blog-links a{display:flex;align-items:center;gap:10px;text-decoration:none;color:#111827;border:2px solid #03c75a;border-radius:10px;padding:8px}
.blog-links img{width:28px;height:28px}
.blog-links span{font-weight:600}
/* 상단 콤보 그리드(급매/블로그 리스트) */
.home-combo-row .row-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width: 1024px){
  .home-combo-row .row-2col{grid-template-columns:1fr}
}
/* Official blog badge */
.blog-links a.official{background:#2db400;color:#fff;border-color:#2db400}
.blog-links a.official span{color:#fff}
.blog-links a.official span{position:relative;display:inline-block}
.blog-links a.official span .char{opacity:0;display:inline-block;animation:ob-appear .5s ease forwards;font-style:normal}
@keyframes ob-appear{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.blog-links a.official span.blink3{animation:ob-blink .25s steps(1) 3}
@keyframes ob-blink{0%,49%{opacity:1}50%,100%{opacity:0}}
.blog-links a.official span.fadeOut{opacity:0;transition:opacity .25s linear}

/* reveal animation */
[data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
[data-reveal].is-visible{opacity:1;transform:none}

/* 문의하기 버튼 가로폭 3배 (기존 좌우 패딩 16px → 48px) */
.alp-hero .btn{padding-left:48px;padding-right:48px}
.alp-hero .cta-row .btn{width:280px;text-align:center;justify-content:center}

/* disable fullpage snap for single-page layout */
body.snap{scroll-snap-type:none;overflow-y:auto;height:auto}
.snap-section{scroll-snap-align:none;min-height:auto;display:block;align-items:unset}
.snap-section.alp-hero{min-height:auto}

/* responsive type scale for hero title */
@media (max-width: 768px){
  .alp-hero .title{font-size:20px;line-height:1.45}
  /* 모바일: 히어로 텍스트 16px */
  .home-main .alp-hero .title{font-size:16px}
  .home-main .alp-hero .hero-head{font-size:inherit}
  .home-main .alp-hero .hero-greet{font-size:inherit}
  /* 모바일 좌우 여백 축소: 컨테이너 패딩 줄임 */
  .container{padding:0 10px}
  .container.narrow{padding:0 10px}
  /* 섹션 박스 좌우 폭 동일 정렬 */
  .home-main section.boxed{margin-left:0;margin-right:0}
  /* 모바일 모든 네모박스 좌우 폭을 평형정보 박스와 동일하게 */
  .consult-card,
  .announcement-card,
  .white-box,
  .info-card{margin-left:0 !important;margin-right:0 !important;width:100%}
  /* 평형정보 네모박스와 동일한 외곽 폭 확장 (화이트박스는 제외) */
  .home-main .consult-card,
  .home-main .announcement-card{margin-left:-10px;margin-right:-10px;width:calc(100% + 20px)}
  /* 화이트박스는 컨테이너 안에서 100% 유지 (음수마진 제거) */
  .home-main .white-box{margin-left:0 !important;margin-right:0 !important;width:100% !important}
  /* 의뢰상담(consult-grid): 평형정보(408px)와 동일한 좌/우 폭(=100% - 20px) */
  .home-main .consult-grid{margin-left:0;margin-right:0}
}
@media (max-width: 480px){
  .alp-hero .title{font-size:17px;line-height:1.5}
  .home-main .alp-hero .title{font-size:22px}
}

/* contact page centering and unified widths */
.contact-page h1{margin-top:20px;text-align:center}
.contact-page .contact-form{max-width:1440px;width:100%;margin:0 auto}
.container.contact-page{max-width:1440px}
.contact-page .contact-form input,
.contact-page .contact-form textarea,
.contact-page .contact-form button,
.contact-page .contact-form select{width:100%}

/* Desktop: double the input/button width */
@media (min-width: 1200px){
  .contact-page .contact-form{width:720px;margin:0 auto}
  .contact-page .contact-form input,
  .contact-page .contact-form textarea,
  .contact-page .contact-form button{width:720px}
}


/* 상담이력 섹션 */
.consult-log-section{padding:16px 0}
.consult-log-section{border-bottom:0;margin-top:16px;margin-bottom:16px;padding-bottom:16px}

/* Home: blog latest section */
.blog-brief{position:relative}
.home-blog-title{margin:0 0 10px;text-align:left;font-size:22px;letter-spacing:.02em;font-weight:500;color:#03c75a}
.home-blog-title::before{content:none !important;display:none !important}
.home-blog-more{position:absolute;right:0;top:0;color:#03c75a;text-decoration:none;font-weight:400}
.home-blog-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr;gap:10px}
@media (min-width: 1280px){
  .home-blog-list{grid-template-columns:repeat(4,minmax(0,1fr))}
}
.home-blog-list a.blog-card{
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px 16px;
  border-radius:14px;
  text-decoration:none;
  background:#f5f6f8; /* 더 연한 회색 */
  border:1px solid #e5e7eb;
  color:#111827;
  font-weight:600
}
.home-blog-list a.blog-card:hover{filter:brightness(.98)}
.home-blog-list a.blog-card .logo-icon{
  width:18px;height:18px;display:block;border-radius:4px;background:#fff;padding:2px;flex:0 0 18px
}
.home-blog-list a.blog-card{position:relative}
.home-blog-list a.blog-card .title{font-weight:700;font-size:17px;line-height:1.4}
.home-blog-list a.blog-card .title-wrap{display:flex;align-items:center;gap:6px;min-width:0;flex:1 1 auto}
/* 첫 번째 카드만 NEW 앞에서 제목을 '…'로 줄임 */
.home-blog-list li:first-child a.blog-card{overflow:hidden}
.home-blog-list li:first-child .title-wrap{overflow:hidden;min-width:0;flex:1 1 auto}
.home-blog-list li:first-child .title{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1 auto}
.home-blog-list .new-badge{position:static;align-self:center;margin-left:8px;background:#03c75a;color:#fff;border-radius:999px;font-size:11px;padding:2px 8px;font-weight:800;box-shadow:0 2px 6px rgba(0,0,0,.2);flex:0 0 auto;line-height:1.2}
/* increase vertical space around home blog section by ~20% (base 40px → 48px) */
.info-section.home-blog-sec{padding-top:48px;padding-bottom:48px}
/* mobile: shrink blog latest titles and ellipsize to one line */
@media (max-width: 820px){
  .home-blog-list a.blog-card .title-wrap{display:flex;align-items:center;gap:6px;min-width:0;flex:1 1 auto}
  .home-blog-list a.blog-card .title{
    font-size:13px !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    display:block;
    flex:1 1 auto;
    min-width:0
  }
  /* ensure blog cards never overflow container on mobile */
  .home-blog-list{
    overflow:visible;
    padding-left:0;
    padding-right:0; /* 우측 라인 다른 박스와 동일 정렬 */
  }
  .home-blog-list a.blog-card{
    max-width:100%;
    width:100%;
    box-sizing:border-box;
    margin:0;
  }
}

/* extra guard on small screens: ensure blog cards don't overshoot container */
@media (max-width: 540px){
  .home-blog-list a.blog-card{width:100%;margin:0}
}

/* home gallery */
.home-g-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.home-g-head h4{margin:0}
.home-g-head .more{color:#111827;text-decoration:none;font-weight:700}
.home-g-main{display:flex;flex-direction:column;gap:10px}
.home-g-view{background:rgba(255,255,255,.4);border:1px solid #e5e7eb;border-radius:12px;display:flex;align-items:center;justify-content:center;height:560px;overflow:hidden}
.home-g-view img{object-fit:cover !important}

/* 블로그 최신글(급매 포맷과 동일) */
.announcement-body .item a{color:inherit;text-decoration:none}
.announcement-body .new-badge{background:#03c75a;color:#fff;border-radius:999px;font-size:11px;padding:2px 8px;font-weight:800;line-height:1.2;margin-left:8px}

/* 급매 상세보기 링크 초록색 */
#r-jamrea-list a{color:#03c75a !important;text-decoration:none}
/* 급매 리스트를 블로그 리스트 포맷과 동일하게 */
#r-jamrea-list{color:#111827}
#r-jamrea-list .item{display:flex;align-items:center;gap:8px;margin:6px 0}
#r-jamrea-list .item a,
#r-jamrea-list .item s{flex:1 1 auto;min-width:0;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#111827;text-decoration:none}
#r-jamrea-list .item s{color:#6b7280}
#r-jamrea-list .btn-more{flex:0 0 auto;color:#03c75a !important;text-decoration:none;white-space:nowrap}
.announcement-body .blog-compact-list{margin:0 !important;padding-left:0 !important}
.home-combo-row .blog-latest-card .announcement-head .btn-more{background:transparent;border:0;padding:0;text-decoration:none}
.home-combo-row .blog-latest-card .announcement-head{justify-content:space-between}
.home-combo-row .hot-card .announcement-head span{color:#03c75a}
/* 콤보 행 양쪽 박스 내부 상/하 패딩 통일(마진 겹침 무관) */
.home-combo-row .announcement-card .announcement-body{padding:8px 0}
/* Hot list(급매) uses the same spacing/typography as blog latest */
.home-combo-row .hot-card .announcement-body .item{margin:15px 0;line-height:1.7;font-weight:700}
/* 급매 앵커 색상은 검정으로 통일 (블로그 최신글과 동일) */
#r-jamrea-list a{color:#111827 !important;text-decoration:none}

@media (max-width: 768px){
  /* 블로그 리스트/급매 카드의 좌측 라인을 평형정보와 정확히 일치 */
  .home-combo-row .blog-latest-card,
  .home-combo-row .hot-card{margin-left:-16px;margin-right:0}
}
.home-g-view.is-portrait{background:rgba(255,255,255,.4)}
.home-g-view img{width:100%;height:100%;object-fit:cover;border-radius:12px}
.home-g-view img.fit-contain{object-fit:contain}
.home-g-thumbs{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:8px;overflow-x:auto;overflow-y:hidden;max-height:none;order:-1;display:flex;gap:8px}
.home-g-tip{display:flex;align-items:center;gap:6px;color:#111827;font-size:13px;margin:6px 0 10px;background:rgba(243,244,246,.92);border:1px solid #e5e7eb;border-radius:8px;padding:8px 10px}
.home-g-tip .ico{color:#2563eb}
.home-g-thumbs .thumb{display:block;border:2px solid transparent;border-radius:8px;overflow:hidden;margin-bottom:0;flex:0 0 auto;width:82px}
.home-g-thumbs .thumb.active{border-color:#03c75a}
.home-g-thumbs .thumb img{display:block;width:100%;height:42px;object-fit:cover}
@media (max-width: 768px){
  .home-g-main{grid-template-columns:1fr}
  .home-g-thumbs{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;max-height:none}
  .home-g-view{height:220px}
  .home-g-thumbs .thumb{flex:0 0 74px}
  .home-g-thumbs .thumb img{height:38px}
}

/* Lightbox (홈 갤러리 확대보기) */
.lb-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;z-index:1000}
.lb-backdrop.on{display:flex}
.lb-inner{position:relative;max-width:92vw;max-height:92vh}
.lb-inner img{display:block;max-width:92vw;max-height:92vh;border-radius:12px}
.lb-close{position:absolute;top:-14px;right:-14px;background:#000;color:#fff;border:2px solid #fff;border-radius:999px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:800}
/* lb arrows */
.lb-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:999px;border:1px solid rgba(255,255,255,.6);background:rgba(0,0,0,.55);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;cursor:pointer;user-select:none}
.lb-nav-btn.prev{left:12px}
.lb-nav-btn.next{right:12px}
.lb-nav-btn:hover{background:rgba(0,0,0,.65)}
@media (min-width: 1024px){
  .lb-nav-btn.prev{left:-56px}
  .lb-nav-btn.next{right:-56px}
}
/* animated wave for each character of title */
.home-blog-title .wave-ch{display:inline-block;animation:homeTextWave 1.2s ease-in-out infinite}
@keyframes homeTextWave{
  0%,80%,100%{transform:translateY(0)}
  40%{transform:translateY(-6px)}
}

/* Remove any accidental divider lines between sections on mobile */
main > section{border:0 !important}
.info-section, .consult-log-section, .announcement-section{border:0 !important}

.home-main section.boxed{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;margin:16px 0}
/* 메인에서 큰 배너 노출 */
.home-main .alp-hero{display:block}
/* 공통 섹션 여백 축소 */
.home-main .info-section,
.home-main .consult-log-section,
.home-main .announcement-section{padding:16px}

/* push NAVER banner section a bit lower (1cm) */
.naver-banner{margin-top:1cm}
.consult-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}
.consult-card{background:#ffffff;border:1px solid #e5e8ef;border-radius:14px;padding:16px}
.consult-card-header{margin:0 0 8px}
.consult-title{margin:0}
.consult-sub{margin:6px 0 0;color:#6b7280;font-size:14px}
.consult-card-header{position:relative;padding-right:120px}
.consult-cta{position:absolute;right:0;top:50%;transform:translateY(-50%);opacity:1;pointer-events:auto;transition:opacity .18s ease, transform .18s ease}
.consult-cta.btn{padding:8px 12px;border-radius:10px;background:#28c400;color:#ffffff;border:1px solid #28c400;text-decoration:none;font-weight:700}
.consult-cta.btn:hover{filter:brightness(.98)}

/* 의뢰 모달 */
.modal .modal-card.wide{max-width:720px}
.request-form{display:grid;gap:12px}
.request-row{display:grid;grid-template-columns:96px 1fr;gap:10px;align-items:center}
.request-row .req-label{color:#374151}
.chip-radios{display:flex;flex-wrap:wrap;gap:12px}
.chip-radio{display:inline-flex;align-items:center;gap:8px;padding:0;border:0;border-radius:0;background:transparent;cursor:pointer}
.chip-radio input{appearance:auto;width:16px;height:16px;accent-color:#28c400}
.request-form input[type="text"], .request-form input[type="tel"], .request-form textarea{width:100%;padding:10px;border:1px solid #e5e7eb;border-radius:8px}
.request-form textarea{min-height:160px}
.request-form input::placeholder, .request-form textarea::placeholder{color:#9ca3af}
.request-form input:focus::placeholder, .request-form textarea:focus::placeholder{color:transparent}
/* phone inputs in one line */
.phone-split{display:flex;gap:8px}
.phone-split input{width:auto;text-align:center;flex:1 1 0}
.phone-split input[name="phone1"]{flex:0 0 63px}
.phone-split input[name="phone2"],.phone-split input[name="phone3"]{flex:0 0 84px}
/* match name input width to phone group total width */
.inline-narrow{max-width:248px;width:248px}
.request-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}
.request-actions .btn{background:#28c400;color:#fff;border:1px solid #28c400}
.btn.submit{background:#28c400;color:#fff;border:1px solid #28c400}
.modal .modal-card .request-actions .btn{background:#28c400;color:#fff;border:1px solid #28c400}
.modal .modal-card .request-actions .btn:hover{filter:brightness(.98)}

/* required red dot */
.req-label.required:after{content:"";display:inline-block;width:6px;height:6px;background:#ef4444;border-radius:50%;margin-left:6px;vertical-align:middle}
.err-msg{color:#ef4444;font-size:12px;margin-top:6px}

/* success info message */
.success-wrap{display:flex;gap:10px;align-items:flex-start}
.success-wrap .ico{width:22px;height:22px;flex:0 0 22px;fill:#2563eb}
.success-wrap .msg{line-height:1.6}
.consult-list{list-style:none!important;list-style-type:none!important;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}
.consult-list li{list-style:none!important;margin:0;padding:0}
.consult-list ul{list-style:none!important;margin:0;padding:0}
.consult-text{word-break:keep-all;overflow-wrap:anywhere}
.consult-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;border:1px solid #e5e7eb;background:#f9fafb;border-radius:10px;padding:10px 12px}
.consult-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.consult-date{color:#6b7280;font-size:14px}
.badge{display:inline-block;padding:8px 10px;border-radius:8px;font-weight:700;font-size:13px;line-height:1}
.badge.done{background:#ef4444;color:#ffffff}
.badge.pending{background:#9ca3af;color:#ffffff}

/* Mobile adjustments for consult rows */
@media (max-width: 480px){
  .consult-grid{gap:12px}
  .consult-card{padding:14px}
  .consult-row{grid-template-columns:1fr auto auto;gap:6px;align-items:center}
  .consult-text{font-size:14px}
  .consult-date{font-size:12px}
  .badge{justify-self:auto}
}

/* 모바일에서 블로그 최신글 섹션(.home-blog-sec)을 평형정보 박스와 동일 폭으로 확장 */
@media (max-width: 820px){
  .home-blog-sec.boxed{
    margin-left:-10px;
    margin-right:-10px;
    width:calc(100% + 20px);
  }
}

/* 모바일: 블로그/급매 박스 좌우 패딩 제거하여 컨테이너 폭을 평형정보와 동일하게 */
@media (max-width: 820px){
  .home-blog-sec.boxed,
  .announcement-section.boxed{
    padding-left:0;
    padding-right:0;
  }
}

/* 모바일: 홈 콤보 행(블로그 최신글/급매) 폭을 평형정보와 동일하게 정렬 */
@media (max-width: 820px){
  .home-combo-row .container.narrow{padding-left:0;padding-right:0}
  .home-combo-row .blog-latest-card,
  .home-combo-row .hot-card{margin-left:-10px;margin-right:-10px;width:calc(100% + 20px)}
}

/* 모바일: 홈 콤보 행 패딩을 컨테이너(10px)와 동일하게, 카드 폭은 100%로 정렬 */
@media (max-width: 820px){
  .home-main .home-combo-row{padding-left:10px !important; padding-right:10px !important}
  .home-main .home-combo-row .blog-latest-card,
  .home-main .home-combo-row .hot-card{margin-left:0 !important; margin-right:0 !important; width:100% !important}
}

/* 모바일: 기타 섹션 폭을 '평형정보'와 동일하게 정렬 */
@media (max-width: 820px){
  /* 매물확인(일반 boxed 섹션) */
  .home-main .info-section.boxed{padding-left:10px !important; padding-right:10px !important}
  .home-main .info-section.boxed > .container.narrow{padding-left:0 !important; padding-right:0 !important}

  /* 이미지 갤러리 섹션 */
  .home-main .gallery-section{padding-left:10px !important; padding-right:10px !important}
  .home-main .gallery-section .container.narrow{padding-left:0 !important; padding-right:0 !important}

  /* NAVER 배너 섹션 */
  .home-main .naver-banner{padding-left:0 !important; padding-right:0 !important}

  /* 전화문의/네이버문의/블로그정보 섹션 */
  .home-main .snap-section.pad-extra{padding-left:10px !important; padding-right:10px !important}
  .home-main .snap-section.pad-extra .container.narrow{padding-left:0 !important; padding-right:0 !important}
  .home-main .snap-section.pad-extra .info-card{width:100% !important; margin-left:0 !important; margin-right:0 !important}
}

/* 모바일: 의뢰 상담 섹션 폭을 '평형정보'와 동일하게 정렬 */
@media (max-width: 820px){
  .home-main .consult-log-section{padding-left:10px !important; padding-right:10px !important}
  .home-main .consult-log-section .container.narrow{padding-left:0 !important; padding-right:0 !important}
  .home-main .consult-log-section .consult-card{width:100% !important; margin-left:0 !important; margin-right:0 !important}
}

/* 연락 카드 내 카카오/네이버 버튼 정렬 및 모양(전화번호 박스와 동일) */
.info-card .btn.kakao,
.info-card .btn.naver{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:100% !important;
  text-align:center !important;
  padding:8px 12px !important; /* same base as .chip */
  border-radius:999px !important; /* pill */
  min-height:44px !important;
}
/* add gap above Kakao */
.info-card .btn.kakao{ margin-top:12px !important; }

/* NAVER 배너 바로 아래 컨테이너는 좌우 패딩 제거 → 위 배너와 동일 폭 */
.home-main .naver-banner + .container.narrow{padding-left:0 !important; padding-right:0 !important}

/* 블로그 최신글 각 줄 맨 앞 아이콘 */
.home-combo-row .blog-latest-card .announcement-body .item a{display:block;color:#111827;text-decoration:none}

/* 블로그 최신글 아이템: 텍스트와 NEW 배지를 같은 줄에 정렬 */
.home-combo-row .blog-latest-card .announcement-body .item{display:block;margin:15px 0}
.home-combo-row .blog-latest-card .announcement-body .item a{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* 헤더 컨테이너 폭을 본문(좁은 컨테이너)와 정렬 */
.site-header .container{max-width:1296px}

@media (min-width: 1024px){
  /* info-cards: 좌측(문의+블로그정보 스택) / 우측(NAVER 배너) 2열 배치 */
  .info-section.snap-section.pad-extra .info-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .info-section.snap-section.pad-extra .info-cards .left-stack{display:grid;gap:14px}
}
/* 우측에 배치되는 NAVER 배너 카드 스타일 */
.info-card.naver-side{background:transparent;border:0;padding:0}
.info-card.naver-side .banner-img{width:100%;height:auto;display:block;border-radius:12px}
.info-card.naver-side .white-box{margin-top:12px}

/* 평형정보 2개 카드: PC에서 좌/우 1개씩 반반 배치 */
@media (min-width: 1024px){
  .alp-services .cards{grid-template-columns:1fr 1fr !important}
}

/* PC 버전: '급매 매물'을 2열 레이아웃 좌측에 배치, 블로그 최신글과 나란히 */
@media (min-width: 1024px){
  .hot-section .row-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
}

/* PC: 블로그 최신글 우측에 붙는 '급매 매물' 카드 스타일을 동일화 */
.home-combo-row .hot-list-card .announcement-body #hot-list .item{color:#111827;font-weight:500;line-height:1.7;margin:15px 0}
.home-combo-row .hot-list-card .announcement-body #hot-list .item a{color:inherit;text-decoration:none;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* 블로그 최신글/급매 매물 카드의 상하 패딩을 동일화 */
.home-combo-row .blog-latest-card,
.home-combo-row .hot-list-card{padding:12px 12px; width:100%; box-sizing:border-box}
.home-combo-row .blog-latest-card .announcement-head,
.home-combo-row .hot-list-card .announcement-head{margin-bottom:8px}

/* 급매 카드 박스 우측 밀림 방지 */
.home-combo-row .hot-list-card{background:#f5f6f8;border:1px solid #e5e7eb;border-radius:12px}
.home-combo-row .row-2col{align-items:start}

/* 요청: 급매 3번째 제목만 강제 말줄임 (박스 밀림 방지) */
.home-combo-row .hot-list-card #hot-list .item:nth-child(3) a{
  display:block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* 좌우 폭을 아래 매물정보(물건리스트)와 동일하게: 모바일 패딩 10px, 내부 컨테이너 0 */
@media (max-width: 820px){
  .home-main .home-combo-row{padding-left:10px !important; padding-right:10px !important}
  .home-main .home-combo-row .container.narrow{padding-left:0 !important; padding-right:0 !important}
}

/* 제목 말줄임(강제) 공통 규칙 */
.home-combo-row .announcement-card .announcement-body .item a{
  display:block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* 블로그 최신글 카드: 제목 말줄임 강제 (우측 밀림 방지) */
.home-combo-row .blog-latest-card .announcement-body .item{display:flex;align-items:center;gap:8px}
.home-combo-row .blog-latest-card .announcement-body .item a{display:block;flex:1 1 0;min-width:0;white-space:nowrap !important;overflow:hidden !important;text-overflow:ellipsis !important}
.home-combo-row .blog-latest-card .announcement-body .item .new-badge{flex:0 0 auto}

/* 강제 오버라이드: 블로그 최신글 제목 옆 NEW 배치 + 말줄임 유지 */
.home-combo-row .blog-latest-card .announcement-body .item{display:block !important}
.home-combo-row .blog-latest-card .announcement-body .item .new-badge{display:none !important}

/* 블로그 최신글: 선행 아이콘 완전 제거 (이미지/가상요소/로고 클래스) */
.home-combo-row .blog-latest-card .announcement-body .item::before,
.home-combo-row .blog-latest-card .announcement-body .item a::before,
.home-combo-row .blog-latest-card .announcement-body .item img,
.home-combo-row .blog-latest-card .announcement-body .item .logo-icon{display:none !important;content:none !important}

/* 블로그/급매 리스트 타이포 통일 (가독성 있는 보통 굵기) */
.home-combo-row .blog-latest-card .announcement-body .item,
.home-combo-row .hot-card .announcement-body .item{font-weight:500 !important}

/* 급매 리스트 제목도 말줄임 강제 */
#r-jamrea-list .item a{white-space:nowrap !important;overflow:hidden !important;text-overflow:ellipsis !important}

/* 블로그/급매 카드 내부 좌우 패딩 보강 → 우측 잘림 방지 */
.home-combo-row .announcement-card .announcement-head{padding:0 12px !important}
.home-combo-row .announcement-card .announcement-body{padding:8px 12px !important}

/* 급매 리스트 제목 말줄임(재확인) */
#r-jamrea-list .item{display:flex;align-items:center;gap:8px}
#r-jamrea-list .item a{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* 좌측 여백 축소: 블로그/급매 제목 시작점을 더 좌측으로 */
.home-combo-row .announcement-card .announcement-head{padding-left:6px !important; padding-right:12px !important}
.home-combo-row .announcement-card .announcement-body{padding-left:6px !important; padding-right:12px !important}

/* 급매 박스 항목도 말줄임 처리 (링크/텍스트 모두) */
.home-combo-row .hot-card .announcement-body .item{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* 급매: 제목 한 줄 말줄임을 강제 (컨테이너/앵커 모두) */
.home-combo-row .hot-card .announcement-body .item,
.home-combo-row .hot-card .announcement-body .item a{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  white-space:nowrap !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
}

/* === 급매 제목 말줄임(현 구조 유지) === */
#r-jamrea-list{overflow-x:hidden}
#r-jamrea-list .item{display:flex;align-items:center;gap:6px}
/* 첫 번째 제목 a 또는 '계약완료'일 때 .sold(=s/span) 요소를 줄임 대상에 지정 */
#r-jamrea-list .item > a:first-child,
#r-jamrea-list .item > .sold{
  flex:1 1 auto;
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  font-weight:400;
}
#r-jamrea-list .item .btn-more{flex:0 0 auto;white-space:nowrap}

/* === 블로그 최신글 제목 말줄임(동일 패턴) === */
#blog-latest-list .item{margin:15px 0}
#blog-latest-list .item > a{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#111827;text-decoration:none}
.n-red{color:#dc2626;font-weight:700;margin-right:6px}
.notice-label{color:#03c75a;font-weight:800;margin-right:6px}
/* 더보기: 제목 옆 녹색 텍스트로, 좌측 정렬 */
.home-combo-row .blog-latest-card .announcement-head{display:flex;align-items:center;gap:10px;justify-content:flex-start}
#home-blog-more{color:#03c75a !important;text-decoration:none;margin-left:8px;position:static}

/* --- 새로운 '급매 매물' 섹션을 블로그 최신글과 동일 톤으로 --- */
.hot-section .nv-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px}
.hot-section .nv-card .nv-card-head .nv-addr{font-weight:700;color:#111827}
.hot-section #hot-list .item{color:#111827;font-weight:500;line-height:1.7;margin:15px 0}
.hot-section #hot-list .item a{color:inherit;text-decoration:none;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width: 820px){
  .hot-section{padding-left:10px !important;padding-right:10px !important}
  .hot-section .container.narrow{padding-left:0 !important;padding-right:0 !important}
}

