/* ============================================================
   SwiftSend Pro Touches
   ------------------------------------------------------------
   Editorial typography, micro-interactions, signature design
   moments. The things that separate "pro fintech" from "AI default".
   ============================================================ */

/* ---- Signature gradient text (used sparingly on key headlines) ---- */

.text-gradient {
  background: linear-gradient(120deg, #ffffff 0%, var(--cyan) 50%, #a78bfa 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  display: inline;
}
.section-light .text-gradient, .section-alt .text-gradient {
  background: linear-gradient(120deg, var(--text-dark) 0%, var(--cyan-on-light) 50%, var(--purple-mesh) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ---- Editorial display numerals (for stats/steps) ---- */

.numeral {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: clamp(3rem, 8vw, 6rem);
  line-height: 0.9;
  letter-spacing: -0.05em;
  color: var(--cyan);
  display: inline-block;
}
.section-light .numeral, .section-alt .numeral { color: var(--cyan-on-light); }

/* ---- Pull quote / editorial thesis block ---- */

.pull-quote {
  position: relative;
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: clamp(1.5rem, 2.5vw + 1rem, 2.5rem);
  line-height: 1.25;
  letter-spacing: -0.025em;
  max-width: 22ch;
  padding-left: var(--s-5);
}
.pull-quote::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.2em;
  bottom: 0.2em;
  width: 3px;
  background: linear-gradient(180deg, var(--cyan), transparent);
  border-radius: 2px;
}
.pull-quote .accent {
  background: linear-gradient(120deg, var(--cyan), #a78bfa);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ---- Animated underline links ---- */

.link-underline {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-weight: 600;
  color: var(--cyan);
  padding-bottom: 2px;
}
.section-light .link-underline, .section-alt .link-underline { color: var(--cyan-on-light); }
.link-underline::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1.5px;
  background: currentColor;
  transform: scaleX(0.4);
  transform-origin: left;
  transition: transform var(--t-base) var(--ease);
}
.link-underline:hover::after { transform: scaleX(1); }

/* ---- Eyebrow with leading line (editorial) ---- */

.eyebrow-line {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-size: var(--t-eyebrow);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--cyan);
  margin-bottom: var(--s-4);
}
.eyebrow-line::before {
  content: '';
  width: 40px;
  height: 1.5px;
  background: var(--cyan);
}
.section-light .eyebrow-line, .section-alt .eyebrow-line { color: var(--cyan-on-light); }
.section-light .eyebrow-line::before, .section-alt .eyebrow-line::before { background: var(--cyan-on-light); }

/* ---- Scroll-reveal (set initial state; JS adds .in-view) ---- */

[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms var(--ease), transform 700ms var(--ease);
}
[data-reveal].in-view {
  opacity: 1;
  transform: translateY(0);
}
[data-reveal-delay="100"] { transition-delay: 100ms; }
[data-reveal-delay="200"] { transition-delay: 200ms; }
[data-reveal-delay="300"] { transition-delay: 300ms; }
[data-reveal-delay="400"] { transition-delay: 400ms; }

@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* ---- Card with numeral / step ---- */

.step-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s-5);
  align-items: start;
  padding: var(--s-5) 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.step-card:first-child { border-top: 0; }
.section-light .step-card, .section-alt .step-card {
  border-top-color: var(--border-light);
}
.step-card .numeral { font-size: clamp(2.5rem, 4vw, 3.5rem); }
.step-card-body { padding-top: 0.5em; }
.step-card h3 { font-size: 1.25rem; margin-bottom: var(--s-2); }
.step-card p { color: var(--text-muted); margin: 0; max-width: 60ch; }
.section-light .step-card p, .section-alt .step-card p { color: var(--text-dark-muted); }

/* ---- Asymmetric "feature row" (alternating side) ---- */

.feature-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-7);
  align-items: center;
  margin-block: var(--s-8);
}
@media (min-width: 900px) {
  .feature-row { grid-template-columns: 1fr 1fr; gap: var(--s-9); }
  .feature-row.reverse > :first-child { order: 2; }
}

.feature-row-visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 320px;
  margin-block: var(--s-5);
}
.feature-row-visual img {
  max-width: 100%;
  width: clamp(280px, 88vw, 460px);
  filter: drop-shadow(0 0 60px rgba(0, 229, 255, 0.28));
  will-change: transform;
}
@media (min-width: 720px) {
  .feature-row-visual { min-height: 380px; margin-block: 0; }
  .feature-row-visual img { width: clamp(280px, 45vw, 460px); }
}
@media (min-width: 1024px) {
  .feature-row-visual { min-height: 440px; }
  .feature-row-visual img { width: clamp(320px, 42vw, 560px); }
}

/* ---- Corridor map (custom visualization, not tile grid) ---- */

