
/* CSS variables scoped to solution-21-page */
.solution-21-page {
  --blue: #005BFF;
  --blue2: #3b82f6;
  --purple: #7c3aed;
  --cyan: #06b6d4;
  --green: #10b981;
  --ink: #1e293b;
  --muted: #64748b;
  --line: #dbe5f3;
  --soft: #f8fafc;
  --dark: #0f172a;
  --shadow: 0 18px 48px rgba(15, 23, 42, .08);
  --ease: cubic-bezier(.4, 0, .2, 1);
}

/* Box-sizing only for elements within our container */
.solution-21-page * { box-sizing: border-box; }

/* Reset styles for elements within our container */
.solution-21-page {
  color: var(--ink);
  background: #fff;
  font-family: 'Montserrat-SemiBold', -apple-system, BlinkMacSystemFont, "PingFang SC", sans-serif;
  letter-spacing: 0;
}

.solution-21-page a { color: inherit; text-decoration: none; cursor: pointer; }
.solution-21-page .page {margin: 0 auto; overflow: hidden; background: #fff; }
.solution-21-page .nav {
  height: 76px; padding: 0 40px; display: flex; align-items: center; justify-content: space-between;
  background: rgba(255, 255, 255, .92); border-bottom: 1px solid rgba(219, 229, 243, .78);
  position: relative; z-index: 10; backdrop-filter: blur(12px);
}
.solution-21-page .brand { display: flex; align-items: center; gap: 11px; font-size: 22px; font-weight: 850; color: #0f172a; }
.solution-21-page .mark {
  width: 36px; height: 36px; border-radius: 11px; display: grid; place-items: center;
  color: #fff; background: linear-gradient(135deg, #06b6d4, #2563eb 58%, #7c3aed);
  box-shadow: 0 12px 24px rgba(37, 99, 235, .22);
  font-weight: 950;
}
.solution-21-page .nav-links { display: flex; gap: 34px; color: #334155; font-weight: 700; font-size: 14px; }
.solution-21-page .nav-actions { display: flex; gap: 12px; align-items: center; }
.solution-21-page .btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 44px; padding: 0 22px; border-radius: 999px; border: 1px solid transparent;
  font-weight: 800; font-size: 14px; transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
  cursor: pointer; white-space: nowrap;
}
.solution-21-page .btn:hover { transform: translateY(-5px); }
.solution-21-page .btn.primary { color: #fff; background: linear-gradient(135deg, var(--blue), #1d4ed8); box-shadow: 0 12px 28px rgba(37, 99, 235, .28); }
.solution-21-page .btn.primary:hover { box-shadow: 0 18px 38px rgba(37, 99, 235, .34); }
.solution-21-page .btn.ghost { color: #0f172a; border-color: #cbd5e1; background: rgba(255, 255, 255, .72); }
.solution-21-page .btn.dark-ghost { color: #fff; border-color: rgba(255,255,255,.36); background: rgba(255,255,255,.06); }

.solution-21-page .hero {
  position: relative; min-height: 790px; padding: 90px 40px 84px;
  background:
  radial-gradient(circle at 82% 22%, rgba(6,182,212,.24), transparent 28%),
  radial-gradient(circle at 31% 18%, rgba(124,58,237,.20), transparent 26%),
  linear-gradient(180deg, #f7fbff 0%, #fff 76%);
  overflow: hidden;
}
.solution-21-page .hero::before {
  content: ""; position: absolute; inset: 0;
  background-image:
  linear-gradient(rgba(37,99,235,.085) 1px, transparent 1px),
  linear-gradient(90deg, rgba(37,99,235,.085) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,.72), transparent 74%);
  mask-image: linear-gradient(180deg, rgba(0,0,0,.72), transparent 74%);
}
.solution-21-page .particle { position: absolute; width: 9px; height: 9px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 24px rgba(6,182,212,.85); opacity: .72; animation: float 7s ease-in-out infinite; }
.solution-21-page .p1 { left: 215px; top: 118px; animation-delay: .2s; }
.solution-21-page .p2 { left: 640px; top: 156px; background: var(--purple); animation-delay: 1.1s; }
.solution-21-page .p3 { right: 265px; top: 104px; animation-delay: .7s; }
.solution-21-page .p4 { right: 158px; top: 456px; background: var(--green); animation-delay: 1.8s; }
.solution-21-page .hero-inner { position: relative; display: grid; grid-template-columns: 480px 1fr; gap: 40px; align-items: center; }
.solution-21-page .eyebrow {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 13px; border-radius: 999px;
  color: #1d4ed8; background: #eff6ff; border: 1px solid #bfdbfe; font-weight: 850; font-size: 13px;
  margin-bottom: 22px;
}
.solution-21-page .pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 6px rgba(16,185,129,.14); }
.solution-21-page h1 { margin: 0; font-size: 44px; line-height: 1.17; letter-spacing: 0; color: #0f172a; font-weight: 700;}
.solution-21-page .word { display: inline-block; opacity: 0; transform: translateY(14px); animation: wordIn .55s var(--ease) forwards; }
.solution-21-page .shot .word { opacity: 1; transform: translateY(0); animation: none; }
.solution-21-page .hero-copy { margin: 16px 0 32px; color: #475569; font-size: 16px; line-height: 1.4; max-width: 560px; font-family: 'Montserrat-medium'}
.solution-21-page .hero-actions { display: flex; gap: 14px; align-items: center; }
.solution-21-page .trust { display: flex; gap: 24px; margin-top: 30px; color: #64748b; font-size: 13px; font-weight: 750; }
.solution-21-page .trust b { display: block; color: #0f172a; font-size: 25px; line-height: 1.05; margin-bottom: 6px; font-weight: 600; }
.solution-21-page .trust div { padding-right: 22px; border-right: 1px solid #dbe5f3; }
.solution-21-page .trust div:last-child { border-right: 0; }

.solution-21-page .hero-visual { position: relative; width: 640px; height: 540px; }
.solution-21-page .hero-visual img {
  height: 100%;
  width: auto;
  object-fit: cover;
}
.solution-21-page .orbit {
  position: absolute; right: 40px; top: 0; width: 420px; height: 420px; border-radius: 50%;
  border: 1px solid rgba(37,99,235,.18); animation: spin 24s linear infinite;
}
.solution-21-page .orbit::before, .solution-21-page .orbit::after {
  content: ""; position: absolute; border-radius: 50%; background: #fff; border: 1px solid #bfdbfe;
  box-shadow: 0 10px 26px rgba(37,99,235,.14);
}
.solution-21-page .orbit::before { width: 74px; height: 74px; left: 22px; top: 74px; }
.solution-21-page .orbit::after { width: 52px; height: 52px; right: 42px; bottom: 92px; }
.solution-21-page .product-board {
  position: absolute; right: 0; top: 42px; width: 540px; height: 432px; border-radius: 24px;
  background: #fff; border: 1px solid rgba(203,213,225,.86); box-shadow: 0 30px 70px rgba(37,99,235,.18);
  overflow: hidden; transform: translateZ(0);
}
.solution-21-page .board-top { height: 50px; display: flex; align-items: center; gap: 8px; padding: 0 18px; border-bottom: 1px solid #e2e8f0; background: #f8fafc; }
.solution-21-page .dot { width: 10px; height: 10px; border-radius: 50%; background: #cbd5e1; }
.solution-21-page .board-body { display: grid; grid-template-columns: 180px 1fr; height: 382px; }
.solution-21-page .side { padding: 20px 16px; background: #fbfdff; border-right: 1px solid #e2e8f0; }
.solution-21-page .side-item { height: 36px; border-radius: 10px; display: flex; align-items: center; gap: 9px; padding: 0 12px; margin-bottom: 10px; color: #64748b; font-size: 12px; font-weight: 850; }
.solution-21-page .side-item.active { color: #2563eb; background: #eef5ff; }
.solution-21-page .main { padding: 22px; }
.solution-21-page .main-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.solution-21-page .main-head strong { font-size: 18px; color: #0f172a; }
.solution-21-page .tag { color: #047857; background: #dcfce7; border-radius: 999px; padding: 7px 10px; font-size: 12px; font-weight: 850; }
.solution-21-page .chat { display: grid; gap: 10px; }
.solution-21-page .bubble { max-width: 84%; padding: 12px 14px; border-radius: 14px; background: #f1f5f9; color: #334155; font-size: 13px; line-height: 1.42; }
.solution-21-page .bubble.ai { margin-left: auto; background: linear-gradient(135deg, #2563eb, #7c3aed); color: #fff; }
.solution-21-page .board-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 18px; }
.solution-21-page .board-metric { border: 1px solid #e2e8f0; border-radius: 14px; padding: 12px; background: #fff; }
.solution-21-page .board-metric b { display: block; font-size: 18px; color: #0f172a; }
.solution-21-page .board-metric span { color: #64748b; font-size: 11px; font-weight: 800; }
.solution-21-page .phone {
  position: absolute; right: -20px; bottom: 8px; width: 238px; height: 404px; border-radius: 34px;
  padding: 12px; background: #0f172a; box-shadow: 0 28px 58px rgba(15,23,42,.28);
  animation: bob 5s ease-in-out infinite;
}
.solution-21-page .phone-screen { height: 100%; border-radius: 25px; padding: 18px 14px; background: linear-gradient(180deg, #eff8ff, #fff); overflow: hidden; }
.solution-21-page .signal-tile { height: 93px; border-radius: 18px; position: relative; background: linear-gradient(135deg, #2563eb, #06b6d4 62%, #10b981); overflow: hidden; }
.solution-21-page .signal-tile::after {
  content: ""; position: absolute; inset: 20px; border: 2px solid rgba(255,255,255,.82); border-radius: 50%;
  box-shadow: 0 0 0 20px rgba(255,255,255,.18), 0 0 0 42px rgba(255,255,255,.08);
}
.solution-21-page .mini-ui { margin-top: 12px; padding: 12px; border-radius: 14px; background: #fff; border: 1px solid #dbeafe; }
.solution-21-page .bar { height: 8px; border-radius: 99px; background: #dbeafe; margin: 7px 0; }
.solution-21-page .short { width: 62%; }
.solution-21-page .hero-card {
  position: absolute; left: 0; bottom: 42px; width: 252px; padding: 18px; border-radius: 18px;
  background: #0f172a; color: #fff; box-shadow: 0 20px 44px rgba(15,23,42,.24);
}
.solution-21-page .hero-card b { display: block; font-size: 34px; color: #fff; }
.solution-21-page .hero-card span { color: #cbd5e1; font-size: 13px; line-height: 1.5; }

.solution-21-page .section { padding: 92px 0px; position: relative; }
.solution-21-page .section.alt { background: #f8fafc; }
.solution-21-page .section-head { max-width: 860px; margin: 0 auto 48px; text-align: center; }
.solution-21-page .kicker { color: #2563eb; font-size: 13px; letter-spacing: .13em; font-weight: 900; }
.solution-21-page h2 { margin: 12px 0 14px; color: #0f172a; font-size: 42px; line-height: 1.14; letter-spacing: 0; font-weight: 700;}
.solution-21-page .section-head p { margin: 0; color: #64748b; font-size: 17px; line-height: 1.65; }

.solution-21-page .flow-lines {
  position: absolute; left: 0; right: 0; top: 0; height: 100%; pointer-events: none; opacity: .42;
  background: linear-gradient(90deg, transparent 0 12%, rgba(37,99,235,.12) 12.2%, transparent 12.4% 48%, rgba(6,182,212,.12) 48.2%, transparent 48.4% 86%, rgba(124,58,237,.1) 86.2%, transparent 86.4%);
  background-size: 280px 100%;
  animation: drift 10s linear infinite;
}
.solution-21-page .pain-flow { display: grid; gap: 32px; position: relative; max-width: 1280px; margin: 0 auto; }
.solution-21-page .pain-flow .arrow { display: none; }
.solution-21-page .flow-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: stretch;
}
.solution-21-page .illo { display: none; }
.solution-21-page .device { position: absolute; border-radius: 14px; background: #fff; border: 1px solid #bfdbfe; box-shadow: 0 14px 30px rgba(37,99,235,.14); }
.solution-21-page .laptop { left: 24px; bottom: 38px; width: 154px; height: 100px; padding: 12px; }
.solution-21-page .laptop::after { content: ""; position: absolute; left: -10px; right: -10px; bottom: -12px; height: 12px; border-radius: 0 0 12px 12px; background: #c7d2fe; }
.solution-21-page .tablet { right: 24px; top: 34px; width: 78px; height: 116px; padding: 10px; }
.solution-21-page .mobile { left: 74px; top: 28px; width: 58px; height: 104px; border-radius: 18px; padding: 9px; }
.solution-21-page .screen-title { height: 10px; width: 56%; border-radius: 99px; background: #bfdbfe; margin-bottom: 8px; }
.solution-21-page .chat-line { height: 12px; border-radius: 99px; background: #dbeafe; margin-bottom: 7px; }
.solution-21-page .chat-line.right { margin-left: auto; width: 72%; background: #c7d2fe; }
.solution-21-page .app-icon { width: 34px; height: 34px; border-radius: 11px; display: grid; place-items: center; color: #fff; font-weight: 950; margin: 7px auto; box-shadow: 0 8px 18px rgba(15,23,42,.14); }
.solution-21-page .wa { background: linear-gradient(135deg, #22c55e, #10b981); }
.solution-21-page .social { background: linear-gradient(135deg, #2563eb, #7c3aed); }
.solution-21-page .confusion { position: absolute; width: 32px; height: 32px; border-radius: 50%; display: grid; place-items: center; font-weight: 950; box-shadow: 0 8px 20px rgba(239,68,68,.14); }
.solution-21-page .q { color: #2563eb; background: #eff6ff; border: 1px solid #bfdbfe; }
.solution-21-page .bang { color: #ef4444; background: #fff1f2; border: 1px solid #fecaca; }
.solution-21-page .ticket-stack { position: absolute; left: 34px; right: 24px; bottom: 28px; height: 154px; }
.solution-21-page .ticket { position: absolute; width: 168px; height: 56px; border-radius: 13px; background: #fff; border: 1px solid #bfdbfe; box-shadow: 0 12px 24px rgba(37,99,235,.13); transform: rotate(var(--r)); left: var(--x); top: var(--y); padding: 11px; }
.solution-21-page .ticket::before, .solution-21-page .ticket::after { content: ""; display: block; height: 8px; border-radius: 99px; background: #dbeafe; margin-bottom: 8px; }
.solution-21-page .ticket::after { width: 62%; background: #bfdbfe; }
.solution-21-page .agent-head { position: absolute; left: 94px; top: 26px; width: 78px; height: 78px; border-radius: 50%; background: linear-gradient(135deg, #fde68a, #f59e0b); border: 6px solid rgba(255,255,255,.72); box-shadow: 0 14px 28px rgba(245,158,11,.18); }
.solution-21-page .agent-head::before { content: ""; position: absolute; left: 18px; top: 26px; width: 8px; height: 8px; border-radius: 50%; background: #78350f; box-shadow: 26px 0 #78350f; }
.solution-21-page .agent-head::after { content: ""; position: absolute; left: 24px; top: 48px; width: 28px; height: 10px; border-bottom: 3px solid #78350f; border-radius: 0 0 24px 24px; }
.solution-21-page .buried-alert { position: absolute; left: 112px; bottom: 26px; width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center; color: #fff; background: #ef4444; border: 5px solid #fee2e2; font-size: 30px; font-weight: 950; box-shadow: 0 14px 26px rgba(239,68,68,.24); }
.solution-21-page .chart-line { position: absolute; left: 28px; right: 28px; bottom: 42px; height: 132px; border-left: 2px solid #bfdbfe; border-bottom: 2px solid #bfdbfe; background: linear-gradient(180deg, transparent 49%, rgba(191,219,254,.35) 50%, transparent 51%); }
.solution-21-page .chart-line svg { position: absolute; left: 15px; bottom: 20px; width: 180px; height: 92px; }
.solution-21-page .chart-badge { position: absolute; right: 22px; top: 34px; width: 38px; height: 38px; border-radius: 12px; display: grid; place-items: center; color: #ef4444; background: #fff1f2; border: 1px solid #fecaca; font-weight: 950; box-shadow: 0 10px 20px rgba(239,68,68,.12); }
.solution-21-page .sad-dot { position: absolute; right: 30px; top: 38px; width: 74px; height: 74px; border-radius: 50%; background: linear-gradient(135deg, #fee2e2, #fff); border: 1px solid #fecaca; display: grid; place-items: center; color: #ef4444; font-weight: 900; font-size: 28px; }
.solution-21-page .card {
  background: #fff; border: 1px solid #e2e8f0; border-radius: 28px; padding: 28px 28px 32px; box-shadow: 0 12px 30px rgba(15, 23, 42, .05);
  transition: transform 0.24s var(--ease), box-shadow 0.24s var(--ease), border-color 0.24s var(--ease);
  height: 100%; display: flex; flex-direction: column;
}
.solution-21-page .card:hover { transform: translateY(-5px); box-shadow: 0 22px 48px rgba(37, 99, 235, .12); border-color: rgba(37, 99, 235, .36); }
.solution-21-page .card.pain { background: #fff1f2; border-color: #fecaca; }
.solution-21-page .card.solution { background: #eff6ff; border-color: #bfdbfe; }
.solution-21-page .label {
  display: flex; align-items: center; gap: 12px; margin-bottom: 0; font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; color: #64748b;
}
.solution-21-page .icon-solution {
  width: 44px; height: 44px; border-radius: 16px; display: inline-grid; place-items: center; color: #2563eb;
  background: #eff6ff; border: 1px solid #bfdbfe; flex-shrink: 0; transition: transform .2s var(--ease);
}
.solution-21-page .card:hover .icon-solution { transform: scale(1.07) rotate(-3deg); }
.solution-21-page .icon-solution.red { color: #ef4444; background: #fff; border-color: #fecaca; }
.solution-21-page .icon-solution.purple { color: #7c3aed; background: #f5f3ff; border-color: #ddd6fe; }
.solution-21-page .icon-solution.green { color: #10b981; background: #ecfdf5; border-color: #bbf7d0; }
.solution-21-page .card h3 { margin: 20px 0 12px; color: #0f172a; font-size: 24px; line-height: 1.28; font-weight: 700;}
.solution-21-page .card p { margin: 0; color: #475569; font-size: 16px; line-height: 1.6; flex: 1; }
.solution-21-page .arrow { display: none; }

.solution-21-page .achieve { position: relative; }
.solution-21-page .achieve-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; position: relative; }
.solution-21-page .achieve-card { min-height: 296px; grid-column: span 2; overflow: hidden; position: relative; }
.solution-21-page .achieve-card.wide { grid-column: span 3; min-height: 278px; }
.solution-21-page .mini-screen {
  margin-top: 20px; height: 160px; border-radius: 16px;
  position: relative;
}
.solution-21-page .mini-screen img{height: 100%;width: auto;object-fit:cover;}
.solution-21-page .achieve-card.wide .mini-screen { height: 160px; }
.solution-21-page .mini-screen .row { height: 11px; border-radius: 99px; background: #dbeafe; margin-bottom: 9px; }
.solution-21-page .mini-screen .row:nth-child(2) { width: 68%; background: #bfdbfe; }
.solution-21-page .mini-screen .row:nth-child(3) { width: 84%; }
.solution-21-page .node-map { position: absolute; right: 12px; bottom: 10px; width: 118px; height: 70px; }
.solution-21-page .inbox-illo { display: grid; grid-template-columns: 88px 1fr; gap: 12px; height: 100%; }
.solution-21-page .source-list { display: grid; gap: 8px; align-content: center; }
.solution-21-page .source { height: 24px; border-radius: 8px; background: #eff6ff; border: 1px solid #bfdbfe; display: flex; align-items: center; gap: 7px; padding: 0 8px; color: #2563eb; font-size: 10px; font-weight: 850; }
.solution-21-page .source i { width: 12px; height: 12px; border-radius: 50%; background: currentColor; display: inline-block; }
.solution-21-page .timeline { position: relative; border-left: 2px solid #2563eb; padding-left: 14px; display: grid; align-content: center; gap: 10px; }
.solution-21-page .timeline::before { content: ""; position: absolute; left: -70px; top: 50%; width: 70px; height: 2px; background: #2563eb; }
.solution-21-page .time-row { height: 12px; border-radius: 99px; background: #dbeafe; }
.solution-21-page .chat-illo { height: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; align-items: center; }
.solution-21-page .chat-person { display: grid; gap: 8px; }
.solution-21-page .avatar { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-size: 16px; font-weight: 900; background: #94a3b8; }
.solution-21-page .avatar.ai { background: linear-gradient(135deg, #2563eb, #7c3aed); }
.solution-21-page .speech { min-height: 46px; border-radius: 14px; padding: 8px 10px; font-size: 10px; line-height: 1.25; color: #334155; background: #f1f5f9; border: 1px solid #e2e8f0; }
.solution-21-page .speech.done { background: #ecfdf5; border-color: #bbf7d0; color: #047857; }
.solution-21-page .resolved { position: absolute; left: 12px; bottom: 8px; color: #10b981; font-size: 11px; font-weight: 900; }
.solution-21-page .voice-illo { height: 100%; display: flex; align-items: center; gap: 18px; justify-content: center; }
.solution-21-page .mini-phone { width: 72px; height: 104px; border-radius: 18px; background: #0f172a; padding: 8px; box-shadow: 0 10px 22px rgba(15,23,42,.18); }
.solution-21-page .mini-phone-screen { height: 100%; border-radius: 12px; background: #fff; padding: 10px 6px; text-align: center; }
.solution-21-page .flags { display: grid; grid-template-columns: repeat(2, 1fr); gap: 5px; }
.solution-21-page .flag { height: 18px; border-radius: 5px; display: grid; place-items: center; color: #fff; font-size: 8px; font-weight: 950; box-shadow: inset 0 0 0 1px rgba(255,255,255,.22); }
.solution-21-page .flag.gb { background: linear-gradient(135deg, #1d4ed8 0 45%, #ef4444 45% 58%, #fff 58% 70%, #1d4ed8 70%); }
.solution-21-page .flag.id { background: linear-gradient(180deg, #ef4444 0 50%, #fff 50%); color: #0f172a; }
.solution-21-page .flag.my { background: repeating-linear-gradient(180deg, #ef4444 0 3px, #fff 3px 6px); color: #1d4ed8; }
.solution-21-page .flag.th { background: linear-gradient(180deg, #ef4444 0 18%, #fff 18% 32%, #1d4ed8 32% 68%, #fff 68% 82%, #ef4444 82%); }
.solution-21-page .flag.vn { background: #ef4444; color: #fde047; }
.solution-21-page .wave { width: 150px; height: 76px; }
.solution-21-page .qa-illo { height: 100%; display: grid; grid-template-columns: 1fr 92px; gap: 10px 12px; align-items: center; }
.solution-21-page .qa-panel { border-radius: 13px; border: 1px solid #dbeafe; background: #fff; padding: 12px; }
.solution-21-page .coverage { color: #10b981; font-weight: 950; font-size: 15px; margin-bottom: 10px; }
.solution-21-page .check-x { display: flex; gap: 10px; font-size: 28px; font-weight: 950; }
.solution-21-page .check { color: #10b981; }
.solution-21-page .cross { color: #ef4444; }
.solution-21-page .score { grid-column: 1 / -1; color: #334155; font-size: 11px; font-weight: 850; margin-top: -2px; }
.solution-21-page .score-bar { height: 9px; border-radius: 99px; background: #e2e8f0; margin-top: 5px; overflow: hidden; }
.solution-21-page .score-bar span { display: block; width: 94%; height: 100%; background: linear-gradient(90deg, #10b981, #06b6d4); }
.solution-21-page .routing-illo { height: 100%; position: relative; }
.solution-21-page .ticket-icon { position: absolute; left: 4px; top: 35px; width: 58px; height: 58px; border-radius: 16px; background: #eff6ff; border: 1px solid #bfdbfe; display: grid; place-items: center; color: #2563eb; font-weight: 950; }
.solution-21-page .route { position: absolute; left: 72px; height: 2px; background: #2563eb; transform-origin: left center; }
.solution-21-page .route.r1 { top: 30px; width: 190px; transform: rotate(-17deg); }
.solution-21-page .route.r2 { top: 63px; width: 180px; }
.solution-21-page .route.r3 { top: 94px; width: 190px; transform: rotate(17deg); }
.solution-21-page .dept { position: absolute; right: 8px; width: 86px; height: 28px; border-radius: 10px; display: grid; place-items: center; font-size: 10px; font-weight: 900; border: 1px solid #bfdbfe; background: #fff; color: #2563eb; }
.solution-21-page .dept.d1 { top: 8px; color: #ef4444; border-color: #fecaca; }
.solution-21-page .dept.d2 { top: 50px; color: #7c3aed; border-color: #ddd6fe; }
.solution-21-page .dept.d3 { top: 91px; color: #10b981; border-color: #bbf7d0; }
.solution-21-page .fold {
  margin-top: 16px; border-top: 1px solid #e2e8f0; padding-top: 12px;
}
.solution-21-page details summary { cursor: pointer; color: #2563eb; font-size: 13px; font-weight: 850; list-style: none; }
.solution-21-page details summary::-webkit-details-marker { display: none; }
.solution-21-page details[open] summary { margin-bottom: 8px; }
.solution-21-page details .detail-text { color: #64748b; font-size: 13px; line-height: 1.55; }

.solution-21-page .story-wrap { display: grid; grid-template-columns: 480px 1fr; gap: 40px; align-items: center; }
.solution-21-page .story-photo {
  min-height: 520px; border-radius: 26px; overflow: hidden; position: relative;

  transition: transform .35s var(--ease);
}
.solution-21-page .story-photo img {
  height: 520px;
  width: auto;
  object-fit: cover;
}
.solution-21-page .story-photo:hover { transform: scale(1.015); }

.solution-21-page .office-wall { position: absolute; left: 38px; right: 38px; top: 36px; height: 120px; border-radius: 22px; background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.34); }
.solution-21-page .wall-logo { position: absolute; left: 28px; top: 26px; display: flex; align-items: center; gap: 9px; color: #fff; font-weight: 950; font-size: 20px; }
.solution-21-page .wall-logo .mark { width: 32px; height: 32px; }
.solution-21-page .office-keywords { position: absolute; left: 34px; right: 34px; bottom: 22px; height: 34px; border-radius: 999px; background: rgba(15,23,42,.66); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 850; letter-spacing: .02em; }
.solution-21-page .people { position: absolute; left: 46px; right: 46px; bottom: 72px; height: 260px; }
.solution-21-page .desk { position: absolute; left: 0; right: 0; bottom: 0; height: 158px; border-radius: 24px; background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.34); backdrop-filter: blur(8px); }
.solution-21-page .workstation { position: absolute; bottom: 62px; width: 114px; height: 68px; border-radius: 14px; background: rgba(255,255,255,.8); border: 1px solid rgba(255,255,255,.55); }
.solution-21-page .workstation::after { content: ""; position: absolute; left: 18px; right: 18px; bottom: 15px; height: 8px; border-radius: 99px; background: #bfdbfe; }
.solution-21-page .ws1 { left: 22px; }
.solution-21-page .ws2 { left: 185px; }
.solution-21-page .ws3 { right: 22px; }
.solution-21-page .person { position: absolute; bottom: 118px; width: 76px; height: 76px; border-radius: 50%; background: linear-gradient(135deg, #bfdbfe, #2563eb); border: 6px solid rgba(255,255,255,.42); }
.solution-21-page .person.one { left: 48px; }
.solution-21-page .person.two { left: 208px; background: linear-gradient(135deg, #a7f3d0, #10b981); }
.solution-21-page .person.three { right: 56px; background: linear-gradient(135deg, #ddd6fe, #7c3aed); }
.solution-21-page .desk-line { position: absolute; height: 14px; border-radius: 99px; background: rgba(255,255,255,.58); left: 92px; right: 92px; bottom: 78px; }
.solution-21-page .desk-line.two { bottom: 48px; left: 150px; right: 150px; }
.solution-21-page .tower { position: absolute; right: 66px; top: 58px; width: 126px; height: 174px; color: rgba(255,255,255,.9); }
.solution-21-page .story h2 { font-size: 32px; margin-top: 0; }
.solution-21-page .info-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 24px 0; }
.solution-21-page .list-box { border: 1px solid #e2e8f0; border-radius: 17px; padding: 20px; background: #fff; box-shadow: 0 10px 26px rgba(15,23,42,.04); }
.solution-21-page .list-box strong { display: block; margin-bottom: 11px; color: #0f172a; }
.solution-21-page .list-box ul { margin: 0; padding-left: 18px; color: #475569; font-size: 14px; line-height: 1.7; list-style-type: disc;}
.solution-21-page .metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.solution-21-page .metric { padding: 18px; border-radius: 17px; border: 1px solid #e2e8f0; background: #fff; box-shadow: 0 12px 28px rgba(15,23,42,.045); position: relative; overflow: hidden; }
.solution-21-page .metric::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: linear-gradient(90deg, #0961FF, #1DB7FF); transform: scaleX(.28); transform-origin: left; transition: transform .3s var(--ease); }
.solution-21-page .metric:hover::after { transform: scaleX(1); }
.solution-21-page .metric b { display: block; color: #2563eb; font-size: 32px; line-height: 1; margin-bottom: 8px; }
.solution-21-page .metric span { display: block; color: #64748b; font-size: 13px; line-height: 1.32; font-weight: 500; }
.solution-21-page .metric b .count { color: #151516; font-size: 18px; line-height: 1; font-weight: 600; }
.solution-21-page .metric b .count-title{ color: #151516; font-size: 18px; line-height: 1; font-weight: 600; }
.solution-21-page .cta {
  padding: 92px 40px 36px; text-align: center; color: #fff; background: #0f172a; position: relative; overflow: hidden;
}
.solution-21-page .cta::before {
  content: ""; position: absolute; inset: -35%;
  background: radial-gradient(circle at 50% 20%, rgba(37,99,235,.52), transparent 28%), radial-gradient(circle at 70% 32%, rgba(6,182,212,.22), transparent 22%);
  animation: pulseBg 6s ease-in-out infinite;
}
.solution-21-page .cta-content { position: relative; max-width: 860px; margin: 0 auto; }
.solution-21-page .cta h2 { color: #fff; font-size: 46px; }
.solution-21-page .cta p { color: #cbd5e1; font-size: 17px; line-height: 1.65; margin: 0 0 30px; }
.solution-21-page .footer { position: relative; margin-top: 66px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.13); display: flex; align-items: center; justify-content: space-between; color: #94a3b8; font-size: 14px; }
.solution-21-page .footer .brand { color: #cbd5e1; }
.solution-21-page .footer-links { display: flex; gap: 26px; }
/* Rich website-style scene cards inspired by the Instadesk Quality Inspection visuals. */
.solution-21-page .scene-card {
  min-height: 246px;
  border-radius: 24px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(191, 219, 254, .9);
  background:
  radial-gradient(circle at 82% 22%, rgba(37, 99, 235, .18), transparent 28%),
  radial-gradient(circle at 18% 78%, rgba(6, 182, 212, .16), transparent 30%),
  linear-gradient(145deg, #eef7ff 0%, #ffffff 58%, #dbeafe 100%);
  box-shadow: 0 22px 52px rgba(37, 99, 235, .12);
}
.solution-21-page .scene-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
  linear-gradient(rgba(37,99,235,.08) 1px, transparent 1px),
  linear-gradient(90deg, rgba(37,99,235,.08) 1px, transparent 1px);
  background-size: 28px 28px;
  -webkit-mask-image: linear-gradient(145deg, rgba(0,0,0,.58), transparent 74%);
  mask-image: linear-gradient(145deg, rgba(0,0,0,.58), transparent 74%);
}
.solution-21-page .scene-window {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  height: 108px;
  border-radius: 16px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(219,234,254,.95);
  box-shadow: 0 18px 38px rgba(15, 23, 42, .08);
  backdrop-filter: blur(8px);
}
.solution-21-page .scene-bar {
  position: absolute;
  height: 9px;
  border-radius: 99px;
  background: #dbeafe;
}
.solution-21-page .scene-pill {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 34px;
  border-radius: 999px;
  padding: 0 13px;
  background: #fff;
  color: #2563eb;
  border: 1px solid #dbeafe;
  font-size: 11px;
  font-weight: 900;
  box-shadow: 0 10px 24px rgba(37,99,235,.12);
}
.solution-21-page .scene-avatar {
  position: absolute;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 950;
  border: 5px solid rgba(255,255,255,.72);
  box-shadow: 0 16px 30px rgba(37,99,235,.16);
}
.solution-21-page .scene-callout {
  position: absolute;
  border-radius: 17px;
  background: #fff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 18px 42px rgba(15,23,42,.10);
  color: #334155;
  font-size: 12px;
  line-height: 1.35;
  font-weight: 800;
  padding: 13px 15px;
}
.solution-21-page .scene-chip {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  color: #fff;
  font-size: 11px;
  font-weight: 950;
  background: linear-gradient(135deg, #2563eb, #7c3aed);
}
.solution-21-page .channel-stack {
  position: absolute;
  left: 24px;
  top: 28px;
  width: 112px;
  display: grid;
  gap: 8px;
}
.solution-21-page .channel-row {
  height: 34px;
  border-radius: 12px;
  background: rgba(255,255,255,.92);
  border: 1px solid #dbeafe;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  color: #2563eb;
  font-size: 10px;
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(37,99,235,.08);
}
.solution-21-page .channel-row i {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: currentColor;
}
.solution-21-page .scene-risk {
  position: absolute;
  right: 20px;
  top: 24px;
  width: 116px;
  transform: rotate(8deg);
  border-radius: 16px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 18px 36px rgba(15,23,42,.12);
  padding: 12px;
  display: grid;
  gap: 8px;
  font-size: 10px;
  color: #475569;
  font-weight: 850;
}
.solution-21-page .risk-line { display: flex; align-items: center; gap: 8px; }
.solution-21-page .risk-dot { width: 10px; height: 10px; border-radius: 3px; background: #ef4444; }
.solution-21-page .risk-dot.mid { background: #facc15; }
.solution-21-page .risk-dot.low { background: #10b981; }
.solution-21-page .scene-table {
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 24px;
  height: 112px;
  border-radius: 16px;
  background: rgba(255,255,255,.9);
  border: 1px solid #dbeafe;
  padding: 13px;
  box-shadow: 0 16px 34px rgba(37,99,235,.10);
}
.solution-21-page .table-head, .solution-21-page .table-row {
  display: grid;
  grid-template-columns: 1.1fr .9fr .8fr;
  gap: 8px;
  align-items: center;
}
.solution-21-page .table-head {
  height: 28px;
  border-radius: 9px;
  background: #eef2ff;
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
  padding: 0 9px;
}
.solution-21-page .table-row { height: 28px; padding: 0 9px; border-bottom: 1px dashed #e2e8f0; color: #334155; font-size: 10px; }
.solution-21-page .score-badge {
  position: absolute;
  left: 22px;
  top: 26px;
  height: 58px;
  min-width: 132px;
  border-radius: 17px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 18px 38px rgba(15,23,42,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  color: #0f172a;
  font-weight: 950;
}
.solution-21-page .score-badge b { font-size: 26px; }
.solution-21-page .score-badge span { display: block; color: #64748b; font-size: 10px; font-weight: 800; }
.solution-21-page .script-sheet {
  position: absolute;
  right: 18px;
  top: 18px;
  width: 150px;
  height: 176px;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(15,23,42,.13);
  padding: 18px;
  color: #334155;
}
.solution-21-page .script-sheet h4 { margin: 0 0 12px; color: #0f172a; font-size: 18px; }
.solution-21-page .script-sheet p { margin: 0 0 10px; font-size: 11px; line-height: 1.35; color: #475569; }
.solution-21-page .wave-card {
  position: absolute;
  left: 28px;
  top: 42px;
  width: 150px;
  height: 48px;
  border-radius: 12px;
  background: #1f2a44;
  box-shadow: 0 14px 30px rgba(15,23,42,.16);
  padding: 12px;
}
.solution-21-page .play-pill {
  position: absolute;
  left: 58px;
  bottom: 24px;
  height: 52px;
  width: 172px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(15,23,42,.14);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 18px;
  color: #2563eb;
  font-weight: 900;
}
.solution-21-page .play-circle {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  display: grid;
  place-items: center;
}
.solution-21-page .word-cloud {
  position: absolute;
  left: 26px;
  top: 42px;
  width: 134px;
  height: 116px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid #dbeafe;
  box-shadow: 0 14px 30px rgba(37,99,235,.10);
  display: grid;
  place-items: center;
  color: #2563eb;
  font-weight: 950;
  font-size: 12px;
  text-align: center;
  line-height: 1.25;
}
.solution-21-page .trend-card {
  position: absolute;
  left: 24px;
  right: 92px;
  bottom: 24px;
  height: 76px;
  border-radius: 15px;
  background: rgba(255,255,255,.92);
  border: 1px solid #dbeafe;
  padding: 12px;
}
.solution-21-page .profile-card {
  position: absolute;
  right: 20px;
  bottom: 20px;
  width: 132px;
  height: 150px;
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(15,23,42,.13);
  padding: 16px;
  color: #334155;
  font-size: 11px;
  font-weight: 850;
}
.solution-21-page .profile-face {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: linear-gradient(135deg, #10b981, #2563eb);
  margin-bottom: 12px;
  box-shadow: inset 0 -8px 0 rgba(255,255,255,.22);
}
.solution-21-page .mini-stage {
  position: relative;
  height: 160px;
  margin-top: 20px;
  border-radius: 20px;
}
.solution-21-page .mini-stage img {
  height: 100%;
  width: auto;
  object-fit: cover;
}
.solution-21-page .mini-stage .scene-window {
  left: 142px;
  top: 76px;
  width: 168px;
  right: auto;
  bottom: auto;
  height: auto;
}
.solution-21-page .mini-stage .scene-pill { right: 18px; top: 22px; height: 30px; font-size: 10px; }
.solution-21-page .story-photo .floating-dashboard {
  position: absolute;
  left: 54px;
  top: 40px;
  right: 54px;
  height: 128px;
  border-radius: 24px;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.34);
  box-shadow: 0 18px 38px rgba(15,23,42,.16);
  backdrop-filter: blur(8px);
  padding: 22px;
  color: #fff;
  font-weight: 900;
}
.solution-21-page .story-photo .call-chip {
  position: absolute;
  right: 34px;
  top: 186px;
  border-radius: 18px;
  background: #fff;
  color: #2563eb;
  padding: 14px 18px;
  font-size: 13px;
  font-weight: 950;
  box-shadow: 0 18px 38px rgba(15,23,42,.16);
}
.solution-21-page .story-photo .metric-strip {
  position: absolute;
  left: 80px;
  bottom: 70px;
  height: 54px;
  min-width: 310px;
  border-radius: 999px;
  background: rgba(15,23,42,.66);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  font-size: 13px;
  font-weight: 900;
}

.solution-21-page .reveal { opacity: 0; transform: translateY(22px); transition: opacity .48s var(--ease), transform .48s var(--ease); }
.solution-21-page .reveal.in, .solution-21-page .shot .reveal { opacity: 1; transform: translateY(0); transition-delay: 0ms !important; }
.solution-21-page svg { width: 20px; height: 20px; stroke: currentColor; stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; }

/* Keyframes for animations */
@keyframes wordIn { to { opacity: 1; transform: translateY(0); } }
@keyframes float { 0%, 100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(18px,-24px,0); } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@keyframes drift { to { background-position: 280px 0; } }
@keyframes arrowFlow { 0%,100% { transform: translateX(-8px); opacity: .42; } 50% { transform: translateX(8px); opacity: 1; } }
@keyframes pulseBg { 0%,100% { transform: scale(1); opacity: .92; } 50% { transform: scale(1.08); opacity: 1; } }
@keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }

/* Mobile responsive styles */
@media (max-width: 1159px) {
  .solution-21-page .page { width: 100%; max-width: 1160px; }
}

@media (max-width: 1024px) {
  .solution-21-page .nav { padding: 0 32px; }
  .solution-21-page .nav-links { gap: 20px; font-size: 13px; }
  .solution-21-page .hero { padding: 60px 32px; min-height: auto; }
  .solution-21-page .hero-inner { grid-template-columns: 1fr; gap: 40px; }
  .solution-21-page .hero-visual { min-height: fit-content; width: auto;height: auto;}
  .solution-21-page .hero-visual img{width: 100%; height: auto;}
  .solution-21-page .product-board { width: 520px; right: 50%; transform: translateX(50%); }
  .solution-21-page .phone { right: 40px; bottom: 20px; width: 180px; height: 300px; }
  .solution-21-page .phone-screen { padding: 12px 10px; }
  .solution-21-page .orbit { right: 50%; transform: translateX(50%); width: 360px; height: 360px; }
  .solution-21-page .hero-card { left: 40px; bottom: 60px; }
  .solution-21-page .section { padding: 60px 32px; }
  .solution-21-page .achieve-grid { grid-template-columns: repeat(4, 1fr); }
  .solution-21-page .achieve-card.wide { grid-column: span 2; }
  .solution-21-page .story-wrap { grid-template-columns: 1fr; gap: 40px; }
  .solution-21-page .story-photo { min-height: 420px; }
  .solution-21-page .cta { padding: 60px 32px 36px; }
  .solution-21-page .metrics { grid-template-columns: repeat(2, 1fr); }
  .solution-21-page .info-pair { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .solution-21-page .nav { height: auto; padding: 16px 20px; flex-wrap: wrap; }
  .solution-21-page .nav-links { display: none; }
  .solution-21-page .nav-actions { gap: 8px; }
  .solution-21-page .btn { height: 40px; padding: 0 16px; font-size: 13px; }
  .solution-21-page .brand { font-size: 18px; }
  .solution-21-page .mark { width: 30px; height: 30px; border-radius: 9px; font-size: 14px; }

  .solution-21-page .hero { padding: 40px 20px 50px; }
  .solution-21-page h1 { font-size: 32px; line-height: 1.2; }
  .solution-21-page .hero-copy { font-size: 15px; max-width: 100%; }
  .solution-21-page .hero-actions { flex-direction: column; gap: 12px; width: 100%; }
  .solution-21-page .hero-actions .btn { width: 100%; }
  .solution-21-page .trust { flex-wrap: wrap; gap: 16px; }
  .solution-21-page .trust div { padding-right: 16px; }
  .solution-21-page .trust b { font-size: 22px; }

  .solution-21-page .hero-visual { min-height: fit-content; width: auto;height: auto;}
  .solution-21-page .hero-visual img{width: 100%; height: auto;}
  .solution-21-page .product-board { width: 100%; max-width: 480px; height: 360px; right: auto; left: 50%; transform: translateX(-50%); top: 20px; }
  .solution-21-page .board-body { grid-template-columns: 140px 1fr; height: 310px; }
  .solution-21-page .side { padding: 16px 12px; }
  .solution-21-page .side-item { font-size: 11px; height: 32px; margin-bottom: 8px; }
  .solution-21-page .main { padding: 16px; }
  .solution-21-page .bubble { font-size: 12px; padding: 10px 12px; }
  .solution-21-page .board-metric { padding: 10px; }
  .solution-21-page .board-metric b { font-size: 16px; }
  .solution-21-page .board-metric span { font-size: 10px; }

  .solution-21-page .orbit { display: none; }
  .solution-21-page .phone { width: 140px; height: 240px; right: 20px; bottom: 0; }
  .solution-21-page .phone-screen { padding: 10px 8px; }
  .solution-21-page .signal-tile { height: 70px; }
  .solution-21-page .mini-ui { margin-top: 10px; padding: 10px; }
  .solution-21-page .hero-card { width: 180px; padding: 14px; left: 20px; bottom: 30px; }
  .solution-21-page .hero-card b { font-size: 26px; }
  .solution-21-page .hero-card span { font-size: 12px; }

  .solution-21-page .particle { display: none; }

  .solution-21-page .section { padding: 48px 20px; }
  .solution-21-page .section-head { margin-bottom: 32px; }
  .solution-21-page h2 { font-size: 28px; }
  .solution-21-page .section-head p { font-size: 15px; }

  .solution-21-page .flow-row { grid-template-columns: 1fr; gap: 20px; }
  .solution-21-page .card { padding: 20px; border-radius: 20px; }
  .solution-21-page .card h3 { font-size: 20px; }
  .solution-21-page .card p { font-size: 14px; }
  .solution-21-page .icon-solution { width: 38px; height: 38px; border-radius: 12px; }

  .solution-21-page .achieve-grid { grid-template-columns: 1fr; gap: 16px; }
  .solution-21-page .achieve-card { grid-column: span 1 !important; min-height: auto; }
  .solution-21-page .mini-screen { height: 140px; padding: 10px; }
  .solution-21-page .mini-stage { height: 140px; }

  .solution-21-page .story-photo { min-height: 320px; border-radius: 20px; }
  .solution-21-page .office-wall { left: 20px; right: 20px; top: 24px; height: 80px; }
  .solution-21-page .wall-logo { left: 16px; top: 16px; font-size: 16px; }
  .solution-21-page .wall-logo .mark { width: 26px; height: 26px; }
  .solution-21-page .tower { width: 80px; height: 110px; right: 40px; top: 40px; }
  .solution-21-page .people { left: 24px; right: 24px; bottom: 60px; height: 180px; }
  .solution-21-page .workstation { width: 80px; height: 48px; bottom: 48px; }
  .solution-21-page .workstation::after { left: 12px; right: 12px; bottom: 10px; height: 6px; }
  .solution-21-page .ws1 { left: 12px; }
  .solution-21-page .ws2 { left: 50%; transform: translateX(-50%); }
  .solution-21-page .ws3 { right: 12px; }
  .solution-21-page .person { width: 56px; height: 56px; bottom: 90px; border-width: 5px; }
  .solution-21-page .person.one { left: 24px; }
  .solution-21-page .person.two { left: 50%; transform: translateX(-50%); }
  .solution-21-page .person.three { right: 24px; }
  .solution-21-page .desk-line { left: 70px; right: 70px; bottom: 60px; height: 10px; }
  .solution-21-page .desk-line.two { left: 100px; right: 100px; bottom: 38px; }
  .solution-21-page .office-keywords { left: 20px; right: 20px; bottom: 16px; height: 30px; font-size: 11px; }

  .solution-21-page .story h2 { font-size: 24px; }
  .solution-21-page .list-box { padding: 16px; }
  .solution-21-page .list-box ul { font-size: 13px; }
  .solution-21-page .metrics { grid-template-columns: 1fr; }
  .solution-21-page .metric { padding: 14px 16px; }
  .solution-21-page .metric b { font-size: 26px; }

  .solution-21-page .cta { padding: 48px 20px 32px; }
  .solution-21-page .cta h2 { font-size: 28px; }
  .solution-21-page .cta p { font-size: 15px; }
  .solution-21-page .footer { flex-direction: column; gap: 16px; text-align: center; }
  .solution-21-page .footer-links { flex-wrap: wrap; justify-content: center; gap: 16px; }

  .solution-21-page .voice-illo { flex-direction: column; gap: 12px; }
  .solution-21-page .wave { width: 120px; height: 60px; }
  .solution-21-page .mini-phone { width: 60px; height: 90px; }

  .solution-21-page .routing-illo { overflow: hidden; }
  .solution-21-page .ticket-icon { left: 10px; width: 48px; height: 48px; }
  .solution-21-page .route.r1, .solution-21-page .route.r2, .solution-21-page .route.r3 { left: 62px; width: 140px; }
  .solution-21-page .dept { right: 8px; width: 70px; font-size: 9px; }

  .solution-21-page .mini-stage .channel-stack { left: 16px; top: 20px; width: 84px; }
  .solution-21-page .mini-stage .channel-row { height: 30px; font-size: 9px; padding: 0 6px; gap: 6px; }
  .solution-21-page .mini-stage .scene-pill { right: 16px; top: 18px; padding: 0 10px; height: 28px; font-size: 9px; }
  .solution-21-page .mini-stage .scene-window { left: 16px; right: 16px; top: auto; width: auto; bottom: 16px; height: 80px; }

  .solution-21-page .mobile-menu-btn {
    display: flex;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    background: #f1f5f9;
    border-radius: 10px;
    cursor: pointer;
  }
  .solution-21-page .mobile-menu-btn svg { width: 24px; height: 24px; }
}

@media (max-width: 480px) {
  .solution-21-page h1 { font-size: 28px; }
  .solution-21-page .hero { padding: 80px 16px 40px; }
  .solution-21-page .hero-visual { min-height: fit-content; }
  .solution-21-page .product-board { height: 300px; }
  .solution-21-page .board-top { height: 40px; }
  .solution-21-page .board-body { height: 260px; }
  .solution-21-page .phone { display: none; }
  .solution-21-page .hero-card { width: 150px; padding: 12px; display: none;}
  .solution-21-page .hero-card b { font-size: 22px; }
  .solution-21-page .section { padding: 40px 16px; }
  .solution-21-page .story-photo { min-height: 260px; }
  .solution-21-page .workstation, .solution-21-page .tower { display: none; }
  .solution-21-page .person.one { left: 20px; }
  .solution-21-page .person.two { left: 50%; transform: translateX(-50%); }
  .solution-21-page .person.three { right: 20px; }
  .solution-21-page .desk-line { display: none; }
}

/* Animation classes for pain flow rows */
.solution-21-page .flow-row {
  animation: fadeUp 0.6s cubic-bezier(0.2, 0.9, 0.4, 1.1) forwards;
  opacity: 0;
}
.solution-21-page .flow-row:nth-child(1) { animation-delay: 0.05s; }
.solution-21-page .flow-row:nth-child(2) { animation-delay: 0.2s; }
.solution-21-page .flow-row:nth-child(3) { animation-delay: 0.35s; }
