/* ============================================================
   viralarc-style.css — ViralArc AI 一個人 + AI = 一間公司
   - 所有 selector 以 .gemini_root 開頭
   - 不使用 :root、不使用 !important、不修改全域變數
   - 不使用純 tag selector
   ============================================================ */

.gemini_root {
  --gem-bg: #000;
  --gem-fg: #fff;
  --gem-mute: #d4d4d8;
  --gem-mute2: #a1a1aa;
  --gem-mute3: #71717a;
  --gem-cyan: #6ed0ee;
  --gem-cyan-dim: rgba(110, 208, 238, 0.08);
  --gem-cyan-bd: rgba(110, 208, 238, 0.3);
  --gem-yellow: #ffb400;
  --gem-red: #ef4444;
  --gem-line: rgba(255, 255, 255, 0.1);

  background: var(--gem-bg);
  color: var(--gem-fg);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang TC", "Noto Sans TC", sans-serif;
  line-height: 1.6;
  padding: 16px;
  max-width: 768px;
  margin: 0 auto;
  box-sizing: border-box;
  overflow-x: hidden;
}

.gemini_root [class^="gemini_"] { box-sizing: border-box; min-width: 0; }

/* 共用 */
.gemini_root .gemini_va_section_head { text-align: center; margin-bottom: 24px; }
.gemini_root .gemini_va_eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--gem-cyan);
}
.gemini_root .gemini_va_section_title {
  margin-top: 8px;
  font-size: 28px;
  font-weight: 900;
  line-height: 1.2;
  color: var(--gem-cyan);
}
.gemini_root .gemini_va_section_pain {
  margin-top: 12px;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.5;
  color: var(--gem-red);
}
@media (min-width: 640px) {
  .gemini_root .gemini_va_section_title { font-size: 36px; }
}
.gemini_root .gemini_va_accent_cyan { color: var(--gem-cyan); }
.gemini_root .gemini_va_accent_white { color: var(--gem-fg); font-weight: 700; }

/* ---------- 1. HERO ---------- */
.gemini_root .gemini_va_hero { padding: 0 0 24px; }
.gemini_root .gemini_va_hero_img {
  width: 100%;
  aspect-ratio: 1 / 1;
  background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962156/ChatGPT_Image_May_2_2026_10_30_29_PM_2_uvr0c1.png');
  background-size: cover;
  background-position: center;
}

/* ---------- 2. PARTNERS MARQUEE ---------- */
.gemini_root .gemini_va_brands { padding: 24px 0; }
.gemini_root .gemini_va_marquee_mask {
  margin-top: 24px;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent, black 12%, black 88%, transparent);
          mask-image: linear-gradient(to right, transparent, black 12%, black 88%, transparent);
}
.gemini_root .gemini_va_marquee_track {
  display: flex;
  width: max-content;
  align-items: center;
  gap: 40px;
  animation: gemini_va_marquee 30s linear infinite;
}
.gemini_root .gemini_va_brand_item {
  flex-shrink: 0;
  width: 80px;
  height: 32px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.8;
}
.gemini_root .gemini_va_brand_nvidia { background-image: url('https://cdn.simpleicons.org/nvidia/76B900'); }
.gemini_root .gemini_va_brand_openai { background-image: url('https://upload.wikimedia.org/wikipedia/commons/e/ef/ChatGPT-Logo.svg'); filter: brightness(0) invert(1); }
.gemini_root .gemini_va_brand_threads { background-image: url('https://cdn.simpleicons.org/threads/FFFFFF'); filter: brightness(0) invert(1); }
.gemini_root .gemini_va_brand_facebook { background-image: url('https://cdn.simpleicons.org/facebook/1877F2'); }
.gemini_root .gemini_va_brand_instagram { background-image: url('https://cdn.simpleicons.org/instagram/E4405F'); }
.gemini_root .gemini_va_brand_viralarc { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779963665/ViralArc_logo_fhngtt.png'); }
.gemini_root .gemini_va_brand_945 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779961710/pic_logo_1_iekfgm.png'); }

@keyframes gemini_va_marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-33.333%); }
}
@media (min-width: 640px) {
  .gemini_root .gemini_va_brand_item { width: 100px; height: 40px; }
  .gemini_root .gemini_va_marquee_track { gap: 56px; }
}

