/* =============================================================================
   redesign.css — UI/UX Pro Max design pass (additive override layer)
   Loaded AFTER styles.css so it wins on equal specificity.
   Scope: marketing homepage (#homepageContent) + global a11y/typography.
   The chat viewer (#mainContainer / .wc-*) is intentionally LEFT on its
   WhatsApp-authentic styling and only inherits the global focus ring.
   Design system source: ui-ux-pro-max "VPN & Privacy Tool" palette
     - Style: Micro-interactions  - Pattern: Minimal single column
     - Palette: ONE emerald brand accent + navy/slate structure + slate neutrals
       ("shield dark + connected green" — disciplined, professional, no purple)
     - Type: Plus Jakarta Sans (headings) + Inter (body)
   ============================================================================= */

/* ---- Design tokens ---------------------------------------------------------- */
:root {
  /* Brand accent — emerald "connected green" (the single brand colour) */
  --rd-green:       #10b981;
  --rd-green-dark:  #059669;
  --rd-green-soft:  #d1fae5;
  /* Structure — navy / slate (dark bands, depth) */
  --rd-navy:        #1e293b;   /* slate-800 */
  --rd-navy-deep:   #0f172a;   /* slate-900 */
  --rd-navy-accent: #1e3a5f;   /* deep professional navy */
  --rd-navy-soft:   #eef2f7;   /* light slate tint */
  /* Neutrals (slate) */
  --rd-fg:          #0f172a;
  --rd-fg-soft:     #475569;
  --rd-fg-mute:     #64748b;
  --rd-bg:          #ffffff;
  --rd-surface:     #ffffff;
  --rd-muted:       #f1f5f9;
  --rd-border:      #e2e8f0;
  /* Effects */
  --rd-radius:      14px;
  --rd-radius-lg:   22px;
  --rd-shadow-sm:   0 1px 2px rgba(15,23,42,.06), 0 1px 3px rgba(15,23,42,.08);
  --rd-shadow-md:   0 4px 12px rgba(15,23,42,.08), 0 2px 4px rgba(15,23,42,.05);
  --rd-shadow-lg:   0 18px 40px -12px rgba(15,23,42,.20), 0 8px 16px -8px rgba(15,23,42,.12);
  --rd-shadow-glow: 0 14px 32px -10px rgba(16,185,129,.45);
  --rd-grad-brand:  linear-gradient(135deg, #0d9488 0%, #10b981 100%); /* teal→emerald */
  --rd-grad-cta:    linear-gradient(135deg, var(--rd-green) 0%, var(--rd-green-dark) 100%);
  --rd-ease:        cubic-bezier(.22,.61,.36,1);
}

/* ---- Typography ------------------------------------------------------------- */
body {
  font-family: "Inter", "Segoe UI", -apple-system, BlinkMacSystemFont, Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
#homepageContent h1, #homepageContent h2, #homepageContent h3,
.hero-title, .promo-title, .features-title, .section-title, .step-title,
.feature-title, .bottom-cta h2, .desktop-text h2 {
  font-family: "Plus Jakarta Sans", "Segoe UI", -apple-system, sans-serif;
  letter-spacing: -0.02em;
}
/* Preserve the chat viewer's WhatsApp-authentic system font */
#mainContainer, #mainContainer * {
  font-family: "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

/* ---- Accessibility: visible keyboard focus (was missing site-wide) ---------- */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
label.upload-btn:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid var(--rd-navy-accent);
  outline-offset: 2px;
  border-radius: 6px;
}
/* don't show focus ring for mouse users that don't need it */
:focus:not(:focus-visible) { outline: none; }

/* =============================================================================
   MARKETING HOMEPAGE
   ============================================================================= */

/* ---- Buttons ---------------------------------------------------------------- */
#homepageContent .btn-primary,
.site-header .btn-primary,
.sh-cta {
  background: var(--rd-grad-cta);
  color: #fff;
  border: none;
  border-radius: 999px;
  font-weight: 600;
  box-shadow: var(--rd-shadow-sm);
  transition: transform .18s var(--rd-ease), box-shadow .18s var(--rd-ease), filter .18s var(--rd-ease);
}
#homepageContent .btn-primary:hover,
.site-header .btn-primary:hover,
.sh-cta:hover {
  transform: translateY(-2px);
  box-shadow: var(--rd-shadow-glow);
  filter: saturate(1.05);
}
#homepageContent .btn-primary:active,
.sh-cta:active { transform: translateY(0) scale(.98); }

.btn-lg { padding: 15px 30px; font-size: 1.05rem; }

/* ---- Header ----------------------------------------------------------------- */
.site-header {
  background: rgba(255,255,255,.82);
  backdrop-filter: saturate(1.4) blur(14px);
  -webkit-backdrop-filter: saturate(1.4) blur(14px);
  border-bottom: 1px solid var(--rd-border);
}
.sh-logo span { font-family: "Outfit", sans-serif; font-weight: 700; color: var(--rd-fg); letter-spacing: -.01em; }
.sh-nav a { color: var(--rd-fg-soft); font-weight: 500; transition: color .15s var(--rd-ease); }
.sh-nav a:hover, .sh-nav a.selected { color: var(--rd-green-dark); }

/* ---- Hero ------------------------------------------------------------------- */
/* Refined deep-emerald brand hero (less neon than before), white-on-green AA. */
#heroSection.hero-section {
  background: linear-gradient(135deg, #064e3b 0%, #047857 48%, #059669 100%);
  position: relative;
}
.hero-eyebrow {
  display: inline-flex; align-items: center;
  background: rgba(255,255,255,.94);
  color: var(--rd-green-dark);
  font-weight: 600; letter-spacing: .04em;
  border: 1px solid rgba(255,255,255,.6);
  border-radius: 999px; padding: 6px 14px;
}
.hero-title { color: #ffffff; line-height: 1.08; font-weight: 700; }
.hero-desc  { color: rgba(255,255,255,.92); line-height: 1.65; }

/* Hero floating blobs — soft light accents over the green (no purple) */
.blob { filter: blur(70px); opacity: .30; }
.blob-1 { background: radial-gradient(circle, #34d399 0%, transparent 70%); }
.blob-2 { background: radial-gradient(circle, #ffffff 0%, transparent 70%); }

/* Upload card sits on the green hero → white card with dark, readable contents */
.upload-zone-label { color: var(--rd-fg); font-weight: 600; }
.upload-zone-or    { color: var(--rd-fg-mute); }
.upload-meta-item  { color: var(--rd-fg-soft); }
.upload-meta-item svg { color: var(--rd-green-dark); }

/* Upload drop zone — the primary action surface */
.upload-zone-card {
  background: var(--rd-surface);
  border: 2px dashed var(--rd-border);
  border-radius: var(--rd-radius-lg);
  box-shadow: var(--rd-shadow-md);
  transition: border-color .2s var(--rd-ease), box-shadow .2s var(--rd-ease), transform .2s var(--rd-ease);
}
.upload-zone-card:hover,
.upload-zone.dragover .upload-zone-card,
.upload-zone-card.dragover {
  border-color: var(--rd-green);
  box-shadow: var(--rd-shadow-lg);
  transform: translateY(-3px);
}
.upload-zone-icon {
  background: var(--rd-grad-brand);
  color: #fff;
  border-radius: 16px;
  box-shadow: var(--rd-shadow-glow);
}
/* Primary action: solid emerald CTA with white label (overrides the original
   white-button + green-text rule that used !important). */
#uploadDropZone .upload-btn,
.upload-zone-card .upload-btn {
  background: var(--rd-grad-cta) !important;
  color: #ffffff !important;
  border: none;
  border-radius: 999px;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  box-shadow: var(--rd-shadow-sm);
  transition: transform .18s var(--rd-ease), box-shadow .18s var(--rd-ease), filter .18s var(--rd-ease);
}
#uploadDropZone .upload-btn:hover,
.upload-zone-card .upload-btn:hover {
  background: var(--rd-grad-cta) !important;
  transform: translateY(-2px);
  box-shadow: var(--rd-shadow-glow);
  filter: saturate(1.05);
}

.hero-trust-bar { color: rgba(255,255,255,.9); font-weight: 500; }
.hero-trust-bar span,
.upload-meta-item { display: inline-flex; align-items: center; gap: 6px; }
.hero-trust-bar span svg { color: rgba(255,255,255,.95); }
.hero-tutorial-link { color: #ffffff; font-weight: 600; opacity: .95; }
.hero-tutorial-link:hover { opacity: 1; }

/* ---- Feature cards ---------------------------------------------------------- */
/* The original .features-grid never declared display:grid, so all 5 cards
   stacked full-width. Make it a real responsive grid. */
.features-section .features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (max-width: 880px) {
  .features-section .features-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .features-section .features-grid { grid-template-columns: 1fr; }
}

/* Airy white background with soft dual-color glows for depth (replaces the
   flat grey tint). */
.features-section {
  background:
    radial-gradient(680px 300px at 6% 2%,  rgba(13,148,136,.10) 0%, transparent 60%),
    radial-gradient(680px 300px at 94% 8%, rgba(16,185,129,.10) 0%, transparent 60%),
    #f8fafc !important;
  padding: 90px 0 !important;
}
.features-title { font-size: clamp(1.6rem, 2.6vw, 2.1rem); margin-bottom: 10px; }
.features-description, .section-subtitle { color: var(--rd-fg-soft); }
.features-title, .section-title { color: var(--rd-fg); }

/* Left-aligned cards with a reveal-on-hover gradient accent bar + vibrant
   gradient icon tiles (override the original !important rules). */
.features-section .feature-card {
  position: relative;
  overflow: hidden;
  text-align: left !important;
  background: #ffffff !important;
  border: 1px solid var(--rd-border) !important;
  border-top: 1px solid var(--rd-border) !important;
  border-radius: 18px !important;
  padding: 32px 28px !important;
  box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 10px 26px -14px rgba(15,23,42,.16) !important;
  transition: transform .22s var(--rd-ease), box-shadow .22s var(--rd-ease), border-color .22s var(--rd-ease) !important;
}
.features-section .feature-card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--rd-grad-brand);
  transform: scaleX(0); transform-origin: left;
  transition: transform .28s var(--rd-ease);
}
.features-section .feature-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 22px 48px -18px rgba(5,150,105,.30) !important;
  border-color: rgba(16,185,129,.32) !important;
  border-top-color: transparent !important;
}
.features-section .feature-card:hover::before { transform: scaleX(1); }
.features-section .feature-icon-wrap {
  width: 54px; height: 54px;
  margin: 0 0 18px;
  background: var(--rd-grad-brand);
  color: #ffffff;
  border-radius: 15px;
  box-shadow: 0 8px 18px -8px rgba(5,150,105,.55);
  transition: transform .22s var(--rd-ease);
}
.features-section .feature-card:hover .feature-icon-wrap { transform: scale(1.06) rotate(-2deg); }
.feature-icon { stroke: currentColor; }
.features-section .feature-title { color: var(--rd-fg); font-size: 1.16rem; margin-bottom: 8px; }
.features-section .feature-description { color: var(--rd-fg-soft); line-height: 1.6; font-size: .96rem; }

/* ---- Steps ------------------------------------------------------------------ */
.step-card {
  background: var(--rd-surface);
  border: 1px solid var(--rd-border);
  border-radius: var(--rd-radius);
  box-shadow: var(--rd-shadow-sm);
  transition: transform .2s var(--rd-ease), box-shadow .2s var(--rd-ease);
}
.step-card:hover { transform: translateY(-4px); box-shadow: var(--rd-shadow-lg); }
.step-number-badge {
  background: var(--rd-grad-cta);
  color: #fff;
  box-shadow: var(--rd-shadow-glow);
}

/* ---- Promo banner — rich, high-contrast premium band ------------------------ */
.promo-banner {
  background:
    radial-gradient(820px 420px at 100% 110%, rgba(16,185,129,.22) 0%, transparent 55%),
    linear-gradient(135deg, #0f172a 0%, #1e293b 55%, #1e3a5f 100%) !important;
  position: relative;
}
/* crisp boundary so it never blends into the green hero above */
.promo-banner::after {
  content: ""; position: absolute; left: 0; right: 0; top: 0; height: 1px;
  background: rgba(255,255,255,.18);
}
.promo-banner .promo-eyebrow {
  display: inline-flex; align-items: center;
  background: rgba(255,255,255,.16);
  color: #ffffff;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 999px; padding: 6px 14px; font-weight: 600; letter-spacing: .04em;
}
.promo-banner .promo-title { color: #ffffff; }
.promo-banner .promo-features li { color: rgba(255,255,255,.92); }
/* Green-filled check markers — the brand accent popping on the navy band */
.promo-banner .promo-features li::before {
  background-color: #10b981;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 12px; background-repeat: no-repeat; background-position: center;
  box-shadow: 0 2px 8px -2px rgba(16,185,129,.7);
}
/* Free callout → bold solid badge that pops on the dark green */
.promo-banner .promo-free-callout {
  background: #ffffff !important;
  border: none !important;
  color: var(--rd-fg) !important;
  border-radius: 12px;
  box-shadow: 0 10px 24px -10px rgba(0,0,0,.45) !important;
}
.promo-banner .promo-free-callout strong { color: var(--rd-green-dark) !important; }
/* Promo CTA → emerald button (the brand accent popping on the navy band) */
.promo-banner .btn-primary,
.promo-banner .btn-lg {
  background: var(--rd-grad-cta) !important;
  color: #ffffff !important;
  box-shadow: 0 12px 30px -10px rgba(16,185,129,.6);
}
.promo-banner .btn-primary:hover,
.promo-banner .btn-lg:hover {
  background: var(--rd-grad-cta) !important;
  transform: translateY(-2px);
  box-shadow: 0 18px 38px -10px rgba(16,185,129,.7);
}
.bottom-cta {
  background: linear-gradient(135deg, #0f172a 0%, #065f46 55%, #059669 100%);
  color: #fff;
}
.bottom-cta h2 { color: #fff; }
.bottom-cta .btn-primary, .bottom-cta .btn-lg {
  background: #fff; color: var(--rd-green-dark);
}
.bottom-cta .btn-primary:hover { background: #fff; box-shadow: 0 14px 30px -10px rgba(0,0,0,.4); }
.bottom-cta-sub { color: rgba(255,255,255,.9); }

/* ---- Carousel controls ------------------------------------------------------ */
.carousel-btn {
  background: var(--rd-surface);
  border: 1px solid var(--rd-border);
  box-shadow: var(--rd-shadow-md);
  color: var(--rd-fg);
  transition: transform .15s var(--rd-ease), box-shadow .15s var(--rd-ease);
}
.carousel-btn:hover { transform: scale(1.08); box-shadow: var(--rd-shadow-lg); color: var(--rd-green-dark); }
.carousel-dots .active, .carousel-dot.active { background: var(--rd-green) !important; }

/* =============================================================================
   DARK MODE — adjust the marketing homepage tokens (viewer keeps its own)
   ============================================================================= */
@media (prefers-color-scheme: dark) {
  :root {
    --rd-fg:      #f1f5f9;
    --rd-fg-soft: #cbd5e1;
    --rd-fg-mute: #94a3b8;
    --rd-bg:      #0b1220;
    --rd-surface: #131c2e;
    --rd-muted:   #1b2538;
    --rd-border:  #29344a;
    --rd-navy-soft:   #1c2440;
    --rd-green-soft:  #0e2a22;
  }
  .site-header { background: rgba(13,18,30,.82); }
  /* hero keeps its green brand gradient in dark mode too */
  .step-card, .upload-zone-card, .carousel-btn {
    background: var(--rd-surface);
    border-color: var(--rd-border);
  }
  /* features: dark section + dark cards (re-assert over the light !important rules) */
  .features-section {
    background: linear-gradient(180deg, #0d1622 0%, #0b1220 100%) !important;
  }
  .features-section .feature-card {
    background: #131c2e !important;
    border-color: var(--rd-border) !important;
    border-top-color: var(--rd-border) !important;
    box-shadow: 0 1px 2px rgba(0,0,0,.3), 0 12px 28px -16px rgba(0,0,0,.6) !important;
  }
  .features-section .feature-card:hover {
    border-color: rgba(16,185,129,.5) !important;
    border-top-color: transparent !important;
  }
  /* icon tiles keep the vibrant gradient (looks good on dark too) */
}

/* =============================================================================
   MOTION — honour reduced-motion preference (a11y)
   ============================================================================= */
@media (prefers-reduced-motion: reduce) {
  #homepageContent *,
  .site-header * {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
  .feature-card:hover, .step-card:hover, .upload-zone-card:hover,
  #homepageContent .btn-primary:hover, .upload-btn:hover { transform: none; }
}

/* =============================================================================
   CHAT VIEWER — message search relocated from the sidebar into the panel header
   ============================================================================= */
.wc-chat-header .wc-header-search {
  width: 230px;
  flex-shrink: 1;
  min-width: 130px;
  margin-right: 4px;
  transition: box-shadow .15s var(--rd-ease), border-color .15s var(--rd-ease);
}
.wc-chat-header .wc-header-search:focus-within {
  border-color: var(--rd-green) !important;
  box-shadow: 0 0 0 3px rgba(16,185,129,.18);
}
.wc-chat-header .wc-header-search .wc-search-input { width: 100%; }
/* keep the header on one line as it gets narrower */
@media (max-width: 1180px) { .wc-chat-header .wc-header-search { width: 170px; } }
@media (max-width: 920px)  { .wc-chat-header .wc-header-search { width: 130px; } }

/* live "N results" badge next to the header search */
.wc-chat-header .wc-search-count {
  display: inline-flex; align-items: center;
  font-size: 12px; font-weight: 600; line-height: 1;
  color: var(--rd-green-dark);
  background: rgba(16,185,129,.12);
  border: 1px solid rgba(16,185,129,.28);
  border-radius: 999px;
  padding: 5px 10px;
  margin-right: 2px;
  white-space: nowrap;
}
.wc-chat-header .wc-search-count.is-empty {
  color: #b91c1c;
  background: rgba(220,38,38,.10);
  border-color: rgba(220,38,38,.28);
}

/* =============================================================================
   CHAT VIEWER — sidebar stats · gallery "New" pill · clean footer
   ============================================================================= */

/* ---- Sidebar "Chat Overview" stats (fills the empty sidebar area) ---------- */
.wc-chat-stats {
  margin: 6px 14px 18px;
  padding: 14px;
  background: #ffffff;
  border: 1px solid #e9edef;
  border-radius: 14px;
  box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 10px 22px -16px rgba(15,23,42,.22);
}
.wc-stats-title {
  font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: #8696a0; margin-bottom: 12px;
}
.wc-stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.wc-stat-tile {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px;
  background: linear-gradient(160deg, #f8fafc, #eef2f7);
  border: 1px solid #eef1f4; border-radius: 12px;
}
.wc-stat-ico { color: var(--rd-green-dark); height: 18px; }
.wc-stat-ico svg { width: 18px; height: 18px; display: block; }
.wc-stat-val {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 19px; font-weight: 700; color: #111b21; line-height: 1.1;
}
.wc-stat-lbl { font-size: 11px; font-weight: 500; color: #8696a0; }
.wc-stats-rows { margin-top: 12px; display: flex; flex-direction: column; gap: 9px; }
.wc-stat-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; font-size: 12.5px; }
.wc-stat-row-lbl { color: #8696a0; font-weight: 500; flex-shrink: 0; }
.wc-stat-row-val { color: #111b21; font-weight: 600; text-align: right; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Top participants — fills the empty sidebar space below the stats */
.wc-stats-people { margin-top: 14px; padding-top: 14px; border-top: 1px solid #eef1f4; }
.wc-stats-subtitle { font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: #8696a0; margin-bottom: 11px; }
.wc-people-row { display: flex; align-items: center; gap: 8px; margin-bottom: 9px; }
.wc-people-row:last-child { margin-bottom: 0; }
.wc-people-name { flex: 0 0 80px; font-size: 12px; font-weight: 600; color: #111b21; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wc-people-bar { flex: 1; height: 6px; background: #eef1f4; border-radius: 999px; overflow: hidden; }
.wc-people-bar i { display: block; height: 100%; background: linear-gradient(90deg, #34d399, #059669); border-radius: 999px; }
.wc-people-count { flex: 0 0 auto; font-size: 11.5px; font-weight: 600; color: #64748b; min-width: 30px; text-align: right; }
@media (prefers-color-scheme: dark) {
  .wc-stats-people { border-top-color: #29344a; }
  .wc-people-name { color: #e9edef; }
  .wc-people-bar { background: #29344a; }
}

/* ---- Gallery nav icon "New" pill ------------------------------------------- */
.wc-nav-rail #wcNavGallery { position: relative; overflow: visible; }
.wc-nav-rail #wcNavGallery::after {
  content: "New";
  position: absolute; top: -3px; right: -7px;
  background: linear-gradient(135deg, #ef4444, #dc2626);
  color: #fff; font-size: 8px; font-weight: 700; letter-spacing: .02em;
  padding: 2px 5px; border-radius: 999px; line-height: 1;
  box-shadow: 0 2px 6px rgba(220,38,38,.6);
  pointer-events: none;
  animation: wcNewPulse 2.4s ease-in-out infinite;
}
@keyframes wcNewPulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.13); }
}

/* ---- Clean footer / pagination bar ----------------------------------------- */
/* Only the status pill + pagination remain (Analyse/Export were removed), so
   centre them as one group — no big blank gap stretched across the bar. */
.wc-bottom-bar {
  gap: 22px !important;
  padding: 9px 16px !important;
  justify-content: center !important;
  flex-wrap: nowrap !important;
}
.wc-bottom-bar .wc-pagination.pagination-controls { flex: 0 0 auto !important; }
@media (max-width: 760px) {
  .wc-bottom-bar .wc-lock-pill { display: none; }  /* save space on small screens */
}
.wc-lock-pill {
  min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  color: #64748b; font-size: 12px;
}
/* the "Previous"/"Next" buttons are TEXT — don't force them to a 32px square */
.wc-bottom-bar .pagination-controls .prev-btn,
.wc-bottom-bar .pagination-controls .next-btn {
  width: auto !important; min-width: 0 !important; padding: 0 14px !important;
}
.wc-bottom-bar .pagination-controls .button {
  height: 32px !important;
  background: #fff !important; color: #334155 !important;
  border: 1px solid #e2e8f0 !important; border-radius: 8px !important;
  font-size: 13px; font-weight: 600; cursor: pointer;
  transition: border-color .15s var(--rd-ease), color .15s var(--rd-ease);
}
.wc-bottom-bar .pagination-controls .button:hover:not([disabled]) {
  border-color: var(--rd-green) !important; color: var(--rd-green-dark) !important;
}
.wc-bottom-bar .pagination-controls .button[disabled] { opacity: .45; cursor: not-allowed; }
.wc-bottom-bar .page-info { font-size: 13px; color: #475569; white-space: nowrap; }
.wc-bottom-bar .page-info .current-page,
.wc-bottom-bar .page-info .total-pages { font-weight: 700; color: #111b21; }
.wc-bottom-bar .page-size-select,
.wc-bottom-bar #pageJumpInput {
  height: 32px !important; border: 1px solid #e2e8f0 !important; border-radius: 8px !important;
  background: #fff; color: #334155; font-size: 13px; padding: 0 8px !important;
}
.wc-bottom-bar #pageJumpInput { width: 52px; text-align: center; }
.wc-bottom-bar .page-jump { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: #475569; }
.wc-bottom-bar .page-jump-btn {
  height: 32px; width: auto !important; padding: 0 14px !important;
  background: var(--rd-grad-cta); color: #fff !important;
  border: none !important; border-radius: 8px; font-weight: 600; cursor: pointer;
}

/* ---- Dark mode for the viewer additions ------------------------------------ */
@media (prefers-color-scheme: dark) {
  .wc-chat-stats { background: #131c2e; border-color: #29344a; }
  .wc-stat-tile { background: linear-gradient(160deg, #1a2335, #161f30); border-color: #29344a; }
  .wc-stat-val, .wc-stat-row-val { color: #e9edef; }
  .wc-bottom-bar .pagination-controls .button,
  .wc-bottom-bar .page-size-select,
  .wc-bottom-bar #pageJumpInput { background: #1f2a30; color: #e9edef; border-color: #2a3942 !important; }
  .wc-bottom-bar .page-info .current-page,
  .wc-bottom-bar .page-info .total-pages { color: #e9edef; }
}

@media (prefers-reduced-motion: reduce) {
  .wc-nav-rail #wcNavGallery::after { animation: none; }
}

/* ---- In the chat viewer, drop the marketing top header (reclaims space) ----- */
body.wc-viewer-active .site-header { display: none !important; }

/* The body has padding-bottom:60px (a homepage style); the viewer is already
   100vh, so that 60px becomes dead space below the app. Remove it + lock the
   page to the viewport in viewer mode (the chat panel scrolls internally). */
body.wc-viewer-active { padding-bottom: 0 !important; overflow: hidden; height: 100vh; }
/* The viewer was sized calc(100vh - 52px) to leave room for the header; with
   the header hidden it should use the full height (kills the bottom strip). */
body.wc-viewer-active #mainContainer.main-container {
  height: 100vh !important;
  max-height: 100vh !important;
}

/* ---- Sidebar brand → clickable homepage link ------------------------------- */
.wc-sidebar-header a.wc-brand { text-decoration: none; cursor: pointer; border-radius: 8px; transition: opacity .15s var(--rd-ease); }
.wc-sidebar-header a.wc-brand:hover { opacity: .72; }
.wc-sidebar-header a.wc-brand .wc-brand-name { color: inherit; }

/* =============================================================================
   LIVE VISITOR STATS strip (homepage)
   ============================================================================= */
.wcv-stats {
  background: linear-gradient(180deg, #ffffff 0%, #f1f5f9 100%);
  border-top: 1px solid var(--rd-border);
  border-bottom: 1px solid var(--rd-border);
  padding: 22px 16px;
}
.wcv-stats-inner {
  max-width: 980px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
}
.wcv-stat {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 14px 10px; text-align: center;
  background: #fff; border: 1px solid var(--rd-border); border-radius: 14px;
  box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 8px 20px -16px rgba(15,23,42,.18);
}
.wcv-num {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(1.5rem, 3.4vw, 2rem); font-weight: 800; line-height: 1.05;
  color: var(--rd-green-dark); letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
}
.wcv-lbl { font-size: 12px; font-weight: 600; color: var(--rd-fg-mute); letter-spacing: .02em; }
/* tiny "live" dot on the first tile */
.wcv-stat:first-child .wcv-lbl::before {
  content: ""; display: inline-block; width: 7px; height: 7px; margin-right: 6px;
  border-radius: 50%; background: #22c55e; vertical-align: middle;
  box-shadow: 0 0 0 0 rgba(34,197,94,.6); animation: wcvPulse 1.8s ease-out infinite;
}
@keyframes wcvPulse { 0% { box-shadow: 0 0 0 0 rgba(34,197,94,.55); } 70%,100% { box-shadow: 0 0 0 7px rgba(34,197,94,0); } }
@media (max-width: 620px) {
  .wcv-stats-inner { grid-template-columns: repeat(2, 1fr); }
}
@media (prefers-reduced-motion: reduce) {
  .wcv-stat:first-child .wcv-lbl::before { animation: none; }
}
@media (prefers-color-scheme: dark) {
  .wcv-stats { background: linear-gradient(180deg, #0d1622 0%, #0b1220 100%); border-color: #29344a; }
  .wcv-stat { background: #131c2e; border-color: #29344a; }
}

/* =============================================================================
   EXPORT POPUP — in-app "export latest 300 messages" via WaChat2PDF API
   ============================================================================= */
#wcExportOverlay {
  position: fixed; inset: 0; z-index: 100000;
  display: none; align-items: center; justify-content: center;
  background: rgba(15, 23, 42, .55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  font-family: "Inter", "Segoe UI", sans-serif;
}
#wcExportOverlay.open { display: flex; animation: wcxFade .2s ease; }
@keyframes wcxFade { from { opacity: 0; } to { opacity: 1; } }
.wcx-card {
  position: relative;
  width: 420px; max-width: 92vw;
  background: #fff; border-radius: 20px;
  padding: 30px 28px 24px; text-align: center;
  box-shadow: 0 30px 70px -20px rgba(15,23,42,.5);
  animation: wcxPop .25s cubic-bezier(.22,.61,.36,1);
}
@keyframes wcxPop { from { transform: translateY(14px) scale(.97); opacity: 0; } to { transform: none; opacity: 1; } }
.wcx-close {
  position: absolute; top: 12px; right: 14px;
  background: none; border: none; font-size: 24px; line-height: 1;
  color: #94a3b8; cursor: pointer;
}
.wcx-close:hover { color: #0f172a; }
.wcx-icon {
  width: 56px; height: 56px; margin: 0 auto 14px;
  border-radius: 16px; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #10b981, #059669);
  box-shadow: 0 10px 22px -8px rgba(16,185,129,.6);
}
.wcx-done .wcx-icon { background: linear-gradient(135deg, #10b981, #059669); }
.wcx-error .wcx-icon { background: linear-gradient(135deg, #ef4444, #dc2626); box-shadow: 0 10px 22px -8px rgba(220,38,38,.5); }
.wcx-title { font-family: "Plus Jakarta Sans", sans-serif; font-size: 19px; font-weight: 700; color: #0f172a; margin: 0 0 12px; }
.wcx-body { color: #475569; font-size: 14px; }
.wcx-msg { margin: 0 0 10px; line-height: 1.55; }
.wcx-msg b { color: #0f172a; }
.wcx-progress {
  height: 8px; background: #e2e8f0; border-radius: 999px; overflow: hidden; margin: 16px 0 8px;
}
.wcx-progress > span {
  display: block; height: 100%; width: 8%;
  background: linear-gradient(90deg, #34d399, #059669); border-radius: 999px;
  transition: width .3s ease;
}
.wcx-done .wcx-progress > span { width: 100% !important; }
.wcx-error .wcx-progress { display: none; }
.wcx-stage { font-size: 12.5px; color: #64748b; min-height: 16px; }
.wcx-note { margin-top: 14px; font-size: 11.5px; color: #94a3b8; line-height: 1.5; }
.wcx-done .wcx-note, .wcx-error .wcx-note, .wcx-done .wcx-stage { display: none; }
.wcx-redirect { font-size: 13px; color: #059669; font-weight: 600; margin: 12px 0 8px; }
.wcx-actions { display: flex; gap: 10px; justify-content: center; margin-top: 8px; }
.wcx-go {
  display: inline-flex; align-items: center; padding: 10px 18px; border-radius: 999px;
  background: linear-gradient(135deg, #10b981, #059669); color: #fff !important;
  font-weight: 600; font-size: 13.5px; text-decoration: none;
  box-shadow: 0 10px 22px -8px rgba(16,185,129,.6);
}
.wcx-stay {
  padding: 10px 16px; border-radius: 999px; border: 1px solid #e2e8f0;
  background: #fff; color: #475569; font-weight: 600; font-size: 13.5px; cursor: pointer;
}
.wcx-stay:hover { border-color: #cbd5e1; }
@media (prefers-color-scheme: dark) {
  .wcx-card { background: #131c2e; }
  .wcx-title, .wcx-msg b { color: #f1f5f9; }
  .wcx-body { color: #cbd5e1; }
  .wcx-progress { background: #29344a; }
  .wcx-stay { background: #1f2a30; border-color: #2a3942; color: #e9edef; }
}

/* ---- Gallery video thumbnails (native first-frame) ------------------------- */
.wc-gallery-card-video { width: 100%; height: 100%; object-fit: cover; display: block; background: #0b141a; }
.wc-gallery-video-ph {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #1a2730, #0b141a);
}

/* ---- Modern "Processing chat" loader (replaces the plain border spinner) ---- */
.loading-indicator {
  background: rgba(248, 250, 252, 0.82) !important;
  backdrop-filter: blur(16px) saturate(1.2);
  -webkit-backdrop-filter: blur(16px) saturate(1.2);
}
.loading-indicator .spinner {
  width: 54px !important; height: 54px !important;
  border: none !important; border-radius: 50%;
  background: conic-gradient(from 90deg, rgba(16,185,129,0) 0%, #34d399 55%, #059669 100%);
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 calc(100% - 5px));
          mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 calc(100% - 5px));
  box-shadow: none !important;
  margin-bottom: 22px !important;
  animation: spin .85s cubic-bezier(.5,.15,.5,.85) infinite;
}
.loading-indicator p {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 17px; font-weight: 700; color: #0f172a; margin: 0 0 6px;
}
.loading-indicator .loading-info {
  font-size: 13px; color: #64748b; margin: 0 0 16px;
}
.loading-indicator .progress-container {
  position: static !important;
  width: 280px; max-width: 70vw; height: 6px;
  background: #e2e8f0; border-radius: 999px; overflow: hidden;
}
.loading-indicator .progress-bar {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, #34d399, #059669);
  border-radius: 999px;
  box-shadow: 0 0 10px rgba(16,185,129,.55);
  transition: width .25s ease;
}
@media (prefers-color-scheme: dark) {
  .loading-indicator { background: rgba(11,18,32,0.86) !important; }
  .loading-indicator p { color: #f1f5f9; }
  .loading-indicator .progress-container { background: #29344a; }
}
