/* ==========================================================================
   Dabuller redesign — enterprise B2B logistics
   Three palettes via [data-palette] on <html>: blue (default), navy, dark
   ========================================================================== */

:root,
[data-palette="blue"] {
  --bg: #ffffff;
  --bg-soft: #eef2fa;
  --bg-panel: #ffffff;
  --bg-inverse: #0b1f3b;
  --line: #e6ebf2;
  --line-strong: #d3dbe6;
  --ink: #0b1f3b;
  --ink-soft: #43536b;
  --ink-mute: #7a8699;
  --ink-on-inverse: #ffffff;

  --brand: #0b6cff;
  --brand-strong: #054ec9;
  --brand-soft: #e8f0ff;
  --brand-tint: #f0f6ff;
  --accent: #00b07a;       /* status active */
  --warn: #ff7a1a;
  --danger: #ef4444;

  --shadow-sm: 0 1px 2px rgba(11,31,59,.04), 0 1px 1px rgba(11,31,59,.03);
  --shadow-md: 0 8px 24px -8px rgba(11,31,59,.12), 0 2px 6px rgba(11,31,59,.06);
  --shadow-lg: 0 24px 48px -16px rgba(11,31,59,.18), 0 6px 16px rgba(11,31,59,.08);

  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 24px;
}

[data-palette="navy"] {
  --bg: #ffffff;
  --bg-soft: #f4f5f8;
  --bg-panel: #ffffff;
  --bg-inverse: #0a1733;
  --line: #e3e6ec;
  --line-strong: #cdd2dc;
  --ink: #0a1733;
  --ink-soft: #46506a;
  --ink-mute: #7d8699;
  --ink-on-inverse: #ffffff;

  --brand: #0a1733;
  --brand-strong: #050c20;
  --brand-soft: #e6e9f0;
  --brand-tint: #f4f5f8;
  --accent: #ff6a13;
  --warn: #ff6a13;
  --danger: #d73a3a;
}

[data-palette="dark"] {
  --bg: #0a1024;
  --bg-soft: #0f172e;
  --bg-panel: #131c39;
  --bg-inverse: #060a18;
  --line: #1f2a4a;
  --line-strong: #2a3760;
  --ink: #ffffff;
  --ink-soft: #b9c2d8;
  --ink-mute: #7d8aa8;
  --ink-on-inverse: #ffffff;

  --brand: #4f8dff;
  --brand-strong: #79a8ff;
  --brand-soft: #1a2548;
  --brand-tint: #131c39;
  --accent: #2dd4a4;
  --warn: #ffa033;
  --danger: #f87171;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow-md: 0 8px 24px -8px rgba(0,0,0,.55), 0 2px 6px rgba(0,0,0,.35);
  --shadow-lg: 0 24px 48px -16px rgba(0,0,0,.7), 0 6px 16px rgba(0,0,0,.4);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { color-scheme: light; scrollbar-gutter: stable; }
[data-palette="dark"] { color-scheme: dark; }

body {
  font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, 'Segoe UI', Roboto, sans-serif;
  font-feature-settings: "ss01", "ss02";
  color: var(--ink);
  background: var(--bg);
  background-image:
    radial-gradient(circle at 1px 1px, color-mix(in srgb, var(--ink) 6%, transparent) 1px, transparent 0);
  background-size: 24px 24px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  letter-spacing: -0.01em;
}
[data-palette="dark"] body {
  background-image:
    radial-gradient(circle at 1px 1px, color-mix(in srgb, #fff 8%, transparent) 1px, transparent 0);
}

img { max-width: 100%; display: block; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
a { color: inherit; text-decoration: none; }

.shell {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
  width: 100%;
}
@media (max-width: 720px) {
  .shell { padding: 0 20px; }
}

/* ============== VIDEO HERO (logispot-style) ============== */
.vhero {
  position: relative;
  width: 100%;
  padding: 0 40px;
  background: #FFFFFF;
}
.vhero-frame {
  position: relative;
  width: 100%;
  height: clamp(520px, 70vh, 820px);
  border-radius: 24px;
  overflow: hidden;
  background: #0F172A;
}
.vhero-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.vhero-overlay {
  position: absolute; inset: 0;
  background: transparent;
  z-index: 1;
}
.vhero-shell {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  text-align: left;
  padding: 0 clamp(40px, 8vw, 120px) 0 clamp(16px, 2vw, 32px);
  max-width: 1280px;
  margin: 0 auto;
  left: 0; right: 0;
}
.vhero-badge {
  display: inline-flex;
  align-items: center;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  color: #FFFFFF;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  border: 1px solid rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.vhero-title {
  font-size: clamp(28px, 3.4vw, 48px);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.3;
  color: #FFFFFF;
  margin: 18px 0 18px;
  max-width: 720px;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.35);
}
.vhero-title-accent {
  color: #FFFFFF;
  font-weight: 700;
}
.vhero-sub {
  font-size: clamp(14px, 1.15vw, 16px);
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.88);
  margin: 0 0 28px;
  font-weight: 400;
  max-width: 540px;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
}
.vhero-cta {
  display: inline-flex;
  gap: 10px;
  flex-wrap: wrap;
}
.vhero-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 11px 22px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
  white-space: nowrap;
  transition: transform .2s ease, box-shadow .25s ease, background .2s ease;
}
.vhero-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.24);
}
.vhero-btn-kakao {
  background: #FEE500;
  color: #181600;
}
.vhero-btn-kakao:hover { background: #FFEB33; }
.vhero-btn-phone {
  background: #2563EB;
  color: #FFFFFF;
}
.vhero-btn-phone:hover { background: #1D4ED8; }

.vhero-scroll {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.25);
  color: #FFFFFF;
  z-index: 3;
  animation: vheroBounce 2.2s ease-in-out infinite;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.vhero-scroll svg { width: 18px; height: 18px; }
@keyframes vheroBounce {
  0%, 100% { transform: translate(-50%, 0); opacity: 0.85; }
  50%      { transform: translate(-50%, 6px); opacity: 1; }
}
@media (max-width: 720px) {
  .vhero { padding: 0 12px; }
  .vhero-frame { height: 70vh; min-height: 460px; border-radius: 10px; }
  .vhero-shell { padding: 0 24px; }
  .vhero-title { margin: 14px 0 14px; }
  .vhero-cta { width: 100%; }
  .vhero-btn { flex: 1; justify-content: center; }
}

/* ============== TOP UTILITY (legacy, no longer rendered) ============== */
.utility {
  background: var(--bg-inverse);
  color: var(--ink-on-inverse);
  font-size: 13px;
}

/* sticky bottom utility — same content as top utility, appears on scroll */
.utility.utility-sticky {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 50;
  transform: translateY(100%);
  transition: transform 320ms cubic-bezier(.2, .9, .3, 1);
  box-shadow: 0 -6px 20px rgba(11, 31, 59, 0.18);
  pointer-events: none;
}
.utility.utility-sticky.is-active {
  transform: translateY(0);
  pointer-events: auto;
}

/* floating buttons rise above sticky bar when active */
body.has-sticky-utility .float-contact {
  bottom: 60px;
}
.float-contact { transition: bottom 320ms cubic-bezier(.2, .9, .3, 1); }
.utility-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 36px;
  gap: 20px;
}
.utility-left { display: flex; gap: 18px; align-items: center; }
.utility-right { display: flex; gap: 14px; align-items: center; }
.utility-right .pill {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 4px 12px 4px 10px; border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  font-size: 13px; font-weight: 500;
  color: #CBD5E1;
}
.utility-right .pill .sep { color: rgba(255,255,255,.40); margin: 0 -5px; font-weight: 500; }
.utility-right .pill .hours { color: rgba(255,255,255,.55); }
.utility-right a {
  color: #CBD5E1;
  font-weight: 500;
  transition: color .15s;
}
.utility-right a:hover { color: #fff; text-decoration: none; }
.utility-right .pill .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
}
.utility-right .pill.is-open .dot {
  background: #10B981;
  animation: utilPillPulse 1.5s ease-in-out infinite;
}
.utility-right .pill.is-closed .dot {
  background: #94A3B8;
  box-shadow: 0 0 0 4px color-mix(in srgb, #94A3B8 22%, transparent);
  animation: none;
}
.utility-right .pill.is-closed { opacity: 0.85; }
@keyframes utilPillPulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 color-mix(in srgb, #10B981 65%, transparent);
  }
  50% {
    transform: scale(1.18);
    box-shadow: 0 0 0 4px color-mix(in srgb, #10B981 0%, transparent);
  }
}
.utility a:hover { text-decoration: underline; }
@media (max-width: 720px) { .utility-left .hide-sm { display: none; } }

/* dispatch availability chip — 5 squares + LIVE + label, capsule outline */
.dispatch-chip {
  --chip-on: #10B981;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 4px 12px 4px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.10);
  color: #FFFFFF;
  letter-spacing: -0.01em;
  cursor: help;
  transition: background .2s ease, border-color .2s ease;
}
.dispatch-chip:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.18);
}
.dispatch-chip-bars {
  display: inline-flex;
  align-items: center;
  gap: 3.5px;
}
.dispatch-chip-bar {
  width: 7px; height: 7px;
  border-radius: 2px;
  background: #475569;
  transition: background .25s ease;
}
.dispatch-chip-bar.is-on { background: var(--chip-on); }
.dispatch-chip-bar.is-on.is-tip {
  animation: dispatchChipPulse 1.5s ease-in-out infinite;
}
@keyframes dispatchChipPulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--chip-on) 65%, transparent);
  }
  50% {
    opacity: 0.6;
    transform: scale(1.18);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--chip-on) 0%, transparent);
  }
}
.dispatch-chip-live {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #FFFFFF;
  line-height: 1;
  margin-left: 1px;
}
.dispatch-chip-sep {
  color: rgba(255, 255, 255, 0.40);
  font-weight: 500;
  line-height: 1;
  margin: 0 -5px;
}
.dispatch-chip-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--chip-on-text, #FFFFFF);
  line-height: 1;
  transition: color .25s ease;
}

