.agency-network-section,
.global-network-section {
  overflow:hidden;
  background:
    linear-gradient(180deg,#f7f7f6 0%,#f0efed 100%);
}
.agency-network-section *,
.agency-network-section *::before,
.agency-network-section *::after,
.global-network-section *,
.global-network-section *::before,
.global-network-section *::after {
  box-sizing:border-box;
}
.agency-network-section .sub-inner,
.global-network-section .sub-inner {
  max-width:1400px;
}
.network-head {
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:48px;
  margin-bottom:34px;
}
.network-kicker {
  display:block;
  margin-bottom:16px;
  color:#7b6f6b;
  font-size:13px;
  font-weight:850;
  letter-spacing:0.18em;
  text-transform:uppercase;
}
.network-title {
  color:#181615;
  font-size:clamp(34px,4vw,58px);
  line-height:1.08;
  font-weight:900;
  letter-spacing:0;
}
.network-copy {
  max-width:560px;
  color:#716866;
  font-size:16px;
  line-height:1.8;
  word-break:keep-all;
}
.agency-map-grid {
  display:grid;
  grid-template-columns:minmax(0,0.95fr) minmax(0,1.05fr);
  gap:24px;
}
.agency-map-card,
.world-map-card,
.global-column {
  border:1px solid rgba(30,28,27,0.08);
  border-radius:8px;
  background:rgba(255,255,255,0.92);
  box-shadow:0 24px 70px rgba(44,24,16,0.08);
}
.agency-map-card,
.world-map-card {
  padding:34px;
}
.map-card-head,
.world-map-meta {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:20px;
  margin-bottom:24px;
}
.map-card-title .en,
.global-column-head .en {
  display:block;
  margin-bottom:9px;
  color:#b87968;
  font-size:12px;
  font-weight:850;
  letter-spacing:0.16em;
  text-transform:uppercase;
}
.map-card-title h3,
.global-column-head h3 {
  color:#2b2725;
  font-size:24px;
  line-height:1.25;
  font-weight:900;
  letter-spacing:0;
  word-break:keep-all;
}
.map-badge,
.world-map-badge {
  flex:0 0 auto;
  padding:13px 17px;
  border:1px solid rgba(30,28,27,0.09);
  border-radius:999px;
  background:#fff;
  color:#201b19;
  font-size:13px;
  font-weight:900;
  letter-spacing:0.14em;
  text-transform:uppercase;
}
.agency-map-stage,
.world-map-stage {
  position:relative;
  overflow:hidden;
  border-radius:8px;
  border:1px solid rgba(30,28,27,0.08);
  background:
    radial-gradient(circle at 52% 38%,rgba(255,255,255,0.98),rgba(246,247,247,0.72) 62%,rgba(232,235,235,0.76)),
    linear-gradient(90deg,rgba(40,48,54,0.04) 1px,transparent 1px),
    linear-gradient(180deg,rgba(40,48,54,0.035) 1px,transparent 1px);
  background-size:100% 100%,86px 100%,100% 72px;
}
.agency-map-stage svg,
.world-map-stage svg {
  display:block;
  width:100%;
  height:auto;
}
.agency-map-stage.seoul { aspect-ratio:620/520; }
.agency-map-stage.korea { aspect-ratio:620/520; }
.agency-map-stage.korea svg {
  height:100%;
  transform:translateY(-14px) scale(1.18);
  transform-origin:center center;
}
.agency-region {
  stroke:#fff;
  stroke-width:1.25;
  vector-effect:non-scaling-stroke;
  cursor:pointer;
  outline:none;
  transition:filter 0.2s ease, opacity 0.2s ease, stroke-width 0.2s ease;
}
.agency-region:hover,
.agency-region:focus {
  filter:brightness(0.92) saturate(1.12);
  stroke:#1f2a34;
  stroke-width:2;
}
.agency-region:focus-visible {
  filter:brightness(0.88) saturate(1.15);
  stroke:#111827;
  stroke-width:2.4;
}
.agency-label {
  fill:#1e1b1a;
  font-size:14px;
  font-weight:900;
  text-anchor:middle;
  paint-order:stroke;
  stroke:rgba(255,255,255,0.86);
  stroke-width:4px;
  stroke-linejoin:round;
  pointer-events:none;
}
.agency-map-tip,
.world-tooltip {
  position:fixed;
  z-index:3000;
  min-width:150px;
  padding:11px 13px;
  border:1px solid rgba(255,255,255,0.14);
  border-radius:8px;
  background:rgba(31,27,25,0.92);
  color:#fff;
  box-shadow:0 16px 40px rgba(20,14,12,0.22);
  opacity:0;
  visibility:hidden;
  transform:translate(-50%,-120%);
  pointer-events:none;
  transition:opacity 0.16s ease, visibility 0.16s ease;
}
.agency-map-tip.show,
.world-tooltip.show {
  opacity:1;
  visibility:visible;
}
.agency-map-tip strong,
.world-tooltip strong,
.world-tooltip span {
  display:block;
}
.agency-map-tip strong,
.world-tooltip strong {
  margin-bottom:4px;
  font-size:14px;
}
.agency-map-tip span,
.world-tooltip span {
  color:rgba(255,255,255,0.72);
  font-size:12px;
  line-height:1.45;
}
.agency-list {
  margin-top:30px;
  border:1px solid rgba(30,28,27,0.08);
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 54px rgba(44,24,16,0.06);
  overflow:hidden;
}
.agency-table-wrap {
  width:100%;
  overflow-x:auto;
}
.agency-table {
  width:100%;
  min-width:760px;
  border-collapse:separate;
  border-spacing:0;
}
.agency-table caption {
  position:absolute;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
}
.agency-table th,
.agency-table td {
  padding:18px 22px;
  border-bottom:1px solid rgba(30,28,27,0.075);
  color:#625b58;
  font-size:15px;
  line-height:1.58;
  letter-spacing:0;
  text-align:left;
  vertical-align:middle;
  word-break:keep-all;
  overflow-wrap:anywhere;
}
.agency-table thead th {
  padding-top:16px;
  padding-bottom:16px;
  background:#f7f6f4;
  color:#2b2725;
  font-size:13px;
  font-weight:900;
  letter-spacing:0.08em;
}
.agency-table tbody th {
  width:150px;
  color:#2b2725;
  font-weight:900;
  white-space:nowrap;
}
.agency-table tbody td:last-child {
  width:190px;
  color:#292522;
  font-weight:850;
}
.agency-table tbody tr {
  transition:background 0.2s ease, box-shadow 0.2s ease;
}
.agency-table tbody tr:hover,
.agency-table tbody tr.is-active {
  background:#fbf8f3;
  box-shadow:inset 4px 0 0 rgba(180,104,80,0.34);
}
.agency-table tbody tr:last-child th,
.agency-table tbody tr:last-child td {
  border-bottom:0;
}
.area-pill {
  display:inline-block;
  width:10px;
  height:10px;
  margin-right:10px;
  border-radius:50%;
  background:var(--area-color,#9da3aa);
  vertical-align:1px;
}
.seoul-zone {
  display:inline-flex;
  align-items:center;
  margin:0 10px 4px 0;
  padding:5px 9px;
  border:1px solid rgba(80,90,100,0.18);
  border:1px solid color-mix(in srgb, var(--zone-color) 42%, #fff);
  border-radius:999px;
  background:#f7f7f6;
  background:color-mix(in srgb, var(--zone-color) 13%, #fff);
  color:#2d2b29;
  font-size:12px;
  font-weight:900;
  line-height:1.1;
  white-space:nowrap;
}
.world-map-card {
  padding:36px;
}
.world-map-meta p {
  max-width:780px;
  color:#77706d;
  font-size:14px;
  line-height:1.75;
}
.world-map-stage {
  aspect-ratio:1200/520;
}
.world-country {
  fill:url(#worldCountryGradient);
  stroke:rgba(255,255,255,0.58);
  stroke-width:0.42;
  vector-effect:non-scaling-stroke;
}
.world-country-shadow {
  fill:#8f9896;
  opacity:0.12;
  transform:translate(0,1.8px);
}
.world-graticule {
  fill:none;
  stroke:rgba(255,255,255,0.52);
  stroke-width:0.55;
  vector-effect:non-scaling-stroke;
}
.world-leader {
  fill:none;
  stroke:rgba(47,43,41,0.35);
  stroke-width:1;
  stroke-dasharray:3 5;
  vector-effect:non-scaling-stroke;
}
.world-anchor-dot {
  fill:#fff;
  stroke:#312d2b;
  stroke-width:1;
  vector-effect:non-scaling-stroke;
}
.world-marker {
  cursor:pointer;
  outline:none;
}
.world-marker .flag-frame {
  fill:#fff;
  stroke:rgba(28,26,25,0.12);
  stroke-width:1;
  filter:url(#markerShadow);
  transition:filter 0.2s ease, transform 0.2s ease;
}
.world-marker image,
.world-marker text,
.world-marker .marker-label-bg {
  transition:transform 0.2s ease;
}
.world-marker:hover .flag-frame,
.world-marker:focus .flag-frame {
  filter:url(#markerGlow);
}
.world-marker:hover image,
.world-marker:hover text,
.world-marker:hover .flag-frame,
.world-marker:hover .marker-label-bg,
.world-marker:focus image,
.world-marker:focus text,
.world-marker:focus .flag-frame,
.world-marker:focus .marker-label-bg {
  transform:scale(1.08);
}
.world-marker text {
  fill:#fff;
  font-size:11px;
  font-weight:850;
  text-anchor:middle;
  paint-order:stroke;
  stroke:rgba(0,0,0,0.24);
  stroke-width:2px;
  stroke-linejoin:round;
}
.marker-label-bg {
  fill:rgba(28,25,24,0.86);
  filter:url(#labelShadow);
}
.global-columns {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:28px;
}
.global-column-head {
  padding:28px 28px 20px;
  border-bottom:1px solid rgba(30,28,27,0.07);
}
.partner-list {
  counter-reset:partner;
}
.partner-item {
  counter-increment:partner;
  display:grid;
  grid-template-columns:34px 42px minmax(0,1fr);
  align-items:center;
  gap:14px;
  padding:16px 24px;
  border-bottom:1px solid rgba(30,28,27,0.06);
}
.partner-item:last-child { border-bottom:0; }
.partner-item::before {
  content:counter(partner, decimal-leading-zero);
  color:#c6bdb9;
  font-size:12px;
  font-weight:900;
}
.partner-flag {
  width:42px;
  height:28px;
  object-fit:cover;
  border:1px solid rgba(30,28,27,0.1);
  background:#fff;
}
.partner-country,
.partner-company {
  display:block;
  word-break:keep-all;
}
.partner-country {
  color:#5f5551;
  font-size:13px;
  font-weight:900;
}
.partner-company {
  margin-top:3px;
  color:#938a86;
  font-size:12px;
  line-height:1.45;
}
@media (max-width:1100px) {
  .network-head { display:grid; grid-template-columns:1fr; gap:24px; }
  .agency-map-grid,
  .global-columns { grid-template-columns:1fr; }
}
@media (max-width:640px) {
  .agency-network-section,
  .global-network-section { padding-left:20px; padding-right:20px; }
  .network-copy { font-size:14px; }
  .agency-map-card,
  .world-map-card { padding:18px; }
  .map-card-head,
  .world-map-meta { flex-direction:column; }
  .agency-label { font-size:13px; }
  .agency-list { margin-left:-2px; margin-right:-2px; }
  .agency-table { min-width:0; }
  .agency-table thead { display:none; }
  .agency-table tbody tr {
    display:grid;
    grid-template-columns:1fr;
    padding:14px 16px;
    border-bottom:1px solid rgba(30,28,27,0.08);
  }
  .agency-table tbody tr:last-child { border-bottom:0; }
  .agency-table th,
  .agency-table td {
    display:block;
    width:auto !important;
    padding:5px 0;
    border-bottom:0;
    font-size:13px;
  }
  .agency-table tbody th { white-space:normal; }
  .agency-table tbody td:last-child { font-size:14px; }
  .agency-table tbody td::before {
    display:block;
    margin-bottom:3px;
    color:#9a908c;
    font-size:11px;
    font-weight:900;
    letter-spacing:0.08em;
  }
  .agency-table tbody td:nth-child(2)::before { content:"관할구역"; }
  .agency-table tbody td:nth-child(3)::before { content:"대리점명"; }
  .world-map-stage { aspect-ratio:1200/520; }
  .world-marker text { font-size:12px; }
  .global-column-head { padding:22px 20px 16px; }
  .partner-item { grid-template-columns:28px 38px minmax(0,1fr); gap:12px; padding:14px 18px; }
}
