/* ============================================================
   이천 신안실크밸리 2차 — 모던 다크 테마
============================================================ */
:root {
  --black:   #0e0e0e;
  --dark:    #1a1a1a;
  --dark2:   #222222;
  --dark3:   #2c2c2c;
  --mid:     #444444;
  --light:   #f5f4f2;
  --white:   #ffffff;
  --gold:    #c4a882;
  --gold2:   #e8d5b0;
  --red:     #9b2020;
  --border:  #e0ddd8;
  --shadow:  0 4px 32px rgba(0,0,0,0.1);
  --r:       10px;
  --ease:    all 0.3s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:'Noto Sans KR',sans-serif; color:var(--dark); background:#fff; overflow-x:hidden; }
img  { max-width:100%; display:block; }

/* ============================================================
   팝업
============================================================ */
.popup-dim {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,0.7); z-index:1200;
  align-items:center; justify-content:center;
}
.popup-dim.show { display:flex; }
.site-popup { width:90%; max-width:400px; border-radius:12px; overflow:hidden; }
.popup-img  { width:100%; display:block; }
.popup-btns { display:flex; }
.popup-btns button {
  flex:1; padding:14px; border:none; cursor:pointer;
  font-family:inherit; font-size:0.88rem; font-weight:600; transition:var(--ease);
}
.popup-btns button:first-child { background:#333; color:#aaa; }
.popup-btns button:first-child:hover { background:#444; color:#fff; }
.popup-btns button:last-child  { background:#111; color:#666; }
.popup-btns button:last-child:hover  { background:#222; color:#999; }

/* ============================================================
   헤더 — 두꺼운 투명 → 스크롤 시 진한 다크
============================================================ */
#header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(14,14,14,0.3);
  backdrop-filter:blur(6px);
  border-bottom:1px solid rgba(255,255,255,0.08);
  transition:background 0.4s ease, backdrop-filter 0.4s ease, box-shadow 0.4s ease;
}
#header.scrolled {
  background:rgba(14,14,14,0.97);
  backdrop-filter:blur(16px);
  box-shadow:0 2px 20px rgba(0,0,0,0.5);
  border-bottom-color:rgba(196,168,130,0.2);
}
.header-inner {
  max-width:1360px; margin:0 auto; padding:0 2.5rem;
  height:64px; display:flex; align-items:center; gap:2rem;
}

/* 로고 */
.site-logo  { flex-shrink:0; text-decoration:none; }
.logo-img   { height:28px; }

/* 네비게이션 */
#mainNav { flex:1; }
.nav-list {
  list-style:none; display:flex; align-items:center;
  height:64px; padding:0; margin:0;
}
.nav-link {
  display:flex; align-items:center; height:64px;
  padding:0 24px; color:rgba(255,255,255,0.85);
  font-size:0.97rem; font-weight:500; text-decoration:none;
  letter-spacing:-0.01em; position:relative; transition:var(--ease);
  white-space:nowrap;
}
.nav-link::after {
  content:''; position:absolute; bottom:0; left:24px; right:24px;
  height:2px; background:var(--gold); transform:scaleX(0); transition:var(--ease);
}
.nav-link:hover,
.nav-link.active { color:#fff; }
.nav-link:hover::after,
.nav-link.active::after { transform:scaleX(1); }

.nav-cta {
  background:var(--red); border-radius:6px;
  height:auto; padding:10px 22px; margin-left:8px; color:#fff !important;
}
.nav-cta::after { display:none; }
.nav-cta:hover  { background:#7a1515; color:#fff !important; }

/* 헤더 우측 */
.header-right { display:flex; align-items:center; gap:16px; flex-shrink:0; }
.phone-img-header { height:32px; opacity:0.9; }

/* 햄버거 */
.hamburger {
  display:none; background:none; border:none; cursor:pointer;
  flex-direction:column; gap:5px; padding:6px;
}
.hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; transition:var(--ease); }

/* ============================================================
   히어로
============================================================ */
#hero { position:relative; }
.hero-swiper { height:100vh; min-height:560px; max-height:920px; }

.hero-slide {
  height:100%; background-size:cover; background-position:center;
  position:relative; display:flex; align-items:center;
}
.hero-slide::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(110deg, rgba(14,14,14,0.72) 0%, rgba(14,14,14,0.2) 65%, transparent 100%);
}
.hero-text-wrap {
  position:relative; z-index:2;
  padding:0 8vw; display:flex; flex-direction:column; gap:18px;
}
.ht-sub  { height:28px; filter:drop-shadow(0 1px 4px rgba(0,0,0,0.5)); }
.ht-main { height:68px; filter:drop-shadow(0 2px 8px rgba(0,0,0,0.4)); }
.ht-logo { height:46px; filter:drop-shadow(0 2px 8px rgba(0,0,0,0.4)); }

.hero-btns { display:flex; gap:12px; margin-top:8px; flex-wrap:wrap; }
.hbtn-primary {
  background:var(--red); color:#fff; border:none; border-radius:6px;
  padding:14px 30px; font-size:0.97rem; font-weight:700;
  font-family:inherit; cursor:pointer; transition:var(--ease);
}
.hbtn-primary:hover { background:#7a1515; transform:translateY(-2px); }
.hbtn-ghost {
  background:transparent; color:rgba(255,255,255,0.9);
  border:1.5px solid rgba(255,255,255,0.6); border-radius:6px;
  padding:14px 30px; font-size:0.97rem; font-weight:500;
  font-family:inherit; cursor:pointer; transition:var(--ease);
}
.hbtn-ghost:hover { background:rgba(255,255,255,0.12); border-color:#fff; color:#fff; }

.hug-badge {
  position:absolute; top:120px; right:5%; z-index:2;
  height:90px; filter:drop-shadow(0 4px 14px rgba(0,0,0,0.3));
}

/* Swiper */
.swiper-button-prev,.swiper-button-next { color:rgba(255,255,255,0.7) !important; }
.swiper-button-prev::after,.swiper-button-next::after { font-size:1.1rem !important; }
.swiper-pagination-bullet { background:rgba(255,255,255,0.5) !important; opacity:1 !important; }
.swiper-pagination-bullet-active { background:var(--gold) !important; width:22px !important; border-radius:3px !important; }

/* ============================================================
   정보 띠
============================================================ */
.info-strip { background:var(--dark); color:rgba(255,255,255,0.85); }
.strip-inner {
  max-width:1360px; margin:0 auto; padding:0 2rem;
  display:flex; align-items:center; justify-content:center;
  min-height:54px; gap:0; flex-wrap:wrap;
}
.strip-inner > span {
  padding:0 18px; font-size:0.85rem; font-weight:400;
  display:flex; align-items:center; gap:6px;
}
.strip-inner > span i { color:var(--gold); font-size:0.8rem; }
.strip-inner > span + span::before {
  content:''; display:inline-block;
  width:1px; height:16px;
  background:rgba(255,255,255,0.2);
  margin-right:6px; flex-shrink:0;
}

/* ============================================================
   섹션 공통
============================================================ */
.sec-wrap     { padding:90px 0; }
.sec-light    { background:#fff; }
.sec-dark-alt { background:#f9f8f6; }
.container    { max-width:1200px; margin:0 auto; padding:0 2rem; }

.sec-header   { text-align:center; margin-bottom:3rem; }
.sec-label {
  display:inline-block; font-size:0.7rem; font-weight:700;
  letter-spacing:0.22em; color:var(--mid);
  background:#f0ede8; padding:4px 14px; border-radius:50px; margin-bottom:12px;
}
.sec-label.light { color:rgba(255,255,255,0.6); background:rgba(255,255,255,0.1); }
.sec-header h2 {
  font-size:clamp(1.7rem,3.5vw,2.5rem); font-weight:900;
  letter-spacing:-0.03em; color:var(--dark); margin-bottom:0.6rem;
}
.sec-header h2.white  { color:#fff; }
.sec-header p         { color:#888; font-size:0.95rem; }
.sec-header p.light-p { color:rgba(255,255,255,0.65); font-size:0.95rem; }

.sec-img { width:100%; border-radius:var(--r); box-shadow:var(--shadow); }

/* ============================================================
   전화 / 문자 상담 스트립
============================================================ */
.contact-strip {
  display:none;
}
@media (max-width:768px) {
  .contact-strip {
    display:flex; align-items:center; justify-content:center; gap:24px;
    padding:14px 1.5rem; background:#f9f8f6; border-bottom:1px solid #e8e4de;
  }
}
/* mobile.html 전용 — 항상 표시 */
.mobile-page .contact-strip {
  display:flex; align-items:center; justify-content:center; gap:24px;
  padding:14px 1.5rem; background:#f9f8f6; border-bottom:1px solid #e8e4de;
}
.cstrip-divider { width:1px; height:40px; background:#ddd; flex-shrink:0; }

/* 전화예약 배너 */
.mob-call-banner {
  display:flex; flex-direction:column; align-items:center;
  background:#f7d22d; padding:14px; text-decoration:none; gap:2px;
}
.mcb-top { font-size:0.95rem; font-weight:700; color:#333; }
.mcb-num { font-size:1.7rem; font-weight:900; color:#c00; letter-spacing:0.02em; }

/* 모바일 섹션 공통 */
.mob-section { background:#fff; border-top:8px solid #f0ede8; }
.mob-sec-title {
  text-align:center; font-size:1.1rem; font-weight:900;
  padding:20px; color:var(--dark); letter-spacing:-0.02em;
}

/* 단지안내 3×2 탭 그리드 */
.mob-tab-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  border-top:1px solid #e8e4de; border-left:1px solid #e8e4de;
}
.mob-tab {
  padding:14px 4px; font-size:0.88rem; font-weight:700;
  border:none; border-right:1px solid #e8e4de; border-bottom:1px solid #e8e4de;
  background:#fafafa; color:#444; cursor:pointer; font-family:inherit;
}
.mob-tab.active { background:var(--dark); color:#fff; }

/* 세대정보 4개 버튼 */
.mob-unit-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:8px; padding:0 12px 16px;
}
.mob-unit-btn {
  padding:16px 4px; font-size:1.1rem; font-weight:900;
  border:none; border-radius:8px; cursor:pointer; font-family:inherit;
}
.mob-unit-btn.active { outline:3px solid var(--dark); }

/* 탭 pane */
.mob-tab-pane { display:none; }
.mob-tab-pane.active { display:block; }
.mob-fullimg { width:100%; height:auto; display:block; }
.mob-stat {
  padding:28px 24px; text-align:center; background:#f9f8f6;
}
.mob-stat strong { display:block; font-size:1.1rem; margin-bottom:8px; color:var(--dark); }
.mob-stat p      { color:#666; font-size:0.92rem; margin-bottom:6px; }
.mob-stat em     { font-style:normal; font-size:0.85rem; color:var(--gold); font-weight:700; }
.cstrip-btn {
  display:flex; flex-direction:column; align-items:center; gap:5px;
  text-decoration:none; color:var(--dark);
}
.cstrip-btn img { width:46px; height:46px; }
.cstrip-btn span { font-size:0.75rem; font-weight:600; }
.cstrip-num {
  font-size:1.4rem; font-weight:900; color:var(--dark);
  letter-spacing:-0.02em; text-decoration:none;
}
.cstrip-num:hover { color:var(--gold); }

/* ============================================================
   단지안내 이미지 full-bleed
============================================================ */
.cx-imgwrap { margin:0 -2rem; }
.cx-imgwrap img { width:100%; height:auto; display:block; }

/* 단지안내 탭 — 모바일 3열 그리드 */
@media (max-width:768px) {
  .cx-tab-bar { display:grid !important; grid-template-columns:repeat(3,1fr); gap:6px; }
  .cx-tab-bar .tab-btn { width:100%; text-align:center; padding:10px 4px; font-size:0.8rem; }
  .cx-imgwrap { margin:0 -1.2rem; }
}

/* ============================================================
   이미지 풀스크린 섹션 (특별공급 / HUG)
============================================================ */
.img-section { padding:60px 0 40px; }
.bg-light    { background:#fff; }
.bg-dark-alt { background:#f9f8f6; }

.img-sec-head { text-align:center; margin-bottom:2rem; padding:0 1rem; }
.img-sec-head h2 {
  font-size:clamp(1.5rem,3vw,2.2rem); font-weight:900;
  letter-spacing:-0.03em; color:var(--dark); margin-bottom:0.4rem;
}
.img-sec-head p { color:#888; font-size:0.92rem; }

/* 세로형 이미지 (특공 3장) — 모바일 꽉 차게, 데스크탑 중앙 고정 */
.portrait-imglist {
  display:flex; flex-direction:column; align-items:center; gap:0;
}
.portrait-imglist img {
  width:100%; max-width:520px; height:auto; display:block;
}

/* 가로형 이미지 (HUG) — 항상 꽉 차게 */
.wide-imglist {
  display:flex; flex-direction:column; gap:0;
}
.wide-imglist img { width:100%; height:auto; display:block; }

/* 간소화된 개인정보 동의 */
.simple-privacy {
  display:flex; align-items:flex-start; gap:10px;
  padding:14px 16px; background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12); border-radius:8px;
  margin-bottom:16px;
}
.simple-privacy input { flex-shrink:0; margin-top:3px; accent-color:var(--gold); width:16px; height:16px; }
.simple-privacy label { font-size:0.82rem; color:rgba(255,255,255,0.65); line-height:1.5; cursor:pointer; }

/* ============================================================
   탭 공통
============================================================ */
.tab-bar {
  display:flex; gap:6px; flex-wrap:wrap;
  margin-bottom:28px; border-bottom:2px solid var(--border); padding-bottom:0;
}
.tab-btn {
  background:none; border:none; border-bottom:3px solid transparent;
  margin-bottom:-2px; padding:10px 22px;
  font-family:inherit; font-size:0.95rem; font-weight:600;
  color:#888; cursor:pointer; transition:var(--ease);
}
.tab-btn:hover   { color:var(--dark); }
.tab-btn.active  { color:var(--dark); border-bottom-color:var(--dark); }

.tab-bar-inner { border-bottom-color:rgba(0,0,0,0.1); margin:20px 0 16px; }
.tab-btn-sm {
  background:none; border:1.5px solid var(--border); border-radius:50px;
  padding:6px 18px; font-family:inherit; font-size:0.85rem; font-weight:600;
  color:#888; cursor:pointer; transition:var(--ease);
}
.tab-btn-sm:hover  { border-color:var(--dark); color:var(--dark); }
.tab-btn-sm.active { background:var(--dark); border-color:var(--dark); color:#fff; }

.tab-pane { display:none; }
.tab-pane.active { display:block; }

/* ============================================================
   사업소개 스펙 카드
============================================================ */
.spec-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:32px; }
.spec-card {
  display:flex; flex-direction:column; align-items:center; text-align:center;
  gap:8px; padding:1.5rem 1rem; border:1.5px solid var(--border); border-radius:var(--r);
  transition:var(--ease);
}
.spec-card:hover { border-color:var(--dark); background:#fafafa; }
.spec-card i    { font-size:1.6rem; color:var(--mid); }
.spec-card strong { font-size:0.75rem; font-weight:700; color:#999; letter-spacing:0.08em; text-transform:uppercase; }
.spec-card span   { font-size:0.88rem; font-weight:600; color:var(--dark); line-height:1.5; }

/* ============================================================
   입지 교통 카드
============================================================ */
.traffic-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; margin-top:20px; }
.traffic-card {
  display:flex; flex-direction:column; align-items:center;
  padding:16px 8px; border:1.5px solid var(--border); border-radius:var(--r); transition:var(--ease);
}
.traffic-card:hover { border-color:var(--dark); }
.t-time { font-size:1.3rem; font-weight:900; color:var(--red); letter-spacing:-0.03em; }
.t-dest { font-size:0.8rem; font-weight:600; color:#777; margin-top:4px; }

/* ============================================================
   단지 시설 카드
============================================================ */
.facility-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:20px; }
.fac-item {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px; background:#f9f8f6; border-radius:8px;
  font-size:0.88rem; font-weight:600; color:var(--dark);
}
.fac-item i { color:var(--mid); width:18px; }

/* ============================================================
   유닛 탭
============================================================ */
.unit-tab-bar { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:28px; }
.unit-tab {
  display:flex; flex-direction:column; align-items:center;
  background:#fff; border:1.5px solid #d8d4ce;
  border-radius:var(--r); padding:12px 28px; cursor:pointer; transition:var(--ease);
}
.unit-tab:hover { background:#f5f0e8; border-color:var(--gold); }
.unit-tab.active { background:var(--dark); border-color:var(--dark); }
.ut-type { font-size:1.15rem; font-weight:900; color:var(--dark); }
.ut-info { font-size:0.75rem; font-weight:500; color:#888; }
.unit-tab.active .ut-type { color:#fff; }
.unit-tab.active .ut-info  { color:rgba(255,255,255,0.6); }

.unit-pane { display:none; }
.unit-pane.active { display:block; }
#special .unit-pane.active { display:flex; justify-content:center; }
#special .unit-pane.active img { display:block; width:100%; max-width:480px; height:auto; }

.unit-meta {
  display:flex; gap:20px; flex-wrap:wrap; margin-bottom:16px;
  padding:12px 16px; background:rgba(255,255,255,0.08);
  border-radius:8px;
}
.unit-meta span { font-size:0.85rem; font-weight:500; color:rgba(255,255,255,0.7); }

/* ============================================================
   분양안내 혜택 스트립
============================================================ */
.benefit-strip { display:flex; gap:0; border:1.5px solid var(--border); border-radius:var(--r); overflow:hidden; }
.bs-item {
  flex:1; display:flex; flex-direction:column; align-items:center; text-align:center;
  gap:6px; padding:20px 10px;
  border-right:1.5px solid var(--border); transition:var(--ease);
}
.bs-item:last-child { border-right:none; }
.bs-item:hover      { background:#f9f8f6; }
.bs-item i      { font-size:1.4rem; color:var(--mid); }
.bs-item strong { font-size:0.9rem; font-weight:800; color:var(--dark); }
.bs-item span   { font-size:0.78rem; color:#888; line-height:1.4; }

/* ============================================================
   방문예약 섹션
============================================================ */
.sec-reservation {
  background: linear-gradient(160deg, #111 0%, #1e1e1e 50%, #111 100%);
}
/* 예약 폼 레이아웃 */
.form-wrap { max-width:680px; margin:0 auto; }

.resv-form-title {
  text-align:center; margin-bottom:2rem;
}
.resv-form-title span {
  color:var(--gold); font-size:1.2rem; font-weight:700; letter-spacing:0.02em;
}

/* 폼 카드 */
.resv-form {
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
  border-radius:16px; padding:2.5rem; backdrop-filter:blur(8px);
}

/* 2열 행 */
.form-group-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

.form-row { margin-bottom:1.1rem; }
.form-row label {
  display:block; color:rgba(255,255,255,0.75); font-size:0.85rem;
  font-weight:600; margin-bottom:6px;
}
.form-row label em { color:var(--gold); font-style:normal; }
.form-row input,.form-row select,.form-row textarea {
  width:100%; padding:11px 14px; border-radius:8px;
  border:1.5px solid rgba(255,255,255,0.15);
  background:rgba(255,255,255,0.92);
  font-size:0.93rem; font-family:inherit; outline:none;
  transition:var(--ease); box-sizing:border-box;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus {
  border-color:var(--gold); box-shadow:0 0 0 3px rgba(196,168,130,0.2);
}
.form-row textarea { resize:vertical; }

/* 개인정보 동의 박스 */
.privacy-box {
  border:1px solid rgba(255,255,255,0.18); border-radius:10px;
  overflow:hidden; margin-bottom:1.4rem;
}
.privacy-title {
  background:rgba(255,255,255,0.1); color:rgba(255,255,255,0.85);
  font-size:0.85rem; font-weight:700; padding:10px 14px;
  border-bottom:1px solid rgba(255,255,255,0.1);
}
.privacy-scroll {
  height:130px; overflow-y:auto; padding:12px 14px;
  background:rgba(0,0,0,0.25);
  color:rgba(255,255,255,0.55); font-size:0.78rem; line-height:1.7;
}
.privacy-scroll p { margin:0 0 10px; }
.privacy-scroll p:last-child { margin:0; }
.privacy-scroll strong { color:rgba(255,255,255,0.75); }
.privacy-scroll::-webkit-scrollbar { width:4px; }
.privacy-scroll::-webkit-scrollbar-track { background:rgba(255,255,255,0.05); }
.privacy-scroll::-webkit-scrollbar-thumb { background:rgba(196,168,130,0.4); border-radius:2px; }
.privacy-check {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; background:rgba(255,255,255,0.04);
  border-top:1px solid rgba(255,255,255,0.1);
}
.privacy-check input { width:16px; height:16px; cursor:pointer; accent-color:var(--gold); }
.privacy-check label {
  color:rgba(255,255,255,0.7); font-size:0.84rem; cursor:pointer;
}
.privacy-check label strong { color:#fff; }
.privacy-check label em { color:var(--gold); font-style:normal; }

.btn-submit {
  width:100%; padding:16px; border:none; border-radius:10px;
  background:var(--gold); color:#111;
  font-size:1rem; font-weight:800; font-family:inherit; cursor:pointer; transition:var(--ease);
}
.btn-submit:hover { background:var(--gold2); transform:translateY(-2px); }
.btn-submit:disabled { opacity:0.5; cursor:not-allowed; transform:none; }

.form-result-msg {
  margin-top:1rem; padding:14px; border-radius:8px;
  font-size:0.9rem; font-weight:600; white-space:pre-line; text-align:center;
}
.form-result-msg.success { background:rgba(196,168,130,0.15); color:var(--gold2); }
.form-result-msg.error   { background:rgba(180,60,60,0.15);   color:#f99; }


/* ============================================================
   네이버 지도
============================================================ */
.map-wrap { border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow); }
#naverMap  { width:100%; height:460px; }

.map-topbar,.map-bottombar {
  background:#eef5ee; border:1px solid #d0e8d0;
  padding:10px 18px; display:flex; align-items:center;
  justify-content:space-between; flex-wrap:wrap; gap:8px;
}
.map-topbar    { border-bottom:none; }
.map-bottombar { border-top:none; }
.map-topbar span,.map-bottombar span { font-size:0.83rem; color:#2e7d32; }
.map-topbar i,.map-bottombar i { margin-right:5px; }

.btn-naver {
  background:#03c75a; color:#fff; border:none;
  font-size:0.83rem; font-weight:700; padding:7px 16px;
  border-radius:6px; text-decoration:none; transition:var(--ease); white-space:nowrap;
}
.btn-naver:hover { background:#02a64c; color:#fff; }

.map-info-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:18px; }
.mi-item {
  display:flex; gap:12px; align-items:flex-start;
  background:#f9f8f6; border-radius:10px; padding:1rem 1.2rem;
}
.mi-item > i { color:var(--mid); font-size:1rem; margin-top:3px; }
.mi-item > div { display:flex; flex-direction:column; gap:4px; }
.mi-item strong { font-size:0.75rem; color:#aaa; font-weight:700; letter-spacing:0.07em; }
.mi-item span   { font-size:0.88rem; font-weight:500; color:var(--dark); }

/* 커스텀 오버레이 */
.naver-custom-overlay {
  background:#fff; border:2px solid var(--dark); border-radius:8px;
  padding:6px 8px; cursor:pointer; max-width:160px; position:relative;
  box-shadow:0 4px 16px rgba(0,0,0,0.25);
}
.naver-custom-overlay img { width:140px; height:80px; object-fit:cover; border-radius:4px; display:block; margin-bottom:4px; }
.naver-custom-overlay .ov-title { font-size:0.72rem; font-weight:700; color:var(--dark); text-align:center; }
.naver-custom-overlay::after {
  content:''; position:absolute; bottom:-10px; left:50%; transform:translateX(-50%);
  border:8px solid transparent; border-top-color:var(--dark); border-bottom:none;
}

/* ============================================================
   푸터
============================================================ */
footer { background:var(--black); color:rgba(255,255,255,0.6); padding:4rem 0 2rem; }
.footer-row {
  display:flex; justify-content:space-between; align-items:flex-start;
  flex-wrap:wrap; gap:2rem; padding-bottom:2rem;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.footer-left p { font-size:0.83rem; line-height:1.9; }
.footer-right  { text-align:right; }
.footer-label  { font-size:0.78rem; color:rgba(255,255,255,0.35); margin-bottom:8px; }
.footer-time   { font-size:0.8rem; color:rgba(255,255,255,0.3); margin-top:8px; }
.btn-footer-reserve {
  margin-top:14px; padding:10px 24px; background:var(--red); color:#fff;
  border:none; border-radius:6px; cursor:pointer;
  font-family:inherit; font-size:0.9rem; font-weight:700; transition:var(--ease);
}
.btn-footer-reserve:hover { background:#7a1515; }
.footer-copy {
  margin-top:1.5rem; text-align:center;
  font-size:0.78rem; color:rgba(255,255,255,0.25); line-height:1.8;
}

/* ============================================================
   플로팅 / 상단으로
============================================================ */
.float-reserve {
  position:fixed; bottom:74px; right:18px;
  background:var(--red); color:#fff; border:none; border-radius:50px;
  padding:12px 20px; font-family:inherit; font-size:0.88rem; font-weight:700;
  cursor:pointer; z-index:900; box-shadow:0 4px 18px rgba(155,32,32,0.45);
  transition:var(--ease); display:none;
}
.float-reserve.show { display:block; }
.float-reserve:hover { background:#7a1515; transform:scale(1.04); }

#backToTop {
  position:fixed; bottom:18px; right:18px;
  width:44px; height:44px; border-radius:50%;
  background:var(--dark2); color:rgba(255,255,255,0.7); border:1px solid rgba(255,255,255,0.1);
  cursor:pointer; z-index:900; font-size:0.9rem;
  display:none; align-items:center; justify-content:center;
  box-shadow:0 4px 14px rgba(0,0,0,0.4); transition:var(--ease);
}
#backToTop.show { display:flex; }
#backToTop:hover { background:var(--dark3); color:#fff; transform:translateY(-2px); }

/* ============================================================
   반응형
============================================================ */
@media (max-width:1024px) {
  .spec-grid    { grid-template-columns:repeat(2,1fr); }
  .traffic-grid { grid-template-columns:repeat(3,1fr); }
  .benefit-strip { flex-wrap:wrap; }
  .bs-item { min-width:33%; border-bottom:1.5px solid var(--border); }
}
@media (max-width:768px) {
  /* 헤더 */
  .header-inner { height:56px; padding:0 1.2rem; }
  .logo-img  { height:24px; }
  .nav-list  { height:56px; }
  .nav-link  { height:56px; }
  .hamburger { display:flex; }
  #mainNav {
    display:none; position:absolute; top:56px; left:0; right:0;
    background:rgba(14,14,14,0.98); padding:1rem 0;
    border-top:1px solid rgba(255,255,255,0.08);
  }
  #mainNav.open { display:block; }
  .nav-list   { flex-direction:column; height:auto; }
  .nav-link   { height:auto; padding:12px 24px; font-size:1rem; }
  .nav-link::after { display:none; }
  .nav-cta    { margin:8px 24px; border-radius:6px; text-align:center; padding:10px 24px; }
  .phone-img-header { display:none; }

  /* 히어로 */
  .hero-swiper { height:65vh; min-height:400px; }
  .ht-main { height:52px; }
  .ht-logo { height:34px; }
  .hug-badge { height:70px; top:80px; right:4%; }
  .hero-btns { flex-direction:column; gap:8px; }
  .hbtn-primary,.hbtn-ghost { width:100%; max-width:250px; }

  /* 섹션 */
  .sec-wrap { padding:60px 0; }
  .spec-grid    { grid-template-columns:1fr 1fr; }
  .traffic-grid { grid-template-columns:repeat(3,1fr); }
  .facility-grid { grid-template-columns:1fr 1fr; }
  .map-info-grid { grid-template-columns:1fr; }
  .benefit-strip { flex-direction:column; }
  .bs-item { border-right:none; }
  .unit-tab-bar { gap:8px; }
  .unit-tab { padding:10px 16px; }
  .strip-inner > span { padding:0 10px; font-size:0.78rem; }
  .portrait-imglist img { max-width:100%; }
}
@media (max-width:480px) {
  .traffic-grid { grid-template-columns:repeat(2,1fr); }
  .spec-grid    { grid-template-columns:1fr; }
  #naverMap { height:300px; }
  .resv-form { padding:1.4rem; }
  .form-group-row { grid-template-columns:1fr; }
  .form-wrap { max-width:100%; }
  .strip-inner { min-height:auto; padding:10px 1rem; gap:4px; }
  .strip-inner > span { padding:4px 8px; font-size:0.75rem; }
  .strip-inner > span + span::before { display:none; }
}

/* ============================================================
   프리미엄 8
============================================================ */
.premium-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
}
.prem-card {
  background:#fff; border:1px solid #e0ddd8;
  border-radius:12px; padding:1.4rem 1.2rem;
  display:flex; align-items:flex-start; gap:14px;
  transition:var(--ease);
}
.prem-card:hover { background:#f5f0e8; border-color:var(--gold); }
.prem-num {
  font-size:1.6rem; font-weight:900; color:var(--gold);
  line-height:1; flex-shrink:0; min-width:32px;
}
.prem-body p { color:#888; font-size:0.78rem; margin:0 0 4px; }
.prem-body strong { color:var(--dark); font-size:0.95rem; font-weight:700; }

@media (max-width:1024px) { .premium-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px)  { .premium-grid { grid-template-columns:1fr; } }

/* ============================================================
   대단지 브랜드타운
============================================================ */
.brand-town-wrap { display:flex; flex-direction:column; gap:28px; }
.brand-stat-row { display:flex; justify-content:center; }
.brand-stat { text-align:center; }
.bs-label { color:rgba(0,0,0,0.6); font-size:0.85rem; font-weight:600; display:block; margin-bottom:16px; }
.bs-bars { display:flex; align-items:flex-end; gap:20px; justify-content:center; min-height:120px; }
.bs-bar-item { display:flex; flex-direction:column; align-items:center; gap:8px; }
.bs-bar {
  width:60px; background:rgba(0,0,0,0.12); border-radius:6px 6px 0 0;
  display:flex; align-items:center; justify-content:center;
}
.bs-bar span { font-weight:700; font-size:0.85rem; color:rgba(0,0,0,0.7); }
.bs-bar-highlight { background:var(--red) !important; }
.bs-bar-highlight span { color:#fff; }
.bs-bar-label { font-size:0.72rem; color:rgba(0,0,0,0.55); text-align:center; line-height:1.4; }
.bs-badge {
  margin-top:14px; background:var(--red); color:#fff;
  padding:8px 20px; border-radius:30px; font-size:0.85rem; display:inline-block;
}
.bs-badge strong { font-weight:900; }
.brand-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
}
.brand-card {
  background:#f8f7f5; border:1px solid #e8e5e0; border-radius:10px;
  padding:1.2rem; display:flex; flex-direction:column; gap:6px;
}
.brand-card i { color:var(--red); font-size:1.2rem; }
.brand-card strong { font-size:0.9rem; font-weight:700; color:#222; }
.brand-card span { font-size:0.78rem; color:#888; }
.brand-total-badge {
  background:linear-gradient(135deg, var(--dark), #2a1a1a);
  color:#fff; border-radius:12px; padding:1.4rem 2rem;
  display:flex; align-items:center; justify-content:center;
  gap:16px; flex-wrap:wrap; text-align:center;
}
.brand-total-badge span { font-size:0.95rem; color:rgba(255,255,255,0.7); }
.brand-total-badge strong { color:#fff; font-size:1.1rem; }
.brand-total-badge .plus, .brand-total-badge .eq { color:var(--gold); font-size:1.4rem; font-weight:900; }
.brand-total-badge .total { color:#fff; font-size:1rem; }
.brand-total-badge .total strong { color:var(--gold); font-size:1.3rem; }
@media (max-width:768px) { .brand-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px) { .brand-grid { grid-template-columns:1fr; } }

/* ============================================================
   주차공간
============================================================ */
.parking-wrap { display:flex; flex-direction:column; gap:24px; }
.parking-headline {
  display:flex; align-items:center; gap:20px;
  background:var(--dark); color:#fff; border-radius:12px; padding:1.5rem 2rem;
}
.parking-headline i { font-size:2.5rem; color:var(--gold); flex-shrink:0; }
.parking-headline strong { font-size:1.2rem; font-weight:800; color:#fff; display:block; margin-bottom:4px; }
.parking-headline p { color:rgba(255,255,255,0.6); margin:0; font-size:0.9rem; }
.parking-stats {
  display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px;
}
.pk-stat {
  background:#f8f7f5; border:2px solid #e8e5e0; border-radius:12px;
  padding:1.5rem; text-align:center;
  display:flex; flex-direction:column; gap:6px;
}
.pk-stat-main { border-color:var(--red); background:#fff8f8; }
.pk-label { font-size:0.8rem; color:#888; font-weight:600; }
.pk-value { font-size:2rem; font-weight:900; color:var(--dark); }
.pk-stat-main .pk-value { color:var(--red); }
.pk-sub { font-size:0.72rem; color:#aaa; }
.parking-compare { background:#f8f7f5; border-radius:12px; padding:1.5rem; }
.pk-compare-title { font-weight:700; font-size:0.9rem; color:#444; margin:0 0 14px; }
.pk-compare-grid { display:flex; flex-direction:column; gap:8px; }
.pk-cmp-item {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 14px; background:#fff; border-radius:8px; border:1px solid #eee;
}
.pk-cmp-item.highlight { background:#fff8f8; border-color:var(--red); }
.pk-apt { font-size:0.85rem; color:#555; }
.pk-ratio { font-size:0.85rem; font-weight:700; }
.pk-ratio.bad { color:#aaa; }
.pk-ratio.good { color:var(--red); }
@media (max-width:768px) { .parking-stats { grid-template-columns:1fr; } }

/* ============================================================
   커뮤니티 시설
============================================================ */
.comm-headline { text-align:center; margin-bottom:24px; }
.comm-headline h3 { font-size:1.3rem; font-weight:800; color:var(--dark); margin:0 0 6px; }
.comm-headline p { color:rgba(0,0,0,0.5); margin:0; }
.comm-facility-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:8px;
}
.comm-fac-card {
  background:#f7f6f4; border:1px solid #e0ddd8;
  border-radius:12px; padding:1.2rem 1.4rem;
  display:flex; align-items:center; gap:16px;
  transition:var(--ease);
}
.comm-fac-card:hover { border-color:var(--gold); background:#f0ece4; }
.cf-icon { font-size:1.6rem; color:var(--gold); flex-shrink:0; width:36px; text-align:center; }
.cf-info { display:flex; flex-direction:column; gap:2px; }
.cf-info strong { color:var(--dark); font-size:0.95rem; font-weight:700; }
.cf-info span { color:rgba(0,0,0,0.55); font-size:0.78rem; }
.cf-height { color:rgba(0,0,0,0.35) !important; font-size:0.72rem !important; }
@media (max-width:768px) { .comm-facility-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px) { .comm-facility-grid { grid-template-columns:1fr; } }