/* 5 status — only the filled square + label color changes */
/* 5단계: 매우 어려움(빨강) → 어려움(주황) → 보통(올리브) → 원활(초록) → 매우 원활(밝은 초록) */
.dispatch-chip.dm-vlow  { --chip-on: #EF4444; --chip-on-text: #FCA5A5; }
.dispatch-chip.dm-low   { --chip-on: #F97316; --chip-on-text: #FDBA74; }
.dispatch-chip.dm-mid   { --chip-on: #B7A52A; --chip-on-text: #E6D88A; }
.dispatch-chip.dm-high  { --chip-on: #34C759; --chip-on-text: #86E5A0; }
.dispatch-chip.dm-vhigh { --chip-on: #28D44B; --chip-on-text: #86E5A0; }

@media (max-width: 720px) {
  .dispatch-chip { gap: 7px; padding: 4px 10px 4px 9px; }
  .dispatch-chip-bar { width: 6px; height: 6px; }
  .dispatch-chip-live { font-size: 10.5px; }
  .dispatch-chip-label { font-size: 12px; }
}

/* ============== NAV ============== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: #FFFFFF;
  border-bottom: 1px solid transparent;
}
.nav .shell {
  max-width: none;
  padding: 0 40px;
}
.nav-row {
  display: flex; align-items: center; justify-content: space-between;
  height: 88px; gap: 40px;
}
.brand {
  display: inline-flex; align-items: center;
}
.brand-logo {
  height: 73px; width: auto; display: block;
  transition: opacity .15s;
}
.brand:hover .brand-logo { opacity: .82; }
[data-palette="dark"] .brand-logo { filter: brightness(0) invert(1); }

.nav-links {
  display: flex; gap: 12px; align-items: center;
}
.nav-item { position: relative; }
.nav-item > a {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 16px; border-radius: 8px;
  font-weight: 600; font-size: 17px; color: #0F172A;
  letter-spacing: -0.01em;
  transition: background .15s, color .15s;
}
.nav-item > a:hover,
.nav-item.open > a { background: var(--brand-tint); color: var(--brand); }
.nav-caret { transition: transform .18s ease; opacity: .55; width: 12px; height: 12px; }
.nav-item.open .nav-caret { transform: rotate(-180deg); opacity: 1; }

.nav-dropdown {
  position: absolute; top: calc(100% + 6px); left: 0;
  min-width: 180px; padding: 6px;
  background: var(--bg-panel); border: 1px solid var(--line);
  border-radius: 12px; box-shadow: var(--shadow-lg);
  display: flex; flex-direction: column; gap: 1px;
  opacity: 0; pointer-events: none;
  transform: translateY(-4px);
  transition: opacity .15s ease, transform .15s ease;
  z-index: 100;
}
.nav-item.open .nav-dropdown {
  opacity: 1; pointer-events: auto; transform: translateY(0);
}
.nav-dropdown a {
  padding: 9px 12px; border-radius: 8px;
  font-size: 14px; font-weight: 500; color: var(--ink-soft);
  white-space: nowrap;
  transition: background .12s, color .12s;
}
.nav-dropdown a:hover { background: var(--brand-tint); color: var(--brand); }

.nav-cta { display: flex; gap: 10px; align-items: center; }
@media (max-width: 980px) { .nav-links { display: none; } }

.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px; border-radius: 10px;
  font-weight: 600; font-size: 14px;
  transition: all .15s ease;
  white-space: nowrap;
}
.btn-primary { background: var(--brand); color: #fff; box-shadow: 0 8px 20px color-mix(in srgb, var(--brand) 25%, transparent), 0 1px 2px rgba(11,31,59,.06); }
.btn-primary:hover { background: var(--brand-strong); transform: translateY(-1px); box-shadow: 0 12px 28px color-mix(in srgb, var(--brand) 32%, transparent), 0 2px 6px rgba(11,31,59,.1); }
.btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--line-strong); }
.btn-ghost:hover { background: var(--bg-soft); }
.btn-soft { background: var(--brand-soft); color: var(--brand); }
.btn-soft:hover { background: color-mix(in srgb, var(--brand-soft) 80%, var(--brand) 20%); }
.btn-kakao {
  background: #FEE500; color: #181600;
  box-shadow: var(--shadow-sm);
}
.btn-kakao:hover { background: #FFD600; transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-quote {
  background: #0891B2; color: #fff;
  box-shadow: var(--shadow-sm);
}
.btn-quote:hover {
  background: #0E7490; transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(8, 145, 178, 0.32);
}
.btn-program {
  background: #1E293B; color: #fff;
  box-shadow: var(--shadow-sm);
}
.btn-program:hover {
  background: #0F172A; transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.3);
}
.btn-lg { padding: 14px 22px; font-size: 15px; border-radius: 12px; }

/* Chips relocated from the (removed) dark utility bar into the light Hero section */
.hero-chips {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
/* Light-background variants — override the dark-bar pill styles for use inside .hero-chips */
.hero-chips .dispatch-chip {
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  color: #0F172A;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.hero-chips .dispatch-chip:hover {
  background: #F8FAFC;
  border-color: #CBD5E1;
}
.hero-chips .dispatch-chip-bar { background: #CBD5E1; }
.hero-chips .dispatch-chip-bar.is-on { background: var(--chip-on); }
.hero-chips .dispatch-chip-live  { color: #0F172A; }
.hero-chips .dispatch-chip-sep   { color: #94A3B8; }
.hero-chips .dispatch-chip-label { color: var(--chip-on-text-light, #0F172A); }
.hero-chips .dispatch-chip.dm-vlow  { --chip-on-text-light: #DC2626; }
.hero-chips .dispatch-chip.dm-low   { --chip-on-text-light: #EA580C; }
.hero-chips .dispatch-chip.dm-mid   { --chip-on-text-light: #B45309; }
.hero-chips .dispatch-chip.dm-high  { --chip-on-text-light: #059669; }
.hero-chips .dispatch-chip.dm-vhigh { --chip-on-text-light: #047857; }

.hero-chips .pill {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 4px 12px 4px 10px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  color: #0F172A;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.hero-chips .pill .sep    { color: #94A3B8; margin: 0 -5px; font-weight: 500; }
.hero-chips .pill .hours  { color: #64748B; }
.hero-chips .pill .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #94A3B8;
}
.hero-chips .pill.is-open .dot {
  background: #10B981;
  animation: utilPillPulse 1.5s ease-in-out infinite;
}
.hero-chips .pill.is-closed .dot {
  background: #94A3B8;
  animation: none;
}
.hero-chips .pill.is-closed { opacity: 0.8; }

/* Footer partner link (relocated from top utility) */
.footer-partner-link {
  display: inline-flex; align-items: center;
  font-size: 13px;
  font-weight: 600;
  color: #93C5FD;
  letter-spacing: -0.005em;
  transition: color .15s ease;
}
.footer-partner-link:hover { color: #FFFFFF; text-decoration: underline; }

/* ============== HERO ============== */
.hero {
  position: relative;
  padding: 80px 0 80px;
  background: var(--bg);
  background-image:
    radial-gradient(circle at 85% 20%, color-mix(in srgb, var(--brand) 6%, transparent) 0%, transparent 50%),
    radial-gradient(circle at 15% 80%, color-mix(in srgb, var(--brand) 4%, transparent) 0%, transparent 40%);
  overflow: hidden;
}
.hero::before { content: none; }
.hero::after {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(180deg, transparent 70%, rgba(255, 255, 255, 0.85) 100%);
}
.hero .shell {
  position: relative;
  z-index: 2;
  width: 100%;
}
@keyframes heroAurora {
  0%, 100% { transform: translate(0, 0); }
  33%      { transform: translate(20px, -10px); }
  66%      { transform: translate(-15px, 12px); }
}
.hero .shell { position: relative; z-index: 2; }
[data-palette="dark"] .hero {
  background: linear-gradient(180deg, var(--bg-soft) 0%, var(--bg) 100%);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 56px;
  align-items: start;
  width: 100%;
}
.hero-grid > :first-child { padding-top: 0; }
.hero-grid .hero-visual-est {
  margin-top: 0;
  filter: drop-shadow(0 24px 48px color-mix(in srgb, var(--brand) 12%, transparent));
}

/* Hero right column heading (above the map) */
.hero-quote-head {
  margin-bottom: -8px;
}
.hero-quote-head .eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.08em;
}
.hero-quote-title {
  margin: 12px 0 -65px;
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--ink);
  line-height: 1.2;
}
.hero-quote-sub {
  margin: 0;
  font-size: 14px;
  color: var(--ink-soft);
  font-weight: 500;
  letter-spacing: -0.01em;
}
/* hide the heading when the result panel is shown */
.hero-visual-est:has(.est-result) .hero-quote-head { display: none; }
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .hero { min-height: 0; padding: 40px 0 60px; }
}
@media (min-width: 1920px) {
  .hero { padding: 80px 0 100px; }
}

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: 999px;
  background: rgba(255, 255, 255, 0.55);
  backdrop-filter: blur(12px) saturate(180%);
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  color: var(--brand);
  font-size: 13px; font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow: 0 4px 14px -4px color-mix(in srgb, var(--brand) 22%, transparent),
              inset 0 1px 0 rgba(255, 255, 255, 0.8);
}
.eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--brand); }

.hero h1 {
  margin: 18px 0 18px;
  font-size: clamp(36px, 5vw, 60px);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.035em;
  color: var(--ink);
  text-wrap: balance;
}
.hero h1 .accent {
  color: var(--brand);
  position: relative;
  white-space: nowrap;
}
.hero p.lede {
  font-size: 16px; line-height: 1.7; color: var(--ink-soft);
  max-width: 560px;
  text-wrap: pretty;
  margin: 14px 0 18px;
}

/* New hero headline block — 3 lines of decreasing weight */
.hero-headline { margin: 24px 0 14px; }
.hero-headline .hl-lead {
  margin: 0 0 14px;
  font-size: clamp(46px, 5.8vw, 76px);
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: -0.04em;
  color: var(--ink);
  text-wrap: balance;
  animation: heroFadeUp .9s cubic-bezier(.2, .9, .3, 1) both;
}
.hero-headline .hl-lead .accent {
  background: linear-gradient(135deg, #0a4fcf 0%, #4f46e5 55%, #0ea5e9 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  white-space: nowrap;
  filter: drop-shadow(0 2px 0 rgba(11, 108, 255, 0.12));
}
@keyframes heroFadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero-headline .hl-sub { animation: heroFadeUp .9s cubic-bezier(.2, .9, .3, 1) .1s both; }
.hero-headline .hl-tag { animation: heroFadeUp .9s cubic-bezier(.2, .9, .3, 1) .18s both; }
.hero p.lede        { animation: heroFadeUp .9s cubic-bezier(.2, .9, .3, 1) .26s both; }
.hero-ctas          { animation: heroFadeUp .9s cubic-bezier(.2, .9, .3, 1) .34s both; }
.hero-meta          { animation: heroFadeUp .9s cubic-bezier(.2, .9, .3, 1) .42s both; }
.hero .eyebrow      { animation: heroFadeUp .8s cubic-bezier(.2, .9, .3, 1) both; }
.hero-visual        { animation: heroFadeUp 1s cubic-bezier(.2, .9, .3, 1) .15s both; }
.hero-headline .hl-sub {
  margin: 0 0 8px;
  font-size: clamp(18px, 1.9vw, 24px);
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.hero-headline .hl-tag {
  margin: 0;
  font-size: clamp(14px, 1.3vw, 17px);
  font-weight: 500;
  line-height: 1.5;
  color: var(--ink-soft);
}
.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-ctas .btn-lg { padding: 16px 26px; font-size: 16px; border-radius: 12px; }
.hero .eyebrow { font-size: 13px; padding: 7px 14px; }

.hero-meta {
  display: flex; gap: 0; margin-top: 40px; padding-top: 24px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.hero-meta .item {
  flex: 1; min-width: 120px;
  padding: 0 20px;
  border-left: 1px solid var(--line);
}
.hero-meta .item:first-child { border-left: 0; padding-left: 0; }
.hero-meta .item .num {
  font-size: clamp(22px, 2.1vw, 30px);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--brand);
  line-height: 1;
}
.hero-meta .item .lbl { font-size: 13px; color: var(--ink-mute); margin-top: 8px; font-weight: 500; }
.hero-meta .kakao-stat {
  display: block; text-decoration: none; color: inherit;
  padding: 8px 12px; margin: -8px -12px;
  border-radius: 10px; transition: background .15s ease;
  position: relative;
}
.hero-meta .kakao-stat::before {
  content: ""; position: absolute; top: 10px; right: 10px;
  width: 6px; height: 6px; border-radius: 50%;
  background: #FEE500; box-shadow: 0 0 0 0 rgba(254,229,0,.6);
  animation: kakaoPulse 2s ease-out infinite;
}
.hero-meta .kakao-stat:hover { background: color-mix(in srgb, #FEE500 14%, transparent); }
.hero-meta .kakao-stat .kakao-ago { color: var(--ink-mute); font-size: 11px; opacity: .8; font-family: 'JetBrains Mono', monospace; }
@keyframes kakaoPulse {
  0%   { box-shadow: 0 0 0 0 rgba(254,229,0,.55); }
  70%  { box-shadow: 0 0 0 8px rgba(254,229,0,0); }
  100% { box-shadow: 0 0 0 0 rgba(254,229,0,0); }
}

/* Hero visual: dispatch console mock */
.hero-visual {
  position: relative;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: var(--shadow-lg);
  padding: 18px;
  overflow: hidden;
}
.hero-visual::before {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(800px 280px at 110% -10%, color-mix(in srgb, var(--brand) 14%, transparent), transparent 60%),
    radial-gradient(500px 200px at -10% 110%, color-mix(in srgb, var(--brand) 10%, transparent), transparent 60%);
}
/* Estimator hero variant: no card chrome, sits directly on page */
.hero-visual.hero-visual-est {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 4px 0 0;
  overflow: visible;
}
.hero-visual.hero-visual-est::before { display: none; }
.hero-visual-est .console-head { padding: 0 2px 12px; border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent); }
.hero-visual-est .console-body { padding: 8px 0 0; }
.console-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 4px 6px 14px;
  border-bottom: 1px dashed var(--line);
}
.console-title { display: flex; align-items: center; gap: 10px; font-weight: 700; font-size: 14px; }
.live-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 25%, transparent);
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.25); } }
.console-tabs { display: flex; gap: 6px; }
.console-tabs .tab {
  font-size: 11px; padding: 4px 8px; border-radius: 6px;
  background: var(--bg-soft); color: var(--ink-mute);
  font-family: 'JetBrains Mono', monospace;
}
.console-tabs .tab.active { background: var(--brand-soft); color: var(--brand); font-weight: 600; }
.console-tabs .tab-est { background: color-mix(in srgb, var(--brand) 6%, transparent); color: var(--brand); font-weight: 700; letter-spacing: -0.01em; }
.console-tabs .tab-est.active { background: var(--brand); color: #fff; box-shadow: 0 4px 10px -4px color-mix(in srgb, var(--brand) 60%, transparent); }

/* Estimator inside hero console */
.console-est { padding: 12px 0 8px; }
.console-est .est-card.est-compact { padding: 0; border: 0; box-shadow: none; background: transparent; }
.console-est .est-card.est-compact .est-head { display: none; }
.console-est .est-card.est-compact .est-stepper { padding: 4px 8px 10px; margin-bottom: 8px; gap: 6px; border-bottom: 1px dashed var(--line); }
.console-est .est-card.est-compact .est-step-num { width: 18px; height: 18px; font-size: 10px; }
.console-est .est-card.est-compact .est-step-lbl { font-size: 11px; }
.console-est .est-card.est-compact .est-route { padding: 8px 12px; font-size: 12px; margin: 0 4px 10px; border-radius: 8px; }
.console-est .est-card.est-compact .est-route-pin { width: 6px; height: 6px; }
.console-est .est-card.est-compact .est-canvas { padding: 12px 6px 14px; min-height: 0; border-radius: 10px; background: linear-gradient(180deg, color-mix(in srgb, var(--brand) 5%, #fff) 0%, var(--bg-soft) 100%); border: 1px solid var(--line); }
.console-est .est-card.est-compact .est-tip { font-size: 11px; padding: 6px 12px; top: 6px; }
.console-est .est-card.est-compact .est-tip-dot-a { width: 5px; height: 5px; }
.console-est .est-card.est-compact .est-tip-dot-b { width: 6px; height: 6px; }
.console-est .est-card.est-compact .est-grid { max-width: 280px; margin: 38px auto 2px; gap: 4px; }
.console-est .est-card.est-compact .est-prov { font-size: 10.5px; border-radius: 7px; border-width: 1px; }
.console-est .est-card.est-compact .est-prov-tag { font-size: 8px; padding: 1px 4px; top: -5px; right: -4px; }
.console-est .est-card.est-compact .est-legend { font-size: 10px; padding: 8px 0 0; gap: 10px; }
.console-est .est-card.est-compact .est-legend i.dot { width: 7px; height: 7px; }
.console-est .est-card.est-compact .est-city-panel { padding: 12px; border-radius: 10px; }
.console-est .est-card.est-compact .est-city-head { margin-bottom: 12px; padding-bottom: 10px; }
.console-est .est-card.est-compact .est-city-eyebrow { font-size: 10px; }
.console-est .est-card.est-compact .est-city-title { font-size: 13px; }
.console-est .est-card.est-compact .est-city-close { font-size: 11px; padding: 5px 10px; }
.console-est .est-card.est-compact .est-city-chip { font-size: 11px; padding: 5px 9px; }
.console-est .est-card.est-compact .est-cta-wrap { padding: 10px 0 2px; }
.console-est .est-card.est-compact .est-cta { font-size: 12px; padding: 9px 18px; border-radius: 10px; }
.console-est .est-card.est-compact .est-result { padding: 14px 12px; gap: 10px; border-radius: 10px; }
.console-est .est-card.est-compact .est-result-route { padding: 10px 12px; gap: 8px; }
.console-est .est-card.est-compact .erp-prov { font-size: 10px; }
.console-est .est-card.est-compact .erp-city { font-size: 13px; }
.console-est .est-card.est-compact .erp-pin { width: 7px; height: 7px; }
.console-est .est-card.est-compact .erp-arr { font-size: 14px; }
.console-est .est-card.est-compact .est-result-grid { gap: 6px; }
.console-est .est-card.est-compact .est-result-tile { padding: 10px 12px; border-radius: 9px; }
.console-est .est-card.est-compact .est-result-tile .lbl { font-size: 10px; }
.console-est .est-card.est-compact .est-result-tile .val { font-size: 16px; }
.console-est .est-card.est-compact .est-result-tile .val .unit { font-size: 10px; }
.console-est .est-card.est-compact .est-result-meta { font-size: 10px; gap: 6px 12px; }
.console-est .est-card.est-compact .est-result-note { font-size: 10px; padding: 8px 10px; line-height: 1.55; }
.console-est .est-card.est-compact .est-live { padding: 10px 12px 8px; border-radius: 9px; }
.console-est .est-card.est-compact .est-live-head { padding-bottom: 8px; margin-bottom: 8px; gap: 6px; }
.console-est .est-card.est-compact .est-live-title { font-size: 11px; }
.console-est .est-card.est-compact .est-live-route { font-size: 10px; padding: 2px 7px; }
.console-est .est-card.est-compact .est-live-meta { font-size: 9px; }
.console-est .est-card.est-compact .est-live-grid { gap: 6px; grid-template-columns: 1fr; }
.console-est .est-card.est-compact .est-live-card { padding: 8px 10px; gap: 4px; }
.console-est .est-card.est-compact .est-live-status { font-size: 9px; padding: 2px 6px; }
.console-est .est-card.est-compact .est-live-time { font-size: 9px; }
.console-est .est-card.est-compact .est-live-veh { font-size: 11px; }
.console-est .est-card.est-compact .est-live-price { font-size: 12px; }
.console-est .est-card.est-compact .est-live-price .unit { font-size: 9px; }
.console-est .est-card.est-compact .est-live-foot { font-size: 9px; padding-top: 6px; margin-top: 8px; }
.console-est .est-card.est-compact .est-result-actions { gap: 6px; }
.console-est .est-card.est-compact .est-result-actions .btn { font-size: 11px; padding: 7px 12px; border-radius: 8px; }

.console-body { padding: 14px 4px 4px; }
.disp-row {
  display: grid;
  grid-template-columns: 60px 1fr 1fr 88px;
  gap: 12px; align-items: center;
  padding: 12px 8px;
  border-radius: 10px;
  font-size: 13px;
  transition: background .2s;
}
.disp-row:hover { background: var(--bg-soft); }
.disp-row + .disp-row { border-top: 1px solid var(--line); }
.disp-time { font-family: 'JetBrains Mono', monospace; color: var(--ink-mute); font-size: 12px; }
.disp-route { display: flex; flex-direction: column; gap: 2px; }
.disp-route .from { font-weight: 600; color: var(--ink); }
.disp-route .to { font-size: 12px; color: var(--ink-soft); display: flex; align-items: center; gap: 6px; }
.disp-route .arrow { color: var(--ink-mute); }
.disp-vehicle { font-size: 12px; color: var(--ink-soft); }
.disp-vehicle b { color: var(--ink); font-weight: 600; }

.status-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 11px; border-radius: 12px;
  font-size: 12px; font-weight: 500;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
/* New status palette (spec) */
.status-pill.st-seeking   { background: rgba(249, 115, 22, 0.15); color: #C2410C; }
.status-pill.st-matched   { background: rgba(52, 211, 153, 0.18); color: #047857; }
.status-pill.st-loading   { background: rgba(16, 185, 129, 0.16); color: #047857; }
.status-pill.st-moving    { background: rgba(16, 185, 129, 0.16); color: #047857; }
.status-pill.st-delivered { background: rgba(148, 163, 184, 0.18); color: #475569; }
/* Backwards-compat for any leftover usages */
.status-pill.active  { background: color-mix(in srgb, var(--accent) 16%, transparent); color: var(--accent); }
.status-pill.pending { background: color-mix(in srgb, var(--warn) 18%, transparent); color: var(--warn); }
.status-pill.done    { background: var(--bg-soft); color: var(--ink-mute); }

/* Single LIVE indicator that replaces the network chips */
.board-live-indicator {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px 6px 12px;
  border-radius: 999px;
  background: rgba(16, 185, 129, 0.10);
  border: 1px solid rgba(16, 185, 129, 0.22);
  font-size: 13px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.board-live-indicator-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #10B981;
  box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.18);
  animation: liveIndPulse 1.8s ease-in-out infinite;
}
@keyframes liveIndPulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.18); }
  50%      { box-shadow: 0 0 0 7px rgba(16, 185, 129, 0.06); }
}
.board-live-indicator-label {
  color: #059669;
  font-weight: 700;
  letter-spacing: 0.06em;
  font-size: 11.5px;
  font-family: 'JetBrains Mono', monospace;
}
.board-live-indicator-sep { color: #CBD5E1; }
.board-live-indicator-text {
  color: #0F172A;
  font-weight: 600;
  font-size: 13.5px;
}

/* Number emphasis inside live counter */
.board-live-text b {
  color: var(--brand);
  font-weight: 700;
  font-feature-settings: 'tnum';
  margin: 0 1px;
}

/* mini map ticker */
.board-live {
  display: flex; align-items: center; gap: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--ink-mute);
  min-width: 320px;
}
.board-live-dot {
  color: var(--brand);
  font-size: 9px;
  animation: pulse 1.4s ease-in-out infinite;
}
.board-live-label { color: var(--brand); font-weight: 700; letter-spacing: 0.05em; }
.board-live-text { color: var(--ink); font-weight: 600; white-space: nowrap; }
.board-live-bar {
  flex: 1; min-width: 80px; height: 4px; border-radius: 2px;
  background: var(--line);
  overflow: hidden;
  position: relative;
}
.board-live-bar-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 35%;
  background: linear-gradient(90deg, color-mix(in srgb, var(--brand) 0%, transparent), var(--brand) 50%, color-mix(in srgb, var(--brand) 0%, transparent));
  animation: liveBarSlide 2.4s ease-in-out infinite;
}
@keyframes liveBarSlide {
  0% { transform: translateX(-30%); }
  50% { transform: translateX(220%); }
  100% { transform: translateX(-30%); }
}
.board-live-meta { color: var(--ink-mute); white-space: nowrap; font-size: 11px; }
@media (max-width: 720px) { .board-live-meta { display: none; } .board-live { min-width: 200px; } }

/* mini map ticker */
.map-ticker {
  margin-top: 10px;
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
  background: var(--bg-soft);
  border-radius: 10px;
  font-size: 12px; color: var(--ink-soft);
  font-family: 'JetBrains Mono', monospace;
}
.map-ticker .pulse-bar {
  flex: 1; height: 4px; border-radius: 2px;
  background: linear-gradient(90deg, var(--brand) 0%, var(--brand) 60%, var(--line) 60%, var(--line) 100%);
  background-size: 200% 100%;
  animation: shift 3.6s linear infinite;
}
@keyframes shift { from { background-position: 100% 0; } to { background-position: -100% 0; } }

/* ============== SECTIONS ============== */
.section { padding: 96px 0; }
.section.tight { padding: 72px 0; }
.section-soft {
  background: var(--bg-soft);
  position: relative;
}
.section-soft + .section-soft { padding-top: 0; }
.trust { background: #F0F7FF; }

/* ============== UNIFIED CTA (shared across all pages) ============== */
.uni-cta {
  position: relative;
  padding: 120px 0;
  text-align: center;
  overflow: hidden;
  isolation: isolate;
  min-height: 560px;
  display: flex;
  align-items: center;
  background:
    /* TEST: filter removed — to revert, restore: linear-gradient(135deg, rgba(15, 23, 42, 0.55) 0%, rgba(15, 23, 42, 0.70) 100%), */
    url('assets/office.jpg') center / cover no-repeat;
  background-attachment: fixed;
}
/* Optional vignette + brand accent on top of overlay */
.uni-cta::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 900px 360px at 50% 0%, rgba(37, 99, 235, 0.22) 0%, transparent 65%),
    radial-gradient(ellipse 80% 90% at 50% 50%, transparent 30%, rgba(0,0,0,0.35) 100%);
  pointer-events: none;
  z-index: 0;
}
/* Disable fixed background on touch / small viewports to avoid jitter */
@media (max-width: 1024px) {
  .uni-cta { background-attachment: scroll, scroll; }
}
@media (hover: none) {
  .uni-cta { background-attachment: scroll, scroll; }
}
.uni-cta-shell {
  position: relative;
  z-index: 1;
  max-width: 760px;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 auto;
}
.uni-cta-headline {
  font-size: 38px;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.025em;
  color: #FFFFFF;
  margin: 0 0 14px;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.35);
}
.uni-cta-sub {
  font-size: 17px;
  line-height: 1.55;
  color: #CBD5E1;
  margin: 0;
  max-width: 540px;
}
.uni-cta-divider {
  display: block;
  width: 100%; max-width: 480px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.16) 30%, rgba(255,255,255,0.16) 70%, transparent 100%);
  margin: 44px 0 36px;
}

/* Channels */
.uni-cta-channels {
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 28px 36px;
  flex-wrap: wrap;
}
.uni-cta-channel {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  color: #E2E8F0;
  letter-spacing: -0.01em;
}
.uni-cta-channel a {
  color: inherit;
  border-bottom: 1px solid transparent;
  transition: color .15s ease, border-color .15s ease;
}
.uni-cta-channel a:hover {
  color: #FFFFFF;
  border-bottom-color: rgba(255,255,255,0.25);
}
.uni-cta-channel-icon {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 32px; height: 32px;
  border-radius: 8px;
  background: rgba(255,255,255,0.06);
  flex-shrink: 0;
}
.uni-cta-channel-icon.ic-mail  { color: #CBD5E1; }
.uni-cta-channel-icon.ic-phone { color: #93C5FD; }
.uni-cta-channel-icon.ic-kakao {
  color: #1A1A1A;
  background: #FEE500;
}
.uni-cta-channel-icon.ic-kakao svg { width: 18px; height: 18px; }
.uni-cta-channel-q {
  color: #94A3B8;
  font-size: 14px;
  margin-left: 2px;
}
.uni-cta-channel-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: 999px;
  background: #FEE500;
  color: #181600;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: -0.005em;
  margin-left: 4px;
}

.uni-cta-hours {
  font-size: 14px;
  color: #94A3B8;
  margin: 0 0 32px;
  font-feature-settings: 'tnum';
  letter-spacing: -0.005em;
}

/* Actions */
.uni-cta-actions {
  display: inline-flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
}
.uni-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 15px 28px;
  border-radius: 10px;
  font-weight: 600;
  font-size: 15.5px;
  letter-spacing: -0.01em;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  font-feature-settings: 'tnum';
}
.uni-cta-btn:hover { transform: translateY(-1px); }
.uni-cta-btn-primary {
  background: #2563EB;
  color: #FFFFFF;
}
.uni-cta-btn-primary:hover {
  background: #1D4ED8;
  box-shadow: 0 10px 28px rgba(37, 99, 235, 0.38);
}
.uni-cta-btn-kakao {
  background: #FEE500;
  color: #181600;
}
.uni-cta-btn-kakao:hover {
  background: #FFEB33;
  box-shadow: 0 10px 28px rgba(254, 229, 0, 0.28);
}

/* Tablet — keep horizontal where it fits */
@media (max-width: 860px) {
  .uni-cta { padding: 88px 0 80px; }
  .uni-cta-headline { font-size: 30px; }
  .uni-cta-sub { font-size: 16px; }
  .uni-cta-channels { gap: 18px 28px; }
}

/* Mobile — stack channels + buttons */
@media (max-width: 560px) {
  .uni-cta { padding: 72px 0; }
  .uni-cta-headline { font-size: 26px; }
  .uni-cta-sub { font-size: 15px; }
  .uni-cta-divider { margin: 32px 0 28px; }
  .uni-cta-channels {
    flex-direction: column;
    align-items: center;
    gap: 14px;
  }
  .uni-cta-channel { font-size: 14.5px; }
  .uni-cta-channel-q { font-size: 13px; }
  .uni-cta-actions {
    flex-direction: column;
    width: 100%;
    gap: 10px;
  }
  .uni-cta-btn {
    width: 100%;
    justify-content: center;
  }
}

/* Slightly cooler soft tone for ABAB rhythm */
[data-palette="blue"] { --bg-soft: #F0F7FF; }
[data-palette="navy"] { --bg-soft: #F0F7FF; }

/* ============== PROBLEMS ============== */
.problems-head { max-width: 720px; margin-bottom: 56px; }
.problems-eyebrow {
  display: inline-block;
  padding: 6px 14px;
  background: #fef3c7;
  color: #92400e;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: 18px;
}
.problems-title {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 900;
  letter-spacing: -0.035em;
  line-height: 1.15;
  margin: 0 0 14px;
  color: var(--ink);
}
.problems-sub {
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0;
  font-weight: 500;
}
.problems-sub b { color: var(--ink); font-weight: 800; letter-spacing: -0.02em; }
.problems-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
@media (max-width: 960px) { .problems-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .problems-grid { grid-template-columns: 1fr; } }
.problem-card {
  --c: #3B82F6;
  position: relative;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
  border-radius: 16px;
  padding: 28px 28px 28px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: 0 2px 8px -2px rgba(15, 23, 42, 0.04);
  transition: transform 0.25s cubic-bezier(.2, .9, .3, 1.1), box-shadow 0.25s ease, border-color 0.2s ease, background 0.2s ease;
  overflow: hidden;
}
.problem-card.cat-ops   { --c: #3B82F6; background: linear-gradient(180deg, #F4F8FF 0%, #fff 60%); }
.problem-card.cat-cost  { --c: #F59E0B; background: linear-gradient(180deg, #FFF9EE 0%, #fff 60%); }
.problem-card.cat-trust { --c: #10B981; background: linear-gradient(180deg, #ECFDF5 0%, #fff 60%); }

.problem-bar {
  position: absolute;
  left: 0; top: 14px; bottom: 14px;
  width: 4px;
  background: var(--c);
  border-radius: 0 4px 4px 0;
}
.problem-card:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--c) 32%, transparent);
  box-shadow: 0 16px 32px -10px color-mix(in srgb, var(--c) 18%, transparent),
              0 4px 10px -2px rgba(15, 23, 42, 0.06);
}
.problem-card-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 2px;
}
.problem-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 10px;
  color: var(--c);
  background: color-mix(in srgb, var(--c) 12%, #fff);
}
.problem-icon svg { width: 22px; height: 22px; }
.problem-quote {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 38px;
  font-weight: 700;
  color: color-mix(in srgb, var(--c) 65%, transparent);
  line-height: 0.6;
  letter-spacing: -0.05em;
}
.problem-text {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.6;
  color: var(--ink);
  letter-spacing: -0.015em;
  text-wrap: pretty;
}

.problems-transition {
  margin-top: 56px;
  display: flex; flex-direction: column; align-items: center; gap: 22px;
}
.problems-transition-line {
  width: 1px; height: 36px;
  background: linear-gradient(180deg, transparent 0%, color-mix(in srgb, var(--ink) 22%, transparent) 100%);
}
.problems-transition-text {
  margin: 0;
  display: inline-flex; align-items: center; gap: 12px;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.02em;
}
.problems-transition-text b {
  color: var(--brand);
  font-weight: 800;
}
.problems-transition-arrow {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--brand);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  margin-left: 4px;
  animation: probArrowBob 1.8s ease-in-out infinite;
  box-shadow: 0 6px 16px -4px color-mix(in srgb, var(--brand) 38%, transparent);
}
@keyframes probArrowBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(4px); }
}

/* ============== SOLUTIONS ============== */
.sol-eyebrow { background: #DBEAFE; color: #1d4ed8; }

.sol-trust-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 48px;
}
@media (max-width: 768px) { .sol-trust-strip { grid-template-columns: 1fr; } }
.sol-trust-card {
  padding: 28px 28px 26px;
  display: flex; align-items: flex-start; gap: 16px;
  position: relative;
}
.sol-trust-card + .sol-trust-card { border-left: 1px solid #E5E7EB; }
@media (max-width: 768px) {
  .sol-trust-card + .sol-trust-card { border-left: 0; border-top: 1px solid #E5E7EB; }
}
.sol-trust-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  border-radius: 12px;
  color: #2563EB;
  background: #EFF6FF;
  flex-shrink: 0;
}
.sol-trust-icon svg { width: 26px; height: 26px; }
.sol-trust-body { flex: 1; min-width: 0; }
.sol-trust-num {
  font-size: 32px; font-weight: 800;
  color: #2563EB;
  letter-spacing: -0.03em;
  line-height: 1.1;
}
.sol-trust-num .unit { font-size: 18px; font-weight: 700; color: #2563EB; margin-left: 2px; }
.sol-trust-num-text { font-size: 22px; font-weight: 800; }
.sol-trust-lbl { font-size: 14px; font-weight: 700; color: var(--ink); margin-top: 6px; letter-spacing: -0.01em; }
.sol-trust-desc { font-size: 13px; color: var(--ink-mute); margin-top: 4px; font-weight: 500; }
.sol-trust-certs {
  display: flex; gap: 8px; margin-top: 10px;
  flex-wrap: wrap;
}
.sol-trust-certs img { height: 28px; width: auto; opacity: 0.92; }

/* Main visual */
.sol-main {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 28px;
  align-items: start;
}
@media (max-width: 1024px) { .sol-main { grid-template-columns: 1fr; } }

.sol-screenshot { position: relative; }
.sol-screenshot-frame {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08), 0 6px 14px rgba(0, 0, 0, 0.04);
  border: 1px solid #E5E7EB;
  background: #fff;
}
.sol-screenshot-frame img { width: 100%; height: auto; display: block; }
@media (max-width: 600px) {
  .sol-screenshot-frame { overflow-x: auto; }
  .sol-screenshot-frame img { min-width: 720px; }
}
.sol-screenshot-cap {
  margin-top: 12px;
  font-size: 12px;
  color: var(--ink-mute);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.02em;
  text-align: center;
}

.sol-marker {
  position: absolute;
  width: 36px; height: 36px;
  transform: translate(-50%, -50%);
  z-index: 2;
}
.sol-marker-pulse {
  position: absolute; inset: 0;
  border-radius: 50%;
  background: #2563EB;
  opacity: 0.45;
  animation: solMarkerPulse 1.8s ease-out infinite;
}
.sol-marker-num {
  position: relative; z-index: 1;
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  background: #2563EB;
  color: #fff;
  font-weight: 800;
  font-size: 15px;
  border-radius: 50%;
  border: 2px solid #fff;
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.4);
}
@keyframes solMarkerPulse {
  0%   { transform: scale(1); opacity: 0.45; }
  100% { transform: scale(2); opacity: 0; }
}

/* Mapping cards */
.sol-mapping {
  display: flex; flex-direction: column;
  gap: 12px;
}
@media (max-width: 1024px) {
  .sol-mapping { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
}
@media (max-width: 600px) { .sol-mapping { grid-template-columns: 1fr; } }

.sol-map-card {
  --c: #3B82F6;
  position: relative;
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 12px;
  padding: 16px 18px 16px 22px;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto auto auto;
  column-gap: 14px;
  row-gap: 6px;
  transition: transform 0.25s cubic-bezier(.2, .9, .3, 1.1), box-shadow 0.25s ease, border-color 0.2s ease;
}
.sol-map-card.cat-ops   { --c: #3B82F6; }
.sol-map-card.cat-cost  { --c: #F59E0B; }
.sol-map-card.cat-trust { --c: #10B981; }
.sol-map-card .problem-bar {
  position: absolute;
  left: 0; top: 12px; bottom: 12px;
  width: 4px;
  background: var(--c);
  border-radius: 0 4px 4px 0;
}
.sol-map-card:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--c) 32%, transparent);
  box-shadow: 0 14px 28px -10px color-mix(in srgb, var(--c) 22%, transparent),
              0 3px 8px -2px rgba(15, 23, 42, 0.06);
}

.sol-map-head {
  grid-column: 1;
  grid-row: 1 / span 4;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.sol-map-num {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--c);
  color: #fff;
  font-weight: 800; font-size: 14px;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px color-mix(in srgb, var(--c) 35%, transparent);
}
.sol-map-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border-radius: 8px;
  color: var(--c);
  background: color-mix(in srgb, var(--c) 12%, #fff);
}
.sol-map-icon svg { width: 16px; height: 16px; }

.sol-map-prob {
  grid-column: 2;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-mute);
  letter-spacing: -0.01em;
  line-height: 1.5;
}
.sol-map-prob-q {
  font-family: Georgia, serif;
  color: color-mix(in srgb, var(--c) 70%, transparent);
  margin-right: 2px;
  font-weight: 700;
}
.sol-map-arrow {
  grid-column: 2;
  color: var(--c);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}
.sol-map-sol {
  grid-column: 2;
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.015em;
  line-height: 1.45;
}

/* ============== CHANNELS (Section 4) ============== */
.ch-eyebrow { background: #DCFCE7; color: #166534; }

.ch-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-bottom: 32px;
}
@media (max-width: 768px) { .ch-grid { grid-template-columns: 1fr; gap: 16px; } }

.ch-card {
  --c: #2563EB;
  position: relative;
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 16px;
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform 0.25s cubic-bezier(.2, .9, .3, 1.1), box-shadow 0.25s ease, border-color 0.2s ease;
  text-align: left;
}
.ch-card:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--c) 32%, transparent);
  box-shadow: 0 18px 36px -12px color-mix(in srgb, var(--c) 24%, transparent),
              0 4px 10px -2px rgba(15, 23, 42, 0.06);
}
.ch-card.ch-kakao { --c: #FEE500; }
.ch-card.ch-phone { --c: #2563EB; }
.ch-card.ch-web   { --c: #1F2937; }

.ch-card-badge {
  position: absolute;
  top: -10px; right: 24px;
  background: var(--c);
  color: #fff;
  font-size: 11px; font-weight: 800;
  padding: 5px 12px;
  border-radius: 999px;
  letter-spacing: -0.01em;
  box-shadow: 0 4px 10px -2px color-mix(in srgb, var(--c) 40%, transparent);
}

.ch-card-icon-wrap {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--c) 14%, #fff);
  margin-bottom: 4px;
}
.ch-card.ch-kakao .ch-card-icon-wrap { background: #FEE500; }
.ch-card.ch-web .ch-card-icon-wrap { background: #F3F4F6; }
.ch-card-icon { display: inline-flex; color: var(--c); }
.ch-card.ch-kakao .ch-card-icon { color: #181600; }
.ch-card.ch-web .ch-card-icon { color: #1F2937; }
.ch-card-icon svg { width: 28px; height: 28px; }

.ch-card-tag {
  font-size: 12px; font-weight: 700;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
}

.ch-card-title {
  margin: 0;
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1.2;
}

.ch-card-meta {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-soft);
  letter-spacing: -0.01em;
}
.ch-card-meta-num {
  font-size: 22px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.02em;
}
.ch-card-meta-num .unit { font-size: 14px; font-weight: 700; color: var(--ink-mute); margin-left: 2px; }

.ch-card-desc {
  margin: 4px 0 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-soft);
  font-weight: 500;
  letter-spacing: -0.01em;
  text-wrap: pretty;
  flex: 1;
}

.ch-card-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 18px;
  width: 184px;
  height: 48px;
  padding: 0 22px;
  box-sizing: border-box;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.01em;
  align-self: flex-start;
  white-space: nowrap;
  text-decoration: none;
  border: 0;
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.08);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.ch-card-cta svg { flex-shrink: 0; }
.ch-card-cta:hover { transform: translateY(-1px); box-shadow: 0 6px 14px -2px rgba(15, 23, 42, 0.14); }
.ch-card-cta.cta-kakao { background: #FEE500; color: #181600; }
.ch-card-cta.cta-kakao:hover { background: #FFD600; }
.ch-card-cta.cta-phone { background: #2563EB; color: #fff; }
.ch-card-cta.cta-phone:hover { background: #1d4ed8; }
.ch-card-cta.cta-web { background: #1F2937; color: #fff; }
.ch-card-cta.cta-web:hover { background: #111827; }

/* response time strip */
.ch-strip {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 24px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--brand) 6%, #fff), #fff);
  border: 1px solid color-mix(in srgb, var(--brand) 18%, transparent);
  border-radius: 12px;
  font-size: 14px;
  color: var(--ink);
  font-weight: 600;
  letter-spacing: -0.01em;
  flex-wrap: wrap;
  justify-content: center;
}
.ch-strip b { color: var(--brand); font-weight: 800; }
.ch-strip-bolt {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--brand);
  color: #fff;
  font-size: 14px;
}
.ch-strip-divider { width: 1px; height: 16px; background: color-mix(in srgb, var(--ink) 16%, transparent); }
.ch-strip-meta { color: var(--ink-mute); font-size: 13px; font-weight: 500; }
@media (max-width: 600px) { .ch-strip-divider { display: none; } }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 40px; flex-wrap: wrap; }
.section-eyebrow { font-size: 13px; font-weight: 600; color: var(--brand); letter-spacing: 0.05em; text-transform: uppercase; font-family: 'JetBrains Mono', monospace; }
.section-title { font-size: clamp(28px, 3.5vw, 40px); font-weight: 800; letter-spacing: -0.03em; margin: 8px 0 0; line-height: 1.15; text-wrap: balance; }
.section-sub { font-size: 16px; color: var(--ink-soft); margin-top: 12px; max-width: 560px; line-height: 1.6; text-wrap: pretty; }
.section-actions { display: flex; gap: 10px; }

/* ============== DISPATCH BOARD (full) ============== */
.board-wrap {
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
.board-head {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 20px 24px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-panel);
  flex-wrap: wrap;
}
.networks { display: flex; gap: 8px; flex-wrap: wrap; }
.net-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: 10px;
  background: var(--bg-soft); color: var(--ink-soft);
  font-size: 13px; font-weight: 600;
  border: 1px solid var(--line);
}
.net-chip .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }
.net-chip.off .dot { background: var(--ink-mute); }
.net-chip.off { color: var(--ink-mute); }

.board-body { overflow-x: auto; }
.board-table {
  width: 100%; border-collapse: collapse; min-width: 880px;
}
.board-table thead th {
  text-align: left; font-size: 12px; font-weight: 600; letter-spacing: 0.04em;
  color: var(--ink-mute); text-transform: uppercase;
  padding: 14px 16px; background: var(--bg-soft);
  border-bottom: 1px solid var(--line);
}
.board-table tbody td {
  padding: 16px; border-bottom: 1px solid var(--line);
  font-size: 14px; vertical-align: middle;
}
.board-table tbody tr:last-child td { border-bottom: 0; }
.board-table tbody tr:hover { background: color-mix(in srgb, var(--brand-tint) 70%, transparent); }
.cell-time { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--ink-soft); white-space: nowrap; }
.cell-company { font-weight: 600; }
.cell-cargo { color: var(--ink-soft); font-size: 13px; }
.cell-vehicle { font-weight: 500; font-size: 13px; }
.cell-route { font-size: 13px; }
.cell-route .arrow { color: var(--ink-mute); margin: 0 6px; }

/* 실시간 배차 현황: 각 셀을 한 줄로(줄바꿈 없이) 깔끔하게, 넘치면 말줄임 */
.board-table { table-layout: fixed; }
.board-table thead th { white-space: nowrap; }
.board-table tbody td {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.board-table th:nth-child(1), .board-table td:nth-child(1) { width: 10%; }  /* 접수시각 */
.board-table th:nth-child(2), .board-table td:nth-child(2) { width: 14%; }  /* 업체명 */
.board-table th:nth-child(3), .board-table td:nth-child(3) { width: 22%; }  /* 화물정보 */
.board-table th:nth-child(4), .board-table td:nth-child(4) { width: 15%; }  /* 수배차종 */
.board-table th:nth-child(5), .board-table td:nth-child(5) { width: 27%; }  /* 운송구간 */
.board-table th:nth-child(6), .board-table td:nth-child(6) { width: 12%; }  /* 진행상태 */

/* ============== NETWORK DIAGRAM (7 networks → engine → result) ============== */
.netdiag-wrap {
  background: rgba(37, 99, 235, 0.03);
  border: 1px solid rgba(37, 99, 235, 0.08);
  border-radius: 16px;
  padding: 48px;
  margin-bottom: 48px;
}
.netdiag-caption {
  margin: 36px 0 0;
  text-align: center;
  font-size: 14px;
  color: var(--ink-soft);
  font-weight: 500;
  letter-spacing: -0.01em;
}
.netdiag-caption b { color: var(--brand); font-weight: 800; }

.netdiag {
  display: grid;
  grid-template-columns: 1.1fr 90px 1fr 90px 1fr;
  position: relative;
  align-items: center;
  gap: 12px;
  position: relative;
}
@media (max-width: 1024px) {
  .netdiag {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

.netdiag-side {
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
}
.netdiag-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--ink-mute);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
  margin-bottom: 6px;
  padding-left: 4px;
}
.netdiag-node {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 10px;
  transition: transform .2s ease, border-color .2s ease;
  animation: netNodeIn .5s cubic-bezier(.2,.9,.3,1) both;
}
@keyframes netNodeIn {
  from { opacity: 0; transform: translateX(-8px); }
  to   { opacity: 1; transform: translateX(0); }
}
.netdiag-node.node-own {
  background: linear-gradient(135deg, #2563EB, #1d4ed8);
  border-color: #1d4ed8;
  color: #fff;
  padding: 14px 16px;
  box-shadow: 0 8px 22px -6px rgba(37, 99, 235, 0.45);
  margin-bottom: 8px;
}
.node-icon {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: rgba(255,255,255,0.18);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.node-icon svg { width: 18px; height: 18px; }
.node-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--ink-mute);
  flex-shrink: 0;
}
.node-body { flex: 1; min-width: 0; }
.node-name {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.netdiag-node.node-own .node-name { color: #fff; font-size: 15px; }
.node-meta {
  font-size: 11px;
  color: var(--ink-mute);
  font-weight: 500;
  margin-top: 2px;
}
.netdiag-node.node-own .node-meta { color: rgba(255,255,255,0.78); }
.netdiag-node.node-ext {
  color: var(--ink-mute);
}
.node-badge {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.1em;
  background: rgba(255,255,255,0.22);
  color: #fff;
  padding: 3px 7px;
  border-radius: 999px;
  font-family: 'JetBrains Mono', monospace;
}

/* Flow arrows */
.netdiag-flow {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  color: rgba(37, 99, 235, 0.4);
}
.flow-arrow {
  width: 0; height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-left: 6px solid currentColor;
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
}
.netdiag-flow .flow-arrow {
  width: 8px; height: 8px;
  border: 0;
  position: relative;
}
.netdiag-flow .flow-arrow::before {
  content: ""; position: absolute; inset: 0;
  background: currentColor;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  animation: flowArrow 1.6s ease-in-out infinite;
}
.netdiag-flow .flow-arrow:nth-child(1)::before { animation-delay: 0s; }
.netdiag-flow .flow-arrow:nth-child(2)::before { animation-delay: .2s; }
.netdiag-flow .flow-arrow:nth-child(3)::before { animation-delay: .4s; }
@keyframes flowArrow {
  0%, 100% { opacity: 0.3; transform: translateX(-2px); }
  50%      { opacity: 1;   transform: translateX(2px); }
}
@media (max-width: 1024px) {
  .netdiag-flow { flex-direction: row; }
  .netdiag-flow .flow-arrow::before { clip-path: polygon(0 0, 50% 100%, 100% 0); }
  @keyframes flowArrow {
    0%, 100% { opacity: 0.3; transform: translateY(-2px); }
    50%      { opacity: 1;   transform: translateY(2px); }
  }
}

/* Engine orb */
.netdiag-engine {
  display: flex; flex-direction: column; align-items: center; gap: 16px;
}
.engine-orb {
  position: relative;
  width: 140px; height: 140px;
  display: flex; align-items: center; justify-content: center;
}
.engine-ring {
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 2px solid #2563EB;
  opacity: 0;
}
.engine-ring.r1 { animation: enginePulse 2.4s ease-out infinite; }
.engine-ring.r2 { animation: enginePulse 2.4s ease-out .8s infinite; }
.engine-ring.r3 { animation: enginePulse 2.4s ease-out 1.6s infinite; }
@keyframes enginePulse {
  0%   { transform: scale(0.7); opacity: 0.7; }
  100% { transform: scale(1.2); opacity: 0; }
}
.engine-core {
  position: relative;
  width: 96px; height: 96px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3B82F6, #1d4ed8);
  display: flex; align-items: center; justify-content: center;
  box-shadow:
    0 12px 32px -6px rgba(37, 99, 235, 0.55),
    inset 0 2px 0 rgba(255,255,255,0.3);
  color: #fff;
}
.engine-spark {
  font-size: 36px;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
  animation: engineSpark 2.4s ease-in-out infinite;
}
@keyframes engineSpark {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.1); }
}
.engine-label { text-align: center; }
.engine-name {
  font-size: 15px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.02em;
}
.engine-sub {
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-mute);
  margin-top: 2px;
}

/* Result card */
.netdiag-result {
  background: #fff;
  border: 1px solid rgba(16, 185, 129, 0.22);
  border-radius: 14px;
  padding: 22px 22px 20px;
  text-align: center;
  box-shadow: 0 8px 22px -8px rgba(16, 185, 129, 0.18);
  transition: box-shadow .35s ease, border-color .35s ease;
}
.netdiag-result.is-receiving {
  border-color: rgba(16, 185, 129, 0.6);
  box-shadow:
    0 0 0 4px rgba(16, 185, 129, 0.18),
    0 16px 36px -10px rgba(16, 185, 129, 0.4);
}
.netdiag-result.is-receiving .result-check { animation: ndCheckPulse 0.35s ease-out; }
@keyframes ndCheckPulse {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.18); box-shadow: 0 0 0 10px rgba(16, 185, 129, 0); }
  100% { transform: scale(1); }
}

/* node active highlight */
.netdiag-node.is-active {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 14%, transparent),
              0 6px 14px -4px color-mix(in srgb, var(--brand) 22%, transparent);
}
.netdiag-node.node-own.is-active {
  box-shadow: 0 0 0 3px rgba(255,255,255,0.25),
              0 12px 28px -6px rgba(37, 99, 235, 0.6);
}
.netdiag-node { transition: box-shadow .25s ease, border-color .25s ease; }

/* engine receiving burst */
.netdiag-engine.is-receiving .engine-core {
  animation: ndEngineFlash .35s ease-out;
}
@keyframes ndEngineFlash {
  0%, 100% { box-shadow: 0 12px 32px -6px rgba(37, 99, 235, 0.55), inset 0 2px 0 rgba(255,255,255,0.3); }
  50%      { box-shadow: 0 16px 44px -4px rgba(37, 99, 235, 0.85), 0 0 0 6px rgba(37, 99, 235, 0.15), inset 0 2px 0 rgba(255,255,255,0.5); }
}
.engine-ring.r-burst {
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 2px solid #2563EB;
  animation: ndBurst .6s ease-out forwards;
}
@keyframes ndBurst {
  0%   { transform: scale(0.7); opacity: 0.9; }
  100% { transform: scale(1.8); opacity: 0; }
}

/* === Sequenced curve overlay (replaces dot particles) === */
.netdiag-curves {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 1;
  overflow: visible;
}
.netdiag-curves .curve-in,
.netdiag-curves .curve-out {
  stroke-linecap: round;
  stroke-dasharray: 100;
  stroke-dashoffset: 100;
  opacity: 0;
  transition: opacity .6s ease-out;
}
.netdiag-curves .curve-in  { stroke: rgba(37, 99, 235, 0.7); stroke-width: 1.6; }
.netdiag-curves .curve-in.is-own { stroke: #2563EB; stroke-width: 2.2; }
.netdiag-curves .curve-out { stroke: rgba(16, 185, 129, 0.85); stroke-width: 2.2; }

/* drawIn — left curves draw simultaneously */
.netdiag-curves.phase-drawIn .curve-in {
  opacity: 1;
  animation: ndDrawCurve 1.2s cubic-bezier(.4,.0,.2,1) forwards;
}
@keyframes ndDrawCurve {
  from { stroke-dashoffset: 100; }
  to   { stroke-dashoffset: 0; }
}

/* hold — fully drawn, sit still */
.netdiag-curves.phase-hold .curve-in,
.netdiag-curves.phase-drawOut .curve-in {
  opacity: 1;
  stroke-dashoffset: 0;
}

/* drawOut — single curve to result */
.netdiag-curves.phase-drawOut .curve-out {
  opacity: 1;
  animation: ndDrawCurve 1.2s cubic-bezier(.4,.0,.2,1) forwards;
}

/* fade — everything fades out together */
.netdiag-curves.phase-fade .curve-in,
.netdiag-curves.phase-fade .curve-out {
  opacity: 0;
  stroke-dashoffset: 0;
  transition: opacity .6s ease-out;
}

/* Hide the old dot particle layer entirely if it ever renders */
.netdiag-particles { display: none; }

@media (prefers-reduced-motion: reduce) {
  .netdiag-curves { display: none; }
}
@media (max-width: 1024px) {
  /* On stacked mobile layout the geometry doesn't match; hide curves */
  .netdiag-curves { display: none; }
}

.result-check {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: #10B981;
  color: #fff;
  margin-bottom: 12px;
  box-shadow: 0 6px 14px -4px rgba(16, 185, 129, 0.5);
}
.result-check svg { width: 24px; height: 24px; }
.result-title {
  font-size: 15px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.02em;
  line-height: 1.4;
}
.result-sub {
  font-size: 12px;
  color: var(--ink-soft);
  margin-top: 8px;
  line-height: 1.6;
}

/* Section sub line with bold */
.section-sub b { color: var(--ink); font-weight: 800; }

/* Divider between netdiag and pillars */
.pillars-divider {
  display: flex; align-items: center; gap: 16px;
  margin: 8px 0 28px;
  color: var(--ink-mute);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
}
.pillars-divider::before,
.pillars-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--line);
}

/* ============== PILLARS ============== */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
@media (max-width: 860px) { .pricing-grid { grid-template-columns: 1fr; } }
.pricing-card {
  position: relative;
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 16px;
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 14px;
  box-shadow: 0 2px 8px -2px rgba(15, 23, 42, 0.04);
  transition: transform .25s cubic-bezier(.2,.9,.3,1.1), box-shadow .25s ease, border-color .2s ease;
}
.pricing-card:hover {
  transform: translateY(-4px);
  border-color: rgba(37, 99, 235, 0.32);
  box-shadow: 0 16px 32px -10px rgba(37, 99, 235, 0.18), 0 4px 10px -2px rgba(15, 23, 42, 0.06);
}
.pricing-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px;
  border-radius: 12px;
  background: color-mix(in srgb, #2563EB 10%, #fff);
  color: #2563EB;
}
.pricing-icon svg { width: 28px; height: 28px; }
.pricing-badge {
  position: absolute; top: -10px; right: 18px;
  background: #2563EB; color: #fff;
  font-size: 11px; font-weight: 800;
  padding: 5px 11px; border-radius: 999px;
  letter-spacing: -0.01em;
  box-shadow: 0 4px 10px -2px rgba(37, 99, 235, 0.35);
}
.pricing-title { margin: 0; font-size: 22px; font-weight: 800; letter-spacing: -0.025em; color: var(--ink); }
.pricing-desc { margin: 0; font-size: 14px; line-height: 1.6; color: var(--ink-soft); font-weight: 500; }
.pricing-pts { list-style: none; padding: 0; margin: 8px 0 0; display: grid; gap: 8px; }
.pricing-pts li {
  position: relative;
  padding-left: 22px;
  font-size: 14px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em;
}
.pricing-pts li::before {
  content: "";
  position: absolute; left: 0; top: 8px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: rgba(37,99,235,0.12);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'><path d='M3 6l2 2 4-4' fill='none' stroke='%232563EB' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-position: center;
  background-repeat: no-repeat;
}
.pricing-note {
  text-align: center; margin: 28px 0 0;
  font-size: 13px; color: var(--ink-mute); font-weight: 500;
}

/* ============== GROWTH CHARTS ============== */
.growth-block { margin: 48px 0 0; }
.growth-head { text-align: center; max-width: 640px; margin: 0 auto 24px; }
.growth-eyebrow {
  display: inline-block;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--brand);
  font-family: 'JetBrains Mono', monospace;
  margin-bottom: 8px;
}
.growth-title { margin: 0; font-size: clamp(22px, 2.4vw, 30px); font-weight: 800; letter-spacing: -0.025em; color: var(--ink); }
.growth-sub { margin: 8px 0 0; font-size: 14px; color: var(--ink-soft); font-weight: 500; }
.growth-sub b { color: var(--ink); font-weight: 800; }

.growth-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 22px;
}
@media (max-width: 860px) { .growth-grid { grid-template-columns: 1fr; } }
.growth-card {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  padding: 22px 24px 14px;
  box-shadow: 0 6px 18px -10px rgba(15, 23, 42, 0.08);
}
.growth-card-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 12px; margin-bottom: 8px;
}
.growth-card-lbl {
  font-size: 12px; font-weight: 700;
  color: var(--ink-mute); letter-spacing: 0.05em; text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
}
.growth-card-final {
  margin-top: 4px;
  font-size: 26px; font-weight: 800; letter-spacing: -0.03em; color: var(--ink);
}
.growth-card-final .unit { font-size: 14px; font-weight: 700; color: var(--ink-mute); margin-left: 2px; }
.growth-year { font-size: 12px; font-weight: 600; color: var(--ink-mute); margin-left: 6px; font-family: 'JetBrains Mono', monospace; }
.growth-card-hi {
  display: inline-flex; align-items: baseline; gap: 4px;
  padding: 6px 12px;
  background: rgba(37, 99, 235, 0.08);
  color: #2563EB;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.growth-card-hi.growth-card-hi-alt { background: rgba(16, 185, 129, 0.1); color: #10B981; }
.growth-card-hi-arrow { font-size: 12px; }
.growth-card-hi-num { font-size: 16px; }
.growth-card-hi-meta { font-size: 11px; font-weight: 600; opacity: 0.75; margin-left: 4px; }
.growth-svg { width: 100%; height: auto; display: block; }

/* cert-row extras */
.cert-extra {
  display: inline-flex; align-items: center; gap: 8px;
  margin-left: 8px;
  padding: 8px 14px;
  background: color-mix(in srgb, var(--brand) 8%, #fff);
  border: 1px solid color-mix(in srgb, var(--brand) 18%, transparent);
  border-radius: 10px;
  font-size: 13px;
  color: var(--ink);
  font-weight: 600;
}
.cert-extra-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--brand); }
.cert-extra b { font-weight: 800; color: var(--brand); }
.cert-extra-meta { display: block; font-size: 11px; color: var(--ink-mute); font-weight: 500; margin-top: 2px; }
.cert-license { margin-left: auto; font-size: 12px; color: var(--ink-mute); }
@media (max-width: 720px) { .cert-license { margin-left: 0; width: 100%; } }
.pillars {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 860px) { .pillars { grid-template-columns: 1fr; } }
.pillar {
  position: relative;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 36px;
  overflow: hidden;
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.pillar:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.pillar-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; color: var(--ink-mute); margin-bottom: 16px;
}
.pillar h3 { font-size: 24px; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 10px; }
.pillar p { color: var(--ink-soft); margin: 0 0 24px; line-height: 1.6; }
.pillar-list { list-style: none; padding: 0; margin: 0 0 28px; display: grid; gap: 10px; }
.pillar-list li { font-size: 14px; color: var(--ink); display: flex; gap: 10px; align-items: start; }
.pillar-list li::before {
  content: ""; flex: 0 0 6px; height: 6px; margin-top: 8px;
  border-radius: 50%; background: var(--brand);
}
.pillar-visual {
  margin-top: 24px;
  height: 160px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--bg-soft);
  position: relative;
  overflow: hidden;
}

