/* ======================================
   MOBVOI PURCHASE PROCESS — mobvoi-purchase.css
   Background: #FFFFFF
   Accent:     #2773DC (blue)
   ====================================== */

/* ── Page base ── */
.mv-page {
  background: white;
  color: #1a1a1a;
}

/* ── Header: same as ShopeePay (black logo + black text) ── */
.mv-page .logo img { filter: invert(1); }
.mv-page .nav a { color: #1a1a1a; }
.mv-page .nav a:hover { background-size: 100% 1px; }
.mv-page .nav a.active { font-weight: 700; }

/* ══════════════════════════════════════
   ① HERO
   ══════════════════════════════════════ */
.mv-hero {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 600px;
  background: white;
  overflow: hidden;
}

.mv-hero-blob {
  position: absolute;
  left: 30%;
  top: -58%;
  width: 86%;
  pointer-events: none;
  z-index: 0;
}
.mv-hero-blob img { width: 100%; height: auto; display: block; }

.mv-hero-mockup {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 66%;
  z-index: 1;
}
.mv-hero-mockup img { width: 100%; height: auto; display: block; }

.mv-hero-text {
  position: absolute;
  right: 120px;
  top: 13%;
  width: 36%;
  z-index: 2;
}
.mv-hero-text h1 {
  font-family: var(--font-display);
  font-size: 52px;
  font-weight: 600;
  color: white;
  text-align: right;
  line-height: 1.28;
  text-shadow: 0 0 18px rgba(39, 115, 220, 0.95);
  margin: 0;
}

/* ══════════════════════════════════════
   SHARED SECTION STYLES
   ══════════════════════════════════════ */
.mv-section {
  background: white;
  padding: 60px 120px;
}

.mv-section-title {
  font-family: var(--font-display);
  font-size: 44px;
  font-weight: 600;
  color: #2c2c2c;
  margin: 0 0 18px;
  line-height: 1.2;
}

.mv-xl-title { /* same as base */ }

.mv-body {
  font-family: var(--font-text);
  font-size: 14px;
  line-height: 1.75;
  color: #444444;
  margin: 0 0 14px;
}
.mv-body:last-child { margin-bottom: 0; }

/* Two-column layout */
.mv-two-col {
  display: flex;
  gap: 73px;
  margin-bottom: 18px;
}
.mv-col { flex: 1; }

/* Full-width edge image (no horizontal padding) */
.mv-edge-img {
  margin: 0 -120px;
}
.mv-edge-img img { width: 100%; height: auto; display: block; }

/* Padded image (inherits section padding) */
.mv-padded-img img { width: 100%; height: auto; display: block; }

/* ══════════════════════════════════════
   ④ PROBLEMS ANALYSIS
   ══════════════════════════════════════ */
.mv-problems-section {
  padding: 60px 120px 0;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.mv-problems-grid {
  display: flex;
  gap: 32px;
}

.mv-issue-col { flex: 1; }

.mv-issue-heading {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 600;
  color: #5a5a5a;
  text-align: center;
  margin: 0 0 14px;
}

.mv-issue-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.mv-issue-list li {
  font-family: var(--font-text);
  font-size: 12.5px;
  line-height: 1.65;
  color: #5a5a5a;
  padding-left: 14px;
  margin-bottom: 8px;
  position: relative;
}
.mv-issue-list li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: #2773DC;
  font-size: 16px;
  line-height: 1.4;
}

/* ══════════════════════════════════════
   ⑤ COMPARATIVE ANALYSIS
   ══════════════════════════════════════ */
.mv-competitive-section {
  display: flex;
  align-items: center;
  gap: 40px;
}

.mv-competitive-left { flex: 4; }

.mv-competitive-right { flex: 6; }
.mv-competitive-right img { width: 100%; height: auto; display: block; }

/* ══════════════════════════════════════
   ⑥ DESIGN PRINCIPLE
   ══════════════════════════════════════ */
.mv-design-section {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.mv-design-header { max-width: 900px; }

/* ══════════════════════════════════════
   ⑦ MOSCOW METHOD
   ══════════════════════════════════════ */
.mv-moscow-section {
  display: flex;
  align-items: flex-start;
  gap: 40px;
}

.mv-moscow-left {
  flex: 4;
  padding-top: 20px;
}

.mv-moscow-right { flex: 6; }
.mv-moscow-right img { width: 100%; height: auto; display: block; }

/* ══════════════════════════════════════
   ⑧ IDEAL USER FLOW + LO-FI
   ══════════════════════════════════════ */
.mv-userflow-section {
  display: flex;
  flex-direction: column;
  gap: 27px;
}

.mv-two-col-equal {
  gap: 40px;
  margin-bottom: 0;
}

.mv-two-col-imgs {
  gap: 40px;
  margin-bottom: 0;
  align-items: center;
}

.mv-two-col-imgs .mv-col img {
  width: 100%;
  height: auto;
  display: block;
}

/* ══════════════════════════════════════
   ⑨ SPECIFIC SOLUTIONS
   ══════════════════════════════════════ */
.mv-solutions-section {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 0;
}

.mv-solutions-grid {
  display: flex;
  gap: 12px;
}

.mv-solution-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.mv-solution-heading {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 600;
  color: rgba(0, 0, 0, 0.6);
  margin: 0;
  text-align: center;
}

.mv-solution-body {
  font-family: var(--font-text);
  font-size: 12px;
  line-height: 1.8;
  color: #444444;
  margin: 0;
  text-align: left;
}

.mv-solution-col--center .mv-solution-body {
  text-align: center;
}

/* ══════════════════════════════════════
   ⑩ UI DETAILS — title + three columns
   Figma proportions: Before 290 | Text 309 | After 601 (gap 40px each)
   ══════════════════════════════════════ */
.mv-uidetails-section {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.mv-uidetails-layout {
  display: flex;
  gap: 40px;
  align-items: flex-start;
}

/* Left — Before (narrow, ~24%) */
.mv-uidetails-before {
  flex: 290;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.mv-uidetails-before img {
  width: 100%;
  height: auto;
  display: block;
}

/* Middle — text (~25%), starts lower per Figma (y=40 offset) */
.mv-uidetails-text {
  flex: 309;
  padding-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Right — After (wide, ~49%) */
.mv-uidetails-after {
  flex: 601;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.mv-uidetails-after img {
  width: 100%;
  height: auto;
  display: block;
}

/* Before / After labels */
.mv-uidetails-label {
  font-family: var(--font-text);
  font-size: 13px;
  color: #888888;
  margin: 0;
  text-align: center;
}

/* Numbered text items */
.mv-uidetails-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.mv-uidetails-num {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  color: rgba(0, 0, 0, 0.6);
  line-height: 1.3;
  flex-shrink: 0;
  width: 20px;
}

.mv-uidetails-item .mv-body {
  margin: 0;
}

/* ══════════════════════════════════════
   ⑫ OUTPUT
   ══════════════════════════════════════ */
.mv-output-section {
  display: flex;
  align-items: flex-start;
  gap: 93px;
  padding: 0 120px 0 120px;
  overflow: hidden;
}

.mv-output-left {
  flex: 4;
  padding: 60px 0;
}

.mv-output-right {
  flex: 6;
  min-height: 680px;
  overflow: hidden;
}
.mv-output-right img {
  width: 100%;
  height: auto;
  display: block;
}

/* ══════════════════════════════════════
   ⑬ RECAP
   ══════════════════════════════════════ */
.mv-recap-section {
  display: flex;
  align-items: flex-start;
  gap: 68px;
  padding: 60px 120px 60px 120px;
  overflow: hidden;
}

.mv-recap-left { flex: 4; }

.mv-recap-right { flex: 6; }
.mv-recap-right img { width: 100%; height: auto; display: block; }

.mv-stats {
  margin: 20px 0 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mv-stats p {
  font-family: var(--font-text);
  font-size: 13.5px;
  line-height: 1.7;
  color: #1a1a1a;
  margin: 0;
}

.mv-confidential {
  margin-top: 12px;
}

/* ══════════════════════════════════════
   CAROUSEL — white background
   ══════════════════════════════════════ */
.mv-page .more-section {
  background: white;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}
.mv-page .more-heading { color: #6b6b6b; }

/* ══════════════════════════════════════
   SECTION GAPS — 100px between every section
   ══════════════════════════════════════ */
.mv-section {
  margin-top: 100px;
}

/* Hero is first, no top margin needed */
.mv-hero { margin-top: 0; }

/* More section also gets the gap */
.mv-page .more-section { margin-top: 100px; }

/* ══════════════════════════════════════
   SCROLL FADE-IN ANIMATION
   ══════════════════════════════════════ */
.mv-animate {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.mv-animate.is-visible {
  opacity: 1;
  transform: translateY(0);
}