.corridor-map {
  position: relative;
  margin-top: var(--s-7);
  padding: var(--s-7) var(--s-5);
  border-radius: var(--r-lg);
  background:
    radial-gradient(circle at 30% 50%, rgba(0,229,255,0.08), transparent 60%),
    radial-gradient(circle at 70% 50%, rgba(167,139,250,0.06), transparent 60%),
    var(--bg-elevated);
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.corridor-list {
  display: grid;
  gap: var(--s-3);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .corridor-list { grid-template-columns: 1fr 1fr; } }

.corridor-row {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  text-decoration: none;
  color: inherit;
  transition: all var(--t-base) var(--ease);
}
.corridor-row:hover {
  background: rgba(0, 229, 255, 0.04);
  border-color: rgba(0, 229, 255, 0.3);
  color: inherit;
  transform: translateX(4px);
}

.corridor-from, .corridor-to {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.04em;
  color: var(--text-light);
  white-space: nowrap;
}
.corridor-arc {
  flex: 1;
  height: 1.5px;
  background:
    radial-gradient(circle at center, var(--cyan), transparent 60%),
    linear-gradient(90deg, transparent, var(--cyan), transparent);
  position: relative;
  min-width: 30px;
}
.corridor-arc::after {
  content: '';
  position: absolute;
  right: -2px; top: 50%;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--cyan);
  transform: translateY(-50%);
  box-shadow: 0 0 8px var(--cyan);
}
.corridor-meta {
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin-left: auto;
  white-space: nowrap;
}

/* ---- Mini stat strip ---- */

.stat-strip {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  padding: var(--s-6) 0;
}
@media (min-width: 600px) { .stat-strip { grid-template-columns: repeat(3, 1fr); } }
.stat-item .numeral { display: block; }
.stat-item-label {
  font-size: 0.9375rem;
  color: var(--text-muted);
  max-width: 24ch;
  margin-top: var(--s-2);
}
.section-light .stat-item-label, .section-alt .stat-item-label { color: var(--text-dark-muted); }

/* ---- Editorial divider ---- */

.divider {
  border: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,229,255,0.3), transparent);
  margin-block: var(--s-7);
}

/* ---- Subtle floating motion (use on small accents) ---- */

@keyframes floaty {
  0%, 100% { transform: translateY(0px); }
  50%      { transform: translateY(-12px); }
}
.floaty { animation: floaty 6s ease-in-out infinite; }

/* ---- Glow ring (for visual accents) ---- */

.glow-ring {
  position: relative;
}
.glow-ring::before {
  content: '';
  position: absolute;
  inset: -10%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0,229,255,0.18), transparent 60%);
  filter: blur(40px);
  z-index: -1;
}

/* ---- "Why broker" rich comparison ---- */

.compare-rich {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: rgba(0, 229, 255, 0.15);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-top: var(--s-6);
  border: 1px solid rgba(0, 229, 255, 0.15);
}
@media (min-width: 720px) { .compare-rich { grid-template-columns: 1fr 1fr; } }

.compare-side {
  padding: var(--s-6);
  background: var(--bg-deep);
}
.compare-side.us {
  background: linear-gradient(160deg, rgba(0, 229, 255, 0.04), transparent);
}
.compare-side-label {
  font-size: var(--t-eyebrow);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: var(--s-5);
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
.compare-side.them .compare-side-label { color: var(--text-muted); }
.compare-side.us .compare-side-label { color: var(--cyan); }
.compare-side.us .compare-side-label::after {
  content: '';
  width: 8px; height: 8px;
  background: var(--cyan);
  border-radius: 50%;
  box-shadow: 0 0 12px var(--cyan);
}

.compare-list { list-style: none; padding: 0; margin: 0; }
.compare-list li {
  padding: var(--s-3) 0;
  border-top: 1px solid rgba(255,255,255,0.05);
  font-size: 1rem;
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
}
.compare-list li:first-child { border-top: 0; }
.compare-side.them .compare-list li { color: var(--text-muted); }
.compare-side.them .compare-list li::before {
  content: '';
  width: 14px; height: 1.5px;
  background: rgba(255,255,255,0.2);
  margin-top: 0.75em;
  flex-shrink: 0;
}
.compare-side.us .compare-list li { color: var(--text-light); font-weight: 500; }
.compare-side.us .compare-list li::before {
  content: '';
  width: 14px; height: 14px;
  background: var(--cyan);
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 14 14' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 7l3.5 3.5L12 3.5' stroke='black' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 14 14' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 7l3.5 3.5L12 3.5' stroke='black' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
  margin-top: 0.4em;
  flex-shrink: 0;
}

/* ---- Trust strip (icon + text inline) ---- */

.trust-strip {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  margin-top: var(--s-6);
  padding: var(--s-6);
  border-radius: var(--r-lg);
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.06);
}
@media (min-width: 720px) { .trust-strip { grid-template-columns: repeat(3, 1fr); } }
.trust-strip-item {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.trust-strip-icon {
  width: 48px; height: 48px;
}
.trust-strip-icon img { width: 100%; height: 100%; object-fit: contain; }
.trust-strip-title {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 1.0625rem;
  color: var(--text-dark);
}
.trust-strip-text {
  font-size: 0.9375rem;
  color: var(--text-dark-muted);
  margin: 0;
  max-width: 30ch;
}

/* ---- Hero subtle accent (3D asset behind type) ---- */

.hero-accent-orb {
  position: absolute;
  pointer-events: none;
  width: 320px;
  height: 320px;
  opacity: 0.6;
  filter: blur(2px) drop-shadow(0 0 60px rgba(0,229,255,0.3));
}

/* ============================================================
   Region Atlas — surprise corridor block
   ============================================================ */

.region-atlas {
  position: relative;
  margin-top: var(--s-7);
  isolation: isolate;
}
.region-atlas::before {
  content: '';
  position: absolute;
  inset: -10% -5%;
  background: radial-gradient(circle at 20% 30%, rgba(0,229,255,0.06), transparent 50%),
              radial-gradient(circle at 80% 70%, rgba(167,139,250,0.05), transparent 50%);
  z-index: -1;
  pointer-events: none;
}

/* Stat row above the grid */
.atlas-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
  margin-bottom: var(--s-7);
  padding: var(--s-6) 0;
  border-top: 1px solid rgba(0,229,255,0.15);
  border-bottom: 1px solid rgba(0,229,255,0.15);
}
@media (min-width: 600px) { .atlas-stats { grid-template-columns: repeat(3, 1fr); gap: var(--s-7); } }