/* mini route diagram */
.route-svg { width: 100%; height: 100%; }
.route-svg .stop { fill: var(--brand); }
.route-svg .road { stroke: var(--brand); stroke-width: 1.5; fill: none; stroke-dasharray: 4 4; }
.route-svg .label { font-size: 10px; font-family: 'JetBrains Mono', monospace; fill: var(--ink-mute); }
.route-svg .truck { fill: var(--ink); }
.route-svg .city { fill: var(--ink-soft); font-size: 11px; font-family: 'Pretendard', sans-serif; font-weight: 600; }
[data-palette="dark"] .route-svg .truck { fill: var(--ink); }

/* ============== TOOL CARDS ============== */
.tools {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 860px) { .tools { grid-template-columns: 1fr; } }
.tool {
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 24px;
  display: flex; flex-direction: column; gap: 12px;
  transition: all .15s;
}
.tool-head { display: flex; align-items: center; gap: 14px; }
.tool-head h4 { margin: 0; }
.tool:hover { border-color: color-mix(in srgb, var(--brand) 35%, var(--line)); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.tool-icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: var(--brand-soft); color: var(--brand);
  border-radius: 12px;
}
.tool-icon svg { width: 22px; height: 22px; }
.tool h4 { margin: 0; font-size: 18px; font-weight: 700; letter-spacing: -0.02em; }
.tool p { margin: 0; color: var(--ink-soft); font-size: 14px; line-height: 1.55; }
.tool-link { display: inline-flex; align-items: center; gap: 4px; color: var(--brand); font-weight: 600; font-size: 14px; margin-top: auto; }
.tool-link:hover { gap: 8px; }

/* ============== RATE WIDGET ============== */
.rate-card {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 0;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
@media (max-width: 860px) { .rate-card { grid-template-columns: 1fr; } }

.rate-form {
  padding: 32px;
  background: var(--bg-soft);
  border-right: 1px solid var(--line);
}
@media (max-width: 860px) { .rate-form { border-right: 0; border-bottom: 1px solid var(--line); } }
.rate-form h4 { margin: 0 0 4px; font-size: 18px; font-weight: 700; }
.rate-form .rate-sub { color: var(--ink-soft); font-size: 13px; margin-bottom: 20px; }

.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.field label { font-size: 12px; font-weight: 600; color: var(--ink-soft); }
.field input, .field select {
  font: inherit; padding: 11px 14px;
  border: 1px solid var(--line-strong); border-radius: 10px;
  background: var(--bg-panel); color: var(--ink);
  outline: none; transition: border-color .15s, box-shadow .15s;
}
.field input:focus, .field select:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 18%, transparent);
}

.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  padding: 7px 11px; border-radius: 8px;
  background: var(--bg-panel); border: 1px solid var(--line-strong);
  font-size: 12px; font-weight: 500; color: var(--ink-soft);
  cursor: pointer;
}
.chip.on { background: var(--brand); color: #fff; border-color: var(--brand); }

.rate-result {
  padding: 32px;
  display: flex; flex-direction: column; gap: 18px;
}
.rate-route {
  display: flex; align-items: center; gap: 16px;
  font-weight: 600; font-size: 16px;
  padding: 16px 20px;
  background: var(--brand-tint); border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--brand) 16%, var(--line));
}
.rate-route .arr { flex: 1; height: 2px; background: var(--brand); position: relative; }
.rate-route .arr::after {
  content: ""; position: absolute; right: 0; top: 50%; transform: translateY(-50%) rotate(45deg);
  width: 8px; height: 8px; border-right: 2px solid var(--brand); border-top: 2px solid var(--brand);
}

.rate-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
}
@media (max-width: 520px) { .rate-grid { grid-template-columns: 1fr 1fr; } }
.rate-tile {
  border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px;
  background: var(--bg-panel);
}
.rate-tile.featured { background: var(--brand); color: #fff; border-color: var(--brand); }
.rate-tile .lbl { font-size: 12px; color: var(--ink-mute); }
.rate-tile.featured .lbl { color: rgba(255,255,255,.75); }
.rate-tile .val { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin-top: 4px; }
.rate-tile .val .unit { font-size: 13px; font-weight: 500; color: var(--ink-mute); margin-left: 2px; }
.rate-tile.featured .val .unit { color: rgba(255,255,255,.75); }

.rate-meta { font-size: 12px; color: var(--ink-mute); display: flex; gap: 14px; flex-wrap: wrap; }
.rate-meta b { color: var(--ink); }

/* ============== RATE ESTIMATOR (지도 기반) ============== */
.est-card {
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow-md);
  padding: 28px 28px 32px;
  position: relative;
}
@media (max-width: 720px) { .est-card { padding: 20px 18px 24px; border-radius: 18px; } }

.est-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.est-title { display: flex; align-items: center; gap: 10px; font-weight: 700; font-size: 17px; letter-spacing: -0.01em; }
.est-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
  position: relative;
}
.est-dot::after {
  content: ""; position: absolute; inset: -4px; border-radius: 50%;
  border: 2px solid var(--accent); opacity: .55;
  animation: estPulse 2s ease-out infinite;
}
@keyframes estPulse { 0% { transform: scale(.6); opacity: .8; } 100% { transform: scale(1.6); opacity: 0; } }

.est-reset {
  background: transparent; border: 0; cursor: pointer;
  font: inherit; font-size: 13px; color: var(--ink-mute);
  padding: 6px 10px; border-radius: 8px; transition: color .15s, background .15s;
}
.est-reset:hover:not(:disabled) { color: var(--ink); background: var(--bg-soft); }
.est-reset:disabled { opacity: .4; cursor: not-allowed; }