/* ---------- 3. COURSE INTRO ---------- */
.gemini_root .gemini_va_intro { padding: 24px 0; }
.gemini_root .gemini_va_intro_card {
  border: 1px solid var(--gem-line);
  background: linear-gradient(180deg, rgba(168, 85, 247, 0.08) 0%, rgba(236, 72, 153, 0.04) 100%);
  border-radius: 16px;
  padding: 24px;
}
.gemini_root .gemini_va_intro_p {
  margin-top: 20px;
  font-size: 14px;
  line-height: 1.9;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_intro_p:first-child { margin-top: 0; }
@media (min-width: 640px) {
  .gemini_root .gemini_va_intro_card { padding: 40px; }
}

.gemini_root .gemini_va_super_card {
  margin-top: 32px;
  border: 1px solid var(--gem-cyan-bd);
  background: rgba(110, 208, 238, 0.1);
  border-radius: 24px;
  padding: 32px 24px;
}
.gemini_root .gemini_va_super_title {
  text-align: center;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.4;
}
.gemini_root .gemini_va_super_badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: 20px auto 0;
  max-width: 560px;
}
.gemini_root .gemini_va_badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 9999px;
}
.gemini_root .gemini_va_badge_nv { border: 1px solid rgba(118, 185, 0, 0.4); background: rgba(118, 185, 0, 0.1); color: #aee576; }
.gemini_root .gemini_va_badge_meta { border: 1px solid rgba(24, 119, 242, 0.4); background: rgba(24, 119, 242, 0.15); color: #80b4ff; }
.gemini_root .gemini_va_super_list {
  list-style: none;
  padding: 0;
  margin: 28px auto 0;
  max-width: 560px;
}
.gemini_root .gemini_va_super_item {
  position: relative;
  padding-left: 24px;
  margin-bottom: 12px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_super_item::before {
  content: '✦';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--gem-cyan);
}
@media (min-width: 640px) {
  .gemini_root .gemini_va_super_card { padding: 56px; }
}

/* ---------- 4. TOOL STACK ---------- */
.gemini_root .gemini_va_tools { padding: 24px 0; }
.gemini_root .gemini_va_tools_card {
  border: 1px solid var(--gem-line);
  background: linear-gradient(180deg, rgba(168, 85, 247, 0.08) 0%, rgba(236, 72, 153, 0.04) 100%);
  border-radius: 16px;
  padding: 24px;
}
.gemini_root .gemini_va_tools_group { text-align: center; }
.gemini_root .gemini_va_tools_group_title {
  display: inline-block;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--gem-fg);
  margin-bottom: 20px;
}
.gemini_root .gemini_va_tools_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  justify-items: center;
}
.gemini_root .gemini_va_tools_socials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  justify-items: center;
}
.gemini_root .gemini_va_tools_gift {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.gemini_root .gemini_va_tool {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.gemini_root .gemini_va_tool_icon {
  width: 48px;
  height: 48px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  border-radius: 12px;
}
.gemini_root .gemini_va_tool_label {
  font-size: 11px;
  color: var(--gem-mute2);
  text-align: center;
  line-height: 1.4;
}
.gemini_root .gemini_va_icon_chatgpt { background-image: url('https://upload.wikimedia.org/wikipedia/commons/e/ef/ChatGPT-Logo.svg'); filter: brightness(0) invert(1); }
.gemini_root .gemini_va_icon_claude { background-image: url('https://cdn.simpleicons.org/claude/D97757'); }
.gemini_root .gemini_va_icon_aistudio { background-image: url('https://www.gstatic.com/aistudio/ai_studio_favicon_256x256.png'); }
.gemini_root .gemini_va_icon_notebooklm { background-image: url('https://notebooklm.google.com/_/NotebookLmWebUi/images/notebook_lm.svg'); }
.gemini_root .gemini_va_icon_capcut { background-image: url('https://sf16-web-tos-buz.capcutstatic.com/obj/capcut-web-buz-sg/common/images/lv_web-2.ico'); }
.gemini_root .gemini_va_icon_higgsfield { background-image: url('https://higgsfield.ai/icon.png'); }
.gemini_root .gemini_va_icon_minimax { background-image: url('https://cdn.simpleicons.org/minimax'); }
.gemini_root .gemini_va_icon_ig { background-image: url('https://cdn.simpleicons.org/instagram/E4405F'); }
.gemini_root .gemini_va_icon_fb { background-image: url('https://cdn.simpleicons.org/facebook/1877F2'); }
.gemini_root .gemini_va_icon_threads { background-image: url('https://cdn.simpleicons.org/threads/FFFFFF'); filter: brightness(0) invert(1); }
.gemini_root .gemini_va_icon_va_big {
  width: 64px;
  height: 64px;
  background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779963665/ViralArc_logo_fhngtt.png');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.gemini_root .gemini_va_divider {
  height: 1px;
  width: 100%;
  background: var(--gem-line);
  margin: 24px 0;
}

@media (min-width: 640px) {
  .gemini_root .gemini_va_tools_card { padding: 32px; }
  .gemini_root .gemini_va_tool_icon { width: 80px; height: 80px; }
  .gemini_root .gemini_va_icon_va_big { width: 96px; height: 96px; }
  .gemini_root .gemini_va_tool_label { font-size: 14px; }
}

/* ---------- 5. REAL USER DATA ---------- */
.gemini_root .gemini_va_data { padding: 24px 0; }
.gemini_root .gemini_va_data_track {
  display: flex;
  width: max-content;
  align-items: stretch;
  gap: 16px;
  animation: gemini_va_data_marquee 80s linear infinite;
}
.gemini_root .gemini_va_data_card {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  width: 280px;
  border: 1px solid var(--gem-line);
  background: rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  padding: 20px;
}
.gemini_root .gemini_va_data_head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.gemini_root .gemini_va_data_tag {
  display: inline-block;
  background: rgba(110, 208, 238, 0.15);
  color: var(--gem-cyan);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 4px 10px;
  border-radius: 9999px;
}
.gemini_root .gemini_va_data_views { text-align: right; }
.gemini_root .gemini_va_data_num { font-size: 20px; font-weight: 900; color: var(--gem-fg); line-height: 1.1; }
.gemini_root .gemini_va_data_views_label { font-size: 11px; letter-spacing: 1px; color: var(--gem-mute2); }
.gemini_root .gemini_va_data_text {
  margin-top: 16px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_data_foot {
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  font-size: 11px;
  color: var(--gem-mute2);
}

@keyframes gemini_va_data_marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@media (min-width: 640px) {
  .gemini_root .gemini_va_data_card { width: 320px; padding: 24px; }
}

/* ---------- 6. TEAM (含 reach + screenshots) ---------- */
.gemini_root .gemini_va_team { padding: 24px 0; }
.gemini_root .gemini_va_reach_card {
  max-width: 480px;
  margin: 0 auto 24px;
  border: 1px solid var(--gem-cyan-bd);
  background: var(--gem-cyan-dim);
  border-radius: 16px;
  padding: 24px;
  text-align: center;
}
.gemini_root .gemini_va_reach_eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 4px; color: var(--gem-cyan); }
.gemini_root .gemini_va_reach_num {
  margin-top: 12px;
  font-size: 44px;
  font-weight: 900;
  color: var(--gem-fg);
  line-height: 1.1;
}
.gemini_root .gemini_va_reach_label {
  display: block;
  margin-top: 8px;
  font-size: 14px;
  color: var(--gem-mute2);
}
@media (min-width: 640px) {
  .gemini_root .gemini_va_reach_card { padding: 32px; }
  .gemini_root .gemini_va_reach_num { font-size: 56px; }
}

.gemini_root .gemini_va_screens_head { text-align: center; margin-bottom: 16px; }
.gemini_root .gemini_va_screens_title { font-size: 17px; font-weight: 700; color: var(--gem-fg); }
.gemini_root .gemini_va_screens_scroll {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 8px;
  margin-bottom: 32px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.gemini_root .gemini_va_screens_scroll::-webkit-scrollbar { display: none; }
.gemini_root .gemini_va_screen {
  flex-shrink: 0;
  width: 240px;
  aspect-ratio: 3 / 4;
  border-radius: 16px;
  background-size: cover;
  background-position: center;
  scroll-snap-align: center;
}
.gemini_root .gemini_va_screen_1 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962604/Screenshot_2026-05-28_at_6.03.17_PM_up47kd.png'); }
.gemini_root .gemini_va_screen_2 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962572/Screenshot_2026-05-28_at_6.02.44_PM_u7l39x.png'); }
.gemini_root .gemini_va_screen_3 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962567/Screenshot_2026-05-28_at_6.02.29_PM_emydu5.png'); }
.gemini_root .gemini_va_screen_4 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962533/Screenshot_2026-05-28_at_6.02.07_PM_ybtsg0.png'); }
.gemini_root .gemini_va_screen_5 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962588/Screenshot_2026-05-28_at_6.03.03_PM_krxdun.png'); }
@media (min-width: 640px) {
  .gemini_root .gemini_va_screen { width: 280px; }
  .gemini_root .gemini_va_screens_scroll { gap: 16px; }
}

.gemini_root .gemini_va_team_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.gemini_root .gemini_va_team_card { border-radius: 16px; padding: 16px; }
.gemini_root .gemini_va_team_card_red { border: 1px solid rgba(239, 68, 68, 0.3); background: rgba(239, 68, 68, 0.05); }
.gemini_root .gemini_va_team_card_cyan { border: 1px solid var(--gem-cyan-bd); background: rgba(110, 208, 238, 0.05); }
.gemini_root .gemini_va_team_head { display: flex; align-items: center; gap: 12px; }
.gemini_root .gemini_va_team_logo {
  width: 32px;
  height: 32px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  border-radius: 6px;
}
.gemini_root .gemini_va_logo_945 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779961710/pic_logo_1_iekfgm.png'); }
.gemini_root .gemini_va_logo_va { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779963665/ViralArc_logo_fhngtt.png'); }
.gemini_root .gemini_va_team_name { font-size: 17px; font-weight: 700; }
.gemini_root .gemini_va_team_tag {
  margin-left: auto;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
}
.gemini_root .gemini_va_team_card_red .gemini_va_team_tag { color: var(--gem-red); }
.gemini_root .gemini_va_team_card_cyan .gemini_va_team_tag { color: var(--gem-cyan); }
.gemini_root .gemini_va_team_text {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_team_stats {
  margin-top: 12px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.gemini_root .gemini_va_team_stat {
  border: 1px solid var(--gem-line);
  background: rgba(0, 0, 0, 0.3);
  border-radius: 8px;
  padding: 8px;
  text-align: center;
}
.gemini_root .gemini_va_team_stat_num {
  font-size: 24px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.5px;
}
.gemini_root .gemini_va_team_card_red .gemini_va_team_stat_num { color: var(--gem-red); }
.gemini_root .gemini_va_team_card_cyan .gemini_va_team_stat_num { color: var(--gem-cyan); }
.gemini_root .gemini_va_team_stat_label {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  color: var(--gem-mute2);
}
@media (min-width: 768px) {
  .gemini_root .gemini_va_team_grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .gemini_root .gemini_va_team_card { border-radius: 24px; padding: 24px; }
  .gemini_root .gemini_va_team_logo { width: 36px; height: 36px; }
  .gemini_root .gemini_va_team_stats { gap: 12px; margin-top: 20px; }
  .gemini_root .gemini_va_team_stat { padding: 12px; border-radius: 12px; }
  .gemini_root .gemini_va_team_stat_num { font-size: 32px; }
}

/* ---------- 7. INSTRUCTORS ---------- */
.gemini_root .gemini_va_instructors { padding: 24px 0; }
.gemini_root .gemini_va_inst_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.gemini_root .gemini_va_inst_card {
  overflow: hidden;
  border: 1px solid var(--gem-line);
  background: rgba(255, 255, 255, 0.05);
  border-radius: 16px;
}
.gemini_root .gemini_va_inst_photo {
  width: 100%;
  aspect-ratio: 4 / 3;
  background-size: cover;
  background-position: center 14%;
}
.gemini_root .gemini_va_inst_king { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962051/ChatGPT_Image_May_2_2026_02_02_18_AM_2_l7ztz1.png'); }
.gemini_root .gemini_va_inst_anna { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779959694/ChatGPT_Image_May_2_2026_02_02_47_AM_wn4oli.png'); }
.gemini_root .gemini_va_inst_elvis { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779959693/ChatGPT_Image_May_2_2026_02_02_41_AM_qrluwz.png'); }
.gemini_root .gemini_va_inst_neil { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779959693/ChatGPT_Image_May_2_2026_02_02_44_AM_rdttlx.png'); }
.gemini_root .gemini_va_inst_body { padding: 20px; }
.gemini_root .gemini_va_inst_name { font-size: 17px; font-weight: 700; color: var(--gem-fg); }
.gemini_root .gemini_va_inst_role {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  color: var(--gem-red);
}
.gemini_root .gemini_va_inst_bio {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--gem-mute2);
}
@media (min-width: 768px) {
  .gemini_root .gemini_va_inst_grid { grid-template-columns: 1fr 1fr; }
}

/* ---------- 8. UGC VIDEO ---------- */
.gemini_root .gemini_va_ugc { padding: 24px 0; }
.gemini_root .gemini_va_ugc_lead {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--gem-fg);
}
.gemini_root .gemini_va_ugc_scroll {
  margin-top: 24px;
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 8px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.gemini_root .gemini_va_ugc_scroll::-webkit-scrollbar { display: none; }
/* 卡片視覺直接掛在 v1..v5（單一 class，CKEditor 不會剝） */
.gemini_root .gemini_va_ugc_v1,
.gemini_root .gemini_va_ugc_v2,
.gemini_root .gemini_va_ugc_v3,
.gemini_root .gemini_va_ugc_v4,
.gemini_root .gemini_va_ugc_v5 {
  flex-shrink: 0;
  width: 240px;
  height: 427px;
  border-radius: 16px;
  scroll-snap-align: center;
  background-color: #1f2937;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(110, 208, 238, 0.2);
  overflow: hidden;
  transition: border-color 0.2s ease, transform 0.2s ease;
}
.gemini_root .gemini_va_ugc_v1:hover,
.gemini_root .gemini_va_ugc_v2:hover,
.gemini_root .gemini_va_ugc_v3:hover,
.gemini_root .gemini_va_ugc_v4:hover,
.gemini_root .gemini_va_ugc_v5:hover { border-color: var(--gem-cyan); transform: translateY(-2px); }
.gemini_root .gemini_va_ugc_v1 { background-image: linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,0.4) 100%), url('https://image.mux.com/sxyyePui1Ov8O8hmjCDlWACtN86XJ4ruC3o4lGf302MU/animated.gif?width=320&fps=15&start=0&end=10'); }
.gemini_root .gemini_va_ugc_v2 { background-image: linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,0.4) 100%), url('https://image.mux.com/6SXJXfLX01YXTqwq33aFdZ6FefsgTlWuG1FPTvw6TwYo/animated.gif?width=320&fps=15&start=0&end=10'); }
.gemini_root .gemini_va_ugc_v3 { background-image: linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,0.4) 100%), url('https://image.mux.com/IxS01ji787blIRrqj4KySlL8nscEYGLmGWsnTZhgHCro/animated.gif?width=320&fps=15&start=0&end=10'); }
.gemini_root .gemini_va_ugc_v4 { background-image: linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,0.4) 100%), url('https://image.mux.com/X028V026smJO02Z5NHTXfuT012EVKkU2K6vvwTtpFZKLOiI/animated.gif?width=320&fps=15&start=0&end=10'); }
.gemini_root .gemini_va_ugc_v5 { background-image: linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,0.4) 100%), url('https://image.mux.com/HJkfq9xepyhtfM48jwK1rl9FJIky3QD8M012G6xewCb00/animated.gif?width=320&fps=15&start=0&end=10'); }
@media (min-width: 640px) {
  .gemini_root .gemini_va_ugc_v1,
  .gemini_root .gemini_va_ugc_v2,
  .gemini_root .gemini_va_ugc_v3,
  .gemini_root .gemini_va_ugc_v4,
  .gemini_root .gemini_va_ugc_v5 { width: 280px; height: 498px; }
  .gemini_root .gemini_va_ugc_scroll { gap: 16px; }
}

