/* promise.css - White + Orange Theme */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* PAGE HERO - Light */
.page-hero{position:relative;background:var(--off-white);padding:80px 0 60px;overflow:hidden;border-bottom:1px solid var(--gray-200)}
.page-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 50% 80% at 90% 50%,rgba(255,114,16,.06) 0%,transparent 70%),linear-gradient(135deg,#fafaf9 0%,#fff7ed 100%)}
.page-hero-bg::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.02) 1px,transparent 1px);background-size:60px 60px}
.page-hero-content{position:relative;z-index:1}
.page-hero-title{font-family:var(--font-serif);font-size:36px;font-weight:900;color:var(--text);line-height:1.3;margin:12px 0 16px;word-break:keep-all}
.page-hero-title .accent{color:var(--orange)}
.page-hero-desc{font-size:15px;color:var(--gray-600);line-height:1.8;word-break:keep-all}

/* TABS */
.promise-tabs-section{padding:72px 0;background:var(--white)}
.promise-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px;padding-bottom:20px;border-bottom:2px solid var(--gray-100)}
.tab-btn{padding:10px 18px;border-radius:30px;font-size:14px;font-weight:600;color:var(--gray-600);background:var(--off-white);border:2px solid transparent;transition:all var(--transition);font-family:var(--font-sans);cursor:pointer}
.tab-btn:hover{color:var(--text);background:var(--gray-100)}
.tab-btn.active{background:var(--orange);color:var(--white);border-color:var(--orange)}

.promise-panel{display:none}
.promise-panel.active{display:block}

.panel-grid{display:flex;flex-direction:column;gap:28px}
.panel-header{display:flex;align-items:center;gap:20px}
.panel-icon{font-size:48px;flex-shrink:0}
.panel-header h3{font-family:var(--font-serif);font-size:26px;font-weight:900;color:var(--text)}
.panel-sub{font-size:14px;color:var(--gray-600);margin-top:4px}

.panel-items{display:flex;flex-direction:column;gap:16px}
.panel-item{display:flex;gap:16px;padding:20px;background:var(--off-white);border-radius:var(--radius-md);border-left:3px solid var(--orange);transition:all var(--transition)}
.panel-item:hover{background:var(--orange);border-left-color:var(--white);transform:translateX(4px)}
.panel-item:hover h4,.panel-item:hover p{color:var(--white)}
.item-dot{width:10px;height:10px;border-radius:50%;background:var(--orange);flex-shrink:0;margin-top:6px}
.panel-item h4{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px;transition:color var(--transition)}
.panel-item p{font-size:13px;color:var(--gray-600);line-height:1.7;word-break:keep-all;transition:color var(--transition)}

.before-after{display:flex;align-items:center;gap:12px;background:var(--gray-100);border-radius:var(--radius-md);padding:20px}
.ba-item{flex:1;padding:16px;border-radius:var(--radius-sm)}
.ba-item.before{background:rgba(90,100,120,.08);border:1px solid rgba(90,100,120,.2)}
.ba-item.after{background:rgba(255,114,16,.1);border:1px solid rgba(255,114,16,.3)}
.ba-label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;margin-bottom:6px}
.ba-item.before .ba-label{color:var(--gray-600)}
.ba-item.after .ba-label{color:var(--orange)}
.ba-item p{font-size:13px;line-height:1.6;word-break:keep-all;color:var(--gray-600)}
.ba-arrow{font-size:24px;color:var(--orange);flex-shrink:0;font-weight:700}

/* MAP */
.map-section{padding:80px 0;background:var(--off-white)}
.map-wrapper{display:flex;flex-direction:column;gap:24px}
.map-container{position:relative;background:var(--white);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-md);border:1px solid var(--gray-100)}