/* Stepper */
.est-stepper { display: flex; align-items: center; gap: 12px; padding: 8px 0 18px; border-bottom: 1px solid var(--line); margin-bottom: 16px; }
.est-step { display: flex; align-items: center; gap: 10px; }
.est-step-num {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--bg-soft); color: var(--ink-mute);
  font-size: 13px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--line);
  transition: all .2s;
}
.est-step-lbl { font-size: 14px; font-weight: 600; color: var(--ink-mute); transition: color .2s; }
.est-step.active .est-step-num { background: var(--brand); color: #fff; border-color: var(--brand); box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand) 14%, transparent); }
.est-step.active .est-step-lbl { color: var(--ink); }
.est-step.done .est-step-num { background: var(--accent); color: #fff; border-color: var(--accent); }
.est-step.done .est-step-lbl { color: var(--ink); }
.est-step-line { flex: 1; height: 2px; background: var(--line); border-radius: 1px; transition: background .3s; }
.est-step-line.on { background: var(--accent); }

/* Route summary bar */
.est-route {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px; background: var(--bg-soft); border-radius: 12px;
  font-size: 14px; font-weight: 500;
  margin-bottom: 18px;
}
.est-route-end { display: inline-flex; align-items: center; gap: 8px; color: var(--ink-mute); font-weight: 500; }
.est-route-end.set { color: var(--ink); font-weight: 700; }
.est-route-arr { color: var(--ink-mute); font-weight: 600; }
.est-route-pin { width: 8px; height: 8px; border-radius: 50%; }
.est-route-pin.origin { background: var(--brand); }
.est-route-pin.dest { background: #f59e0b; }
.est-route-end.set .est-route-pin { box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 8%, transparent); }

/* Canvas (map / city / result) */
.est-canvas {
  position: relative;
  background: linear-gradient(180deg, color-mix(in srgb, var(--brand) 4%, var(--bg-soft)) 0%, var(--bg-soft) 100%);
  border-radius: 16px;
  padding: 24px 16px;
  min-height: 540px;
  display: flex;
  flex-direction: column;
}

/* Map */
.est-map { position: relative; flex: 1; display: flex; flex-direction: column; }
.est-tip {
  position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
  background: #1f2937; color: #fff;
  padding: 9px 18px; border-radius: 999px;
  font-size: 13px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 6px;
  z-index: 5;
  box-shadow: 0 8px 24px -6px rgba(0,0,0,.25), 0 2px 8px rgba(0,0,0,.12);
  white-space: nowrap;
}
.est-tip-dot-a { width: 6px; height: 6px; border-radius: 50%; background: #f59e0b; }
.est-tip-dot-b { width: 8px; height: 8px; border-radius: 50%; background: #fbbf24; box-shadow: 0 0 0 3px rgba(251,191,36,.25); margin-right: 4px; }

.est-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(60px, 96px));
  grid-template-rows: repeat(7, 1fr);
  gap: 8px;
  width: 100%;
  max-width: 540px;
  margin: 64px auto 8px;
  aspect-ratio: 5 / 7;
  justify-content: center;
}

/* SVG map */
.est-svg {
  display: block;
  width: 100%;
  max-width: 420px;
  margin: 0 0 0 auto;
  aspect-ratio: 260 / 360;
}
.est-svg-water path { stroke: color-mix(in srgb, var(--brand) 16%, transparent); stroke-width: 1.2; stroke-dasharray: 3 4; opacity: .6; }
.est-region { cursor: pointer; transition: transform .12s; }
.est-region polygon, .est-region path {
  fill: #fff;
  stroke: var(--line-strong);
  stroke-width: 0.8;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
  transition: fill .15s, stroke .15s, filter .15s;
}
.est-region.g-cap polygon, .est-region.g-cap path { fill: #f0f6ff; stroke: #b9d0f7; }
.est-region.g-chc polygon, .est-region.g-chc path { fill: #f0fdf4; stroke: #b8dec7; }
.est-region.g-hon polygon, .est-region.g-hon path { fill: #fef9e7; stroke: #e6d7a0; }
.est-region.g-yeo polygon, .est-region.g-yeo path { fill: #fef2f2; stroke: #e9c0c0; }
.est-region.g-gw  polygon, .est-region.g-gw  path { fill: #f5f3ff; stroke: #c8c0e2; }
.est-region.g-jj  polygon, .est-region.g-jj  path { fill: #ecfeff; stroke: #a6dde7; }
.est-region.is-metro polygon, .est-region.is-metro path { stroke-width: 1; stroke: #7c93b3; }
.est-region:not(.is-disabled):hover polygon, .est-region:not(.is-disabled):hover path { fill: var(--brand); stroke: var(--brand); filter: url(#estShadow); }
.est-region:not(.is-disabled):hover .est-region-label { fill: #fff; }
.est-region.is-origin polygon, .est-region.is-origin path { fill: var(--brand) !important; stroke: var(--brand) !important; filter: url(#estShadow); }
.est-region.is-origin .est-region-label { fill: #fff; }
.est-region.is-dest polygon, .est-region.is-dest path { fill: #f59e0b !important; stroke: #f59e0b !important; filter: url(#estShadow); }
.est-region.is-dest .est-region-label { fill: #fff; }
.est-region.is-disabled { cursor: not-allowed; opacity: .7; }

.est-region-label {
  font-size: 11px;
  font-weight: 700;
  fill: var(--ink);
  pointer-events: none;
  letter-spacing: -0.01em;
  font-family: 'Pretendard', sans-serif;
}
.est-region.is-metro .est-region-label { font-size: 9.5px; }
.est-region-pin.origin { fill: #fff; stroke: var(--brand); stroke-width: 2; }
.est-region-pin.dest { fill: #fff; stroke: #f59e0b; stroke-width: 2; }
.est-region-pin-text { font-size: 9px; font-weight: 800; pointer-events: none; font-family: 'Pretendard', sans-serif; }
.est-region.is-origin .est-region-pin-text { fill: var(--brand); }
.est-region.is-dest .est-region-pin-text { fill: #f59e0b; }

/* compact + console-est tweaks for SVG */
.est-card.est-compact .est-svg { max-width: 100%; margin: 38px auto 2px; }
.console-est .est-card.est-compact .est-svg { max-width: 100%; margin: 32px auto 2px; }
.console-est .est-card.est-compact .est-region-label { font-size: 10px; }
.console-est .est-card.est-compact .est-region.is-metro .est-region-label { font-size: 8.5px; }
.est-prov {
  position: relative;
  font: inherit; font-size: 14px; font-weight: 700;
  letter-spacing: -0.01em;
  border: 1.5px solid var(--line-strong);
  background: #fff;
  color: var(--ink);
  border-radius: 12px;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s, border-color .15s, background .15s, color .15s;
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 0;
}
.est-prov.g-cap { background: #f0f6ff; border-color: #cfe0ff; }
.est-prov.g-chc { background: #f0fdf4; border-color: #c8ebd2; }
.est-prov.g-hon { background: #fef9e7; border-color: #f1e3b0; }
.est-prov.g-yeo { background: #fef2f2; border-color: #f3cfcf; }
.est-prov.g-gw  { background: #f5f3ff; border-color: #d6cfee; }
.est-prov.g-jj  { background: #ecfeff; border-color: #b5e6ed; }
.est-prov:hover:not(:disabled) {
  border-color: var(--brand);
  background: var(--brand);
  color: #fff;
  transform: translateY(-2px) scale(1.04);
  box-shadow: 0 10px 24px -8px color-mix(in srgb, var(--brand) 50%, transparent);
  z-index: 2;
}
.est-prov.is-origin { background: var(--brand) !important; color: #fff !important; border-color: var(--brand) !important; box-shadow: 0 6px 16px -4px color-mix(in srgb, var(--brand) 50%, transparent); }
.est-prov.is-dest { background: #f59e0b !important; color: #fff !important; border-color: #f59e0b !important; box-shadow: 0 6px 16px -4px rgba(245,158,11,.5); }
.est-prov:disabled { opacity: .55; cursor: not-allowed; }

.est-prov-tag {
  position: absolute; top: -8px; right: -8px;
  font-size: 10px; font-weight: 700;
  padding: 3px 7px; border-radius: 999px;
  background: #fff; color: var(--ink);
  box-shadow: 0 2px 6px rgba(0,0,0,.15);
  border: 1.5px solid currentColor;
}
.est-prov-tag.origin { color: var(--brand); }
.est-prov-tag.dest { color: #f59e0b; }

.est-legend { display: flex; gap: 18px; align-items: center; justify-content: center; font-size: 12px; color: var(--ink-mute); padding: 14px 0 4px; flex-wrap: wrap; }
.est-legend i.dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: 5px; vertical-align: -1px; }
.est-legend i.dot.origin { background: var(--brand); }
.est-legend i.dot.dest { background: #f59e0b; }
.est-legend-note { font-style: italic; opacity: .8; }

/* City list */
.est-city-panel {
  flex: 1;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 22px 26px;
  display: flex; flex-direction: column;
  animation: estSlideIn .25s ease-out;
}
@keyframes estSlideIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.est-city-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; flex-wrap: wrap; margin-bottom: 18px; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.est-city-eyebrow { font-size: 12px; font-weight: 600; color: var(--brand); letter-spacing: 0.04em; text-transform: uppercase; font-family: 'JetBrains Mono', monospace; margin-bottom: 4px; }
.est-city-eyebrow b { color: var(--ink); font-weight: 700; font-family: inherit; text-transform: none; letter-spacing: 0; }
.est-city-title { font-size: 18px; font-weight: 700; letter-spacing: -0.01em; }
.est-city-close { background: transparent; border: 1px solid var(--line-strong); cursor: pointer; font: inherit; font-size: 13px; color: var(--ink-soft); padding: 7px 14px; border-radius: 8px; transition: all .15s; }
.est-city-close:hover { background: var(--bg-soft); color: var(--ink); }
.est-city-list { display: flex; flex-wrap: wrap; gap: 8px; }
.est-city-chip {
  font: inherit; font-size: 13px; font-weight: 500;
  padding: 9px 14px; border-radius: 8px;
  background: var(--bg-soft); border: 1px solid var(--line);
  color: var(--ink); cursor: pointer;
  transition: all .15s;
}
.est-city-chip:hover { background: var(--brand); color: #fff; border-color: var(--brand); transform: translateY(-1px); }
/* '전체(시·군·구청 기준)' 칩 — 읍·면·동 목록 맨 앞, 강조 */
.est-city-chip.is-whole { font-weight: 700; border-color: var(--brand); color: var(--brand); background: color-mix(in srgb, var(--brand) 8%, #fff); }
.est-city-chip.is-whole:hover { background: var(--brand); color: #fff; }
.est-city-chip.is-whole .est-city-chip-arr { font-weight: 500; opacity: .8; }

/* CTA */
.est-cta-wrap { display: flex; justify-content: center; padding: 18px 0 6px; }
.est-cta {
  font-size: 15px; padding: 14px 28px; border-radius: 12px;
  animation: estCtaIn .3s ease-out;
}
@keyframes estCtaIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }

/* Result */
.est-result {
  flex: 1;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 26px;
  display: flex; flex-direction: column; gap: 18px;
  animation: estSlideIn .25s ease-out;
}
.est-result-route {
  display: flex; align-items: center; gap: 14px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--brand) 8%, #fff), #fff);
  padding: 16px 18px; border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--brand) 20%, var(--line));
  flex-wrap: nowrap;
  min-width: 0;
}
.est-result-route .erp { min-width: 0; flex-shrink: 1; }
.est-result-route .erp-city { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@media (max-width: 720px) {
  .est-result-route { flex-wrap: wrap; }
}
.erp-veh-wrap {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 10px 6px 12px;
  background: #fff;
  border: 1.5px solid color-mix(in srgb, var(--brand) 38%, transparent);
  border-radius: 12px;
  box-shadow: 0 6px 14px -4px color-mix(in srgb, var(--brand) 22%, transparent),
              0 0 0 4px color-mix(in srgb, var(--brand) 8%, transparent);
  position: relative;
  flex-shrink: 0;
  animation: erpVehPulse 2.4s ease-in-out infinite;
}
@keyframes erpVehPulse {
  0%, 100% { box-shadow: 0 6px 14px -4px color-mix(in srgb, var(--brand) 22%, transparent),
                          0 0 0 4px color-mix(in srgb, var(--brand) 8%, transparent); }
  50%      { box-shadow: 0 8px 18px -4px color-mix(in srgb, var(--brand) 34%, transparent),
                          0 0 0 6px color-mix(in srgb, var(--brand) 14%, transparent); }
}
/* 차체(윙/카고 · 카고) 토글 — 차종 왼쪽 */
.erp-body-wrap {
  margin-left: auto;               /* 그룹(차체+차종)을 우측으로 */
  display: inline-flex; align-items: center; gap: 8px;
  flex-shrink: 0;
}
.est-result-route .erp-veh-wrap { margin-left: 10px; } /* 토글 바로 오른쪽에 차종 */
.erp-body-toggle {
  display: inline-flex;
  background: color-mix(in srgb, var(--ink) 6%, #fff);
  border: 1px solid color-mix(in srgb, var(--ink) 14%, transparent);
  border-radius: 10px; padding: 2px;
}
.erp-body-btn {
  appearance: none; -webkit-appearance: none; border: 0; background: transparent;
  cursor: pointer; font-family: inherit; font-size: 12.5px; font-weight: 600;
  color: var(--ink-mute, #64748B);
  padding: 6px 12px; border-radius: 8px; line-height: 1;
  transition: background .18s ease, color .18s ease;
}
.erp-body-btn.is-on {
  background: var(--brand); color: #fff;
  box-shadow: 0 2px 6px -2px color-mix(in srgb, var(--brand) 50%, transparent);
}
@media (max-width: 720px) {
  .erp-body-wrap { margin-left: 0; width: 100%; padding-top: 10px; }
  .est-result-route .erp-veh-wrap { margin-left: 0; }
}
.erp-veh-label {
  font-size: 13px; font-weight: 700;
  color: var(--brand);
  letter-spacing: -0.01em;
}
.erp-veh-req {
  color: #ef4444;
  font-weight: 800;
  margin-left: 1px;
}
.erp-veh-select {
  font: inherit;
  font-size: 15px; font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--brand);
  background: color-mix(in srgb, var(--brand) 8%, #fff);
  border: 1px solid color-mix(in srgb, var(--brand) 22%, transparent);
  border-radius: 8px;
  padding: 9px 34px 9px 14px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  text-align: left;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M3 5l3 3 3-3' fill='none' stroke='%230b6cff' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
  min-width: 130px;
}
.erp-veh-select.is-placeholder { color: color-mix(in srgb, var(--brand) 55%, #fff); font-weight: 700; }
.erp-veh-select:hover { background-color: color-mix(in srgb, var(--brand) 14%, #fff); }
.erp-veh-combo.is-open .erp-veh-select,
.erp-veh-select:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 22%, transparent);
  outline: none;
}
.erp-veh-combo { position: relative; }
.erp-veh-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 140px;
  max-height: 264px;
  overflow-y: auto;
  margin: 0;
  padding: 6px;
  list-style: none;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  border-radius: 10px;
  box-shadow: 0 16px 36px -8px rgba(15, 23, 42, 0.18), 0 4px 12px -2px rgba(15, 23, 42, 0.08);
  z-index: 30;
  animation: erpVehMenuIn .15s ease-out;
}
@keyframes erpVehMenuIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.erp-veh-menu::-webkit-scrollbar { width: 6px; }
.erp-veh-menu::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--ink) 14%, transparent); border-radius: 3px; }
.erp-veh-opt {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
  padding: 9px 12px;
  font-size: 14px; font-weight: 600;
  color: var(--ink);
  border-radius: 6px;
  cursor: pointer;
  letter-spacing: -0.01em;
  transition: background .12s ease, color .12s ease;
}
.erp-veh-opt:hover { background: color-mix(in srgb, var(--brand) 8%, #fff); color: var(--brand); }
.erp-veh-opt.is-active { background: var(--brand); color: #fff; }
.erp-veh-opt.is-active:hover { background: color-mix(in srgb, var(--brand) 88%, #000); color: #fff; }
.erp-veh-check { width: 14px; height: 14px; flex-shrink: 0; }
@media (max-width: 540px) {
  .erp-veh-wrap { margin-left: 0; padding-left: 0; border-left: 0; width: 100%; padding-top: 10px; border-top: 1px solid color-mix(in srgb, var(--ink) 10%, transparent); }
  .erp-veh-select { flex: 1; }
}

/* ───── Route difficulty meter ───── */
.est-diff {
  --diff-color: var(--brand);
  background: linear-gradient(180deg, #fff 0%, color-mix(in srgb, var(--diff-color) 4%, #fff) 100%);
  border: 1px solid color-mix(in srgb, var(--diff-color) 18%, var(--line));
  border-radius: 12px;
  padding: 16px 20px 14px;
  display: flex; flex-direction: column; gap: 10px;
}
.est-diff.t-a { --diff-color: #EF4444; }
.est-diff.t-b { --diff-color: #F97316; }
.est-diff.t-c { --diff-color: #FBBF24; }
.est-diff.t-d { --diff-color: #10B981; }
.est-diff.t-e { --diff-color: #059669; }

.est-diff-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.est-diff-title {
  font-size: 13px; font-weight: 700; color: var(--ink); letter-spacing: -0.01em;
  display: inline-flex; align-items: center; gap: 6px;
}
.est-diff-info {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px;
  color: var(--ink-soft);
  cursor: help;
  outline: none;
}
.est-diff-info:hover, .est-diff-info:focus { color: var(--ink); }
.est-diff-tip {
  position: absolute;
  top: calc(100% + 8px); left: 50%;
  transform: translateX(-50%) translateY(-4px);
  background: #0f172a; color: #f8fafc;
  font-size: 11.5px; font-weight: 500; line-height: 1.5;
  letter-spacing: -0.01em;
  padding: 8px 10px;
  border-radius: 6px;
  width: 220px;
  white-space: normal;
  opacity: 0; pointer-events: none;
  transition: opacity .15s ease, transform .15s ease;
  z-index: 50;
  box-shadow: 0 8px 20px rgba(15,23,42,.18);
}
.est-diff-tip::before {
  content: "";
  position: absolute;
  bottom: 100%; left: 50%; transform: translateX(-50%);
  border: 5px solid transparent;
  border-bottom-color: #0f172a;
}
.est-diff-info:hover .est-diff-tip,
.est-diff-info:focus .est-diff-tip {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.est-diff-level {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700;
  color: var(--diff-color);
  letter-spacing: -0.01em;
}
.est-diff-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--diff-color);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--diff-color) 22%, transparent);
}
.est-diff-score {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 600;
  color: var(--ink-mute);
  letter-spacing: 0.02em;
  padding-left: 8px;
  border-left: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
}

.est-diff-bar {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
}
.est-diff-seg {
  height: 8px;
  border-radius: 3px;
  background: color-mix(in srgb, var(--ink) 8%, transparent);
  transition: background 280ms ease 60ms, transform 280ms cubic-bezier(.34, 1.4, .64, 1);
  transform: scaleY(0.7);
  transform-origin: bottom;
}
.est-diff-seg.is-on {
  background: var(--diff-color);
  transform: scaleY(1);
}
.est-diff-seg.is-on:nth-child(1) { transition-delay: 80ms; }
.est-diff-seg.is-on:nth-child(2) { transition-delay: 160ms; }
.est-diff-seg.is-on:nth-child(3) { transition-delay: 240ms; }
.est-diff-seg.is-on:nth-child(4) { transition-delay: 320ms; }
.est-diff-seg.is-on:nth-child(5) { transition-delay: 400ms; }

.est-diff-scale {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
  font-size: 10px;
  font-weight: 500;
  color: var(--ink-mute);
  letter-spacing: -0.02em;
}
.est-diff-scale span { text-align: center; }
.est-diff-scale span:first-child { text-align: left; }
.est-diff-scale span:last-child { text-align: right; }
.est-diff-desc {
  font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.5;
  padding-top: 6px;
  border-top: 1px dashed color-mix(in srgb, var(--ink) 8%, transparent);
}

/* ───── Result fare range card ───── */
.est-result-range {
  background: linear-gradient(135deg, var(--brand) 0%, color-mix(in srgb, var(--brand) 78%, #6366f1) 100%);
  color: #fff;
  border-radius: 14px;
  padding: 22px 24px 18px;
  box-shadow: 0 14px 30px -10px color-mix(in srgb, var(--brand) 50%, transparent);
  display: flex; flex-direction: column; gap: 12px;
  position: relative;
  overflow: hidden;
}
.est-result-range::after {
  content: "";
  position: absolute;
  top: -40%; right: -10%;
  width: 280px; height: 280px;
  background: radial-gradient(circle, rgba(255,255,255,0.18) 0%, transparent 60%);
  pointer-events: none;
}
.est-result-range-head {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px; font-weight: 600;
  letter-spacing: -0.01em;
}
.est-result-range-label { color: rgba(255,255,255,0.92); }
.est-result-range-meta { color: rgba(255,255,255,0.65); font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.02em; }
.est-result-range-value {
  display: flex; align-items: baseline; gap: 8px;
  position: relative; z-index: 1;
}
.est-result-range-value .num {
  font-size: clamp(36px, 5.4vw, 56px);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
}
.est-result-range-value .tilde {
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 600;
  color: rgba(255,255,255,0.7);
  margin: 0 -2px;
}
.est-result-range-value .unit {
  font-size: 18px;
  font-weight: 600;
  color: rgba(255,255,255,0.8);
  margin-left: 2px;
}
/* 한 줄: 평균운임은 정중앙, 예상운임 범위는 왼쪽 끝 고정 */
.est-result-range-line {
  display: flex; align-items: flex-end; justify-content: center;
  margin: 2px 0 8px; position: relative; z-index: 1;
}
/* 예상운임 — 라벨+금액 컬럼, 왼쪽 끝 고정 */
.est-result-range-est {
  position: absolute; left: 0; bottom: 0;
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
}
/* 평균운임(유가 포함) — 강조, 라벨은 금액 기준 좌측 정렬 */
.est-result-range-avg {
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 2px; position: relative; z-index: 1;
}
.est-result-range-avg-label {
  font-size: 12px; font-weight: 700; letter-spacing: 0.04em;
  color: rgba(255,255,255,0.82);
}
.est-result-range-avg-row { display: flex; align-items: baseline; gap: 6px; }
.est-result-range-avg-row .num {
  font-size: clamp(36px, 5.4vw, 56px);
  font-weight: 800; letter-spacing: -0.04em; line-height: 1;
}
.est-result-range-avg-row .unit {
  font-size: 18px; font-weight: 600; color: rgba(255,255,255,0.85);
}
/* 예상운임 범위 — 70% 축소, 원래대로 왼쪽 정렬 */
.est-result-range-value.is-small { justify-content: flex-start; opacity: 0.9; }
.est-result-range-value.is-small .num { font-size: clamp(25px, 3.8vw, 39px); }
.est-result-range-value.is-small .tilde { font-size: clamp(18px, 2.8vw, 27px); }
.est-result-range-value.is-small .unit { font-size: 13px; }
.est-result-range-bar {
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,0.18);
  position: relative;
  overflow: hidden;
}
.est-result-range-bar-fill {
  display: block;
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,0.4) 0%, #fff 50%, rgba(255,255,255,0.4) 100%);
  border-radius: 999px;
  animation: estRangeShimmer 2.4s ease-in-out infinite;
}
@keyframes estRangeShimmer {
  0%, 100% { transform: translateX(-20%); opacity: 0.6; }
  50%      { transform: translateX(20%); opacity: 1; }
}
.est-result-range-foot {
  display: flex; justify-content: space-between;
  font-size: 12px;
  color: rgba(255,255,255,0.78);
}
.est-result-range-foot b { color: #fff; font-weight: 700; margin-left: 4px; }
/* ── 모바일: 좁은 폭에서 예상운임(절대배치)·평균운임(중앙)이 겹치는 문제 해소 ──
   절대배치를 풀고 양끝 정렬(예상 왼쪽 · 평균 오른쪽)로 바꿔 겹침/우측치우침 방지. */
@media (max-width: 560px) {
  .est-result-range { padding: 18px 16px 16px; }
  .est-result-range-line { justify-content: space-between; align-items: flex-end; gap: 12px; }
  .est-result-range-est { position: static; order: -1; align-items: flex-start; }
  .est-result-range-avg { align-items: flex-end; text-align: right; }
  .est-result-range-avg-row .num { font-size: clamp(28px, 11vw, 44px); }
  .est-result-range-avg-row .unit { font-size: 15px; }
  .est-result-range-value.is-small .num { font-size: clamp(18px, 6vw, 26px); }
  .est-result-range-value.is-small .tilde { font-size: clamp(13px, 4.5vw, 19px); }
  .est-result-range-value.is-small .unit { font-size: 12px; }
  .est-result-range-avg-label { font-size: 11px; }
  .est-result-range-foot { font-size: 11px; }
}
.erp { display: flex; align-items: center; gap: 10px; }
.erp-pin { width: 10px; height: 10px; border-radius: 50%; }
.erp-pin.origin { background: var(--brand); box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand) 18%, transparent); }
.erp-pin.dest { background: #f59e0b; box-shadow: 0 0 0 4px rgba(245,158,11,.18); }
.erp-prov { font-size: 13px; color: var(--ink-mute); font-weight: 600; }
.erp-city { font-size: 17px; font-weight: 700; letter-spacing: -0.01em; }
.erp-arr { color: var(--ink-mute); font-weight: 600; font-size: 18px; }

.est-result-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 540px) { .est-result-grid { grid-template-columns: 1fr; } }
.est-result-tile {
  position: relative;
  border: 1px solid var(--line); border-radius: 12px; padding: 18px 20px;
  background: #fff;
}
.est-result-tile.featured { background: var(--brand); border-color: var(--brand); color: #fff; box-shadow: 0 12px 28px -10px color-mix(in srgb, var(--brand) 60%, transparent); }
.est-result-tile .lbl { font-size: 12px; color: var(--ink-mute); font-weight: 600; }
.est-result-tile.featured .lbl { color: rgba(255,255,255,.8); }
.est-result-tile .val { font-size: 28px; font-weight: 800; letter-spacing: -0.03em; margin-top: 6px; line-height: 1; }
.est-result-tile .val .unit { font-size: 14px; font-weight: 600; color: var(--ink-mute); margin-left: 4px; }
.est-result-tile.featured .val .unit { color: rgba(255,255,255,.85); }
.est-result-tile .badge { position: absolute; top: 12px; right: 12px; font-size: 10px; font-weight: 700; background: rgba(255,255,255,.22); color: #fff; padding: 3px 8px; border-radius: 999px; }

.est-result-meta {
  display: flex; flex-wrap: wrap;
  justify-content: center;
  gap: 14px 28px;
  font-size: 13px; color: var(--ink-mute);
  padding: 4px 2px;
  text-align: center;
}
.est-result-meta b { color: var(--ink); font-weight: 700; }

.est-result-note { font-size: 12px; color: var(--ink-mute); line-height: 1.7; padding: 12px 16px; background: var(--bg-soft); border-radius: 10px; }
.est-result-note b { color: var(--ink); font-weight: 700; }

/* Live similar routes */
.est-live {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 18px 20px 16px;
  background: linear-gradient(180deg, #fff 0%, var(--bg-soft) 100%);
}
.est-live-head { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding-bottom: 14px; border-bottom: 1px dashed var(--line); margin-bottom: 14px; }
.est-live-pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
  animation: estLivePulse 1.6s ease-out infinite;
}
@keyframes estLivePulse {
  0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 55%, transparent); }
  100% { box-shadow: 0 0 0 8px color-mix(in srgb, var(--accent) 0%, transparent); }
}
.est-live-title { font-size: 14px; font-weight: 700; letter-spacing: -0.01em; }
.est-live-route { font-size: 13px; font-weight: 600; color: var(--ink-soft); padding: 3px 10px; background: var(--bg-soft); border-radius: 999px; border: 1px solid var(--line); }
.est-live-arr { color: var(--ink-mute); margin: 0 4px; }
.est-live-meta { margin-left: auto; font-size: 11px; color: var(--ink-mute); font-family: 'JetBrains Mono', monospace; letter-spacing: 0.02em; }

.est-live-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
@media (max-width: 720px) { .est-live-grid { grid-template-columns: 1fr; } }

.est-live-card {
  background: #fff; border: 1px solid var(--line); border-radius: 10px;
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 8px;
  transition: border-color .15s, transform .15s;
}
.est-live-card:hover { border-color: var(--brand); transform: translateY(-1px); }

.est-live-row1 { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.est-live-date {
  font-size: 13px; font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
  font-family: 'JetBrains Mono', monospace;
}
.est-live-time { font-size: 11px; color: var(--ink-mute); font-family: 'JetBrains Mono', monospace; }

.est-live-veh { font-size: 13px; font-weight: 600; color: var(--ink); }

.est-live-row2 { display: flex; align-items: center; gap: 10px; }
.est-live-price { font-size: 16px; font-weight: 800; letter-spacing: -0.02em; color: var(--ink); }
.est-live-price .unit { font-size: 11px; font-weight: 600; color: var(--ink-mute); margin-left: 2px; }
.est-live-bar { flex: 1; height: 4px; background: var(--bg-soft); border-radius: 2px; overflow: hidden; }
.est-live-bar-fill {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--brand), var(--accent));
  border-radius: 2px;
  animation: estLiveSlide 2.6s ease-in-out infinite;
}
@keyframes estLiveSlide {
  0%, 100% { transform: translateX(-6%); opacity: .85; }
  50% { transform: translateX(0); opacity: 1; }
}

.est-live-foot { font-size: 11px; color: var(--ink-mute); margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--line); }

/* ============== EMBEDDED ESTIMATOR (in DispatchBoard) ============== */
.board-estimator {
  border-top: 1px solid var(--line);
  padding: 28px 24px 28px;
  background: linear-gradient(180deg, var(--bg-soft) 0%, var(--bg-panel) 100%);
}
.board-estimator-head { margin-bottom: 16px; }
.board-estimator-eyebrow { font-size: 11px; font-weight: 600; color: var(--brand); letter-spacing: 0.06em; text-transform: uppercase; font-family: 'JetBrains Mono', monospace; display: block; margin-bottom: 4px; }
.board-estimator-title { margin: 0 0 4px; font-size: 18px; font-weight: 800; letter-spacing: -0.02em; }
.board-estimator-sub { margin: 0; font-size: 13px; color: var(--ink-soft); }

.est-card.est-compact {
  padding: 16px 18px 18px;
  border-radius: 14px;
  box-shadow: var(--shadow-sm);
}
.est-card.est-compact .est-head { margin-bottom: 12px; }
.est-card.est-compact .est-title { font-size: 14px; }
.est-card.est-compact .est-stepper { padding: 4px 0 12px; margin-bottom: 12px; gap: 8px; }
.est-card.est-compact .est-step-num { width: 22px; height: 22px; font-size: 11px; }
.est-card.est-compact .est-step-lbl { font-size: 12px; }
.est-card.est-compact .est-route { padding: 10px 14px; font-size: 13px; margin-bottom: 14px; }
.est-card.est-compact .est-canvas { padding: 14px 6px; min-height: 380px; border-radius: 12px; }
.est-card.est-compact .est-tip { font-size: 12px; padding: 7px 14px; top: 4px; }
.est-card.est-compact .est-grid { max-width: 360px; margin: 46px auto 4px; gap: 6px; }
.est-card.est-compact .est-prov { font-size: 11.5px; border-radius: 9px; border-width: 1.25px; }
.est-card.est-compact .est-prov-tag { font-size: 9px; padding: 2px 5px; top: -6px; right: -5px; border-width: 1px; }
.est-card.est-compact .est-legend { font-size: 11px; padding: 10px 0 0; gap: 12px; }
.est-card.est-compact .est-city-panel { padding: 16px; }
.est-card.est-compact .est-city-eyebrow { font-size: 11px; }
.est-card.est-compact .est-city-title { font-size: 15px; }
.est-card.est-compact .est-city-chip { font-size: 12px; padding: 7px 11px; }
.est-card.est-compact .est-cta-wrap { padding: 12px 0 4px; }
.est-card.est-compact .est-cta { font-size: 14px; padding: 11px 22px; }

.est-card.est-compact .est-result { padding: 18px 16px; gap: 14px; }
.est-card.est-compact .est-result-route { padding: 12px 16px; gap: 12px; }
.est-card.est-compact .erp-prov { font-size: 12px; }
.est-card.est-compact .erp-city { font-size: 15px; }
.est-card.est-compact .est-result-tile { padding: 12px 14px; }
.est-card.est-compact .est-result-tile .val { font-size: 22px; }
.est-card.est-compact .est-result-meta { font-size: 12px; gap: 10px 18px; }
.est-card.est-compact .est-result-note { font-size: 11px; padding: 10px 12px; }
.est-card.est-compact .est-live { padding: 14px 14px 12px; }
.est-card.est-compact .est-live-title { font-size: 13px; }
.est-card.est-compact .est-live-route { font-size: 12px; }
.est-card.est-compact .est-live-card { padding: 10px 12px; }
.est-card.est-compact .est-live-veh { font-size: 12px; }
.est-card.est-compact .est-live-price { font-size: 14px; }

/* ============== METRICS / TRUST ============== */
.trust {
  background: var(--bg-soft);
  position: relative;
}
.trust::before {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(700px 350px at 0% 0%, color-mix(in srgb, var(--brand) 6%, transparent), transparent 60%),
    radial-gradient(600px 300px at 100% 100%, color-mix(in srgb, var(--brand) 4%, transparent), transparent 60%);
}
.trust > * { position: relative; z-index: 1; }
.metrics {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-radius: 24px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--brand) 0%, color-mix(in srgb, var(--brand) 78%, #1e3a8a) 100%);
  box-shadow:
    0 24px 60px -20px color-mix(in srgb, var(--brand) 55%, transparent),
    0 8px 24px -8px color-mix(in srgb, var(--brand) 30%, transparent);
  position: relative;
}
.metrics::before {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(900px 380px at 100% -20%, rgba(255,255,255,0.22), transparent 55%),
    radial-gradient(700px 320px at 0% 120%, rgba(255,255,255,0.08), transparent 55%);
}
@media (max-width: 860px) { .metrics { grid-template-columns: 1fr 1fr; } }
.metric {
  padding: 38px 32px;
  background: transparent;
  position: relative;
  z-index: 1;
}
.metric + .metric { border-left: 1px solid rgba(255,255,255,0.12); }
@media (max-width: 860px) {
  .metric:nth-child(odd) { border-left: 0; }
  .metric:nth-child(n+3) { border-top: 1px solid rgba(255,255,255,0.12); }
}
.metric .num {
  font-size: clamp(34px, 4vw, 48px);
  font-weight: 800; letter-spacing: -0.03em; color: #fff;
  line-height: 1;
}
.metric .num .plus { color: rgba(255,255,255,0.7); font-weight: 700; margin-left: 2px; font-size: 0.7em; vertical-align: super; }
.metric .lbl { margin-top: 14px; font-size: 14px; color: rgba(255,255,255,0.78); font-weight: 600; }

.cert-row {
  margin-top: 32px;
  display: flex; align-items: center; gap: 32px; flex-wrap: wrap;
  padding: 24px;
  border-radius: 16px;
  background: var(--bg-panel);
  border: 1px solid var(--line);
}

/* Customer logos marquee */
.logos-marquee {
  margin-top: 32px;
  padding: 28px 0 24px;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  position: relative;
}
.logos-marquee-eyebrow {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 0 28px 18px;
  margin-bottom: 4px;
  border-bottom: 1px dashed var(--line);
  flex-wrap: wrap; gap: 8px;
}
.logos-marquee-eyebrow > span:first-child {
  font-size: 13px; font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.logos-marquee-meta {
  font-size: 11px; font-weight: 500;
  color: var(--ink-mute);
  letter-spacing: 0.02em;
  font-family: 'JetBrains Mono', monospace;
}
.logos-track-wrap {
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent 0%, #000 7%, #000 93%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 7%, #000 93%, transparent 100%);
  padding: 18px 0 2px;
}
.logos-track {
  display: flex;
  align-items: center;
  gap: 56px;
  width: max-content;
  animation: logosScroll 42s linear infinite;
  will-change: transform;
}
@keyframes logosScroll {
  0%   { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(-50%, 0, 0); }
}
.logo-tile {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: color-mix(in srgb, var(--ink) 38%, transparent);
  white-space: nowrap;
  flex-shrink: 0;
  user-select: none;
}
.cert-label { font-size: 13px; color: var(--ink-mute); margin-right: 8px; font-weight: 600; }
.cert-row img { height: 52px; opacity: .9; }
[data-palette="dark"] .cert-row img { filter: brightness(0) invert(1) opacity(0.85); }

/* ============== CTA ============== */
.brand-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: stretch;
}
@media (max-width: 960px) { .brand-grid { grid-template-columns: 1fr; gap: 40px; } }
.brand-col { display: flex; flex-direction: column; }
.brand-eyebrow {
  display: inline-block;
  font-size: 11px; font-weight: 700;
  color: var(--brand);
  letter-spacing: 0.1em; text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
  margin-bottom: 12px;
}
.brand-title {
  font-size: clamp(24px, 2.6vw, 32px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin: 0 0 24px;
  line-height: 1.25;
}
.brand-quote {
  position: relative;
  padding: 24px 28px 24px 32px;
  margin: 0 0 28px;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
  border-radius: 14px;
  border-left: 4px solid var(--brand);
}
.brand-quote-mark {
  font-family: Georgia, 'Times New Roman', serif;
  position: absolute;
  top: 4px; left: 14px;
  font-size: 48px;
  line-height: 1;
  color: color-mix(in srgb, var(--brand) 30%, transparent);
  font-weight: 700;
}
.brand-quote p {
  margin: 0;
  font-size: 16px;
  line-height: 1.85;
  color: var(--ink);
  font-weight: 500;
  letter-spacing: -0.01em;
  padding-left: 24px;
}
.brand-quote p b { color: var(--brand); font-weight: 800; }
.brand-mark {
  display: flex; align-items: center; justify-content: center;
  padding: 28px;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}
.brand-mark img {
  width: 100%; max-width: 200px; height: auto;
  display: block;
  transform: translate3d(var(--mark-x, 0px), 0, 0);
  will-change: transform;
}

.hq-photo {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  flex: 1;
  min-height: 360px;
  box-shadow: 0 18px 40px -16px rgba(11, 31, 59, 0.35);
}
.hq-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hq-photo-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(11,31,59,0.18) 100%);
  pointer-events: none;
}
.hq-info {
  display: flex; flex-direction: column; gap: 14px;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
  border-radius: 14px;
  padding: 22px 24px;
}
.hq-info-row {
  display: flex; align-items: flex-start; gap: 14px;
}
.hq-info-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 10px;
  background: color-mix(in srgb, var(--brand) 10%, #fff);
  color: var(--brand);
  flex-shrink: 0;
}
.hq-info-icon svg { width: 18px; height: 18px; }
.hq-info-main {
  font-size: 15px; font-weight: 700; color: var(--ink);
  letter-spacing: -0.015em;
  line-height: 1.4;
}
.hq-info-sub {
  font-size: 13px; color: var(--ink-mute);
  margin-top: 2px;
  font-weight: 500;
}
.hq-cta {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 4px;
  padding: 10px 16px;
  background: var(--brand);
  color: #fff;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  align-self: flex-start;
  transition: background .15s ease, transform .15s ease, box-shadow .15s ease;
  box-shadow: 0 6px 16px -4px color-mix(in srgb, var(--brand) 38%, transparent);
}
.hq-cta:hover { background: var(--brand-strong); transform: translateY(-1px); box-shadow: 0 10px 22px -4px color-mix(in srgb, var(--brand) 48%, transparent); }

/* ============== CTA ============== */
.cta-band {
  position: relative;
  margin-top: 0;
  padding: 80px 0;
  background: var(--bg-inverse);
  color: var(--ink-on-inverse);
  overflow: hidden;
}
.cta-band::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(800px 300px at 90% 20%, color-mix(in srgb, var(--brand) 30%, transparent), transparent 60%),
    radial-gradient(600px 240px at 0% 100%, color-mix(in srgb, var(--brand) 22%, transparent), transparent 60%);
  pointer-events: none;
}
.cta-grid {
  position: relative;
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center;
}
@media (max-width: 860px) { .cta-grid { grid-template-columns: 1fr; } }
.cta-grid h2 { font-size: clamp(28px, 3.6vw, 40px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.15; margin: 0 0 16px; text-wrap: balance; }
.cta-grid p { color: rgba(255,255,255,.78); font-size: 16px; line-height: 1.6; max-width: 460px; margin: 0 0 24px; }
.cta-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.cta-band .cta-phone {
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 18px;
  padding: 28px;
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(8px);
}
.cta-band .cta-phone .lbl { font-size: 13px; color: rgba(255,255,255,.7); font-weight: 600; }
.cta-band .cta-phone .num {
  font-size: clamp(32px, 4vw, 44px);
  font-weight: 800; letter-spacing: -0.03em; margin: 6px 0;
  color: #fff;
}
.cta-band .cta-phone .hours { font-size: 13px; color: rgba(255,255,255,.7); display: flex; gap: 8px; align-items: center; }
.cta-band .cta-phone .hours .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }

/* ============== FOOTER ============== */
.footer {
  padding: 64px 0 40px;
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.footer-grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px;
}
@media (max-width: 860px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer-brand { display: flex; flex-direction: column; gap: 16px; }
.footer-brand .logo {
  display: flex; align-items: center; gap: 10px;
  font-weight: 800; font-size: 20px; letter-spacing: -0.03em;
}
.footer-info {
  font-size: 13px; color: var(--ink-mute); line-height: 1.7;
}
.footer-info b { color: var(--ink-soft); font-weight: 600; }

.footer-col h5 {
  font-size: 12px; font-weight: 700; color: var(--ink); margin: 0 0 14px;
  letter-spacing: 0.05em; text-transform: uppercase;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.footer-col a { font-size: 14px; color: var(--ink-soft); }
.footer-col a:hover { color: var(--brand); }

.footer-bot {
  margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  font-size: 12px; color: var(--ink-mute);
}
.footer-legal { display: flex; gap: 18px; }

/* ============== Floating quick contact ============== */
.float-contact {
  position: fixed; right: 24px; bottom: 24px; z-index: 30;
  display: flex; flex-direction: column; gap: 10px;
}
.float-btn {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--brand); color: #fff;
  display: grid; place-items: center;
  box-shadow: var(--shadow-lg);
  transition: transform .15s;
}
.float-btn:hover { transform: scale(1.06); }
.float-btn svg { width: 24px; height: 24px; }
.float-btn.ghost { background: var(--bg-panel); color: var(--brand); border: 1px solid var(--line); }
.float-btn.kakao { background: #FEE500; color: #181600; }
.float-btn.kakao:hover { background: #FFD600; }
.float-btn.quote { background: #0F172A; color: #fff; }
.float-btn.quote:hover { background: #1E293B; }

/* arrow icon utility */
.iarrow { display: inline-block; transition: transform .15s; }
.tool:hover .iarrow { transform: translateX(2px); }

/* ============== ESTIMATOR — BARE EMBED MODE (no card frame) ============== */
.est-bare {
  background: transparent;
  border: 0;
  padding: 0;
  width: 100%;
  min-height: 0;
  box-shadow: none;
  padding: 0;
  margin: 0;
  position: relative;
  width: 100%;
}
.est-bare-stage { position: relative; width: 100%; min-height: 0; display: flex; flex-direction: column; align-items: stretch; }
.est-bare-stage .est-bare-head {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  pointer-events: none;
}
.est-bare-stage .est-bare-head .est-bare-status { pointer-events: auto; }
.est-bare-mapwrap { width: 100%; flex: 1; display: flex; align-items: center; justify-content: center; }
.est-bare-mapwrap .est-map { width: 100%; }
.est-bare .est-svg {
  max-width: 500px;
  margin: 0 auto;
}
.est-bare-head {
  display: flex;
  justify-content: center;
  padding: 4px 4px 12px;
  z-index: 4;
  transition: opacity 240ms ease, transform 280ms ease, max-height 320ms ease, padding 320ms ease;
}
.est-bare-head.is-hidden {
  opacity: 0;
  transform: translateY(-4px);
  max-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  overflow: hidden;
  pointer-events: none;
}
.est-bare-head .est-bare-status { pointer-events: auto; }
.est-bare-head .est-bare-status {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--ink-soft); font-weight: 500;
  padding: 9px 16px;
  background: rgba(255,255,255,0.7);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 999px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* ─────────────────────────────────────────────────────────────────────
   Map: paper-feel base + spring hover lift
   apply transform to the <g> so mainland + insets (울릉/독도) move together
   ───────────────────────────────────────────────────────────────────── */
.est-bare .est-region {
  transition:
    transform 380ms cubic-bezier(.34, 1.55, .64, 1) 80ms,
    filter 260ms cubic-bezier(.4, 0, .2, 1) 80ms;
  transform-box: fill-box;
  transform-origin: center;
  filter: drop-shadow(0 1px 1px rgba(15, 23, 42, 0.06))
          drop-shadow(0 2px 4px rgba(15, 23, 42, 0.04));
  will-change: transform, filter;
}
.est-bare .est-region:not(.is-disabled):hover,
.est-bare .est-region.is-origin,
.est-bare .est-region.is-dest {
  transition:
    transform 380ms cubic-bezier(.34, 1.55, .64, 1) 0s,
    filter 260ms cubic-bezier(.4, 0, .2, 1) 0s;
}
.est-bare .est-region polygon,
.est-bare .est-region path {
  fill: rgba(255, 255, 255, 0.78);
  stroke: color-mix(in srgb, var(--ink) 16%, transparent);
  stroke-width: 1;
  transition: fill 240ms ease 80ms, stroke 200ms ease 80ms;
  paint-order: stroke fill;
}
.est-bare .est-region:not(.is-disabled):hover polygon,
.est-bare .est-region:not(.is-disabled):hover path,
.est-bare .est-region.is-origin polygon,
.est-bare .est-region.is-origin path,
.est-bare .est-region.is-dest polygon,
.est-bare .est-region.is-dest path {
  transition: fill 240ms ease 0s, stroke 200ms ease 0s;
}
/* subtle paper-map region tints */
.est-bare .est-region.g-cap polygon, .est-bare .est-region.g-cap path { fill: #eef4ff; stroke: #b9cdee; }
.est-bare .est-region.g-chc polygon, .est-bare .est-region.g-chc path { fill: #eef9f0; stroke: #bcd9c5; }
.est-bare .est-region.g-hon polygon, .est-bare .est-region.g-hon path { fill: #fbf6e3; stroke: #dfcf99; }
.est-bare .est-region.g-yeo polygon, .est-bare .est-region.g-yeo path { fill: #fbecec; stroke: #e3b7b7; }
.est-bare .est-region.g-gw  polygon, .est-bare .est-region.g-gw  path { fill: #f1eefa; stroke: #c4bbe1; }
.est-bare .est-region.g-jj  polygon, .est-bare .est-region.g-jj  path { fill: #e6f7f9; stroke: #a3d4dd; }
.est-bare .est-region.is-metro polygon,
.est-bare .est-region.is-metro path {
  stroke: color-mix(in srgb, var(--ink) 30%, transparent);
  stroke-width: 1;
}

/* hover — spring lift + glow shadow */
.est-bare .est-region:not(.is-disabled):hover {
  transform: translateY(-5px);
  filter:
    drop-shadow(0 10px 14px color-mix(in srgb, var(--brand) 28%, transparent))
    drop-shadow(0 3px 5px rgba(15, 23, 42, 0.14));
}
.est-bare .est-region:not(.is-disabled):hover polygon,
.est-bare .est-region:not(.is-disabled):hover path {
  fill: color-mix(in srgb, var(--brand) 18%, #fff);
  stroke: var(--brand);
  stroke-width: 1;
}
/* when picking destination, hover shows orange tint instead of blue */
.is-pick-dest .est-region:not(.is-disabled):hover {
  filter:
    drop-shadow(0 10px 14px rgba(245, 158, 11, 0.28))
    drop-shadow(0 3px 5px rgba(15, 23, 42, 0.14));
}
.is-pick-dest .est-region:not(.is-disabled):hover polygon,
.is-pick-dest .est-region:not(.is-disabled):hover path {
  fill: color-mix(in srgb, #f59e0b 18%, #fff);
  stroke: #f59e0b;
}
.is-pick-dest .est-region:not(.is-disabled):hover .est-region-label { fill: #f59e0b; }
.est-bare .est-region:not(.is-disabled):hover .est-region-label { fill: var(--brand); }

/* Auto-cycle "ghost hover" — same visual as :hover, applied via class so it works
   without a real mouse. Stops as soon as the user actually hovers / picks. */
.est-bare .est-region.is-auto {
  transform: translateY(-5px);
  filter:
    drop-shadow(0 10px 14px color-mix(in srgb, var(--brand) 28%, transparent))
    drop-shadow(0 3px 5px rgba(15, 23, 42, 0.14));
}
.est-bare .est-region.is-auto polygon,
.est-bare .est-region.is-auto path {
  fill: color-mix(in srgb, var(--brand) 18%, #fff);
  stroke: var(--brand);
}
.est-bare .est-region.is-auto .est-region-label { fill: var(--brand); }

/* selected — locked lift, brand-color fill */
.est-bare .est-region.is-origin {
  transform: translateY(-5px);
  filter:
    drop-shadow(0 12px 18px color-mix(in srgb, var(--brand) 40%, transparent))
    drop-shadow(0 4px 6px rgba(15, 23, 42, 0.18));
}
.est-bare .est-region.is-origin polygon,
.est-bare .est-region.is-origin path {
  fill: var(--brand) !important;
  stroke: var(--brand) !important;
  stroke-width: 1;
}
.est-bare .est-region.is-dest {
  transform: translateY(-5px);
  filter:
    drop-shadow(0 12px 18px rgba(245, 158, 11, 0.42))
    drop-shadow(0 4px 6px rgba(15, 23, 42, 0.18));
}
.est-bare .est-region.is-dest polygon,
.est-bare .est-region.is-dest path {
  fill: #f59e0b !important;
  stroke: #f59e0b !important;
  stroke-width: 1;
}
.est-bare .est-region.is-origin .est-region-label,
.est-bare .est-region.is-dest .est-region-label { fill: #fff; }

.est-bare .est-region-label {
  fill: color-mix(in srgb, var(--ink) 62%, transparent);
  font-weight: 700;
  transition: fill 220ms ease;
}

.est-bare-head .est-bare-status.is-bob {
  animation: estStatusBob 1.6s ease-in-out infinite;
  border-color: color-mix(in srgb, var(--brand) 25%, transparent);
  color: var(--brand);
  font-weight: 700;
}
@keyframes estStatusBob {
  0%, 100% { transform: translateY(0); box-shadow: 0 6px 16px color-mix(in srgb, var(--brand) 14%, transparent); }
  50% { transform: translateY(-6px); box-shadow: 0 12px 22px color-mix(in srgb, var(--brand) 22%, transparent); }
}

/* Route animation overlay (calculating state) */
.est-route-fx { animation: estFxIn .25s ease-out both; }
.est-route-trail {
  fill: none;
  stroke: color-mix(in srgb, var(--brand) 18%, transparent);
  stroke-width: 1.4;
  stroke-dasharray: 3 4;
}
.est-route-arc {
  fill: none;
  stroke: var(--brand);
  stroke-width: 2;
  stroke-linecap: round;
  filter: drop-shadow(0 1px 2px color-mix(in srgb, var(--brand) 35%, transparent));
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
  animation: estDraw 1.4s cubic-bezier(.55,.08,.2,1) forwards;
}
.est-route-end-pulse {
  fill: var(--brand);
  opacity: .35;
  transform-origin: center;
  transform-box: fill-box;
  animation: estPulse 1.4s ease-in-out infinite;
}
.est-route-end-pulse.dest { fill: #f59e0b; }
.est-route-end-dot { fill: var(--brand); }
.est-route-end-dot.dest { fill: #f59e0b; }
.est-route-truck-halo {
  fill: var(--brand);
  opacity: .22;
  transform-origin: center;
  transform-box: fill-box;
  animation: estTruckHalo 1.2s ease-in-out infinite;
}
.est-route-truck-dot {
  fill: #fff;
  stroke: var(--brand);
  stroke-width: 1.6;
  filter: drop-shadow(0 1px 3px color-mix(in srgb, var(--brand) 45%, transparent));
}
.est-route-truck-icon { font-size: 9px; }
.est-bare .est-bare-status.is-calcing {
  border-color: color-mix(in srgb, var(--brand) 30%, transparent);
  background: color-mix(in srgb, var(--brand) 5%, rgba(255,255,255,0.85));
  color: var(--brand);
  font-weight: 600;
}
.est-bare-pin.calc {
  background: var(--brand);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand) 22%, transparent);
  animation: estPinPulse 1s ease-in-out infinite;
}
@keyframes estDraw {
  0% { stroke-dashoffset: 600; }
  100% { stroke-dashoffset: 0; }
}
@keyframes estPulse {
  0%, 100% { transform: scale(1); opacity: .35; }
  50% { transform: scale(1.6); opacity: 0; }
}
@keyframes estTruckHalo {
  0%, 100% { transform: scale(1); opacity: .22; }
  50% { transform: scale(1.4); opacity: 0; }
}
@keyframes estPinPulse {
  0%, 100% { box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand) 22%, transparent); }
  50%      { box-shadow: 0 0 0 8px color-mix(in srgb, var(--brand) 8%, transparent); }
}
@keyframes estFxIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Floating popover (city picker) */
.est-pop-backdrop {
  position: absolute; inset: 0;
  background: transparent;
  display: flex; align-items: center; justify-content: center;
  z-index: 5;
  border-radius: 12px;
  animation: estPopFade .18s ease-out;
}
@keyframes estPopFade { from { opacity: 0; } to { opacity: 1; } }
.est-pop {
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 24px 48px -12px rgba(15, 23, 42, 0.18), 0 4px 12px -4px rgba(15, 23, 42, 0.08);
  padding: 20px 22px;
  width: min(420px, calc(100% - 24px));
  max-height: calc(100% - 24px);
  overflow: auto;
  animation: estPopIn .22s cubic-bezier(.2, .9, .3, 1.2);
}
@keyframes estPopIn { from { opacity: 0; transform: scale(.95) translateY(6px); } to { opacity: 1; transform: scale(1) translateY(0); } }

/* Status + route bar below the map */
.est-bare-foot {
  display: flex; flex-direction: column; gap: 14px;
  padding: 18px 4px 4px;
  align-items: center;
  min-height: 64px;
  box-sizing: border-box;
}
.est-bare-status {
  display: flex; align-items: center; gap: 10px;
  font-size: 12.5px; color: var(--ink-soft); font-weight: 500;
  letter-spacing: -0.01em;
}
.est-bare-pin {
  width: 8px; height: 8px; border-radius: 50%;
  background: color-mix(in srgb, var(--ink) 25%, transparent);
}
.est-bare-pin.origin {
  background: var(--brand);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand) 22%, transparent);
}
.est-bare-pin.dest {
  background: #f59e0b;
  box-shadow: 0 0 0 4px color-mix(in srgb, #f59e0b 22%, transparent);
}
.est-bare-status-text { flex: 1; }
.est-bare-reset {
  background: transparent; border: 0; cursor: pointer;
  font: inherit; font-size: 12px; color: var(--ink-mute);
  padding: 4px 8px; border-radius: 6px;
  transition: color .15s, background .15s;
}
.est-bare-reset:hover { color: var(--ink); background: color-mix(in srgb, var(--ink) 6%, transparent); }

.est-bare-route {
  display: flex; align-items: center; gap: 12px;
  font-size: 13.5px; font-weight: 500; letter-spacing: -0.01em;
  flex-wrap: wrap;
}
.ebr-end {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--ink-mute);
  padding: 9px 14px;
  background: color-mix(in srgb, var(--bg-panel) 75%, transparent);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 999px;
  transition: all .18s;
}
.ebr-end.set { color: var(--ink); background: var(--bg-panel); border-color: color-mix(in srgb, var(--ink) 14%, transparent); font-weight: 600; }
.ebr-pin { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.ebr-pin.origin { background: var(--brand); }
.ebr-pin.dest { background: #f59e0b; }
.ebr-arr { color: var(--ink-mute); font-weight: 500; }
.ebr-cta {
  margin-left: auto;
  font-size: 13px; padding: 9px 18px; border-radius: 999px;
  animation: ebrCtaPop .25s cubic-bezier(.2, .9, .3, 1.3);
}
@keyframes ebrCtaPop { from { opacity: 0; transform: scale(.92); } to { opacity: 1; transform: scale(1); } }

/* Result inside bare mode — strip card chrome */
.est-bare .est-result { background: transparent; padding: 0; gap: 16px; margin-left: 48px; }
.est-bare .est-result-actions { display: flex; justify-content: flex-end; gap: 10px; }

/* Sequential reveal after vehicle selection */
.est-stagger { animation: estStaggerIn 0.55s cubic-bezier(.2, .9, .3, 1) both; }
@keyframes estStaggerIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Vehicle-selection prompt — shown while waiting */
.est-result-prompt {
  display: flex; align-items: center; gap: 12px;
  padding: 18px 22px;
  background: color-mix(in srgb, var(--brand) 6%, #fff);
  border: 1px dashed color-mix(in srgb, var(--brand) 35%, transparent);
  border-radius: 12px;
  color: var(--brand);
  font-size: 14px; font-weight: 600;
  animation: estPromptBob 1.8s ease-in-out infinite;
}
.est-result-prompt-arrow {
  font-size: 20px; font-weight: 800;
  animation: estPromptArrow 1.4s ease-in-out infinite;
}
@keyframes estPromptBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}
@keyframes estPromptArrow {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-4px); opacity: 0.7; }
}
.erp-veh-wrap.is-waiting {
  animation: erpVehUrge 1.4s ease-in-out infinite;
}
@keyframes erpVehUrge {
  0%, 100% { box-shadow: 0 6px 14px -4px color-mix(in srgb, var(--brand) 28%, transparent),
                          0 0 0 4px color-mix(in srgb, var(--brand) 12%, transparent); }
  50%      { box-shadow: 0 10px 22px -4px color-mix(in srgb, var(--brand) 42%, transparent),
                          0 0 0 8px color-mix(in srgb, var(--brand) 18%, transparent); }
}


/* ============== STATS BAND (premium dark band) ============== */
.stats-band {
  position: relative;
  background: linear-gradient(180deg, #0B1F3B 0%, #0F172A 100%);
  padding: 36px 0;
  overflow: hidden;
}
.stats-band::before,
.stats-band::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  width: 240px;
  pointer-events: none;
  background:
    radial-gradient(ellipse 60% 100% at 50% 50%,
      color-mix(in srgb, #2563EB 14%, transparent) 0%,
      transparent 70%);
}
.stats-band::before { left: 0; }
.stats-band::after  { right: 0; transform: scaleX(-1); }
.stats-band-row {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: center;
}
.stats-band-item {
  position: relative;
  text-align: center;
  padding: 4px 24px;
}
.stats-band-item + .stats-band-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 56%;
  background: linear-gradient(180deg,
    transparent 0%,
    rgba(255, 255, 255, 0.18) 50%,
    transparent 100%);
}
.stats-band-value {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  color: #FFFFFF;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
}
.stats-band-value .num {
  font-size: clamp(28px, 3vw, 44px);
  font-feature-settings: 'tnum';
}
.stats-band-value .unit {
  font-size: clamp(15px, 1.2vw, 20px);
  font-weight: 700;
  color: #60A5FA;
  margin-left: 2px;
}
.stats-band-label {
  margin-top: 8px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.62);
}
@media (max-width: 720px) {
  .stats-band { padding: 28px 0; }
  .stats-band-row { grid-template-columns: repeat(2, 1fr); gap: 24px 0; }
  .stats-band-item + .stats-band-item:nth-child(odd)::before { display: none; }
  .stats-band-label { font-size: 12px; }
}

.stats-band-item { padding-top: 22px; }
.stats-band-badge {
  position: absolute;
  top: -4px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2563EB 0%, #0EA5E9 100%);
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  white-space: nowrap;
  box-shadow:
    0 4px 12px rgba(37, 99, 235, 0.45),
    0 0 0 2px rgba(15, 23, 42, 1);
}
@media (max-width: 720px) {
  .stats-band-badge { font-size: 10px; padding: 3px 8px; }
}


/* ============== HERO — CENTERED (map-as-main) ============== */
.hero.hero-center {
  padding: 80px 0 96px;
}
.hero-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 36px;
}
.hero-head {
  max-width: 760px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hero-head-title {
  font-size: clamp(32px, 4.6vw, 56px);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
  color: #0F172A;
  margin: 16px 0 12px;
}
.hero-head-title .accent { color: var(--brand); }
.hero-head-sub {
  font-size: clamp(16px, 1.5vw, 20px);
  color: #475569;
  font-weight: 500;
  margin: 0 0 14px;
  letter-spacing: -0.01em;
}
.hero-head-hint {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid #DBEAFE;
  color: #475569;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0;
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.06);
}
.hero-head-hint b { color: var(--brand); font-weight: 700; margin: 0 1px; }

.hero-map-stage {
  position: relative;
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  height: 720px;
  min-height: 720px;
  display: flex;
  align-items: stretch;
  justify-content: center;
  animation: heroMapFloat 6s ease-in-out infinite;
}
.hero-map-stage > .hero-visual { width: 100%; height: 100%; min-height: inherit; display: flex; flex-direction: column; }
@keyframes heroMapFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
.hero-map-stage .hero-visual { margin-top: 0; }
.hero-map-stage .hero-visual-est { filter: drop-shadow(0 36px 64px rgba(37, 99, 235, 0.14)); }

/* small click-pulse indicator (animated cursor pulses near the map) */
.hero-map-cursor {
  position: absolute;
  top: 0; left: 0;
  width: 26px; height: 26px;
  pointer-events: none;
  z-index: 5;
  opacity: 0;
  margin-left: -2px;
  margin-top: -2px;
  transform: translate(-9999px, -9999px);
  transition: transform 1.05s cubic-bezier(.45, .05, .25, 1), opacity .35s ease;
  filter: drop-shadow(0 4px 8px rgba(37, 99, 235, 0.40));
}
.hero-map-cursor svg { width: 26px; height: 26px; display: block; }

@media (max-width: 720px) {
  .hero.hero-center { padding: 56px 0 72px; }
  .hero-stack { gap: 24px; }
  .hero-head-title { margin: 12px 0 10px; }
  .hero-map-cursor { display: none; }
}


/* Lock the embedded estimator height so picking/result/calculating doesn't shift page content */
.hero-map-stage .hero-visual { flex: 1; }
.hero-map-stage .est-bare {
  min-height: 720px;
  height: 720px;
  display: flex;
  flex-direction: column;
}
.hero-map-stage .est-bare-stage {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.hero-map-stage .est-bare-mapwrap { flex: 1; }
/* Result panel sits inside the locked area; content scrolls within if it ever overflows */
.hero-map-stage .est-bare > div { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.hero-map-stage .est-bare .est-result {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
@media (max-width: 720px) {
  .hero-map-stage { height: 620px; min-height: 620px; }
  .hero-map-stage .est-bare { height: 620px; min-height: 620px; }
}


/* Result panel — pin the action row to the bottom of the locked area */
.hero-map-stage .est-bare .est-result {
  position: relative;
  padding-bottom: 76px;
}
.hero-map-stage .est-bare .est-result-actions {
  position: absolute;
  left: 0; right: 0; bottom: 12px;
  margin: 0;
  padding: 12px 4px 4px;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  border-top: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, #ffffff 35%);
}
.hero-map-stage .est-bare .est-result-actions .btn {
  padding: 9px 14px;
  font-size: 13px;
}
@media (max-width: 720px) {
  .hero-map-stage .est-bare .est-result-actions {
    flex-wrap: wrap;
    justify-content: stretch;
  }
  .hero-map-stage .est-bare .est-result-actions .btn { flex: 1; justify-content: center; }
}

/* ── 결과 패널: 잠긴 높이(720/620px) 대신 내용 높이에 맞춤 ──
   유사노선 등 일부 블록을 숨기거나 다시 켤 때 높이가 내용에 맞춰 자동으로 변함.
   (지도/선택 화면은 그대로 잠긴 높이 유지 → :has(.est-result) 일 때만 해제) */
.hero-map-stage:has(.est-result),
.hero-map-stage:has(.est-result) .hero-visual,
.hero-map-stage:has(.est-result) .est-bare {
  height: auto;
  min-height: 0;
}
.hero-map-stage:has(.est-result) .est-bare > div,
.hero-map-stage:has(.est-result) .est-bare .est-result {
  flex: none;
  overflow: visible;
}
.hero-map-stage:has(.est-result) .est-bare .est-result {
  padding-bottom: 0;
}
.hero-map-stage:has(.est-result) .est-bare .est-result-actions {
  position: static;
  margin: 14px 0 0;
  padding: 12px 4px 0;
  background: none;
}
/* 차종 선택 대기 상태: 톤수 드롭다운(최대 264px)이 다음 섹션에 가려지지 않도록
   리스트가 들어갈 최소 높이 확보 (차종 선택 후에는 내용이 더 커서 불필요) */
.hero-map-stage:has(.est-result) .est-result:has(.erp-veh-wrap.is-waiting) {
  min-height: 350px;
}


/* ===== Stats band — premium impact override ===== */
.stats-band {
  background:
    radial-gradient(ellipse 60% 80% at 50% 0%, rgba(37, 99, 235, 0.18) 0%, transparent 60%),
    linear-gradient(180deg, #0A1733 0%, #060F24 100%);
  padding: 56px 0 60px;
}
.stats-band::before,
.stats-band::after {
  width: 320px;
  background:
    radial-gradient(ellipse 70% 100% at 50% 50%,
      color-mix(in srgb, #2563EB 22%, transparent) 0%,
      transparent 70%);
}
.stats-band-item {
  padding: 6px 28px;
}
/* Highlighted stats with a badge — give them a luminous treatment */
.stats-band-item:has(.stats-band-badge) .stats-band-value .num {
  background: linear-gradient(180deg, #FFFFFF 0%, #DBEAFE 60%, #93C5FD 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 0 28px rgba(96, 165, 250, 0.45);
  filter: drop-shadow(0 4px 18px rgba(37, 99, 235, 0.35));
}
.stats-band-item:has(.stats-band-badge) .stats-band-value .unit {
  color: #93C5FD;
  text-shadow: 0 0 16px rgba(96, 165, 250, 0.45);
}
.stats-band-item:has(.stats-band-badge) .stats-band-label {
  color: rgba(255, 255, 255, 0.82);
  font-weight: 600;
}

/* Make all numbers larger and punchier */
.stats-band-value .num {
  font-size: clamp(34px, 3.6vw, 56px);
  font-weight: 900;
  letter-spacing: -0.035em;
}
.stats-band-value .unit {
  font-size: clamp(16px, 1.3vw, 22px);
  font-weight: 800;
}
.stats-band-label {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.70);
  margin-top: 10px;
}

/* Bigger, more eye-catching badge */
.stats-band-badge {
  top: -10px;
  padding: 5px 13px;
  font-size: 11.5px;
  letter-spacing: 0.06em;
  background: linear-gradient(135deg, #FFD93D 0%, #FBBF24 50%, #F59E0B 100%);
  color: #1F1300;
  font-weight: 800;
  box-shadow:
    0 6px 18px rgba(251, 191, 36, 0.45),
    0 0 0 2px #060F24,
    inset 0 1px 0 rgba(255, 255, 255, 0.55);
  animation: statsBadgePulse 2.6s ease-in-out infinite;
}
.stats-band-badge::before {
  content: "★";
  margin-right: 4px;
  color: #B45309;
  font-size: 10px;
}
@keyframes statsBadgePulse {
  0%, 100% { transform: translateX(-50%) translateY(0); box-shadow: 0 6px 18px rgba(251, 191, 36, 0.45), 0 0 0 2px #060F24, inset 0 1px 0 rgba(255, 255, 255, 0.55); }
  50%      { transform: translateX(-50%) translateY(-2px); box-shadow: 0 10px 26px rgba(251, 191, 36, 0.6), 0 0 0 2px #060F24, inset 0 1px 0 rgba(255, 255, 255, 0.55); }
}

/* Stronger separators */
.stats-band-item + .stats-band-item::before {
  height: 64%;
  background: linear-gradient(180deg,
    transparent 0%,
    rgba(96, 165, 250, 0.28) 50%,
    transparent 100%);
}

@media (max-width: 720px) {
  .stats-band { padding: 40px 0 44px; }
  .stats-band-value .num { font-size: 32px; }
  .stats-band-badge { font-size: 10.5px; padding: 4px 10px; }
  .stats-band-label { font-size: 12.5px; }
}


/* ===== Problems — stronger readability + scroll reveal ===== */
.problem-card {
  --c: #2563EB;
  padding: 36px 32px 32px 36px;
  gap: 16px;
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 18px;
  box-shadow: 0 4px 14px -4px rgba(15, 23, 42, 0.06);
  position: relative;
  opacity: 0;
  transform: translateY(28px) scale(0.985);
  transition:
    opacity .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    transform .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    border-color .25s ease,
    box-shadow .25s ease;
  min-height: 200px;
}
.problem-card.is-revealed {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.problem-card.cat-ops   { --c: #2563EB; background: linear-gradient(155deg, #EFF6FF 0%, #FFFFFF 65%); }
.problem-card.cat-cost  { --c: #F59E0B; background: linear-gradient(155deg, #FFF7E6 0%, #FFFFFF 65%); }
.problem-card.cat-trust { --c: #10B981; background: linear-gradient(155deg, #ECFDF5 0%, #FFFFFF 65%); }

.problem-card:hover {
  transform: translateY(-4px) scale(1);
  border-color: color-mix(in srgb, var(--c) 36%, transparent);
  box-shadow:
    0 24px 40px -12px color-mix(in srgb, var(--c) 24%, transparent),
    0 6px 14px -2px rgba(15, 23, 42, 0.08);
}

.problem-bar {
  position: absolute;
  left: 0; top: 22px; bottom: 22px;
  width: 5px;
  background: linear-gradient(180deg, var(--c) 0%, color-mix(in srgb, var(--c) 60%, transparent) 100%);
  border-radius: 0 4px 4px 0;
}

/* Big background quote-mark watermark — adds character without hurting readability */
.problem-watermark {
  position: absolute;
  top: 8px;
  right: 18px;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 130px;
  font-weight: 700;
  line-height: 1;
  color: color-mix(in srgb, var(--c) 16%, transparent);
  pointer-events: none;
  user-select: none;
  letter-spacing: -0.08em;
}

.problem-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  color: #FFFFFF;
  background: linear-gradient(135deg, var(--c) 0%, color-mix(in srgb, var(--c) 80%, #000) 100%);
  box-shadow: 0 8px 18px -6px color-mix(in srgb, var(--c) 60%, transparent);
}
.problem-icon svg { width: 22px; height: 22px; stroke-width: 2; }

.problem-text {
  font-size: 17.5px;
  font-weight: 700;
  line-height: 1.55;
  color: #0F172A;
  letter-spacing: -0.02em;
  text-wrap: balance;
  margin: 0;
  position: relative;
  z-index: 1;
}
@media (max-width: 720px) {
  .problem-card { padding: 28px 24px 26px 28px; min-height: 0; }
  .problem-text { font-size: 16px; }
  .problem-watermark { font-size: 96px; }
}


/* ===== Solutions — stronger readability + scroll reveal ===== */
.sol-map-card {
  --c: #2563EB;
  position: relative;
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 18px;
  padding: 28px 32px 26px 36px !important;
  display: grid;
  grid-template-columns: 60px 1fr;
  grid-template-rows: auto auto auto auto;
  column-gap: 18px;
  row-gap: 6px;
  align-items: center;
  box-shadow: 0 4px 14px -4px rgba(15, 23, 42, 0.06);
  overflow: hidden;
  opacity: 0;
  transform: translateY(28px) scale(0.985);
  transition:
    opacity .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    transform .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    border-color .25s ease,
    box-shadow .25s ease;
}
.sol-map-card.is-revealed {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.sol-map-card.cat-ops   { background: linear-gradient(155deg, #EFF6FF 0%, #FFFFFF 65%); }
.sol-map-card.cat-cost  { background: linear-gradient(155deg, #FFF7E6 0%, #FFFFFF 65%); }
.sol-map-card.cat-trust { background: linear-gradient(155deg, #ECFDF5 0%, #FFFFFF 65%); }

.sol-map-card:hover {
  transform: translateY(-3px) scale(1);
  border-color: color-mix(in srgb, var(--c) 34%, transparent);
  box-shadow:
    0 18px 32px -10px color-mix(in srgb, var(--c) 22%, transparent),
    0 4px 12px -2px rgba(15, 23, 42, 0.08);
}

.sol-map-card .problem-bar {
  position: absolute;
  left: 0; top: 18px; bottom: 18px;
  width: 5px;
  background: linear-gradient(180deg, var(--c) 0%, color-mix(in srgb, var(--c) 60%, transparent) 100%);
  border-radius: 0 4px 4px 0;
}

/* Big quote-mark watermark in the card */
.sol-map-watermark {
  position: absolute;
  top: 2px;
  right: 18px;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 90px;
  font-weight: 700;
  line-height: 1;
  color: color-mix(in srgb, var(--c) 16%, transparent);
  pointer-events: none;
  user-select: none;
  letter-spacing: -0.08em;
}

.sol-map-head {
  grid-column: 1;
  grid-row: 1 / span 4;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  align-self: center;
}
.sol-map-num {
  width: 34px; height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c) 0%, color-mix(in srgb, var(--c) 80%, #000) 100%);
  color: #FFFFFF;
  font-size: 14px;
  font-weight: 800;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 14px -4px color-mix(in srgb, var(--c) 55%, transparent);
}
.sol-map-icon {
  width: 34px; height: 34px;
  border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c);
  background: color-mix(in srgb, var(--c) 14%, #FFFFFF);
}
.sol-map-icon svg { width: 18px; height: 18px; }

.sol-map-prob {
  grid-column: 2;
  grid-row: 1;
  font-size: 14px;
  font-weight: 600;
  color: #64748B;
  letter-spacing: -0.01em;
  position: relative;
  padding-left: 22px;
}
.sol-map-prob::before {
  content: "\201C";
  position: absolute;
  left: 0; top: -2px;
  font-family: Georgia, serif;
  font-size: 26px;
  font-weight: 700;
  color: color-mix(in srgb, var(--c) 60%, transparent);
  line-height: 1;
}
.sol-map-arrow {
  grid-column: 2;
  grid-row: 2;
  display: inline-flex; align-items: center;
  color: var(--c);
  margin: 2px 0;
}
.sol-map-arrow svg { width: 16px; height: 16px; }
.sol-map-sol {
  grid-column: 2;
  grid-row: 3;
  font-size: 17px;
  font-weight: 700;
  color: #0F172A;
  letter-spacing: -0.02em;
  line-height: 1.5;
  position: relative;
  z-index: 1;
}
@media (max-width: 720px) {
  .sol-map-card { padding: 22px 24px 22px 28px !important; column-gap: 14px; }
  .sol-map-watermark { font-size: 64px; }
  .sol-map-sol { font-size: 16px; }
}

/* Trust strip — scroll reveal */
.sol-trust-card {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity .6s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    transform .6s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms);
}
.sol-trust-card.is-revealed { opacity: 1; transform: translateY(0); }


/* ===== Solutions — large hero screenshot + 4-card row below ===== */
.sol-main {
  display: block !important;
}
.sol-screenshot {
  margin: 0 auto 40px;
  max-width: 1180px;
}
.sol-screenshot-frame {
  border-radius: 18px !important;
  box-shadow:
    0 32px 64px -20px rgba(15, 23, 42, 0.22),
    0 12px 24px -6px rgba(15, 23, 42, 0.08) !important;
  border: 1px solid #E2E8F0 !important;
  overflow: hidden;
  position: relative;
}
.sol-screenshot-frame::after {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6);
}
.sol-screenshot-frame img { width: 100%; height: auto; display: block; }

/* New caption strip below the screenshot — embed the 20yr know-how + gov cert message */
.sol-screenshot-cap {
  margin-top: 18px !important;
  font-size: 14px !important;
  color: #94A3B8 !important;
  text-align: center;
}
.sol-screenshot-meta {
  margin: 18px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 14.5px;
  color: #334155;
  letter-spacing: -0.01em;
}
.sol-screenshot-meta b { color: #2563EB; font-weight: 800; }
.sol-screenshot-meta .dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: #CBD5E1;
  display: inline-block;
}
.sol-screenshot-tag {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 14px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid #DBEAFE;
  color: #0F172A;
  font-weight: 600;
  font-size: 13.5px;
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.06);
}
.sol-screenshot-tag svg { width: 15px; height: 15px; color: #2563EB; }

/* 4 mapping cards now sit in a single horizontal row */
.sol-mapping {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px;
}
@media (max-width: 1024px) {
  .sol-mapping { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 600px) {
  .sol-mapping { grid-template-columns: 1fr !important; }
}
/* Tighten the card padding now that they're narrower in a 4-up row */
@media (min-width: 1025px) {
  .sol-map-card { padding: 22px 22px 22px 26px !important; column-gap: 12px; }
  .sol-map-head { gap: 6px; }
  .sol-map-num, .sol-map-icon { width: 28px; height: 28px; }
  .sol-map-icon svg { width: 14px; height: 14px; }
  .sol-map-sol { font-size: 15px; }
  .sol-map-prob { font-size: 13px; padding-left: 18px; }
  .sol-map-watermark { font-size: 72px; right: 12px; }
}


/* ===== Channels — stronger readability, more persuasive ===== */
.ch-card {
  padding: 36px 32px 32px !important;
  border-radius: 18px !important;
  border: 1px solid #E2E8F0 !important;
  box-shadow: 0 4px 14px -4px rgba(15, 23, 42, 0.06) !important;
  opacity: 0;
  transform: translateY(28px) scale(0.985);
  transition:
    opacity .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    transform .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    border-color .25s ease,
    box-shadow .25s ease !important;
  position: relative;
  overflow: visible;
}
.ch-card.is-revealed {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.ch-card.ch-kakao { background: linear-gradient(160deg, #FFFCE6 0%, #FFFFFF 60%); }
.ch-card.ch-phone { background: linear-gradient(160deg, #EFF6FF 0%, #FFFFFF 60%); }
.ch-card.ch-web   { background: linear-gradient(160deg, #F1F5F9 0%, #FFFFFF 60%); }

.ch-card:hover {
  transform: translateY(-5px) scale(1) !important;
  box-shadow:
    0 22px 40px -14px color-mix(in srgb, var(--c) 28%, transparent),
    0 6px 14px -2px rgba(15, 23, 42, 0.08) !important;
}

/* Badge in upper-right of each card */
.ch-card-badge {
  position: absolute;
  top: -12px;
  right: 24px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, #FFD93D 0%, #FBBF24 50%, #F59E0B 100%);
  color: #1F1300;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.02em;
  box-shadow:
    0 8px 18px rgba(251, 191, 36, 0.45),
    0 0 0 3px #ffffff;
}
.ch-card-badge span { font-size: 11px; }
.ch-card-badge.ch-badge-blue {
  background: linear-gradient(135deg, #3B82F6 0%, #2563EB 50%, #1D4ED8 100%);
  color: #FFFFFF;
  box-shadow:
    0 8px 18px rgba(37, 99, 235, 0.40),
    0 0 0 3px #ffffff;
}
.ch-card-badge.ch-badge-blue span { color: #BFDBFE; animation: chBadgeDot 1.6s ease-in-out infinite; }
@keyframes chBadgeDot {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.45; }
}
.ch-card-badge.ch-badge-dark {
  background: linear-gradient(135deg, #334155 0%, #0F172A 100%);
  color: #FFFFFF;
  box-shadow:
    0 8px 18px rgba(15, 23, 42, 0.30),
    0 0 0 3px #ffffff;
}

/* Larger, bolder icon wraps */
.ch-card-icon-wrap {
  width: 64px !important;
  height: 64px !important;
  border-radius: 16px !important;
  margin-bottom: 12px;
  box-shadow: 0 8px 20px -6px rgba(15, 23, 42, 0.18);
}
.ch-card.ch-phone .ch-card-icon-wrap {
  background: linear-gradient(135deg, #3B82F6 0%, #1D4ED8 100%);
}
.ch-card.ch-phone .ch-card-icon { color: #FFFFFF; }
.ch-card.ch-web .ch-card-icon-wrap {
  background: linear-gradient(135deg, #1F2937 0%, #0F172A 100%);
}
.ch-card.ch-web .ch-card-icon { color: #FFFFFF; }
.ch-card-icon svg { width: 30px !important; height: 30px !important; }

.ch-card-tag {
  font-size: 11.5px !important;
  font-weight: 800 !important;
  color: #94A3B8 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.ch-card-title {
  font-size: clamp(20px, 2.1vw, 26px) !important;
  font-weight: 800 !important;
  color: #0F172A !important;
  letter-spacing: -0.025em !important;
  line-height: 1.3 !important;
  margin: 0 0 14px !important;
}
.ch-card-title-phone {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: clamp(28px, 3vw, 38px) !important;
  letter-spacing: -0.02em !important;
  font-feature-settings: 'tnum';
}

.ch-card-meta {
  margin: 0 0 14px;
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}
.ch-card-meta-num {
  font-size: 32px !important;
  font-weight: 900 !important;
  color: #0F172A !important;
  letter-spacing: -0.03em !important;
  line-height: 1 !important;
}
.ch-card-meta-num .unit {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #F59E0B !important;
  margin-left: 2px !important;
}
.ch-card-meta-sub {
  font-size: 13px;
  color: #64748B;
  font-weight: 600;
}
.ch-card-meta-pulse {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13.5px;
  color: #334155;
  font-weight: 600;
}
.ch-card-meta-pulse .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #10B981;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.20);
  animation: chPhonePulse 1.6s ease-in-out infinite;
}
@keyframes chPhonePulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.20); }
  50%      { transform: scale(1.2); box-shadow: 0 0 0 6px rgba(16, 185, 129, 0); }
}

.ch-card-desc {
  font-size: 15px !important;
  font-weight: 500 !important;
  color: #475569 !important;
  line-height: 1.7 !important;
  letter-spacing: -0.01em !important;
  margin: 0 0 22px !important;
}
.ch-card-desc b { color: #0F172A; font-weight: 800; }

.ch-card-cta {
  padding: 13px 22px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  border-radius: 12px !important;
  box-shadow: 0 6px 16px -4px rgba(15, 23, 42, 0.12) !important;
}
.ch-card-cta:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 24px -6px rgba(15, 23, 42, 0.20) !important;
}

/* Bottom strip — make it punchier */
.ch-strip {
  margin-top: 36px;
  padding: 18px 28px !important;
  background: linear-gradient(135deg, #EFF6FF 0%, #FFFFFF 100%) !important;
  border: 1px solid #DBEAFE !important;
  border-radius: 14px !important;
}
.ch-strip-bolt {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3B82F6, #2563EB);
  color: #FFFFFF;
  font-size: 14px;
  box-shadow: 0 6px 14px -4px rgba(37, 99, 235, 0.45);
  animation: chBoltPulse 2.2s ease-in-out infinite;
}
@keyframes chBoltPulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.08); }
}

@media (max-width: 720px) {
  .ch-card { padding: 28px 24px 26px !important; }
  .ch-card-meta-num { font-size: 28px !important; }
  .ch-card-title-phone { font-size: 28px !important; }
  .ch-card-desc { font-size: 14.5px !important; }
}


/* ===== Network diagram — clean pixel-accurate curves ===== */
/* Hide the old triangle arrows but keep the flow containers as grid spacers */
.netdiag-flow { visibility: hidden; }
.netdiag-flow .flow-arrow { display: none; }

.netdiag-curves {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none;
  overflow: visible;
  z-index: 1;
}
.netdiag-curves .curve-in,
.netdiag-curves .curve-out {
  stroke-linecap: round;
  stroke-dasharray: 100;
  stroke-dashoffset: 100;
  opacity: 0;
  transition: opacity .55s ease-out;
}
.netdiag-curves .curve-in  { stroke: rgba(37, 99, 235, 0.65); stroke-width: 1.6; }
.netdiag-curves .curve-in.is-own { stroke: #2563EB; stroke-width: 2.4; }
.netdiag-curves .curve-out { stroke: #10B981; stroke-width: 2.6; }

.netdiag-curves.phase-drawIn .curve-in {
  opacity: 1;
  animation: ndDrawCurve 1.15s cubic-bezier(.4,.0,.2,1) forwards;
}
@keyframes ndDrawCurve {
  from { stroke-dashoffset: 100; }
  to   { stroke-dashoffset: 0; }
}
.netdiag-curves.phase-hold .curve-in,
.netdiag-curves.phase-drawOut .curve-in {
  opacity: 1;
  stroke-dashoffset: 0;
}
.netdiag-curves.phase-drawOut .curve-out {
  opacity: 1;
  animation: ndDrawCurve 1.15s cubic-bezier(.4,.0,.2,1) forwards;
}
.netdiag-curves.phase-fade .curve-in,
.netdiag-curves.phase-fade .curve-out {
  opacity: 0;
  stroke-dashoffset: 0;
  transition: opacity .55s ease-out;
}


/* ===== Match Criteria — 4 cards below the network diagram ===== */
.match-criteria {
  margin: 64px 0 24px;
  padding: 56px 32px 48px;
  background: linear-gradient(180deg, #F8FAFC 0%, #FFFFFF 100%);
  border: 1px solid #E2E8F0;
  border-radius: 24px;
  position: relative;
  overflow: hidden;
}
.match-criteria::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(37, 99, 235, 0.08) 0%, transparent 70%);
  pointer-events: none;
}
.match-criteria-head { text-align: center; margin-bottom: 40px; position: relative; }
.match-criteria-eyebrow {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #2563EB;
  padding: 6px 14px;
  background: #EFF6FF;
  border-radius: 999px;
  margin-bottom: 14px;
}
.match-criteria-title {
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: #0F172A;
  margin: 0 0 14px;
  line-height: 1.25;
}
.match-criteria-title .accent { color: #2563EB; }
.match-criteria-sub {
  font-size: 16px;
  color: #475569;
  line-height: 1.7;
  margin: 0;
  font-weight: 500;
  max-width: 540px;
  margin: 0 auto;
}

.match-criteria-grid {
  list-style: none; margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  position: relative;
}
@media (max-width: 960px) {
  .match-criteria-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .match-criteria-grid { grid-template-columns: 1fr; }
}

.match-criteria-card {
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 16px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: 0 4px 14px -4px rgba(15, 23, 42, 0.06);
  transition:
    opacity .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    transform .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    border-color .25s ease,
    box-shadow .25s ease;
  opacity: 0;
  transform: translateY(24px) scale(0.985);
}
.match-criteria-card.is-revealed {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.match-criteria-card:hover {
  transform: translateY(-4px) scale(1);
  border-color: #BFDBFE;
  box-shadow:
    0 18px 32px -10px rgba(37, 99, 235, 0.18),
    0 4px 12px -2px rgba(15, 23, 42, 0.08);
}
.match-criteria-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #2563EB 0%, #1D4ED8 100%);
  color: #FFFFFF;
  margin-bottom: 8px;
  box-shadow: 0 8px 18px -6px rgba(37, 99, 235, 0.45);
}
.match-criteria-icon svg { width: 26px; height: 26px; }
.match-criteria-en {
  font-size: 12px;
  font-weight: 700;
  color: #2563EB;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.match-criteria-ko {
  font-size: 19px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0F172A;
  margin: 4px 0 8px;
}
.match-criteria-desc {
  font-size: 14.5px;
  font-weight: 500;
  color: #475569;
  line-height: 1.7;
  letter-spacing: -0.01em;
  margin: 0;
}

.match-criteria-foot {
  margin-top: 36px;
  text-align: center;
  position: relative;
}
.match-criteria-foot-line {
  font-size: 17px;
  font-weight: 600;
  color: #0F172A;
  margin: 0 0 8px;
  letter-spacing: -0.015em;
}
.match-criteria-foot-line b { color: #2563EB; font-weight: 800; }
.match-criteria-foot-emph {
  font-size: 20px;
  font-weight: 800;
  color: #0F172A;
  margin: 0;
  letter-spacing: -0.025em;
}
.match-criteria-foot-emph .accent { color: #2563EB; }

@media (max-width: 720px) {
  .match-criteria { padding: 40px 20px 32px; margin: 40px 0 16px; }
  .match-criteria-head { margin-bottom: 28px; }
  .match-criteria-foot-line { font-size: 15px; }
  .match-criteria-foot-emph { font-size: 17px; }
}


/* ===== Fuse netdiag + match-criteria into a single continuous block ===== */
.netdiag-wrap-fused .match-criteria {
  margin: 0;
  padding: 8px 0 0;
  background: transparent;
  border: 0;
  border-radius: 0;
}
.netdiag-wrap-fused .match-criteria::before { display: none; }

/* Bridge connector between the diagram and the criteria */
.netdiag-bridge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  margin: 24px 0 8px;
  position: relative;
}
.netdiag-bridge-line {
  width: 1px;
  height: 28px;
  background: linear-gradient(180deg,
    rgba(37, 99, 235, 0.30) 0%,
    rgba(37, 99, 235, 0.55) 100%);
}
.netdiag-bridge-pill {
  display: inline-flex;
  align-items: center;
  padding: 7px 16px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid #DBEAFE;
  color: #2563EB;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.01em;
  box-shadow: 0 6px 14px rgba(37, 99, 235, 0.10);
}
.netdiag-bridge-arrow {
  width: 22px; height: 22px;
  color: #2563EB;
  animation: ndBridgeBob 1.8s ease-in-out infinite;
}
@keyframes ndBridgeBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(4px); }
}
@media (max-width: 720px) {
  .netdiag-bridge { margin: 18px 0 4px; gap: 10px; }
  .netdiag-bridge-line { height: 20px; }
  .netdiag-bridge-pill { font-size: 12.5px; padding: 6px 14px; }
}


/* ===== Bridge tweaks — faster bob, two-line copy ===== */
@keyframes ndBridgeBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(4px); }
}
.netdiag-bridge-arrow { animation: ndBridgeBob 1.2s ease-in-out infinite !important; }
.netdiag-bridge-sub {
  font-size: 14.5px;
  color: #475569;
  font-weight: 500;
  letter-spacing: -0.01em;
  text-align: center;
  margin-top: -4px;
}
.netdiag-bridge-sub b { color: #2563EB; font-weight: 700; }

/* ===== Match criteria cards — vary colors per criterion, improve readability ===== */
.match-criteria-card {
  --c-from: #2563EB;
  --c-to: #1D4ED8;
  --c-text: #2563EB;
  --c-bg: #EFF6FF;
}
.match-criteria-card:nth-child(1) { --c-from: #2563EB; --c-to: #1D4ED8; --c-text: #2563EB; --c-bg: #EFF6FF; }
.match-criteria-card:nth-child(2) { --c-from: #F59E0B; --c-to: #D97706; --c-text: #D97706; --c-bg: #FFF7E6; }
.match-criteria-card:nth-child(3) { --c-from: #10B981; --c-to: #059669; --c-text: #047857; --c-bg: #ECFDF5; }
.match-criteria-card:nth-child(4) { --c-from: #8B5CF6; --c-to: #7C3AED; --c-text: #6D28D9; --c-bg: #F5F3FF; }

.match-criteria-card {
  background: linear-gradient(160deg, var(--c-bg) 0%, #FFFFFF 60%) !important;
  border: 1px solid #E2E8F0 !important;
  padding: 30px 26px !important;
}
.match-criteria-card:hover {
  border-color: color-mix(in srgb, var(--c-text) 34%, transparent) !important;
  box-shadow:
    0 18px 32px -10px color-mix(in srgb, var(--c-text) 24%, transparent),
    0 4px 12px -2px rgba(15, 23, 42, 0.08) !important;
}
.match-criteria-icon {
  background: linear-gradient(135deg, var(--c-from) 0%, var(--c-to) 100%) !important;
  box-shadow: 0 8px 18px -6px color-mix(in srgb, var(--c-from) 55%, transparent) !important;
}
.match-criteria-en {
  color: var(--c-text) !important;
  font-size: 12.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
}
.match-criteria-ko {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: #0F172A !important;
  margin: 6px 0 10px !important;
}
.match-criteria-desc {
  font-size: 14.5px !important;
  color: #334155 !important;
  font-weight: 500 !important;
  line-height: 1.7 !important;
}


/* ===== Two Dispatch Modes — standalone section ===== */
.dispatch-modes { padding: 96px 0; }
.dm-head {
  text-align: center;
  margin: 0 auto 56px;
  max-width: 640px;
}
.dm-eyebrow {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #2563EB;
  padding: 6px 14px;
  background: #EFF6FF;
  border-radius: 999px;
  margin-bottom: 16px;
}
.dm-title {
  font-size: clamp(30px, 3.6vw, 44px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0F172A;
  margin: 0 0 14px;
  line-height: 1.2;
}
.dm-sub {
  font-size: 17px;
  color: #475569;
  font-weight: 500;
  margin: 0;
  line-height: 1.6;
}

.dm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
@media (max-width: 960px) {
  .dm-grid { grid-template-columns: 1fr; gap: 20px; }
  .dispatch-modes { padding: 64px 0; }
}

.dm-card {
  --c-from: #2563EB;
  --c-to: #1D4ED8;
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 24px;
  padding: 40px 36px 32px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  box-shadow: 0 8px 24px -8px rgba(15, 23, 42, 0.08);
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity .7s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    transform .7s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    border-color .25s ease,
    box-shadow .25s ease;
  position: relative;
  overflow: hidden;
}
.dm-card.is-revealed { opacity: 1; transform: translateY(0); }
.dm-card.dm-fixed { --c-from: #10B981; --c-to: #059669; }
.dm-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--c-from) 0%, var(--c-to) 100%);
}
.dm-card:hover {
  border-color: color-mix(in srgb, var(--c-from) 30%, transparent);
  box-shadow: 0 22px 44px -12px color-mix(in srgb, var(--c-from) 24%, transparent);
}

.dm-card-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 6px 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--c-from) 10%, #FFFFFF);
  color: var(--c-from);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: 14px;
}
.dm-card-tag-num {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-from), var(--c-to));
  color: #FFFFFF;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  font-weight: 800;
}
.dm-card-title {
  font-size: clamp(26px, 2.8vw, 34px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: #0F172A;
  margin: 0 0 14px;
  line-height: 1.2;
}
.dm-card-desc {
  font-size: 16px;
  color: #475569;
  line-height: 1.7;
  font-weight: 500;
  margin: 0;
}
.dm-card-desc b { color: var(--c-from); font-weight: 800; }

.dm-card-pts {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.dm-card-pts li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  background: color-mix(in srgb, var(--c-from) 5%, #FFFFFF);
  border: 1px solid color-mix(in srgb, var(--c-from) 14%, transparent);
  border-radius: 12px;
  font-size: 14.5px;
  color: #334155;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: -0.01em;
}
.dm-card-pts li b { color: var(--c-from); font-weight: 800; }
.dm-card-pt-icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  font-size: 15px;
}

/* Viz container */
.dm-viz {
  background: color-mix(in srgb, var(--c-from) 5%, #FFFFFF);
  border: 1px solid color-mix(in srgb, var(--c-from) 14%, transparent);
  border-radius: 14px;
  padding: 14px 16px 8px;
  margin-top: 4px;
}
.dm-viz-svg { width: 100%; height: 180px; display: block; }
.dm-viz-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  fill: color-mix(in srgb, var(--c-from) 70%, #0F172A);
  letter-spacing: 0.06em;
}
.dm-viz-foot {
  font-size: 11.5px;
  fill: #64748B;
  font-weight: 600;
}
.dm-viz-foot-dot { fill: var(--c-from); font-size: 10px; }
.dm-viz-foot-fixed { fill: #047857; font-weight: 600; }

/* Call dispatch — animated scattered single trips */
.dm-call-trip { opacity: 0; animation: dmCallTrip 3.6s ease-in-out infinite; }
@keyframes dmCallTrip {
  0%      { opacity: 0; }
  10%, 70% { opacity: 1; }
  100%    { opacity: 0; }
}
.dm-pin-origin { fill: #2563EB; }
.dm-pin-dest   { fill: #F97316; }
.dm-call-path {
  fill: none;
  stroke: #2563EB;
  stroke-width: 1.6;
  stroke-dasharray: 4 4;
  opacity: 0.75;
}

/* Fixed route — repetition lines + truck cycling */
.dm-fixed-track { stroke: #10B981; stroke-width: 2.5; stroke-linecap: round; }
.dm-fixed-track-ghost { stroke: #10B981; stroke-width: 1.5; stroke-linecap: round; stroke-dasharray: 4 6; opacity: 0.28; }
.dm-fixed-stop { fill: #10B981; stroke: #FFFFFF; stroke-width: 3; }
.dm-fixed-stop-mid { fill: #6EE7B7; }
.dm-fixed-city { fill: #0F172A; font-size: 13px; font-weight: 800; letter-spacing: -0.02em; }
.dm-fixed-city-mid { fill: #64748B; font-weight: 600; }
.dm-fixed-time { fill: #64748B; font-size: 11px; font-weight: 600; font-family: 'JetBrains Mono', monospace; }
.dm-fixed-truck-g {
  animation: dmFixedTruck 4.2s cubic-bezier(.55,0,.45,1) infinite;
  transform-origin: 50% 50%;
}
.dm-fixed-truck { fill: #059669; }
.dm-fixed-truck-wheel { fill: #0F172A; }
@keyframes dmFixedTruck {
  0%, 5%   { transform: translate(52px, 78px); }
  45%, 55% { transform: translate(268px, 78px); }
  95%, 100% { transform: translate(52px, 78px); }
}
.dm-fixed-loop-bg { fill: #10B981; }
.dm-fixed-loop-arrow { stroke: #FFFFFF; stroke-width: 2; stroke-linecap: round; }
.dm-fixed-loop-arrow-head { fill: #FFFFFF; }

@media (max-width: 720px) {
  .dm-card { padding: 28px 22px 24px; gap: 16px; }
  .dm-card-title { font-size: 24px; }
  .dm-card-desc { font-size: 15px; }
  .dm-viz-svg { height: 160px; }
}


/* ===== Pricing — readability + variation + reveal ===== */
.pricing-card {
  --c-from: #2563EB;
  --c-to: #1D4ED8;
  --c-bg: #EFF6FF;
  border: 1px solid #E2E8F0 !important;
  border-radius: 20px !important;
  padding: 36px 32px 32px !important;
  background: linear-gradient(160deg, var(--c-bg) 0%, #FFFFFF 60%) !important;
  display: flex !important;
  flex-direction: column;
  gap: 14px;
  box-shadow: 0 6px 18px -6px rgba(15, 23, 42, 0.08) !important;
  opacity: 0;
  transform: translateY(26px) scale(0.985);
  transition:
    opacity .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    transform .65s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    border-color .25s ease,
    box-shadow .25s ease !important;
  position: relative;
}
.pricing-card.is-revealed {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.pricing-card-1 { --c-from: #2563EB; --c-to: #1D4ED8; --c-bg: #EFF6FF; }
.pricing-card-2 { --c-from: #F59E0B; --c-to: #D97706; --c-bg: #FFF7E6; }
.pricing-card-3 { --c-from: #10B981; --c-to: #059669; --c-bg: #ECFDF5; }
.pricing-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 4px;
  border-radius: 20px 20px 0 0;
  background: linear-gradient(90deg, var(--c-from), var(--c-to));
}
.pricing-card:hover {
  transform: translateY(-4px) scale(1) !important;
  border-color: color-mix(in srgb, var(--c-from) 38%, transparent) !important;
  box-shadow:
    0 22px 40px -14px color-mix(in srgb, var(--c-from) 28%, transparent),
    0 6px 14px -2px rgba(15, 23, 42, 0.08) !important;
}
.pricing-icon {
  width: 56px !important; height: 56px !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg, var(--c-from) 0%, var(--c-to) 100%) !important;
  color: #FFFFFF !important;
  box-shadow: 0 10px 22px -8px color-mix(in srgb, var(--c-from) 55%, transparent);
  margin-bottom: 4px;
}
.pricing-icon svg { width: 28px !important; height: 28px !important; stroke-width: 1.8; }
.pricing-badge {
  background: linear-gradient(135deg, #FFD93D 0%, #FBBF24 50%, #F59E0B 100%) !important;
  color: #1F1300 !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em;
  padding: 5px 12px !important;
  border-radius: 999px !important;
  font-size: 11.5px !important;
  box-shadow:
    0 6px 14px rgba(251, 191, 36, 0.40),
    0 0 0 2px #FFFFFF !important;
}
.pricing-title {
  font-size: 26px !important;
  font-weight: 900 !important;
  color: #0F172A !important;
  letter-spacing: -0.025em !important;
  margin: 6px 0 4px !important;
}
.pricing-desc {
  font-size: 15.5px !important;
  font-weight: 500 !important;
  color: #475569 !important;
  line-height: 1.7 !important;
  letter-spacing: -0.01em !important;
  margin: 0 0 6px !important;
}
.pricing-pts { margin-top: 6px !important; gap: 10px !important; }
.pricing-pts li {
  font-size: 14.5px !important;
  font-weight: 600 !important;
  color: #0F172A !important;
  padding-left: 28px !important;
  letter-spacing: -0.01em !important;
  line-height: 1.55;
}
.pricing-pts li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important; top: 2px !important;
  width: 18px !important; height: 18px !important;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-from) 0%, var(--c-to) 100%) !important;
  border: 0 !important;
}
.pricing-pts li::after {
  content: "" !important;
  position: absolute !important;
  left: 4px !important; top: 7px !important;
  width: 10px !important; height: 7px !important;
  border-left: 2px solid #FFFFFF;
  border-bottom: 2px solid #FFFFFF;
  transform: rotate(-45deg);
}
.pricing-note {
  margin-top: 28px !important;
  text-align: center;
  font-size: 14px !important;
  color: #475569 !important;
  font-weight: 500;
}
@media (max-width: 720px) {
  .pricing-card { padding: 28px 24px 24px !important; }
  .pricing-title { font-size: 22px !important; }
  .pricing-desc { font-size: 14.5px !important; }
}


/* ===== Trust — complete redesign ===== */
.trust-headline {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 56px;
  align-items: center;
  padding: 48px 8px 12px;
  margin-bottom: 28px;
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s ease, transform .7s ease;
}
.trust-headline.is-revealed { opacity: 1; transform: translateY(0); }
@media (max-width: 960px) { .trust-headline { grid-template-columns: 1fr; gap: 32px; } }

.trust-headline-title {
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: #0F172A;
  margin: 0 0 32px;
  line-height: 1.3;
}
.trust-bignum {
  font-size: clamp(48px, 5vw, 64px);
  font-weight: 900;
  color: #2563EB;
  letter-spacing: -0.04em;
  display: inline-block;
  margin-right: 6px;
  vertical-align: -8px;
}
.trust-bignum em { font-style: normal; color: #60A5FA; font-size: 0.7em; }

.trust-headline-stats {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.trust-headline-stats li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 18px 22px;
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 14px;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}
.trust-headline-stats li span {
  font-size: 14.5px;
  color: #475569;
  font-weight: 600;
}
.trust-headline-stats li b {
  font-size: 32px;
  color: #2563EB;
  font-weight: 900;
  letter-spacing: -0.03em;
}
.trust-headline-stats li b em { font-style: normal; font-size: 16px; color: #60A5FA; font-weight: 800; margin-left: 2px; }

.trust-donuts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
@media (max-width: 560px) { .trust-donuts { grid-template-columns: 1fr; } }

.customer-donut {
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 18px;
  padding: 24px 22px;
  box-shadow: 0 4px 14px -4px rgba(15, 23, 42, 0.06);
}
.customer-donut-title {
  font-size: 14px;
  font-weight: 700;
  color: #94A3B8;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0 12px;
  text-align: center;
}
.customer-donut-chart {
  position: relative;
  width: 100%;
  max-width: 220px;
  margin: 0 auto;
}
.customer-donut-chart svg {
  width: 100%; height: auto;
  display: block;
  filter: drop-shadow(0 6px 14px rgba(37, 99, 235, 0.12));
}
.customer-donut-center {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  pointer-events: none;
}
.customer-donut-center-num {
  font-size: 14px;
  font-weight: 800;
  color: #0F172A;
  letter-spacing: -0.01em;
}
.customer-donut-center-sub {
  font-size: 11px;
  color: #64748B;
  font-weight: 600;
}
.customer-donut-legend {
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.customer-donut-legend li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: #334155;
}
.customer-donut-legend .dot {
  width: 10px; height: 10px;
  border-radius: 3px;
  flex-shrink: 0;
}
.customer-donut-legend .lbl { flex: 1; font-weight: 600; }
.customer-donut-legend b { color: #0F172A; font-weight: 800; font-feature-settings: 'tnum'; }

/* Two-row marquee with opposite scroll directions */
.logos-marquee { padding-bottom: 8px; }
.logos-track-wrap-2 { margin-top: 8px; }
.logos-track-left {
  animation: logosScrollLeft 38s linear infinite;
  will-change: transform;
}
.logos-track-right {
  animation: logosScrollRight 42s linear infinite;
  will-change: transform;
}
@keyframes logosScrollLeft {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes logosScrollRight {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}

/* Slightly nicer logo tiles */
.logo-tile {
  font-weight: 700;
  color: #475569;
  font-size: 15px;
  padding: 12px 22px;
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  border-radius: 12px;
  white-space: nowrap;
  letter-spacing: -0.01em;
  transition: color .2s, border-color .2s, transform .2s;
  flex-shrink: 0;
  margin-right: 14px;
}
.logo-tile:hover {
  color: #2563EB;
  border-color: #BFDBFE;
  transform: translateY(-2px);
}
/* 업로드된 로고 이미지 타일 */
.logo-tile:has(.logo-tile-img) { padding: 10px 18px; display: flex; align-items: center; justify-content: center; }
.logo-tile-img {
  display: block;
  height: 34px;
  max-width: 150px;
  width: auto;
  object-fit: contain;
}


/* Full-bleed logos marquee — flows continuously with the section above */
.logos-marquee-fullbleed {
  margin: 24px 0 0;
  padding: 16px 0 8px;
  background: transparent;
  border: 0;
}
.logos-marquee-fullbleed .logos-marquee-eyebrow {
  padding: 0 0 14px;
}


/* ===== Customer Donuts — confident, no box, in-segment labels ===== */
.customer-donut {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}
.customer-donut-title {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #94A3B8 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin: 0 0 18px !important;
  text-align: center !important;
}
.customer-donut-chart {
  position: relative;
  width: 100%;
  max-width: 320px !important;
  margin: 0 auto !important;
}
.customer-donut-chart svg {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 12px 28px rgba(37, 99, 235, 0.16));
}
.customer-donut-seg-label {
  font-size: 11px;
  font-weight: 700;
  fill: #0F172A;
  letter-spacing: -0.01em;
}
.customer-donut-seg-label.is-dark { fill: #FFFFFF; }
.customer-donut-seg-value {
  font-size: 13px;
  font-weight: 900;
  fill: #0F172A;
  letter-spacing: -0.02em;
}
.customer-donut-seg-value.is-dark { fill: #FFFFFF; }
.customer-donut-center-num {
  font-size: 15px !important;
  font-weight: 800 !important;
}
.customer-donut-center-sub {
  font-size: 12px !important;
}


/* Image-based logo tracks */
.logos-track-img { display: flex; align-items: center; flex-shrink: 0; }
.logos-track-img img {
  height: 64px;
  width: auto;
  display: block;
  flex-shrink: 0;
}
/* Single donut — make it bigger and centered */
.trust-donuts {
  display: flex !important;
  justify-content: center !important;
}
.customer-donut-chart {
  max-width: 420px !important;
}
.customer-donut-center-num {
  font-size: 24px !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  color: #0F172A !important;
}
.customer-donut-center-sub {
  font-size: 13px !important;
  color: #475569 !important;
}
.customer-donut-seg-value {
  font-size: 14px !important;
}


/* ===== Donut — outside labels with leader lines ===== */
.customer-donut-chart {
  max-width: 580px !important;
  padding: 0 8px;
}
.customer-donut-chart svg {
  width: 100%;
  height: auto;
  display: block;
  overflow: visible;
}
.customer-donut-out-label {
  font-size: 16px;
  font-weight: 700;
  fill: #0F172A;
  letter-spacing: -0.01em;
}
.customer-donut-out-value {
  font-size: 18px;
  font-weight: 900;
  fill: #0F172A;
  font-feature-settings: 'tnum';
  letter-spacing: -0.02em;
}
.customer-donut-center {
  display: none !important;
}
.customer-donut-title { display: none !important; }

/* ===== Sample logo tiles (placeholders until real logos arrive) ===== */
.logo-tile-sample {
  background: linear-gradient(135deg, #F8FAFC 0%, #FFFFFF 100%);
  border: 1px dashed #CBD5E1;
  color: #94A3B8;
  font-weight: 600;
  font-size: 14.5px;
  letter-spacing: -0.005em;
  font-family: 'Pretendard', sans-serif;
}

/* ===== Tools — bigger cards with scroll reveal ===== */
.tools {
  display: grid !important;
  grid-template-columns: repeat(5, 1fr) !important;
  gap: 16px;
}
@media (max-width: 1024px) { .tools { grid-template-columns: repeat(3, 1fr) !important; } }
@media (max-width: 720px)  { .tools { grid-template-columns: 1fr !important; } }
.tool {
  display: flex !important;
  flex-direction: column;
  gap: 12px;
  padding: 28px 24px !important;
  background: #FFFFFF !important;
  border: 1px solid #E2E8F0 !important;
  border-radius: 18px !important;
  box-shadow: 0 4px 14px -4px rgba(15, 23, 42, 0.06) !important;
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity .6s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    transform .6s cubic-bezier(.2, .9, .3, 1) var(--delay, 0ms),
    border-color .2s ease,
    box-shadow .2s ease;
  text-decoration: none !important;
}
.tool.is-revealed { opacity: 1; transform: translateY(0); }
.tool:hover {
  transform: translateY(-4px);
  border-color: #BFDBFE !important;
  box-shadow: 0 18px 32px -10px rgba(37, 99, 235, 0.20), 0 4px 12px -2px rgba(15, 23, 42, 0.08) !important;
}
.tool-icon {
  width: 48px !important; height: 48px !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #2563EB 0%, #1D4ED8 100%) !important;
  color: #FFFFFF !important;
  display: inline-flex !important;
  align-items: center; justify-content: center;
  box-shadow: 0 8px 16px -6px rgba(37, 99, 235, 0.45);
  margin: 0 0 4px !important;
}
.tool-icon svg { width: 24px !important; height: 24px !important; }
.tool-title {
  font-size: 17px !important;
  font-weight: 800 !important;
  color: #0F172A !important;
  margin: 0 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.35;
}
.tool-desc {
  font-size: 13.5px !important;
  font-weight: 500 !important;
  color: #475569 !important;
  margin: 0 !important;
  line-height: 1.6 !important;
  letter-spacing: -0.005em !important;
  flex: 1;
}
.tool-link {
  display: inline-flex !important;
  align-items: center;
  gap: 4px !important;
  margin-top: 6px;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #2563EB !important;
  letter-spacing: -0.01em;
  transition: gap .2s ease;
}
.tool:hover .tool-link { gap: 8px !important; }

/* ===== GrowthCharts redesign ===== */
.growth-block {
  margin: 56px 0 0 !important;
  padding: 48px 32px !important;
  background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%);
  border: 1px solid #E2E8F0;
  border-radius: 24px;
  box-shadow: 0 8px 24px -8px rgba(15, 23, 42, 0.06);
}
.growth-head { margin-bottom: 36px !important; }
.growth-eyebrow {
  font-size: 12px !important;
  letter-spacing: 0.12em !important;
  color: #2563EB !important;
  background: #EFF6FF;
  padding: 6px 14px;
  border-radius: 999px;
  font-family: 'JetBrains Mono', monospace;
}
.growth-title {
  font-size: clamp(26px, 3vw, 38px) !important;
  font-weight: 800 !important;
  margin: 14px 0 8px !important;
}
.growth-sub { font-size: 16px !important; color: #475569 !important; }
.growth-card {
  border-radius: 18px !important;
  padding: 28px 28px 14px !important;
  border: 1px solid #E2E8F0 !important;
  background: #FFFFFF !important;
  position: relative;
  overflow: hidden;
}
.growth-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, #2563EB, #1D4ED8);
}
.growth-card:nth-child(2)::before { background: linear-gradient(90deg, #10B981, #059669); }
.growth-card-lbl {
  font-size: 11.5px !important;
  letter-spacing: 0.12em !important;
  color: #94A3B8 !important;
}
.growth-card-final {
  font-size: 36px !important;
  font-weight: 900 !important;
  margin-top: 8px !important;
}
.growth-card-final .unit { font-size: 16px !important; font-weight: 700 !important; color: #475569 !important; }
.growth-year { font-size: 13px !important; color: #94A3B8 !important; }
.growth-card-hi {
  padding: 8px 14px !important;
  border-radius: 999px !important;
  background: rgba(37, 99, 235, 0.10) !important;
  color: #2563EB !important;
  font-size: 13px !important;
  font-weight: 800 !important;
}
.growth-card-hi-num { font-size: 17px !important; }
.growth-card-hi-meta { font-size: 11.5px !important; opacity: 0.85; }


/* ===== FOOTER — dark, logispot-style ===== */
.footer {
  background: linear-gradient(180deg, #0B1226 0%, #060B1A 100%);
  color: #CBD5E1;
  padding: 80px 0 36px;
  margin-top: 0;
}
.footer .shell { width: 100%; }

.footer-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 56px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr; gap: 40px; }
}

.footer-logo {
  display: inline-block;
  margin-bottom: 24px;
}
.footer-logo img {
  height: 36px;
  width: auto;
  display: block;
  /* The source JPG is on white — turn it monochrome white via multiply */
  filter: brightness(0) invert(1);
}

.footer-company {
  display: flex;
  flex-direction: column;
  gap: 14px;
  font-size: 13px;
  line-height: 1.7;
}
.footer-company-block {
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: rgba(255,255,255,0.62);
}
.footer-company-block > div {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}
.footer-company-block span {
  font-size: 12px;
  color: rgba(255,255,255,0.40);
  flex-shrink: 0;
  min-width: 110px;
  letter-spacing: -0.005em;
}
.footer-company-block b {
  color: rgba(255,255,255,0.85);
  font-weight: 500;
  letter-spacing: -0.01em;
}
@media (max-width: 560px) {
  .footer-company-block span { min-width: 0; }
}

.footer-menus {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
}
@media (max-width: 960px) {
  .footer-menus { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
  .footer-menus { grid-template-columns: repeat(2, 1fr); }
}
.footer-col h5 {
  color: #FFFFFF;
  font-size: 14px;
  font-weight: 700;
  margin: 0 0 14px;
  letter-spacing: -0.01em;
}
.footer-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-col a {
  color: rgba(255,255,255,0.60);
  font-size: 13px;
  letter-spacing: -0.01em;
  transition: color .15s ease;
}
.footer-col a:hover { color: #FFFFFF; }

.footer-bot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 28px;
  gap: 16px;
  flex-wrap: wrap;
}
.footer-legal {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.footer-legal a {
  color: rgba(255,255,255,0.72);
  font-size: 13px;
  font-weight: 500;
  transition: color .15s ease;
}
.footer-legal a:hover { color: #FFFFFF; }
.footer-legal-sep { color: rgba(255,255,255,0.20); }
.footer-copy {
  color: rgba(255,255,255,0.40);
  font-size: 12.5px;
  letter-spacing: -0.005em;
}
@media (max-width: 720px) {
  .footer { padding: 64px 0 24px; }
}


/* ===== GrowthCharts — give it a clear blue card background ===== */
.growth-block {
  background: linear-gradient(180deg, #EFF6FF 0%, #F0F7FF 100%) !important;
  border: 1px solid #DBEAFE !important;
}

/* HQ section title — inline small address */
.brand-title-addr {
  display: inline-block;
  margin-left: 14px;
  font-size: 14px;
  font-weight: 500;
  color: #64748B;
  letter-spacing: -0.005em;
  vertical-align: middle;
}
@media (max-width: 720px) {
  .brand-title-addr { display: block; margin: 6px 0 0; font-size: 13px; }
}

/* ===== FOOTER — cooler dark with blue depth that matches the Dabuller logo ===== */
.footer {
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(37, 99, 235, 0.18) 0%, transparent 60%),
    linear-gradient(180deg, #0A1733 0%, #060F24 60%, #04081A 100%) !important;
  position: relative;
  overflow: hidden;
}
.footer::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 12% 18%, rgba(96, 165, 250, 0.08) 0%, transparent 35%),
    radial-gradient(circle at 88% 92%, rgba(37, 99, 235, 0.10) 0%, transparent 40%);
  pointer-events: none;
}
.footer .shell { position: relative; z-index: 1; }
.footer-logo img {
  height: 38px;
  filter: brightness(0) invert(1) drop-shadow(0 6px 12px rgba(96, 165, 250, 0.35));
}


/* ===== Trust section is now fully blue — GrowthCharts becomes white card on blue ===== */
.growth-block {
  background: #FFFFFF !important;
  border: 1px solid #E2E8F0 !important;
  box-shadow: 0 12px 32px -16px rgba(15, 23, 42, 0.12), 0 4px 12px -2px rgba(15, 23, 42, 0.04) !important;
}

/* Chart redesign — more polished line + grid + axis */
.growth-card {
  padding: 32px 32px 18px !important;
  background: #FFFFFF !important;
  border: 1px solid #E2E8F0 !important;
  box-shadow: 0 6px 18px -8px rgba(15, 23, 42, 0.08) !important;
}
.growth-card-head { margin-bottom: 18px !important; align-items: flex-end !important; }
.growth-card-final {
  font-size: 40px !important;
  letter-spacing: -0.035em !important;
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.growth-card-final .unit {
  font-size: 17px !important;
}
.growth-year {
  font-size: 12px !important;
  margin-left: 0 !important;
  align-self: flex-end;
  padding-bottom: 4px;
}
.growth-svg {
  width: 100%;
  height: 220px;
  display: block;
  margin-top: 4px;
}


/* Donut + logos area → white. Growth block → blue card. */
.growth-block {
  background: linear-gradient(180deg, #EFF6FF 0%, #F0F7FF 100%) !important;
  border: 1px solid #DBEAFE !important;
  box-shadow: 0 12px 32px -16px rgba(37, 99, 235, 0.18), 0 4px 12px -2px rgba(15, 23, 42, 0.04) !important;
}
/* But each inner chart card stays white so the lines stay legible */
.growth-block .growth-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(255,255,255,0.7) !important;
}


/* Growth band wraps Growth+cert in full-width blue background */
.trust-growth-band {
  background: #F0F7FF;
  padding: 56px 0 64px;
  margin-top: 48px;
}
.growth-block {
  background: #FFFFFF !important;
  border: 1px solid #DBEAFE !important;
}


/* Footer — white background to accommodate the JPG logo as-is */
.footer {
  background: #FFFFFF !important;
  color: #475569 !important;
  border-top: 1px solid #E2E8F0;
  padding: 80px 0 36px !important;
}
.footer::before { display: none !important; }
.footer-logo img {
  height: 90px !important;
  filter: none !important;
  drop-shadow: none;
}
.footer-grid {
  border-bottom-color: #E2E8F0 !important;
}
.footer-company-block { color: #475569 !important; }
.footer-company-block span { color: #94A3B8 !important; }
.footer-company-block b { color: #0F172A !important; font-weight: 600 !important; }
.footer-col h5 { color: #0F172A !important; }
.footer-col a { color: #64748B !important; }
.footer-col a:hover { color: #2563EB !important; }
.footer-legal a { color: #475569 !important; }
.footer-legal a:hover { color: #2563EB !important; }
.footer-legal-sep { color: #CBD5E1 !important; }
.footer-copy { color: #94A3B8 !important; }


/* Footer — bigger logo, single clean bottom row, bottom safe area */
.footer {
  padding: 96px 0 120px !important;
}
.footer-logo img {
  height: 225px !important;
  margin: -40px 0 -30px -40px !important;
  display: block;
}
.footer-brand { min-width: 0; }
.footer-grid {
  padding-bottom: 36px !important;
  border-bottom: 0 !important;
}
.footer-bot {
  padding-top: 24px !important;
  border-top: 1px solid #E2E8F0;
}
.footer-bot .footer-legal a {
  font-weight: 600;
  font-size: 13.5px;
}
.footer-copy {
  font-size: 13px !important;
}
/* When sticky utility bar appears at bottom, ensure footer isn't covered */
body.has-sticky-utility .footer { padding-bottom: 160px !important; }
@media (max-width: 720px) {
  .footer-logo img { height: 160px !important; margin: -30px 0 -20px -20px !important; }
}


/* Footer — company info top-left, big full-width logo below menus, readable text */
.footer { padding: 96px 0 140px !important; }
.footer-logo,
.footer-logo img { /* hide the old in-brand logo */
}
.footer-brand .footer-logo { display: none !important; }

.footer-company-block { color: #1E293B !important; }
.footer-company-block > div { gap: 10px !important; line-height: 1.6; }
.footer-company-block span {
  font-size: 13px !important;
  color: #64748B !important;
  font-weight: 600 !important;
  min-width: 130px !important;
}
.footer-company-block b {
  color: #0F172A !important;
  font-weight: 700 !important;
  font-size: 14.5px !important;
  letter-spacing: -0.01em;
}
.footer-col h5 {
  font-size: 15px !important;
  font-weight: 800 !important;
  color: #0F172A !important;
  margin-bottom: 16px !important;
}
.footer-col a {
  font-size: 14px !important;
  color: #475569 !important;
  font-weight: 500 !important;
}
.footer-col a:hover { color: #2563EB !important; }
.footer-col ul { gap: 12px !important; }

/* Big logo BELOW menus, full bleed within shell */
.footer-logo-big {
  display: block;
  margin: 24px -40px 16px;
  overflow: hidden;
  border-radius: 12px;
}
.footer-logo-big img {
  width: 100%;
  height: auto;
  display: block;
  /* Hide the heavy white margins inside the source JPG by scaling and cropping */
  transform: scale(1.25);
  transform-origin: center;
}
@media (max-width: 720px) {
  .footer-logo-big { margin: 16px -20px 8px; }
}

.footer-bot {
  border-top: 1px solid #E2E8F0;
  padding-top: 24px !important;
}
.footer-legal a {
  font-size: 14px !important;
  color: #334155 !important;
  font-weight: 600 !important;
}
.footer-copy {
  font-size: 13.5px !important;
  color: #64748B !important;
  font-weight: 500 !important;
}

/* Logo lives at the bottom of the right-side menu area, centered, sized to fit */
.footer-menus {
  align-content: start;
  position: relative;
}
.footer-menus-logo {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 32px;
  padding: 0 20px;
}
.footer-menus-logo img {
  width: 100%;
  max-width: 520px;
  height: auto;
  display: block;
  transform: scale(1.18);
  transform-origin: center;
}
.footer-logo-big { display: none !important; }
@media (max-width: 720px) {
  .footer-menus-logo img { max-width: 360px; }
}

.footer-menus-logo img { transform: none !important; max-width: 480px !important; }

.hero-floats { position: absolute; inset: 0; pointer-events: none; z-index: 4; }
.hero-float {
  position: absolute;
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px;
  border-radius: 16px;
  background: #FFFFFF;
  border: 1px solid #E2E8F0;
  box-shadow: 0 18px 32px -12px rgba(15, 23, 42, 0.10), 0 4px 12px rgba(15, 23, 42, 0.04);
  animation: heroFloatBob 5s ease-in-out infinite;
}
.hero-float-1 { top: 8%;  left: -6%;  animation-delay: 0s; }
.hero-float-2 { top: 12%; right: -4%; animation-delay: -1.2s; }
.hero-float-3 { bottom: 22%; left: -2%; animation-delay: -2.4s; }
.hero-float-4 { bottom: 12%; right: -6%; animation-delay: -3.6s; }
@keyframes heroFloatBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}
.hero-float-icon {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, #EFF6FF 0%, #DBEAFE 100%);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 20px;
}
.hero-float-num {
  font-size: 20px; font-weight: 900;
  color: #0F172A; letter-spacing: -0.02em;
  line-height: 1; font-feature-settings: 'tnum';
}
.hero-float-num em { font-style: normal; font-size: 12px; font-weight: 700; color: #2563EB; margin-left: 3px; }
.hero-float-lbl { font-size: 12px; color: #64748B; font-weight: 600; margin-top: 4px; }
.hero-float-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  z-index: -1;
}
.hero-float-blob-1 { width: 280px; height: 280px; top: 20%; left: -10%; background: rgba(37, 99, 235, 0.10); }
.hero-float-blob-2 { width: 240px; height: 240px; bottom: 10%; right: -8%; background: rgba(96, 165, 250, 0.10); }
@media (max-width: 980px) {
  .hero-float-1, .hero-float-2, .hero-float-3, .hero-float-4 { display: none; }
}

/* Interactive rotating orb — decorative accent in hero area */
.hero-orb {
  position: absolute;
  bottom: 6%;
  right: 8%;
  width: 120px; height: 120px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.85) 0%, rgba(255,255,255,0) 40%),
    radial-gradient(circle at 70% 70%, #1D4ED8 0%, #2563EB 35%, #3B82F6 60%, #93C5FD 100%);
  box-shadow:
    0 24px 48px -12px rgba(37, 99, 235, 0.55),
    inset 0 0 40px rgba(255, 255, 255, 0.2),
    inset -20px -20px 40px rgba(15, 23, 42, 0.4);
  animation: heroOrbSpin 14s linear infinite, heroOrbBob 6s ease-in-out infinite;
  pointer-events: none;
  z-index: 3;
}
.hero-orb::before, .hero-orb::after {
  content: "";
  position: absolute; inset: 6%;
  border-radius: 50%;
  background:
    conic-gradient(from 0deg,
      rgba(255,255,255,0) 0%,
      rgba(255,255,255,0.18) 25%,
      rgba(255,255,255,0) 50%,
      rgba(96, 165, 250, 0.25) 75%,
      rgba(255,255,255,0) 100%);
  animation: heroOrbSpinRev 10s linear infinite;
  mix-blend-mode: screen;
}
.hero-orb::after {
  inset: 14%;
  background:
    conic-gradient(from 90deg,
      rgba(255,255,255,0.30) 0%,
      rgba(255,255,255,0) 30%,
      rgba(147, 197, 253, 0.40) 60%,
      rgba(255,255,255,0) 100%);
  animation: heroOrbSpin 7s linear infinite;
}
@keyframes heroOrbSpin     { from { transform: rotate(0); }    to { transform: rotate(360deg); } }
@keyframes heroOrbSpinRev  { from { transform: rotate(0); }    to { transform: rotate(-360deg); } }
@keyframes heroOrbBob {
  0%, 100% { translate: 0 0; }
  50%      { translate: 0 -10px; }
}
@media (max-width: 720px) { .hero-orb { display: none; } }

.hero-region-bg {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
}
.hero-region-land {
  fill: #F1F5F9;
  stroke: #CBD5E1;
  stroke-width: 0.6;
  opacity: 0.7;
}
.hero-region-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  fill: #94A3B8;
  letter-spacing: 0.14em;
}
.hero-region-label-big { font-size: 13px; letter-spacing: 0.18em; }
.hero-region-label-sub {
  font-size: 11px;
  fill: #94A3B8;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.hero-region-sea {
  font-size: 10.5px;
  fill: #BFDBFE;
  font-weight: 600;
  font-style: italic;
  letter-spacing: 0.05em;
}
.hero-map-stage > .hero-visual { position: relative; z-index: 1; }
.hero-map-stage > .hero-map-cursor { z-index: 5; }

.hero-globe {
  position: absolute;
  bottom: 8%;
  right: 4%;
  width: 180px; height: 180px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.55) 0%, rgba(255,255,255,0) 35%),
    radial-gradient(circle at 70% 70%, #1D4ED8 0%, #2563EB 40%, #60A5FA 80%, #BFDBFE 100%);
  box-shadow:
    0 30px 60px -16px rgba(37, 99, 235, 0.40),
    inset -22px -22px 50px rgba(15, 23, 42, 0.35),
    inset 18px 18px 38px rgba(255, 255, 255, 0.18);
  overflow: hidden;
}
.hero-globe::before, .hero-globe::after {
  content: "";
  position: absolute; inset: 0;
  border-radius: 50%;
  background:
    radial-gradient(ellipse 60% 8% at 22% 28%, rgba(255,255,255,0.55), transparent 70%),
    radial-gradient(ellipse 18% 38% at 38% 55%, rgba(15,23,42,0.20), transparent 70%),
    radial-gradient(ellipse 22% 12% at 65% 38%, rgba(15,23,42,0.18), transparent 70%),
    radial-gradient(ellipse 28% 22% at 72% 70%, rgba(15,23,42,0.20), transparent 70%);
  animation: heroGlobeSpin 18s linear infinite;
}
.hero-globe::after {
  background:
    radial-gradient(ellipse 24% 10% at 30% 45%, rgba(255,255,255,0.18), transparent 70%),
    radial-gradient(ellipse 18% 26% at 55% 70%, rgba(15,23,42,0.16), transparent 70%);
  animation: heroGlobeSpin 12s linear infinite;
  mix-blend-mode: screen;
}
@keyframes heroGlobeSpin {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}
@media (max-width: 720px) { .hero-globe { display: none; } }


/* ===== Hero chips (relocated from removed dark utility bar) — light-bg variant ===== */
.hero-chips {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin: 0 auto 18px;
  justify-content: center;
}
.hero-chips .dispatch-chip {
  background: #FFFFFF;
  border: 1px solid #DBEAFE;
  color: #0F172A;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}
.hero-chips .dispatch-chip:hover {
  background: #F8FAFC;
  border-color: #BFDBFE;
}
.hero-chips .dispatch-chip-bar { background: #CBD5E1; }
.hero-chips .dispatch-chip-bar.is-on { background: var(--chip-on); }
.hero-chips .dispatch-chip-live  { color: #0F172A; }
.hero-chips .dispatch-chip-sep   { color: #94A3B8; }
.hero-chips .dispatch-chip-label { color: var(--chip-on-text-light, #0F172A); }
.hero-chips .dispatch-chip.dm-vlow  { --chip-on-text-light: #DC2626; }
.hero-chips .dispatch-chip.dm-low   { --chip-on-text-light: #EA580C; }
.hero-chips .dispatch-chip.dm-mid   { --chip-on-text-light: #B45309; }
.hero-chips .dispatch-chip.dm-high  { --chip-on-text-light: #059669; }
.hero-chips .dispatch-chip.dm-vhigh { --chip-on-text-light: #047857; }

.hero-chips .pill {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 4px 12px 4px 10px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid #DBEAFE;
  color: #0F172A;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}
.hero-chips .pill .sep   { color: #94A3B8; margin: 0 -5px; font-weight: 500; }
.hero-chips .pill .hours { color: #64748B; }
.hero-chips .pill .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #94A3B8;
}
.hero-chips .pill.is-open .dot {
  background: #10B981;
  animation: utilPillPulse 1.5s ease-in-out infinite;
}
.hero-chips .pill.is-closed .dot {
  background: #94A3B8;
  animation: none;
}
.hero-chips .pill.is-closed { opacity: 0.8; }


/* ===== Logispot-style header — clean white, no border at top ===== */


/* ===== Nav scroll effect: shrink height + show 1px divider ===== */
.nav {
  transition: border-color .3s ease;
}
.nav .nav-row {
  transition: height .3s ease;
}
.nav.is-scrolled {
  border-bottom: 1px solid #E5E7EB !important;
}
.nav.is-scrolled .nav-row {
  height: 60px;
}


/* Stats band — separate the badge from the number so they don't overlap */
.stats-band-item { padding-top: 6px !important; }
.stats-band-badge { top: -22px !important; }

/* Kakao-themed number for the 4th stat (10,000+ 카카오톡 친구) */
.stats-band-item:nth-child(4) .stats-band-value .num,
.stats-band-item:nth-child(4) .stats-band-value .unit {
  background: none !important;
  -webkit-text-fill-color: #FEE500 !important;
  color: #FEE500 !important;
  text-shadow: 0 0 24px rgba(254, 229, 0, 0.45) !important;
  filter: drop-shadow(0 4px 14px rgba(254, 229, 0, 0.30)) !important;
}


/* Move hero content below center + thicker buttons */
.vhero-shell {
  justify-content: flex-end !important;
  padding-bottom: clamp(72px, 14vh, 140px) !important;
}
.vhero-btn {
  padding: 16px 30px !important;
  font-size: 15.5px !important;
}
.vhero-title { white-space: normal; }


/* =============== FOOTER — REDESIGN =============== */
.footer {
  background: linear-gradient(180deg, #0A1226 0%, #060A1A 100%) !important;
  color: #94A3B8 !important;
  padding: 80px 0 32px !important;
  position: relative;
  border-top: 0 !important;
  overflow: hidden;
}
.footer::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(96,165,250,0.4), transparent);
  pointer-events: none;
}

.footer-top {
  display: grid;
  grid-template-columns: 1.2fr 2fr;
  gap: 64px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
@media (max-width: 960px) { .footer-top { grid-template-columns: 1fr; gap: 48px; } }

/* Brand column */
.footer-brand-col {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.footer-logo {
  display: inline-block;
  width: fit-content;
}
.footer-logo img {
  height: 36px !important;
  width: auto !important;
  display: block;
  filter: brightness(0) invert(1);
  margin: 0 !important;
}
.footer-tagline {
  font-size: 15px;
  line-height: 1.6;
  color: rgba(255,255,255,0.78) !important;
  margin: 0;
  letter-spacing: -0.01em;
  font-weight: 500;
}

/* Primary contact cards (phone + email) */
.footer-contact-prim {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 6px;
}
@media (max-width: 540px) { .footer-contact-prim { grid-template-columns: 1fr; } }
.footer-prim {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 18px;
  border-radius: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  transition: background .2s ease, border-color .2s ease;
  color: inherit;
}
.footer-prim:hover {
  background: rgba(96, 165, 250, 0.08);
  border-color: rgba(96, 165, 250, 0.25);
}
.footer-prim-lbl {
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45) !important;
}
.footer-prim-val {
  font-size: 16px;
  font-weight: 700;
  color: #FFFFFF !important;
  letter-spacing: -0.01em;
  font-feature-settings: 'tnum';
}
.footer-prim-mail .footer-prim-val { font-size: 14.5px; }

/* Menu area */
.footer-menus {
  display: grid !important;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
}
@media (max-width: 960px) { .footer-menus { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .footer-menus { grid-template-columns: repeat(2, 1fr); } }

.footer-col h5 {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #FFFFFF !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 16px !important;
  position: relative;
  padding-bottom: 10px;
}
.footer-col h5::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0;
  width: 22px; height: 2px;
  background: linear-gradient(90deg, #60A5FA, #2563EB);
  border-radius: 1px;
}
.footer-col ul { gap: 11px !important; }
.footer-col a {
  font-size: 14px !important;
  color: rgba(255,255,255,0.55) !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em;
  transition: color .15s ease;
}
.footer-col a:hover { color: #FFFFFF !important; }

/* Meta info — company details strip */
.footer-meta {
  padding: 28px 0 32px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.footer-meta-grid {
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px 28px;
}
@media (max-width: 960px) { .footer-meta-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .footer-meta-grid { grid-template-columns: 1fr; } }
.footer-meta-grid > div { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.footer-meta-grid .span-2 { grid-column: span 2; }
@media (max-width: 960px) { .footer-meta-grid .span-2 { grid-column: span 1; } }
.footer-meta-grid dt {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.40);
  font-weight: 600;
  text-transform: uppercase;
}
.footer-meta-grid dd {
  font-size: 13.5px;
  color: rgba(255,255,255,0.82);
  font-weight: 500;
  letter-spacing: -0.005em;
  margin: 0;
}

/* Bottom legal + copyright */
.footer-bot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 24px !important;
  border-top: 0 !important;
  flex-wrap: wrap;
  gap: 12px;
}
.footer-legal a {
  font-size: 13px !important;
  color: rgba(255,255,255,0.55) !important;
  font-weight: 500 !important;
  transition: color .15s ease;
}
.footer-legal a:hover { color: #FFFFFF !important; }
.footer-legal-sep { color: rgba(255,255,255,0.20); margin: 0 4px; }
.footer-copy {
  color: rgba(255,255,255,0.40) !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
}

/* Hide leftover old footer styles that no longer apply */
.footer-grid, .footer-company, .footer-company-block, .footer-menus-logo,
.footer-brand .footer-logo, .footer-logo-big { /* legacy classes — ensure not visible */ }
.footer-menus-logo { display: none !important; }
.footer-logo-big { display: none !important; }


/* Footer — IT company vibe (Logispot-style deep blue/violet) + bigger logo */
.footer {
  background:
    radial-gradient(ellipse 70% 60% at 20% 0%, rgba(59, 130, 246, 0.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 100%, rgba(99, 102, 241, 0.14) 0%, transparent 60%),
    linear-gradient(180deg, #0E1638 0%, #0B112A 50%, #080E22 100%) !important;
}
.footer::before {
  background: linear-gradient(90deg, transparent, rgba(96, 165, 250, 0.55), transparent) !important;
  height: 1px !important;
}
.footer-logo img {
  height: 80px !important;
  filter: brightness(0) invert(1) drop-shadow(0 6px 18px rgba(96, 165, 250, 0.35)) !important;
}
@media (max-width: 720px) {
  .footer-logo img { height: 56px !important; }
}


/* Logo image is already white — no color filter needed */
.footer-logo img {
  filter: drop-shadow(0 6px 18px rgba(96, 165, 250, 0.35)) !important;
}


/* Bigger footer logo */
.footer-logo img {
  height: 120px !important;
}
@media (max-width: 720px) {
  .footer-logo img { height: 84px !important; }
}


/* Push the right-side menu columns down so they align with the contact cards */
.footer-top { align-items: stretch; }
.footer-menus { align-self: end; padding-bottom: 8px; }
@media (max-width: 960px) {
  .footer-menus { align-self: stretch; padding-bottom: 0; }
}


/* ===== Unified CTA — text readability on raw photo (all pages) ===== */
.uni-cta .uni-cta-shell { position: relative; z-index: 1; }
.uni-cta-headline {
  text-shadow:
    0 2px 18px rgba(0, 0, 0, 0.70),
    0 0 10px rgba(0, 0, 0, 0.55),
    0 1px 2px rgba(0, 0, 0, 0.85);
}
.uni-cta-sub,
.uni-cta-channel,
.uni-cta-hours {
  text-shadow:
    0 2px 12px rgba(0, 0, 0, 0.65),
    0 0 6px rgba(0, 0, 0, 0.50);
}
.uni-cta .uni-cta-channels,
.uni-cta .uni-cta-hours {
  background: rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  border-radius: 999px;
  padding: 10px 22px;
}
.uni-cta .uni-cta-channels {
  display: inline-flex;
  gap: 22px;
  width: auto;
  margin: 0 auto 14px;
}


/* Video hero — strong text-shadow for readability (no overlay, no capsule) */
.vhero-title {
  text-shadow:
    0 4px 24px rgba(0, 0, 0, 0.72),
    0 2px 8px rgba(0, 0, 0, 0.55),
    0 0 12px rgba(0, 0, 0, 0.45) !important;
}
.vhero-sub {
  text-shadow:
    0 3px 16px rgba(0, 0, 0, 0.70),
    0 1px 6px rgba(0, 0, 0, 0.50) !important;
}
.vhero-badge {
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.45);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.35);
}
.vhero-btn {
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35), 0 4px 10px rgba(0, 0, 0, 0.25) !important;
}


/* ===== Mobile nav: hamburger + slide-down panel ===== */
.nav-burger {
  display: none;
  width: 44px; height: 44px;
  border-radius: 10px;
  background: transparent;
  border: 1px solid #E2E8F0;
  cursor: pointer;
  padding: 0;
  position: relative;
}
.nav-burger span {
  position: absolute;
  left: 11px; right: 11px;
  height: 2px;
  background: #0F172A;
  border-radius: 2px;
  transition: transform .25s ease, opacity .25s ease, top .25s ease;
}
.nav-burger span:nth-child(1) { top: 14px; }
.nav-burger span:nth-child(2) { top: 21px; }
.nav-burger span:nth-child(3) { top: 28px; }
.nav-burger.is-open span:nth-child(1) { top: 21px; transform: rotate(45deg); }
.nav-burger.is-open span:nth-child(2) { opacity: 0; }
.nav-burger.is-open span:nth-child(3) { top: 21px; transform: rotate(-45deg); }

.nav-mobile-panel {
  display: none;
  position: fixed;
  left: 0; right: 0; top: 72px;
  bottom: 0;
  background: #FFFFFF;
  z-index: 49;
  overflow-y: auto;
  padding: 24px 32px 120px;
  transform: translateY(-8px);
  opacity: 0;
  transition: transform .25s ease, opacity .25s ease;
  pointer-events: none;
}
.nav.is-menu-open .nav-mobile-panel {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.nav-mobile-links {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.nav-mobile-links > li { border-bottom: 1px solid #F1F5F9; padding: 16px 0; }
.nav-mobile-links > li > a {
  display: block;
  font-size: 19px;
  font-weight: 700;
  color: #0F172A;
  letter-spacing: -0.02em;
  padding: 8px 0;
}
.nav-mobile-sub {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.nav-mobile-sub li a {
  display: block;
  font-size: 15px;
  color: #475569;
  font-weight: 500;
  padding: 8px 0 8px 14px;
  letter-spacing: -0.01em;
}
body.has-mobile-menu-open { overflow: hidden; }

/* Mobile breakpoint: ≤720px → icon-only CTAs, show burger */
@media (max-width: 720px) {
  .nav-row { gap: 12px; }
  .brand-logo { height: 32px !important; }
  .nav-cta { gap: 8px !important; }
  .nav-cta .btn {
    padding: 0 !important;
    width: 40px;
    height: 40px;
    justify-content: center;
    border-radius: 50% !important;
  }
  .nav-cta .btn .btn-label { display: none; }
  .nav-cta .btn svg { width: 18px !important; height: 18px !important; }
  /* Hide the 견적문의 CTA on very small screens (covered by mobile menu) */
  .nav-cta .btn-quote { display: none; }
  .nav-burger { display: inline-flex; align-items: center; justify-content: center; }
  .nav-mobile-panel { display: block; top: 64px; }
}
@media (max-width: 720px) {
  .nav-row { height: 64px !important; }
}


/* Tablet (≤980px): nav-links already hidden — show burger but keep CTA labels */
@media (max-width: 980px) and (min-width: 721px) {
  .nav-burger { display: inline-flex; align-items: center; justify-content: center; }
  .nav-mobile-panel { display: block; top: 72px; }
}


/* Show burger earlier — before nav items start wrapping */
@media (max-width: 1180px) and (min-width: 721px) {
  .nav-links { display: none !important; }
  .nav-burger { display: inline-flex !important; align-items: center; justify-content: center; }
  .nav-mobile-panel { display: block; top: 72px; }
}


/* Show full nav from 1260px, burger below */
@media (max-width: 1259px) and (min-width: 721px) {
  .nav-links { display: none !important; }
  .nav-burger { display: inline-flex !important; align-items: center; justify-content: center; }
  .nav-mobile-panel { display: block; top: 72px; }
}
@media (min-width: 1260px) {
  .nav-links { display: flex !important; }
  .nav-burger { display: none !important; }
  .nav-mobile-panel { display: none !important; }
}

@media (max-width: 720px) {
  .brand-logo { height: 44px !important; }
}


/* Mobile: replace fixed-attachment parallax (which iOS disables) with a slow Ken-Burns zoom */
@media (max-width: 1024px) {
  .uni-cta {
    background-attachment: scroll !important;
    overflow: hidden;
    background-size: 130% auto !important;
    background-position: center !important;
    animation: uniCtaKenBurns 24s ease-in-out infinite alternate;
  }
}
@keyframes uniCtaKenBurns {
  from { background-position: 45% 40%; background-size: 130% auto; }
  to   { background-position: 55% 60%; background-size: 145% auto; }
}


/* Mobile/tab: stronger override that wins over the .uni-cta shorthand background */
@media (max-width: 1024px) {
  .uni-cta {
    background-image: url('assets/office.jpg') !important;
    background-attachment: scroll !important;
    background-repeat: no-repeat !important;
    background-size: 140% auto !important;
    background-position: 50% 50% !important;
    overflow: hidden;
    animation: uniCtaKenBurns 22s ease-in-out infinite alternate !important;
  }
}
@keyframes uniCtaKenBurns {
  0%   { background-size: 140% auto; background-position: 45% 40%; }
  100% { background-size: 160% auto; background-position: 55% 60%; }
}


/* Ken Burns via pseudo-element — works reliably on all viewports under 1024px */
@media (max-width: 1024px) {
  .uni-cta {
    background: none !important;
    background-color: #0F172A !important;
    animation: none !important;
    position: relative;
    overflow: hidden;
  }
  .uni-cta::after {
    content: "";
    position: absolute;
    inset: -10%;
    background: url('assets/office.jpg') center/cover no-repeat;
    z-index: -1;
    animation: uniCtaKenBurnsBg 22s ease-in-out infinite alternate;
    will-change: transform;
  }
  .uni-cta::before { z-index: 0; }
}
@keyframes uniCtaKenBurnsBg {
  0%   { transform: scale(1.05) translate(-1%, -1%); }
  100% { transform: scale(1.18) translate(2%, 2%); }
}


/* Mobile — let map stage grow with content; result actions stay in flow */
@media (max-width: 720px) {
  .hero-map-stage,
  .hero-map-stage .est-bare {
    height: auto !important;
    min-height: 0 !important;
  }
  .hero-map-stage .est-bare .est-result {
    overflow: visible !important;
    padding-bottom: 16px !important;
  }
  .hero-map-stage .est-bare .est-result-actions {
    position: static !important;
    background: transparent !important;
    border-top: 1px solid #E2E8F0;
    padding: 14px 0 0 !important;
    margin-top: 12px !important;
    justify-content: stretch !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
  }
  /* 긴 라벨(전화 상담 1800-0510 / 배차프로그램)이 칸 안에서 줄바꿈되며 정렬 깨지던 문제:
     2개씩 배치(45% basis)하고 텍스트는 줄바꿈 금지 → 안 들어가면 다음 줄로 넘기고 꽉 채움. */
  .hero-map-stage .est-bare .est-result-actions .btn {
    flex: 1 1 45%;
    justify-content: center;
    min-width: 0;
    white-space: nowrap;
    font-size: 12px;
    padding: 9px 8px;
    gap: 5px;
  }
}