/* ---------- 9. CURRICULUM ---------- */
.gemini_root .gemini_va_curriculum { padding: 24px 0; }
.gemini_root .gemini_va_curr_scroll {
  margin-top: 24px;
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 8px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.gemini_root .gemini_va_curr_scroll::-webkit-scrollbar { display: none; }
.gemini_root .gemini_va_curr_card {
  flex-shrink: 0;
  width: 280px;
  border: 1px solid var(--gem-line);
  background: rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  padding: 24px;
  scroll-snap-align: center;
}
.gemini_root .gemini_va_curr_label {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  color: var(--gem-red);
  margin-bottom: -2px;
}
.gemini_root .gemini_va_curr_title { font-size: 17px; font-weight: 700; color: var(--gem-fg); }
.gemini_root .gemini_va_curr_pain {
  margin-top: 8px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
  color: var(--gem-red);
}
.gemini_root .gemini_va_curr_desc {
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_curr_list {
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
}
.gemini_root .gemini_va_curr_item {
  position: relative;
  padding-left: 14px;
  margin-bottom: 4px;
  font-size: 14px;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_curr_item::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--gem-mute2);
}
@media (min-width: 640px) {
  .gemini_root .gemini_va_curr_card { width: 320px; }
}

/* ---------- 10. 9 FEATURES ---------- */
.gemini_root .gemini_va_features { padding: 24px 0; }
.gemini_root .gemini_va_feat_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.gemini_root .gemini_va_feat_card {
  border: 1px solid var(--gem-line);
  background: rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  padding: 16px;
}
.gemini_root .gemini_va_feat_num {
  font-size: 22px;
  font-weight: 900;
  color: var(--gem-cyan);
  line-height: 1;
}
.gemini_root .gemini_va_feat_title {
  margin-top: 8px;
  font-size: 17px;
  font-weight: 700;
  color: var(--gem-fg);
}
.gemini_root .gemini_va_feat_text {
  margin-top: 8px;
  font-size: 14px;
  color: var(--gem-mute2);
  line-height: 1.6;
}
@media (min-width: 640px) {
  .gemini_root .gemini_va_feat_grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1024px) {
  .gemini_root .gemini_va_feat_grid { grid-template-columns: repeat(3, 1fr); }
}

/* ---------- 11. AUDIENCE ---------- */
.gemini_root .gemini_va_audience { padding: 24px 0; }
.gemini_root .gemini_va_aud_list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.gemini_root .gemini_va_aud_card {
  display: grid;
  grid-template-columns: 22% 1fr;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--gem-line);
  background: rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  padding: 12px;
}
.gemini_root .gemini_va_aud_photo {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 12px;
  background-size: cover;
  background-position: center;
}
.gemini_root .gemini_va_aud_1 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962976/ChatGPT_Image_May_28_2026_06_09_20_PM_zcy7wz.png'); }
.gemini_root .gemini_va_aud_2 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779962978/ChatGPT_Image_May_28_2026_06_09_24_PM_hrhxno.png'); }
.gemini_root .gemini_va_aud_3 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779963034/ChatGPT_Image_May_28_2026_06_10_07_PM_d3bx9g.png'); }
.gemini_root .gemini_va_aud_4 { background-image: url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779963131/ChatGPT_Image_May_28_2026_06_11_58_PM_gtmxfh.png'); }
.gemini_root .gemini_va_aud_title {
  font-size: 17px;
  font-weight: 700;
  color: var(--gem-fg);
  line-height: 1.5;
}
@media (min-width: 640px) {
  .gemini_root .gemini_va_aud_card { grid-template-columns: 18% 1fr; gap: 16px; padding: 16px; }
}

/* ---------- 12. PRICING ---------- */
.gemini_root .gemini_va_pricing { padding: 24px 0; }
.gemini_root .gemini_va_pricing_lead {
  margin-top: 16px;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
  font-size: 14px;
  line-height: 1.7;
  color: var(--gem-fg);
}
.gemini_root .gemini_va_price_card {
  margin-top: 32px;
  border: 1px solid var(--gem-cyan-bd);
  background: linear-gradient(180deg, rgba(168, 85, 247, 0.08) 0%, rgba(236, 72, 153, 0.04) 100%);
  border-radius: 24px;
  padding: 24px;
}
.gemini_root .gemini_va_price_head { text-align: center; }
.gemini_root .gemini_va_price_eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--gem-cyan);
}
.gemini_root .gemini_va_price_main {
  margin-top: 8px;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 4px;
}
.gemini_root .gemini_va_price_curr { font-size: 22px; font-weight: 700; color: var(--gem-cyan); }
.gemini_root .gemini_va_price_amt { font-size: 48px; font-weight: 900; color: var(--gem-cyan); line-height: 1; }
.gemini_root .gemini_va_price_sub { display: block; margin-top: 8px; font-size: 14px; color: var(--gem-mute2); }
.gemini_root .gemini_va_price_grid {
  margin-top: 28px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.gemini_root .gemini_va_price_block {
  border: 1px solid var(--gem-line);
  border-radius: 12px;
  padding: 20px;
}
.gemini_root .gemini_va_price_row {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding-bottom: 8px;
  margin-bottom: 8px;
}
.gemini_root .gemini_va_price_row_last { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }
.gemini_root .gemini_va_price_row_main {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}
.gemini_root .gemini_va_price_label { font-size: 17px; font-weight: 700; color: var(--gem-fg); }
.gemini_root .gemini_va_price_value { font-size: 14px; font-weight: 900; color: var(--gem-cyan); white-space: nowrap; }
.gemini_root .gemini_va_price_desc {
  margin-top: 2px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_price_bonus {
  position: relative;
  border: 1px solid rgba(110, 208, 238, 0.4);
  background: rgba(110, 208, 238, 0.1);
  border-radius: 12px;
  padding: 28px 20px 20px;
  margin-top: 20px;
}
.gemini_root .gemini_va_price_bonus_tag {
  position: absolute;
  left: 50%;
  top: -16px;
  transform: translateX(-50%);
  background: var(--gem-cyan);
  color: #000;
  font-size: 14px;
  font-weight: 900;
  padding: 6px 16px;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

/* ---------- 13. FAQ（收合） ---------- */
.gemini_root .gemini_va_faq { padding: 24px 0; max-width: 720px; margin: 0 auto; }
.gemini_root .gemini_va_faq_list { display: flex; flex-direction: column; gap: 12px; }
.gemini_root .gemini_va_faq_item {
  border: 1px solid var(--gem-line);
  background: rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  padding: 20px;
  cursor: pointer;
  outline: none;
  transition: border-color 0.2s ease, background 0.2s ease;
}
.gemini_root .gemini_va_faq_item:hover { border-color: rgba(110, 208, 238, 0.4); }
.gemini_root .gemini_va_faq_item:focus,
.gemini_root .gemini_va_faq_item:focus-within {
  border-color: var(--gem-cyan);
  background: rgba(110, 208, 238, 0.06);
}
.gemini_root .gemini_va_faq_q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 17px;
  font-weight: 700;
  color: var(--gem-fg);
}
.gemini_root .gemini_va_faq_q::after {
  content: '▼';
  flex-shrink: 0;
  font-size: 12px;
  color: var(--gem-cyan);
  transition: transform 0.25s ease;
}
.gemini_root .gemini_va_faq_item:focus .gemini_va_faq_q::after,
.gemini_root .gemini_va_faq_item:focus-within .gemini_va_faq_q::after {
  transform: rotate(180deg);
}
.gemini_root .gemini_va_faq_body {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.2s ease 0.05s;
}
.gemini_root .gemini_va_faq_item:focus .gemini_va_faq_body,
.gemini_root .gemini_va_faq_item:focus-within .gemini_va_faq_body {
  max-height: 1500px;
  opacity: 1;
}
.gemini_root .gemini_va_faq_a {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_faq_a_warn { color: var(--gem-yellow); font-size: 12px; }
.gemini_root .gemini_va_faq_a_muted { color: var(--gem-mute2); font-size: 12px; }
.gemini_root .gemini_va_faq_kicker {
  display: inline-block;
  margin-right: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--gem-cyan);
}
.gemini_root .gemini_va_faq_inner {
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
}
.gemini_root .gemini_va_faq_li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 6px;
  font-size: 14px;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_faq_li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--gem-cyan);
}
/* ==================== ACQUISITION FUNNEL BENTO ==================== */
.gemini_root .gemini_va_funnel { padding: 32px 0; }
.gemini_root .gemini_va_funnel_lead {
  margin-top: 12px;
  text-align: center;
  font-size: 14px;
  color: var(--gem-mute2);
}
.gemini_root .gemini_va_funnel_stages {
  margin-top: 32px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

/* Card base */
.gemini_root .gemini_va_funnel_card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
  border-radius: 24px;
  padding: 24px;
  overflow: hidden;
  cursor: pointer;
  outline: none;
  transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1),
              border-color 0.3s ease,
              box-shadow 0.3s ease;
  opacity: 0;
  transform: translateY(16px);
  animation: gemini_va_funnel_in 0.6s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}
.gemini_root .gemini_va_funnel_card:nth-child(1)  { animation-delay: 0.05s; }
.gemini_root .gemini_va_funnel_card:nth-child(3)  { animation-delay: 0.10s; }
.gemini_root .gemini_va_funnel_card:nth-child(4)  { animation-delay: 0.15s; }
.gemini_root .gemini_va_funnel_card:nth-child(5)  { animation-delay: 0.20s; }
.gemini_root .gemini_va_funnel_card:nth-child(6)  { animation-delay: 0.25s; }
.gemini_root .gemini_va_funnel_card:nth-child(8)  { animation-delay: 0.30s; }
.gemini_root .gemini_va_funnel_card:nth-child(10) { animation-delay: 0.35s; }
.gemini_root .gemini_va_funnel_card:hover,
.gemini_root .gemini_va_funnel_card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(110, 208, 238, 0.18);
}