.atlas-stat {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.atlas-stat-number {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: 0.9;
  letter-spacing: -0.04em;
  background: linear-gradient(120deg, #ffffff, var(--cyan));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  display: inline-block;
}
.atlas-stat-label {
  font-size: 0.875rem;
  color: var(--text-dark-muted);
  max-width: 22ch;
}
.section-dark .atlas-stat-label { color: var(--text-muted); }

/* Region grid — asymmetric */
.atlas-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
}
@media (min-width: 720px) { .atlas-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .atlas-grid { grid-template-columns: repeat(3, 1fr); } }

.region-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  padding: var(--s-6);
  border-radius: var(--r-lg);
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.06);
  text-decoration: none;
  color: inherit;
  transition: all var(--t-base) var(--ease);
  overflow: hidden;
  min-height: 220px;
}
.region-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(0,229,255,0.08), transparent 60%);
  opacity: 0;
  transition: opacity var(--t-base) var(--ease);
  pointer-events: none;
}
.region-card:hover {
  border-color: rgba(0, 229, 255, 0.4);
  background: rgba(0, 229, 255, 0.04);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.3);
  color: inherit;
}
.region-card:hover::before { opacity: 1; }

/* Feature region (takes 2 columns on wide screens) */
@media (min-width: 1024px) {
  .region-card.feature { grid-column: span 2; min-height: 280px; }
}

.region-card-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
}
.region-card-name {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: clamp(1.5rem, 2vw + 1rem, 2.25rem);
  letter-spacing: -0.025em;
  color: var(--text-dark);
  margin: 0;
  line-height: 1.05;
}
.region-card.feature .region-card-name { font-size: clamp(2rem, 3vw + 1rem, 3rem); }
.region-card-from {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-dark-muted);
}
.region-card-from::after {
  content: ' →';
  color: var(--cyan-on-light);
  font-weight: 700;
}

.region-card-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: auto;
}
.region-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--text-dark);
  background: rgba(0, 229, 255, 0.08);
  border: 1px solid rgba(0, 229, 255, 0.2);
  border-radius: var(--r-pill);
  transition: all var(--t-fast) var(--ease);
  white-space: nowrap;
}
.region-card:hover .region-chip {
  background: rgba(0, 229, 255, 0.15);
  border-color: rgba(0, 229, 255, 0.4);
}

.region-card-tag {
  position: absolute;
  top: var(--s-4);
  right: var(--s-4);
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  background: var(--cyan-on-light);
  color: white;
}

.region-card-meta {
  font-size: 0.9375rem;
  color: var(--text-dark-muted);
  margin: 0;
  max-width: 38ch;
}

.region-card-arrow {
  position: absolute;
  bottom: var(--s-5);
  right: var(--s-5);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  display: grid;
  place-items: center;
  font-size: 1.125rem;
  color: var(--cyan-on-light);
  transition: all var(--t-base) var(--ease);
}
.region-card:hover .region-card-arrow {
  background: var(--cyan-on-light);
  color: white;
  border-color: var(--cyan-on-light);
  transform: translate(2px, -2px);
}

/* ---- Marquee strip (for partner names — text only) ---- */

.marquee {
  overflow: hidden;
  padding-block: var(--s-5);
  border-block: 1px solid rgba(255,255,255,0.06);
  background: rgba(0, 0, 0, 0.2);
  -webkit-mask: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
          mask: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}
.marquee-track {
  display: flex;
  gap: var(--s-7);
  width: max-content;
  animation: marquee 40s linear infinite;
}
.marquee-item {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--text-muted);
  letter-spacing: 0.05em;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
}
.marquee-item::before {
  content: '';
  width: 4px; height: 4px;
  background: var(--cyan);
  border-radius: 50%;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; }
}