.map-popup{
  display:none;
  position:absolute;
  bottom:20px;
  left:50%;
  transform:translateX(-50%);
  background:var(--dark);
  color:var(--white);
  border-radius:var(--radius-md);
  padding:18px 22px;
  min-width:280px;
  max-width:340px;
  box-shadow:var(--shadow-lg);
  border:2px solid var(--orange);
  z-index:10
}
.map-popup.show{display:block}
.popup-dong{font-size:17px;font-weight:800;color:var(--orange);margin-bottom:8px;font-family:var(--font-serif)}
.popup-promise{font-size:14px;line-height:1.8;word-break:keep-all;color:rgba(255,255,255,0.92)}
.popup-close{position:absolute;top:10px;right:12px;color:rgba(255,255,255,.6);font-size:16px;background:none;border:none;cursor:pointer;transition:color var(--transition);font-family:inherit}
.popup-close:hover{color:var(--white)}

.map-legend{background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100)}
.legend-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px}
.map-legend p{font-size:13px;color:var(--gray-600);line-height:1.7;margin-bottom:16px;word-break:keep-all}
.legend-dongs{display:flex;flex-wrap:wrap;gap:6px}
.dong-tag{font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px;background:var(--off-white);color:var(--text);border:1px solid var(--gray-100);cursor:pointer;transition:all var(--transition)}
.dong-tag:hover,.dong-tag.active{background:var(--orange);color:var(--white);border-color:var(--orange)}

/* CTA */
.promise-cta{padding:72px 0;background:var(--orange)}
.promise-cta-inner{text-align:center}
.promise-cta-inner h2{font-family:var(--font-serif);font-size:26px;font-weight:900;color:var(--white);margin-bottom:12px;word-break:keep-all}
.promise-cta-inner p{font-size:15px;color:rgba(255,255,255,.8)}
.btn-outline-light{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--white);font-weight:600;font-size:15px;padding:13px 27px;border-radius:var(--radius-full);border:2px solid rgba(255,255,255,.5);transition:all var(--transition);font-family:var(--font-sans)}
.btn-outline-light:hover{border-color:var(--white);background:rgba(255,255,255,.15)}

@media(min-width:768px){
  .page-hero-title{font-size:52px}
  .map-wrapper{flex-direction:row;align-items:flex-start}
  .map-container{flex:1}
  .map-legend{width:260px;flex-shrink:0}
  .panel-items{display:grid;grid-template-columns:repeat(2,1fr)}
  .before-after{padding:24px}
}
@media(min-width:1024px){
  .map-legend{width:300px}
}

/* 동 라벨 텍스트 */
.dong-label {
  fill: var(--white);
  font-size: 11px;
  font-family: var(--font-sans);
  font-weight: 600;
  pointer-events: none;
  dominant-baseline: middle;
  text-anchor: middle;
}

/* ── SVG 지도 ── */
.district-map { width:100%; height:auto; cursor:pointer; }
.district path {
  fill: var(--orange);
  stroke: rgba(255,255,255,0.6);
  stroke-width: 1.5;
  transition: all .2s ease;
}
.district:hover path, .district.active path {
  fill: var(--orange-dark);
  stroke: var(--white);
  stroke-width: 2;
}
.dong-label {
  fill: rgba(255,255,255,0.98);
  paint-order: stroke;
  stroke: rgba(200,80,0,0.3);
  stroke-width: 2px;
  font-size: 11px;
  font-family: var(--font-sans);
  font-weight: 700;
  pointer-events: none;
  dominant-baseline: middle;
  text-anchor: middle;
}
.district:hover .dong-label, .district.active .dong-label { fill: var(--white); }

/* 연결선 */
.label-line {
  stroke: rgba(200,80,0,0.4);
  stroke-width: 1;
  stroke-dasharray: 3,2;
  pointer-events: none;
}

/* 외부 라벨 */
.ext-label rect {
  fill: var(--orange);
  stroke: rgba(255,255,255,0.3);
  stroke-width: 1;
  transition: all .2s ease;
}
.ext-label:hover rect, .ext-label.active rect { fill: var(--orange-dark); }
.ext-label-text {
  fill: white;
  font-size: 10px;
  font-family: var(--font-sans);
  font-weight: 700;
  text-anchor: middle;
  dominant-baseline: middle;
  pointer-events: none;
}
.ext-label:hover .ext-label-text, .ext-label.active .ext-label-text { fill: var(--white); }

/* 클릭 포커스 박스 제거 */
.district:focus,
.district:focus-visible,
.ext-label:focus,
.ext-label:focus-visible {
  outline: none;
}