/* Step pill */
.gemini_root .gemini_va_funnel_step {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 9999px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 2px;
  background: rgba(255, 255, 255, 0.85);
  color: #000;
}
.gemini_root .gemini_va_funnel_title {
  margin-top: 12px;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.25;
  color: var(--gem-fg);
}
.gemini_root .gemini_va_funnel_desc {
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.85);
}
.gemini_root .gemini_va_funnel_text { position: relative; z-index: 2; }
.gemini_root .gemini_va_funnel_visual {
  position: relative;
  z-index: 1;
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

/* Unified dark card */
.gemini_root .gemini_va_funnel_card {
  background:
    radial-gradient(140% 90% at 50% -20%, rgba(255, 255, 255, 0.04), transparent 60%),
    linear-gradient(180deg, #1a1a1f 0%, #0c0c10 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
.gemini_root .gemini_va_funnel_card:hover,
.gemini_root .gemini_va_funnel_card:focus,
.gemini_root .gemini_va_funnel_card:focus-within {
  transform: translateY(-6px) scale(1.01);
  border-color: color-mix(in srgb, var(--stage, #6ed0ee) 50%, transparent);
  box-shadow:
    0 24px 72px rgba(0, 0, 0, 0.5),
    0 0 60px color-mix(in srgb, var(--stage, #6ed0ee) 25%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}
.gemini_root .gemini_va_funnel_card:hover .gemini_va_funnel_visual,
.gemini_root .gemini_va_funnel_card:focus .gemini_va_funnel_visual,
.gemini_root .gemini_va_funnel_card:focus-within .gemini_va_funnel_visual {
  transform: scale(1.06);
}
.gemini_root .gemini_va_funnel_visual {
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.gemini_root .gemini_va_funnel_card:hover .gemini_va_funnel_step,
.gemini_root .gemini_va_funnel_card:focus .gemini_va_funnel_step,
.gemini_root .gemini_va_funnel_card:focus-within .gemini_va_funnel_step {
  box-shadow: 0 0 16px color-mix(in srgb, var(--stage, #fff) 60%, transparent);
}

/* All cards share brand cyan accent for tags + shadow */
.gemini_root .gemini_va_funnel_card { --stage: #6ed0ee; --stage-2: #22d3ee; }
.gemini_root .gemini_va_funnel_card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(60% 80% at 100% 0%, color-mix(in srgb, var(--stage, #fff) 18%, transparent), transparent 60%);
  pointer-events: none;
  opacity: 0.7;
  transition: opacity 0.4s ease;
}
.gemini_root .gemini_va_funnel_card:hover::before,
.gemini_root .gemini_va_funnel_card:focus-visible::before { opacity: 1; }
.gemini_root .gemini_va_funnel_step {
  background: color-mix(in srgb, var(--stage, #fff) 92%, transparent);
  color: #0c0c10;
  transition: box-shadow 0.3s ease;
}


/* Tag chips */
.gemini_root .gemini_va_funnel_tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}
.gemini_root .gemini_va_funnel_tags span {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 9999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: color-mix(in srgb, var(--stage, #fff) 85%, white);
  background: color-mix(in srgb, var(--stage, #fff) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--stage, #fff) 25%, transparent);
}

/* Connector arrow */
.gemini_root .gemini_va_funnel_arrow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
}
.gemini_root .gemini_va_funnel_arrow_label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--gem-cyan);
  opacity: 0.85;
}
.gemini_root .gemini_va_funnel_arrow_line {
  width: 2px;
  height: 28px;
  background: linear-gradient(to bottom, var(--gem-cyan), transparent);
  position: relative;
  border-radius: 2px;
}
.gemini_root .gemini_va_funnel_arrow_line::after {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 50%;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--gem-cyan);
  border-bottom: 2px solid var(--gem-cyan);
  transform: translateX(-50%) rotate(45deg);
  animation: gemini_va_funnel_pulse_arrow 1.6s ease-in-out infinite;
}

/* ============ Mockup: Browser (Brand) ============ */
.gemini_root .gemini_va_mock_browser {
  position: relative;
  width: 280px;
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(192, 132, 252, 0.2),
              0 0 0 1px rgba(0, 0, 0, 0.06);
  font-family: -apple-system, BlinkMacSystemFont, "PingFang TC", sans-serif;
  animation: gemini_va_funnel_float 5s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_browser_bar {
  position: relative;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 12px;
  background: #f5f5f7;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.gemini_root .gemini_va_mock_browser_bar span {
  width: 8px; height: 8px; border-radius: 50%;
}
.gemini_root .gemini_va_mock_browser_bar span:nth-child(1) { background: #ff5f57; }
.gemini_root .gemini_va_mock_browser_bar span:nth-child(2) { background: #febc2e; }
.gemini_root .gemini_va_mock_browser_bar span:nth-child(3) { background: #28c840; }
.gemini_root .gemini_va_mock_browser_bar::after {
  content: "your-brand.com";
  margin-left: auto;
  padding: 3px 12px;
  border-radius: 9999px;
  background: #fff;
  font-size: 9px;
  color: #5b86ef;
  font-weight: 600;
  font-family: -apple-system, monospace;
}
.gemini_root .gemini_va_mock_browser_body {
  position: relative;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
/* Hero (photo + name) */
.gemini_root .gemini_va_mock_brand_hero {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}
.gemini_root .gemini_va_mock_avatar {
  position: relative;
  width: 48px; height: 48px;
  border-radius: 50%;
  background:
    url('https://res.cloudinary.com/dpohwt5xc/image/upload/v1779963665/ViralArc_logo_fhngtt.png') center / 70% no-repeat,
    linear-gradient(135deg, #6ed0ee 0%, #5b86ef 100%);
  box-shadow: 0 6px 18px rgba(91, 134, 239, 0.35),
              0 0 0 2px #fff;
  flex-shrink: 0;
}
.gemini_root .gemini_va_mock_brand_meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.gemini_root .gemini_va_mock_brand_meta strong {
  font-size: 13px;
  font-weight: 800;
  color: #0c0c10;
  letter-spacing: 0.3px;
}
.gemini_root .gemini_va_mock_brand_meta span {
  font-size: 10px;
  color: rgba(0, 0, 0, 0.5);
}
/* Services */
.gemini_root .gemini_va_mock_brand_services {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.gemini_root .gemini_va_mock_brand_service {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 8px 4px;
  border-radius: 8px;
  background: #f5f5f7;
}
.gemini_root .gemini_va_mock_brand_service small {
  font-size: 9px;
  color: rgba(0, 0, 0, 0.65);
  font-weight: 700;
}
.gemini_root .gemini_va_mock_brand_icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px; height: 26px;
  border-radius: 7px;
  font-size: 12px;
  background: #ef4444;
  color: #fff;
  box-shadow: 0 4px 10px rgba(239, 68, 68, 0.35);
}
.gemini_root .gemini_va_mock_brand_icon_2 {
  background: #5b86ef;
  box-shadow: 0 4px 10px rgba(91, 134, 239, 0.35);
}
.gemini_root .gemini_va_mock_brand_icon_3 {
  background: #facc15;
  color: #422006;
  box-shadow: 0 4px 10px rgba(250, 204, 21, 0.45);
}
/* Stats */
.gemini_root .gemini_va_mock_brand_stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 10px 4px;
  border-radius: 8px;
  background: #fafafa;
  border: 1px solid rgba(0, 0, 0, 0.06);
}
.gemini_root .gemini_va_mock_brand_stats > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.gemini_root .gemini_va_mock_brand_stats strong {
  font-size: 15px;
  font-weight: 900;
  letter-spacing: -0.3px;
}
.gemini_root .gemini_va_mock_brand_stats > div:nth-child(1) strong { color: #ef4444; }
.gemini_root .gemini_va_mock_brand_stats > div:nth-child(2) strong { color: #5b86ef; }
.gemini_root .gemini_va_mock_brand_stats > div:nth-child(3) strong { color: #f59e0b; }
.gemini_root .gemini_va_mock_brand_stats small {
  font-size: 9px;
  color: rgba(0, 0, 0, 0.5);
  font-weight: 600;
}
/* Legacy classes kept for fallback */
.gemini_root .gemini_va_mock_line {
  height: 6px;
  border-radius: 3px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.3), rgba(255, 255, 255, 0.12));
}
.gemini_root .gemini_va_mock_line_w1 { width: 70%; }
.gemini_root .gemini_va_mock_line_w2 { width: 48%; }
.gemini_root .gemini_va_mock_btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 22px;
  border-radius: 10px;
  background: #facc15;
  color: #0c0c10;
  font-size: 12px;
  font-weight: 900;
  text-align: center;
  box-shadow: 0 6px 18px rgba(250, 204, 21, 0.5);
  animation: gemini_va_funnel_btn_pulse 2.4s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_avatar_dot {
  position: absolute;
  top: 0; right: 0;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: #ef4444;
  border: 2px solid #fff;
  box-shadow: 0 0 8px rgba(239, 68, 68, 0.6);
  animation: gemini_va_funnel_dot_pulse 1.6s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_avatar { position: relative; }
.gemini_root .gemini_va_mock_browser_cursor {
  position: absolute;
  bottom: 18px;
  right: 24%;
  width: 0; height: 0;
  border-left: 12px solid #fff;
  border-top: 6px solid transparent;
  border-bottom: 18px solid transparent;
  transform: rotate(-18deg);
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.5));
  animation: gemini_va_funnel_browser_cursor 4s ease-in-out infinite;
  z-index: 3;
}
@keyframes gemini_va_funnel_btn_pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 6px 20px rgba(192, 132, 252, 0.4); }
  50%      { transform: scale(1.04); box-shadow: 0 8px 28px rgba(192, 132, 252, 0.7); }
}
@keyframes gemini_va_funnel_dot_pulse {
  0%, 100% { box-shadow: 0 0 8px rgba(239, 68, 68, 0.6); }
  50%      { box-shadow: 0 0 14px rgba(239, 68, 68, 0.95), 0 0 0 4px rgba(239, 68, 68, 0.2); }
}
@keyframes gemini_va_funnel_browser_cursor {
  0%, 100% { transform: translate(0, 0) rotate(-18deg); opacity: 0.7; }
  40%      { transform: translate(-30px, -8px) rotate(-18deg); opacity: 1; }
  60%      { transform: translate(-30px, -8px) rotate(-18deg) scale(0.85); opacity: 1; }
  80%      { transform: translate(-30px, -8px) rotate(-18deg) scale(1); opacity: 1; }
}

/* ============ Mockup: Phone (Avatar — person speaking) ============ */
.gemini_root .gemini_va_mock_phone {
  position: relative;
  width: 130px;
  height: 200px;
  border-radius: 24px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 18px 48px rgba(110, 208, 238, 0.3),
              0 0 0 1px rgba(0, 0, 0, 0.06),
              inset 0 0 0 6px #f5f5f7;
  animation: gemini_va_funnel_float 4s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_phone::before {
  content: "";
  position: absolute;
  top: 14px; left: 50%;
  transform: translateX(-50%);
  width: 36px; height: 5px;
  border-radius: 4px;
  background: #0c0c10;
  z-index: 4;
}
/* Speech bubble */
.gemini_root .gemini_va_mock_phone_bubble {
  position: absolute;
  top: 26px;
  right: -14px;
  padding: 5px 12px;
  border-radius: 14px 14px 4px 14px;
  background: #5b86ef;
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.5px;
  box-shadow: 0 6px 16px rgba(91, 134, 239, 0.45);
  z-index: 5;
  animation: gemini_va_funnel_bubble 3.2s ease-in-out infinite;
}
/* Face */
.gemini_root .gemini_va_mock_phone_face {
  position: relative;
  width: 64px; height: 64px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 32% 32%, #fff 0%, transparent 35%),
    linear-gradient(135deg, #ef4444 0%, #facc15 100%);
  box-shadow: 0 8px 22px rgba(239, 68, 68, 0.4),
              inset 0 -6px 14px rgba(180, 83, 9, 0.3);
  margin-top: -20px;
  z-index: 2;
}
.gemini_root .gemini_va_mock_phone_eyes {
  position: absolute;
  top: 38%; left: 0; right: 0;
  display: flex;
  justify-content: center;
  gap: 14px;
}
.gemini_root .gemini_va_mock_phone_eyes span {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: #0c0c10;
  animation: gemini_va_funnel_blink 4s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_phone_mouth {
  position: absolute;
  bottom: 24%;
  left: 50%;
  transform: translateX(-50%);
  width: 18px;
  height: 4px;
  border-radius: 0 0 18px 18px;
  background: #0c0c10;
  animation: gemini_va_funnel_mouth 0.45s ease-in-out infinite;
}
/* Pulse rings around face */
.gemini_root .gemini_va_mock_phone_pulse {
  position: absolute;
  top: 50%; left: 50%;
  width: 70px; height: 70px;
  border-radius: 50%;
  border: 2px solid #5b86ef;
  transform: translate(-50%, -50%);
  margin-top: -10px;
  opacity: 0.55;
  animation: gemini_va_funnel_radar 2.4s ease-out infinite;
}
.gemini_root .gemini_va_mock_phone_pulse_2 { animation-delay: 1.2s; }
/* Audio bars at bottom */
.gemini_root .gemini_va_mock_phone_bars {
  position: absolute;
  bottom: 22px; left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: flex-end;
  gap: 4px;
  height: 22px;
  z-index: 3;
}
.gemini_root .gemini_va_mock_phone_bars span {
  width: 4px;
  border-radius: 2px;
  background: #5b86ef;
  animation: gemini_va_funnel_bar 0.9s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_phone_bars span:nth-child(1) { height: 60%; animation-delay: 0s; }
.gemini_root .gemini_va_mock_phone_bars span:nth-child(2) { height: 100%; animation-delay: 0.15s; background: #ef4444; }
.gemini_root .gemini_va_mock_phone_bars span:nth-child(3) { height: 80%; animation-delay: 0.3s; background: #facc15; }
.gemini_root .gemini_va_mock_phone_bars span:nth-child(4) { height: 50%; animation-delay: 0.45s; }
@keyframes gemini_va_funnel_blink {
  0%, 95%, 100% { transform: scaleY(1); }
  97%           { transform: scaleY(0.1); }
}
@keyframes gemini_va_funnel_mouth {
  0%, 100% { width: 18px; height: 4px; }
  50%      { width: 12px; height: 8px; border-radius: 50%; }
}
@keyframes gemini_va_funnel_bar {
  0%, 100% { transform: scaleY(0.4); }
  50%      { transform: scaleY(1); }
}
@keyframes gemini_va_funnel_bubble {
  0%, 30%, 100% { opacity: 0; transform: translateY(4px) scale(0.8); }
  40%, 80%      { opacity: 1; transform: translateY(0) scale(1); }
}

/* ============ Mockup: Reels (UGC) ============ */
.gemini_root .gemini_va_mock_reels {
  position: relative;
  width: 150px;
  height: 220px;
  filter: drop-shadow(0 16px 40px rgba(91, 134, 239, 0.25));
}
.gemini_root .gemini_va_mock_reels_back {
  position: absolute;
  width: 110px;
  height: 200px;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.06);
  top: 4px; left: 8px;
  transform: rotate(-7deg);
  opacity: 0.5;
}
.gemini_root .gemini_va_mock_reels_back_2 {
  left: 0;
  transform: rotate(-14deg) translateY(-4px);
  opacity: 0.3;
}
.gemini_root .gemini_va_mock_reels_main {
  position: absolute;
  top: 8px; left: 22px;
  width: 120px;
  height: 210px;
  border-radius: 14px;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.4), transparent 50%),
    linear-gradient(160deg, #ef4444 0%, #facc15 100%);
  box-shadow: 0 12px 28px rgba(239, 68, 68, 0.35),
              0 0 0 1px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  transform: rotate(4deg);
  animation: gemini_va_funnel_stack 4s ease-in-out infinite;
}
/* Top progress bar */
.gemini_root .gemini_va_mock_reels_progress {
  position: absolute;
  top: 8px; left: 8px; right: 8px;
  height: 3px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.3);
  overflow: hidden;
  z-index: 2;
}
.gemini_root .gemini_va_mock_reels_progress span {
  display: block;
  height: 100%;
  background: #fff;
  border-radius: 3px;
  animation: gemini_va_funnel_reels_progress 4s ease-in-out infinite;
}
/* Center play */
.gemini_root .gemini_va_mock_reels_play {
  position: absolute;
  top: 38%; left: 50%;
  transform: translate(-50%, -50%);
  width: 38px; height: 38px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.95);
  z-index: 2;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}
.gemini_root .gemini_va_mock_reels_play::before {
  content: "";
  position: absolute;
  top: 50%; left: 56%;
  transform: translate(-50%, -50%);
  width: 0; height: 0;
  border-left: 12px solid #ef4444;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
}
/* Right action stack */
.gemini_root .gemini_va_mock_reels_actions {
  position: absolute;
  right: 6px; bottom: 56px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 3;
}
.gemini_root .gemini_va_mock_reels_act {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  color: #fff;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.4));
}
.gemini_root .gemini_va_mock_reels_act small {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.3px;
}
.gemini_root .gemini_va_mock_reels_heart {
  animation: gemini_va_funnel_heart 1.6s ease-in-out infinite;
}
/* CSS-drawn icons (no emoji) */
.gemini_root .gemini_va_icon_heart {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 12px;
}
.gemini_root .gemini_va_icon_heart::before,
.gemini_root .gemini_va_icon_heart::after {
  content: "";
  position: absolute;
  top: 0; left: 7px;
  width: 7px; height: 11px;
  background: #fff;
  border-radius: 7px 7px 0 0;
  transform: rotate(-45deg);
  transform-origin: 0 100%;
}
.gemini_root .gemini_va_icon_heart::after {
  left: 0;
  transform: rotate(45deg);
  transform-origin: 100% 100%;
}
.gemini_root .gemini_va_mock_reels_heart .gemini_va_icon_heart::before,
.gemini_root .gemini_va_mock_reels_heart .gemini_va_icon_heart::after {
  background: #ef4444;
}
.gemini_root .gemini_va_icon_chat {
  display: inline-block;
  position: relative;
  width: 14px;
  height: 12px;
  border-radius: 4px;
  border: 1.5px solid #fff;
  background: transparent;
}
.gemini_root .gemini_va_icon_chat::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 2px;
  width: 0; height: 0;
  border-top: 4px solid #fff;
  border-right: 3px solid transparent;
}
.gemini_root .gemini_va_icon_share {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 14px;
}
.gemini_root .gemini_va_icon_share::before {
  content: "";
  position: absolute;
  top: 9px; left: 1px;
  width: 12px; height: 1.5px;
  background: #fff;
  transform: rotate(-40deg);
  transform-origin: 0 50%;
  border-radius: 1px;
}
.gemini_root .gemini_va_icon_share::after {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 6px; height: 6px;
  border-top: 1.5px solid #fff;
  border-right: 1.5px solid #fff;
  border-radius: 1px 1px 0 0;
}
/* Bottom caption */
.gemini_root .gemini_va_mock_reels_caption {
  position: absolute;
  bottom: 10px; left: 10px; right: 28px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  z-index: 2;
  color: #fff;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
}
.gemini_root .gemini_va_mock_reels_caption strong {
  font-size: 10px;
  font-weight: 800;
}
.gemini_root .gemini_va_mock_reels_caption span {
  font-size: 9px;
  font-weight: 600;
  opacity: 0.95;
}
@keyframes gemini_va_funnel_reels_progress {
  0%   { width: 0%; }
  100% { width: 100%; }
}
@keyframes gemini_va_funnel_heart {
  0%, 60%, 100% { transform: scale(1); }
  30%           { transform: scale(1.25); }
}

/* ============ Mockup: Threads UI (Patrol) ============ */
.gemini_root .gemini_va_mock_threads {
  width: 220px;
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(250, 204, 21, 0.25),
              0 0 0 1px rgba(0, 0, 0, 0.08);
  font-family: -apple-system, BlinkMacSystemFont, "PingFang TC", sans-serif;
  animation: gemini_va_funnel_float 6s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_threads_top {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}
.gemini_root .gemini_va_mock_threads_logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #000;
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  font-family: Georgia, serif;
}
.gemini_root .gemini_va_mock_threads_logo::before {
  content: "@";
  font-style: italic;
}
.gemini_root .gemini_va_mock_threads_search {
  flex: 1;
  padding: 4px 10px;
  border-radius: 9999px;
  background: rgba(0, 0, 0, 0.05);
  font-size: 10px;
  font-weight: 700;
  color: #444;
}
/* Post */
.gemini_root .gemini_va_mock_threads_post {
  position: relative;
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.gemini_root .gemini_va_mock_threads_post_hot {
  background: linear-gradient(180deg, rgba(250, 204, 21, 0.18), rgba(250, 204, 21, 0.04));
  animation: gemini_va_funnel_threads_hot 3s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_threads_avatar {
  flex-shrink: 0;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, #fb7185, #f43f5e);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.06);
}
.gemini_root .gemini_va_mock_threads_avatar_2 {
  background: linear-gradient(135deg, #60a5fa, #3b82f6);
}
.gemini_root .gemini_va_mock_threads_body {
  flex: 1;
  min-width: 0;
}
.gemini_root .gemini_va_mock_threads_meta {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 4px;
}
.gemini_root .gemini_va_mock_threads_meta strong {
  font-size: 11px;
  font-weight: 700;
  color: #000;
}
.gemini_root .gemini_va_mock_threads_meta span {
  font-size: 9px;
  color: rgba(0, 0, 0, 0.45);
}
.gemini_root .gemini_va_mock_threads_text {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-bottom: 6px;
}
.gemini_root .gemini_va_mock_threads_text > div {
  height: 4px;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.18);
}
.gemini_root .gemini_va_mock_threads_text > div:first-child { width: 90%; }
.gemini_root .gemini_va_mock_threads_text > div:last-child { width: 60%; }
.gemini_root .gemini_va_mock_threads_actions {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 10px;
  color: rgba(0, 0, 0, 0.55);
  font-weight: 600;
}
.gemini_root .gemini_va_mock_threads_actions span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
/* Dark variant of heart icon for Threads (light bg) */
.gemini_root .gemini_va_icon_heart_dark::before,
.gemini_root .gemini_va_icon_heart_dark::after {
  background: rgba(0, 0, 0, 0.55);
}
/* Reply icon (curved arrow) */
.gemini_root .gemini_va_icon_reply {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 12px;
}
.gemini_root .gemini_va_icon_reply::before {
  content: "";
  position: absolute;
  top: 2px; left: 4px;
  width: 8px; height: 6px;
  border: 1.5px solid rgba(0, 0, 0, 0.55);
  border-bottom: none;
  border-right: none;
  border-radius: 6px 0 0 0;
}
.gemini_root .gemini_va_icon_reply::after {
  content: "";
  position: absolute;
  top: 0; left: 1px;
  width: 0; height: 0;
  border-top: 3px solid transparent;
  border-bottom: 3px solid transparent;
  border-right: 4px solid rgba(0, 0, 0, 0.55);
}
.gemini_root .gemini_va_mock_threads_tag {
  position: absolute;
  top: 8px;
  right: 8px;
  padding: 2px 8px;
  border-radius: 9999px;
  background: linear-gradient(135deg, #facc15, #f59e0b);
  color: #422006;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 1px;
  box-shadow: 0 4px 12px rgba(250, 204, 21, 0.6);
  animation: gemini_va_funnel_tag_in 3s ease-in-out infinite;
}
@keyframes gemini_va_funnel_threads_hot {
  0%, 100% { box-shadow: inset 0 0 0 0 rgba(250, 204, 21, 0); }
  50%      { box-shadow: inset 0 0 0 1.5px rgba(250, 204, 21, 0.5); }
}
@keyframes gemini_va_funnel_tag_in {
  0%, 30% { opacity: 0; transform: scale(0.6); }
  40%, 90% { opacity: 1; transform: scale(1); }
  100% { opacity: 0.7; }
}

/* ============ Mockup: Radar (Patrol — legacy, kept) ============ */
.gemini_root .gemini_va_mock_radar {
  position: relative;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(250, 204, 21, 0.08) 0%, transparent 70%),
    repeating-radial-gradient(circle, transparent 0, transparent 18px, rgba(250, 204, 21, 0.12) 18px, rgba(250, 204, 21, 0.12) 19px);
  border: 1px solid rgba(250, 204, 21, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.gemini_root .gemini_va_mock_radar::before,
.gemini_root .gemini_va_mock_radar::after {
  content: "";
  position: absolute;
  background: rgba(250, 204, 21, 0.25);
}
.gemini_root .gemini_va_mock_radar::before { top: 50%; left: 0; right: 0; height: 1px; }
.gemini_root .gemini_va_mock_radar::after { top: 0; bottom: 0; left: 50%; width: 1px; }
.gemini_root .gemini_va_mock_radar_ring {
  position: absolute;
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 2px solid rgba(250, 204, 21, 0.85);
  box-shadow: 0 0 20px rgba(250, 204, 21, 0.5),
              inset 0 0 12px rgba(250, 204, 21, 0.3);
  animation: gemini_va_funnel_radar 2.4s ease-out infinite;
}
.gemini_root .gemini_va_mock_radar_ring_2 { animation-delay: 0.8s; }
.gemini_root .gemini_va_mock_radar_ring_3 { animation-delay: 1.6s; }
.gemini_root .gemini_va_mock_radar_dot {
  position: relative;
  z-index: 2;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #fffbeb, #facc15 50%, #a16207 100%);
  box-shadow: 0 0 30px rgba(250, 204, 21, 0.95),
              0 0 0 4px rgba(250, 204, 21, 0.18);
}
.gemini_root .gemini_va_mock_radar_sweep {
  position: absolute;
  top: 0; left: 50%;
  width: 50%; height: 100%;
  background: conic-gradient(from 0deg at 0% 50%,
    transparent 0deg,
    rgba(250, 204, 21, 0.35) 30deg,
    transparent 60deg);
  transform-origin: 0 50%;
  animation: gemini_va_funnel_sweep 3.6s linear infinite;
  pointer-events: none;
}
.gemini_root .gemini_va_mock_radar_blip {
  position: absolute;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #fde047;
  box-shadow: 0 0 10px rgba(253, 224, 71, 0.9);
  z-index: 2;
  opacity: 0;
}
.gemini_root .gemini_va_mock_radar_blip_1 { top: 28%; left: 22%; animation: gemini_va_funnel_blip 3.6s ease-out 0.4s infinite; }
.gemini_root .gemini_va_mock_radar_blip_2 { top: 65%; left: 70%; animation: gemini_va_funnel_blip 3.6s ease-out 1.6s infinite; }
.gemini_root .gemini_va_mock_radar_blip_3 { top: 78%; left: 32%; animation: gemini_va_funnel_blip 3.6s ease-out 2.6s infinite; }
@keyframes gemini_va_funnel_sweep {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@keyframes gemini_va_funnel_blip {
  0%, 100% { opacity: 0; transform: scale(0.6); }
  10%      { opacity: 1; transform: scale(1.4); }
  40%      { opacity: 1; transform: scale(1); }
  70%      { opacity: 0.4; }
}

/* ============ Mockup: Send Bubbles (Outreach) ============ */
.gemini_root .gemini_va_mock_send {
  position: relative;
  width: 180px;
  height: 180px;
}
.gemini_root .gemini_va_mock_send::before {
  content: "";
  position: absolute;
  top: 50%; right: -10%;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, #fb923c, #f97316);
  transform: translateY(-50%);
  box-shadow: 0 0 30px rgba(251, 146, 60, 0.6);
}
.gemini_root .gemini_va_mock_send::after {
  content: "→";
  position: absolute;
  top: 50%; right: -2%;
  width: 36px;
  font-size: 18px;
  color: #fff;
  font-weight: 900;
  text-align: center;
  transform: translate(50%, -50%);
  z-index: 2;
}
.gemini_root .gemini_va_mock_send_bubble {
  position: absolute;
  width: 100px;
  height: 30px;
  padding-left: 12px;
  display: flex;
  align-items: center;
  border-radius: 18px 18px 18px 4px;
  background: linear-gradient(135deg, rgba(251, 146, 60, 0.9), rgba(194, 65, 12, 0.85));
  border: 1px solid rgba(251, 146, 60, 0.4);
  box-shadow: 0 4px 16px rgba(251, 146, 60, 0.25);
  animation: gemini_va_funnel_send 3.6s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_send_bubble::before {
  content: "";
  width: 16px; height: 16px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
  flex-shrink: 0;
}
.gemini_root .gemini_va_mock_send_bubble::after {
  content: "";
  flex: 1;
  height: 4px;
  margin: 0 10px 0 6px;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0.2));
}
.gemini_root .gemini_va_mock_send_bubble:nth-child(1) { top: 12%; left: 0; }
.gemini_root .gemini_va_mock_send_bubble_2 { top: 42%; left: 8px; animation-delay: 1.2s; }
.gemini_root .gemini_va_mock_send_bubble_3 { top: 72%; left: 0; animation-delay: 2.4s; }

/* Recipient targets (right side) */
.gemini_root .gemini_va_mock_send_target {
  position: absolute;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.06));
  border: 1px solid rgba(255, 255, 255, 0.2);
  z-index: 1;
}
.gemini_root .gemini_va_mock_send_target::after {
  content: "✓";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: #4ade80;
  font-weight: 900;
  opacity: 0;
  animation: gemini_va_funnel_check 3.6s ease-out infinite;
}
.gemini_root .gemini_va_mock_send_target_1 { top: 16%; right: 6%; }
.gemini_root .gemini_va_mock_send_target_1::after { animation-delay: 1s; }
.gemini_root .gemini_va_mock_send_target_2 { top: 46%; right: 0; }
.gemini_root .gemini_va_mock_send_target_2::after { animation-delay: 2.2s; }
.gemini_root .gemini_va_mock_send_target_3 { top: 76%; right: 6%; }
.gemini_root .gemini_va_mock_send_target_3::after { animation-delay: 3.4s; }
@keyframes gemini_va_funnel_check {
  0%, 65% { opacity: 0; transform: scale(0.6); }
  75%, 100% { opacity: 1; transform: scale(1); }
}

/* ============ Mockup: Post → DM (STEP 03) ============ */
.gemini_root .gemini_va_mock_post2dm {
  position: relative;
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: -apple-system, BlinkMacSystemFont, "PingFang TC", sans-serif;
}
/* Public post card */
.gemini_root .gemini_va_mock_post {
  width: 200px;
  background: #fff;
  border-radius: 12px;
  padding: 12px;
  box-shadow: 0 12px 32px rgba(91, 134, 239, 0.2),
              0 0 0 1px rgba(0, 0, 0, 0.06);
  animation: gemini_va_funnel_float 5s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_post_head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.gemini_root .gemini_va_mock_post_avatar {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ef4444 0%, #facc15 100%);
}
.gemini_root .gemini_va_mock_post_meta {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.gemini_root .gemini_va_mock_post_meta strong {
  font-size: 11px;
  font-weight: 700;
  color: #0c0c10;
}
.gemini_root .gemini_va_mock_post_meta span {
  font-size: 9px;
  color: rgba(0, 0, 0, 0.45);
}
.gemini_root .gemini_va_mock_post_text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 10px;
}
.gemini_root .gemini_va_mock_post_text > div {
  height: 5px;
  border-radius: 3px;
  background: rgba(0, 0, 0, 0.16);
}
.gemini_root .gemini_va_mock_post_text > div:first-child { width: 100%; }
.gemini_root .gemini_va_mock_post_text > div:last-child { width: 65%; }
/* Highlighted comment */
.gemini_root .gemini_va_mock_post_comment {
  position: relative;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(250, 204, 21, 0.18), rgba(250, 204, 21, 0.06));
  border: 1px solid rgba(250, 204, 21, 0.4);
  animation: gemini_va_funnel_post_hl 3s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_post_comment_avatar {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: linear-gradient(135deg, #5b86ef, #3b82f6);
  flex-shrink: 0;
}
.gemini_root .gemini_va_mock_post_comment_body {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
  min-width: 0;
}
.gemini_root .gemini_va_mock_post_comment_body strong {
  font-size: 9px;
  font-weight: 700;
  color: #0c0c10;
}
.gemini_root .gemini_va_mock_post_comment_body span {
  font-size: 9px;
  color: rgba(0, 0, 0, 0.7);
}
.gemini_root .gemini_va_mock_post_trigger {
  position: absolute;
  top: -8px;
  right: -6px;
  padding: 2px 8px;
  border-radius: 9999px;
  background: linear-gradient(135deg, #facc15, #f59e0b);
  color: #422006;
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 1px;
  box-shadow: 0 4px 10px rgba(250, 204, 21, 0.5);
  animation: gemini_va_funnel_tag_in 3s ease-in-out infinite;
}
/* Connector arrow with label */
.gemini_root .gemini_va_mock_p2d_arrow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.gemini_root .gemini_va_mock_p2d_arrow span {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1px;
  color: var(--gem-cyan);
  white-space: nowrap;
}
.gemini_root .gemini_va_mock_p2d_line {
  position: relative;
  width: 36px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gem-cyan), var(--gem-cyan));
  border-radius: 2px;
}
.gemini_root .gemini_va_mock_p2d_line::after {
  content: "";
  position: absolute;
  right: -4px;
  top: 50%;
  width: 8px; height: 8px;
  border-top: 2px solid var(--gem-cyan);
  border-right: 2px solid var(--gem-cyan);
  transform: translateY(-50%) rotate(45deg);
  animation: gemini_va_funnel_p2d_arrow 1.6s ease-in-out infinite;
}
/* DM card */
.gemini_root .gemini_va_mock_dmcard {
  width: 180px;
  background: #fff;
  border-radius: 12px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: 0 12px 32px rgba(91, 134, 239, 0.25),
              0 0 0 1px rgba(0, 0, 0, 0.06);
  animation: gemini_va_funnel_dmcard_in 4s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_dmcard_head {
  display: flex;
  align-items: center;
  gap: 6px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.gemini_root .gemini_va_mock_dmcard_avatar {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ef4444 0%, #facc15 100%);
}
.gemini_root .gemini_va_mock_dmcard_head strong {
  font-size: 10px;
  font-weight: 700;
  color: #0c0c10;
}
.gemini_root .gemini_va_mock_dmcard_msg {
  padding: 7px 10px;
  border-radius: 12px 12px 12px 4px;
  background: #5b86ef;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.4;
  align-self: flex-start;
  max-width: 90%;
}
.gemini_root .gemini_va_mock_dmcard_msg:nth-of-type(2) {
  animation-delay: 0.4s;
}
@keyframes gemini_va_funnel_post_hl {
  0%, 100% { box-shadow: 0 0 0 0 rgba(250, 204, 21, 0); }
  50%      { box-shadow: 0 0 0 4px rgba(250, 204, 21, 0.25); }
}
@keyframes gemini_va_funnel_p2d_arrow {
  0%, 100% { transform: translateY(-50%) rotate(45deg) translateX(0); opacity: 0.5; }
  50%      { transform: translateY(-50%) rotate(45deg) translateX(3px); opacity: 1; }
}
@keyframes gemini_va_funnel_dmcard_in {
  0%, 30% { opacity: 0.5; transform: translateY(8px) scale(0.94); }
  50%, 90% { opacity: 1; transform: translateY(0) scale(1); }
  100% { opacity: 0.5; transform: translateY(-4px) scale(1); }
}

/* ============ Mockup: Funnel Chats (DM — legacy, kept) ============ */
.gemini_root .gemini_va_mock_funnel {
  position: relative;
  width: 280px;
  height: 200px;
}
.gemini_root .gemini_va_mock_funnel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 80% at 50% 100%, rgba(74, 222, 128, 0.18), transparent 70%);
  pointer-events: none;
}
.gemini_root .gemini_va_mock_funnel_cone {
  position: absolute;
  top: 30px;
  left: 50%;
  transform: translateX(-50%);
  width: 220px;
  height: 130px;
  background: linear-gradient(180deg,
    rgba(74, 222, 128, 0.04) 0%,
    rgba(74, 222, 128, 0.18) 100%);
  border: 1px solid rgba(74, 222, 128, 0.18);
  clip-path: polygon(0 0, 100% 0, 70% 100%, 30% 100%);
  pointer-events: none;
  z-index: 0;
}
.gemini_root .gemini_va_mock_lead {
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 9999px;
  background: linear-gradient(135deg, #4ade80, #22c55e);
  color: #052e16;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 1px;
  box-shadow: 0 8px 24px rgba(74, 222, 128, 0.5);
  animation: gemini_va_funnel_lead_in 4s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_lead_check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: #052e16;
  color: #4ade80;
  font-size: 11px;
}
@keyframes gemini_va_funnel_lead_in {
  0%, 60% { opacity: 0; transform: translate(-50%, 12px) scale(0.8); }
  75%, 95% { opacity: 1; transform: translate(-50%, 0) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -8px) scale(1); }
}
.gemini_root .gemini_va_mock_chat {
  position: absolute;
  height: 32px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
  animation: gemini_va_funnel_chat_in 4s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_chat::before {
  content: "";
  width: 18px; height: 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4ade80, #22c55e);
  margin-right: 8px;
  flex-shrink: 0;
}
.gemini_root .gemini_va_mock_chat_1 {
  top: 0; left: 0; width: 200px;
  border-radius: 16px 16px 16px 4px;
  background: rgba(255, 255, 255, 0.06);
}
.gemini_root .gemini_va_mock_chat_1::after {
  content: "想了解課程";
  font-weight: 600;
}
.gemini_root .gemini_va_mock_chat_2 {
  top: 50px; right: 0; width: 160px;
  border-radius: 16px 16px 4px 16px;
  background: linear-gradient(135deg, rgba(74, 222, 128, 0.4), rgba(34, 197, 94, 0.25));
  animation-delay: 0.8s;
  flex-direction: row-reverse;
}
.gemini_root .gemini_va_mock_chat_2::before {
  background: linear-gradient(135deg, #facc15, #f59e0b);
  margin: 0 0 0 8px;
}
.gemini_root .gemini_va_mock_chat_2::after {
  content: "馬上幫您安排";
  font-weight: 600;
  margin-right: auto;
}
.gemini_root .gemini_va_mock_chat_3 {
  top: 100px; left: 0; width: 180px;
  border-radius: 16px 16px 16px 4px;
  background: rgba(255, 255, 255, 0.06);
  animation-delay: 1.6s;
}
.gemini_root .gemini_va_mock_chat_3::after {
  content: "好，謝謝您 ✓";
  font-weight: 600;
}
.gemini_root .gemini_va_mock_typing {
  position: absolute;
  bottom: 12px; right: 20px;
  display: flex; gap: 4px;
  padding: 8px 14px;
  border-radius: 9999px;
  background: linear-gradient(135deg, rgba(74, 222, 128, 0.6), rgba(34, 197, 94, 0.4));
  border: 1px solid rgba(74, 222, 128, 0.4);
  box-shadow: 0 4px 16px rgba(74, 222, 128, 0.3);
}
.gemini_root .gemini_va_mock_typing span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #fff;
  animation: gemini_va_funnel_typing 1.2s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_typing span:nth-child(2) { animation-delay: 0.2s; }
.gemini_root .gemini_va_mock_typing span:nth-child(3) { animation-delay: 0.4s; }

/* ============ Mockup: Site (Final — same browser as STEP 01 + click success) ============ */
.gemini_root .gemini_va_mock_browser_site {
  box-shadow: 0 16px 48px rgba(250, 204, 21, 0.25),
              0 0 0 1px rgba(0, 0, 0, 0.06);
}
/* Override CTA to read 立即預約 in yellow with ripple */
.gemini_root .gemini_va_mock_btn_book {
  position: relative;
  animation: gemini_va_funnel_book_btn 4s ease-in-out infinite;
}
/* Cursor that moves to button + clicks */
.gemini_root .gemini_va_mock_browser_cursor_book {
  bottom: 12px;
  right: 30%;
  animation: gemini_va_funnel_book_cursor 4s ease-in-out infinite;
}
/* Click ripple at button position */
.gemini_root .gemini_va_mock_browser_ripple {
  position: absolute;
  bottom: 36px;
  left: 50%;
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 2px solid #facc15;
  transform: translateX(-50%);
  opacity: 0;
  animation: gemini_va_funnel_book_ripple 4s ease-out infinite;
  pointer-events: none;
  z-index: 4;
}
/* Success toast */
.gemini_root .gemini_va_mock_browser_toast {
  position: absolute;
  top: 50%;
  left: 50%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 12px;
  background: linear-gradient(135deg, #5b86ef, #3b82f6);
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 1px;
  white-space: nowrap;
  box-shadow: 0 12px 32px rgba(91, 134, 239, 0.5);
  opacity: 0;
  z-index: 5;
  animation: gemini_va_funnel_book_toast 4s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_browser_toast_check {
  position: relative;
  display: inline-block;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #fff;
}
.gemini_root .gemini_va_mock_browser_toast_check::before {
  content: "";
  position: absolute;
  top: 5px; left: 4px;
  width: 4px; height: 8px;
  border-right: 2px solid #5b86ef;
  border-bottom: 2px solid #5b86ef;
  transform: rotate(45deg);
}
@keyframes gemini_va_funnel_book_btn {
  0%, 60%, 100% { transform: scale(1); box-shadow: 0 6px 18px rgba(250, 204, 21, 0.5); }
  65%, 70%      { transform: scale(0.93); box-shadow: 0 4px 12px rgba(250, 204, 21, 0.3); }
  80%           { transform: scale(1); box-shadow: 0 6px 18px rgba(250, 204, 21, 0.5); }
}
@keyframes gemini_va_funnel_book_cursor {
  0%       { transform: rotate(-18deg) translate(40px, 40px); opacity: 0.6; }
  35%      { transform: rotate(-18deg) translate(0, 0); opacity: 1; }
  50%      { transform: rotate(-18deg) translate(0, 0) scale(0.85); opacity: 1; }
  60%      { transform: rotate(-18deg) translate(0, 0) scale(1); opacity: 1; }
  85%, 100% { transform: rotate(-18deg) translate(0, 0); opacity: 0; }
}
@keyframes gemini_va_funnel_book_ripple {
  0%, 50%  { opacity: 0; transform: translateX(-50%) scale(0.4); }
  60%      { opacity: 1; transform: translateX(-50%) scale(1); }
  80%      { opacity: 0; transform: translateX(-50%) scale(2.8); }
  100%     { opacity: 0; }
}
@keyframes gemini_va_funnel_book_toast {
  0%, 60%   { opacity: 0; transform: translate(-50%, -30%) scale(0.8); }
  72%, 92%  { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  100%      { opacity: 0; transform: translate(-50%, -65%) scale(1); }
}

/* ============ Legacy Site mockup (kept for fallback) ============ */
.gemini_root .gemini_va_mock_site {
  position: relative;
  width: 280px;
  height: 200px;
  border-radius: 14px;
  background:
    radial-gradient(80% 80% at 50% 0%, rgba(253, 224, 71, 0.16), transparent 70%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
  border: 1px solid rgba(253, 224, 71, 0.35);
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(253, 224, 71, 0.25),
              inset 0 1px 0 rgba(255, 255, 255, 0.08);
  animation: gemini_va_funnel_float 5s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_site::before {
  content: "★ ★ ★ ★ ★";
  position: absolute;
  top: 12px; left: 16px;
  font-size: 11px;
  letter-spacing: 2px;
  color: #fde047;
  text-shadow: 0 0 8px rgba(253, 224, 71, 0.6);
}
.gemini_root .gemini_va_mock_site::after {
  content: "5.0 · 32 則評價";
  position: absolute;
  top: 14px; right: 16px;
  font-size: 9px;
  color: rgba(255, 255, 255, 0.5);
}
.gemini_root .gemini_va_mock_site_hero {
  position: absolute;
  top: 36px; left: 16px; right: 16px;
  height: 70px;
  border-radius: 10px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.2), transparent 60%),
    linear-gradient(135deg, #fde047 0%, #f59e0b 60%, #b45309 100%);
  box-shadow: 0 8px 24px rgba(253, 224, 71, 0.3);
}
.gemini_root .gemini_va_mock_site_hero::after {
  content: "Pro Plan · 客製方案";
  position: absolute;
  bottom: 8px; left: 12px;
  font-size: 10px;
  font-weight: 700;
  color: rgba(0, 0, 0, 0.7);
}
.gemini_root .gemini_va_mock_site_cta {
  position: absolute;
  bottom: 24px; left: 50%;
  transform: translateX(-50%);
  padding: 11px 28px;
  border-radius: 9999px;
  background: linear-gradient(135deg, #fde047, #f59e0b);
  color: #0c0c10;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 1px;
  box-shadow: 0 6px 28px rgba(253, 224, 71, 0.6),
              inset 0 1px 0 rgba(255, 255, 255, 0.4);
  animation: gemini_va_funnel_cta 2s ease-in-out infinite;
}
.gemini_root .gemini_va_mock_site_cursor {
  position: absolute;
  bottom: 8px;
  right: 30%;
  width: 0; height: 0;
  border-left: 12px solid #fff;
  border-top: 6px solid transparent;
  border-bottom: 18px solid transparent;
  transform: rotate(-18deg);
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.5));
  animation: gemini_va_funnel_cursor 4s ease-in-out infinite;
  z-index: 3;
}
.gemini_root .gemini_va_mock_site_ripple {
  position: absolute;
  bottom: 24px; left: 50%;
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 2px solid #fde047;
  transform: translateX(-50%);
  opacity: 0;
  animation: gemini_va_funnel_site_ripple 4s ease-out infinite;
  pointer-events: none;
}
.gemini_root .gemini_va_mock_site_toast {
  position: absolute;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.8);
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 12px;
  background: linear-gradient(135deg, #4ade80, #22c55e);
  color: #052e16;
  font-size: 13px;
  font-weight: 900;
  box-shadow: 0 12px 32px rgba(74, 222, 128, 0.5);
  opacity: 0;
  animation: gemini_va_funnel_toast 4s ease-in-out infinite;
  z-index: 4;
  white-space: nowrap;
}
.gemini_root .gemini_va_mock_site_toast span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #052e16;
  color: #4ade80;
}
@keyframes gemini_va_funnel_site_ripple {
  0%, 50% { opacity: 0; transform: translateX(-50%) scale(0.4); }
  60%     { opacity: 1; transform: translateX(-50%) scale(1); }
  80%     { opacity: 0; transform: translateX(-50%) scale(2.6); }
  100%    { opacity: 0; }
}
@keyframes gemini_va_funnel_toast {
  0%, 60% { opacity: 0; transform: translate(-50%, -50%) scale(0.8); }
  75%, 90% { opacity: 1; transform: translate(-50%, -65%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -75%) scale(1); }
}

/* ============ Keyframes ============ */
@keyframes gemini_va_funnel_in {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes gemini_va_funnel_float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
@keyframes gemini_va_funnel_radar {
  0%   { transform: translate(-50%, -50%) scale(0.5); opacity: 1; }
  100% { transform: translate(-50%, -50%) scale(2.4); opacity: 0; }
}
@keyframes gemini_va_funnel_pulse_arrow {
  0%, 100% { transform: translateX(-50%) rotate(45deg) translateY(0); opacity: 0.5; }
  50%      { transform: translateX(-50%) rotate(45deg) translateY(4px); opacity: 1; }
}
@keyframes gemini_va_funnel_stack {
  0%, 100% { transform: rotate(4deg) translateY(0); }
  50%      { transform: rotate(4deg) translateY(-4px); }
}
@keyframes gemini_va_funnel_send {
  0%   { opacity: 0; transform: translateX(-20px); }
  20%  { opacity: 1; }
  60%  { opacity: 1; transform: translateX(40px); }
  100% { opacity: 0; transform: translateX(60px); }
}
@keyframes gemini_va_funnel_chat_in {
  0%, 100% { opacity: 0.3; transform: scale(0.95); }
  20%, 80% { opacity: 1; transform: scale(1); }
}
@keyframes gemini_va_funnel_typing {
  0%, 60%, 100% { opacity: 0.3; transform: translateY(0); }
  30%           { opacity: 1; transform: translateY(-3px); }
}
@keyframes gemini_va_funnel_cta {
  0%, 100% { transform: translateX(-50%) scale(1); box-shadow: 0 4px 20px rgba(253, 224, 71, 0.4); }
  50%      { transform: translateX(-50%) scale(1.05); box-shadow: 0 6px 30px rgba(253, 224, 71, 0.7); }
}
@keyframes gemini_va_funnel_cursor {
  0%       { transform: rotate(-18deg) translate(40px, 30px); opacity: 0.6; }
  35%      { transform: rotate(-18deg) translate(0, 0); opacity: 1; }
  50%      { transform: rotate(-18deg) translate(0, 0) scale(0.85); }
  60%      { transform: rotate(-18deg) translate(0, 0) scale(1); }
  80%      { transform: rotate(-18deg) translate(0, 0); opacity: 1; }
  100%     { transform: rotate(-18deg) translate(40px, 30px); opacity: 0.6; }
}

/* ============ Responsive ============ */
@media (min-width: 768px) {
  .gemini_root .gemini_va_funnel_stages {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .gemini_root .gemini_va_funnel_full,
  .gemini_root .gemini_va_funnel_arrow {
    grid-column: span 3;
  }
  .gemini_root .gemini_va_funnel_full {
    flex-direction: row;
    align-items: center;
    gap: 32px;
    padding: 32px;
  }
  .gemini_root .gemini_va_funnel_full .gemini_va_funnel_text {
    flex: 1;
  }
  .gemini_root .gemini_va_funnel_full .gemini_va_funnel_visual {
    flex: 1;
    height: 200px;
  }
  .gemini_root .gemini_va_funnel_title { font-size: 26px; }
}


