/*
 * Movo design tokens + landing layout
 * Source: Figma 02tumkW5XqCPOP5zJFnKQu (2026-05-20)
 *
 * Fonts: Plus Jakarta Sans (Latin) + Noto Sans SC (CJK) — wp_enqueue_style
 */

:root {
  /* Brand */
  --brand-primary: #0028AF;
  --brand-primary-dark: #312C85;
  --brand-primary-light: #1D4ED8;
  --brand-accent-gold: #F2B425;
  --brand-accent-orange-1: #F59A0B;
  --brand-accent-orange-2: #F99112;
  --brand-accent-orange-3: #FC6306;
  --brand-gradient-cta: linear-gradient(90deg, #F2B425 0%, #FC6306 100%);
  --brand-gradient-hero-bg: linear-gradient(135deg, #0028AF 0%, #1D4ED8 50%, #312C85 100%);
  --brand-gradient-orange-bar: linear-gradient(90deg, #F59A0B 0%, #FC6306 100%);

  /* Neutrals */
  --neutral-surface-1: #FFFFFF;
  --neutral-surface-2: #FEFEFE;
  --neutral-surface-3: #F8FAFC;
  --neutral-surface-4: #E0E7FF;
  --neutral-text-strong: #1D293D;
  --neutral-text-muted: #62748E;
  --neutral-text-soft: #90A1B9;

  /* Typography */
  --font-sans: 'Plus Jakarta Sans', 'Noto Sans SC', -apple-system, 'PingFang SC', 'Microsoft YaHei', sans-serif;
  --font-display: 'Plus Jakarta Sans', 'Noto Sans SC', sans-serif;
  --font-weight-bold: 700;
  --font-weight-extra: 800;
  --font-weight-regular: 400;

  /* Spacing */
  --space-xs: 8px;
  --space-sm: 16px;
  --space-md: 24px;
  --space-lg: 32px;
  --space-xl: 48px;
  --space-2xl: 64px;
  --space-3xl: 96px;

  /* Radii / Shadow */
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --shadow-md: 0 20px 25px -5px rgba(0,0,0,.10), 0 8px 10px -6px rgba(0,0,0,.10);
  --shadow-card: 0 30px 60px -15px rgba(0,40,175,.30);

  --container-max: 1240px;
  --container-pad: 32px;
}

/* ============ BASE ============ */

body {
  font-family: var(--font-sans);
  color: var(--neutral-text-strong);
  background: var(--neutral-surface-1);
}

.movo-landing {
  display: block;
  padding: 0 var(--container-pad);
  max-width: var(--container-max);
  margin: 0 auto;
  box-sizing: border-box;
}

.movo-landing > section {
  padding: var(--space-3xl) 0;
}

/* Hide Blocksy site title/tagline */
.ct-site-title,
.site-title,
.ct-tagline,
.site-description,
[data-row="middle"] .ct-stack > .site-branding-container .site-title {
  display: none !important;
}

body.home .entry-header,
body.home .page-title,
body.page-id-59 .entry-header {
  display: none !important;
}

.custom-logo {
  max-height: 44px;
  width: auto !important;
}

/* ============ SECTION HEADINGS ============ */

.movo-section__heading {
  text-align: center;
  font-size: 40px;
  line-height: 1.1;
  font-weight: var(--font-weight-extra);
  color: var(--neutral-text-strong);
  margin: 0 0 var(--space-sm);
}

.movo-section__sub {
  text-align: center;
  font-size: 16px;
  color: var(--neutral-text-muted);
  margin: 0 auto var(--space-xl);
  max-width: 640px;
}

/* ============ HERO ============ */

.movo-hero {
  padding-top: var(--space-xl) !important;
  padding-bottom: var(--space-lg) !important;
}

.movo-hero__card {
  background: var(--brand-gradient-hero-bg);
  border-radius: var(--radius-lg);
  padding: 64px;
  display: flex;
  align-items: center;
  gap: 32px;
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
  min-height: 480px;
}

.movo-hero__content {
  flex: 1;
  color: #FFFFFF;
  z-index: 2;
}

.movo-hero__badge {
  display: inline-block;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.30);
  color: #FFFFFF;
  padding: 7px 17px;
  border-radius: 100px;
  font-size: 10px;
  font-weight: var(--font-weight-bold);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 24px;
}

.movo-hero__headline {
  font-size: 72px;
  line-height: 1.1;
  font-weight: var(--font-weight-extra);
  color: #FFFFFF;
  margin: 0 0 24px;
}

.movo-hero__gradient {
  background: var(--brand-gradient-cta);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  display: inline-block;
}

.movo-hero__sub {
  font-size: 16px;
  line-height: 1.6;
  color: rgba(255,255,255,0.90);
  max-width: 530px;
  margin: 0 0 32px;
}

.movo-hero__actions {
  display: flex;
  gap: 16px;
}

.movo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 16px 32px;
  border-radius: var(--radius-md);
  font-weight: var(--font-weight-bold);
  font-size: 14px;
  text-decoration: none !important;
  transition: transform .12s ease, box-shadow .12s ease;
  cursor: pointer;
  border: 2px solid transparent;
}

.movo-btn--solid {
  background: #FFFFFF;
  color: var(--brand-primary-dark);
  box-shadow: 0 20px 25px -5px rgba(0,0,0,.10), 0 8px 10px -6px rgba(0,0,0,.10);
}
.movo-btn--solid:hover { background: #F8FAFC; transform: translateY(-1px); }

.movo-btn--outline {
  background: transparent;
  color: #FFFFFF;
  border-color: rgba(255,255,255,0.40);
}
.movo-btn--outline:hover { background: rgba(255,255,255,0.10); border-color: #FFFFFF; }

.movo-btn--primary { background: var(--brand-primary); color: #FFFFFF; }
.movo-btn--primary:hover { background: var(--brand-primary-dark); }

.movo-hero__illustration {
  max-width: 480px;
  width: 45%;
  height: auto;
  object-fit: contain;
  z-index: 2;
  position: relative;
}

@media (max-width: 960px) {
  .movo-hero__card { flex-direction: column; padding: 40px 24px; gap: 16px; }
  .movo-hero__headline { font-size: 48px; }
  .movo-hero__illustration { width: 70%; max-width: 320px; }
}

/* ============ STATS BAR ============ */

.movo-stats { padding-top: 0 !important; }

.movo-stats__inner {
  background: var(--brand-gradient-orange-bar);
  border-radius: var(--radius-md);
  padding: 32px 48px;
  display: flex;
  justify-content: space-around;
  align-items: center;
  gap: 32px;
}

.movo-stat { text-align: center; color: #FFFFFF; }

.movo-stat__num {
  font-size: 36px;
  font-weight: var(--font-weight-extra);
  line-height: 1;
  margin-bottom: 4px;
}

.movo-stat__label { font-size: 14px; opacity: 0.95; font-weight: 500; }

@media (max-width: 640px) {
  .movo-stats__inner { flex-direction: column; padding: 24px; }
  .movo-stat__num { font-size: 28px; }
}

/* ============ CATEGORIES ============ */

.movo-categories__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}

.movo-category {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--neutral-surface-3);
  border-radius: var(--radius-md);
  padding: 24px 16px;
  text-decoration: none !important;
  color: var(--neutral-text-strong);
  transition: transform .15s ease, box-shadow .15s ease;
  aspect-ratio: 1;
  cursor: pointer;
}

.movo-category:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.movo-category__icon { font-size: 48px; line-height: 1; margin-bottom: 12px; }
.movo-category__label { font-size: 14px; font-weight: var(--font-weight-bold); text-align: center; }

@media (max-width: 960px) { .movo-categories__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .movo-categories__grid { grid-template-columns: repeat(2, 1fr); } }

/* ============ FEATURED STORES (Dokan) override ============ */

.movo-stores .dokan-store-list-wrap { padding: 0; }

button.dokan-store-list-filter-button,
button.dokan-store-list-filter-button.dokan-btn-theme,
.dokan-store-list-filter-button-mobile,
.dokan-btn.dokan-btn-theme,
button.dokan-btn-theme,
a.dokan-btn-theme,
.dokan-btn-theme {
  background: var(--brand-primary) !important;
  background-image: none !important;
  border-color: var(--brand-primary) !important;
  color: #FFFFFF !important;
}
button.dokan-store-list-filter-button:hover,
.dokan-btn.dokan-btn-theme:hover,
.dokan-btn-theme:hover {
  background: var(--brand-primary-dark) !important;
  background-image: none !important;
  border-color: var(--brand-primary-dark) !important;
}

/* ============ HOW IT WORKS ============ */

.movo-how {
  background: var(--neutral-surface-3);
  border-radius: var(--radius-lg);
}

.movo-how__steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  position: relative;
}

.movo-how__step { text-align: center; padding: 24px; }

.movo-how__visual {
  font-size: 64px;
  line-height: 1;
  margin-bottom: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: #FFFFFF;
  box-shadow: var(--shadow-md);
}

.movo-how__visual--shop  { background: #FFFFFF; }
.movo-how__visual--earn  { background: linear-gradient(135deg, #FFFFFF 0%, #E0E7FF 100%); }
.movo-how__visual--grow  { background: linear-gradient(135deg, #0028AF 0%, #312C85 100%); color: #FFFFFF; }

.movo-how__title { font-size: 24px; font-weight: var(--font-weight-extra); margin: 16px 0 8px; }
.movo-how__desc { font-size: 14px; color: var(--neutral-text-muted); line-height: 1.6; max-width: 260px; margin: 0 auto; }

@media (max-width: 960px) { .movo-how__steps { grid-template-columns: 1fr; } }

/* ============ EXPLORE OPPORTUNITIES ============ */

.movo-explore__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.movo-explore__grid--single {
  grid-template-columns: minmax(0, 720px);
  justify-content: center;
}

.movo-promo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 40px;
  border-radius: var(--radius-md);
  text-decoration: none !important;
  color: #FFFFFF;
  position: relative;
  overflow: hidden;
  min-height: 220px;
  transition: transform .15s ease;
}

.movo-promo:hover { transform: translateY(-3px); }
.movo-promo--blue   { background: var(--brand-gradient-hero-bg); }
.movo-promo--orange { background: var(--brand-gradient-orange-bar); }

.movo-promo__content { flex: 1; z-index: 2; }
.movo-promo__title { font-size: 28px; font-weight: var(--font-weight-extra); color: #FFFFFF; margin: 0 0 12px; }
.movo-promo__body  { font-size: 14px; color: rgba(255,255,255,0.95); line-height: 1.6; margin: 0 0 20px; max-width: 380px; }

.movo-promo__cta {
  display: inline-block;
  background: #FFFFFF;
  color: var(--brand-primary-dark);
  padding: 12px 24px;
  border-radius: var(--radius-md);
  font-weight: var(--font-weight-bold);
  font-size: 14px;
}
.movo-promo--orange .movo-promo__cta { color: var(--brand-accent-orange-3); }

.movo-promo__icon {
  font-size: 100px;
  line-height: 1;
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,.15));
}

@media (max-width: 960px) {
  .movo-explore__grid { grid-template-columns: 1fr; }
  .movo-promo { padding: 24px; }
  .movo-promo__title { font-size: 22px; }
  .movo-promo__icon { font-size: 64px; }
}

/* ============ HEADER SEARCH BAR ============ */

.movo-header-search {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--neutral-surface-3);
  border: 1px solid #E0E7FF;
  border-radius: 100px;
  padding: 8px 18px;
  margin-left: 24px;
  width: 320px;
  max-width: 100%;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.movo-header-search:focus-within {
  border-color: var(--brand-primary);
  box-shadow: 0 0 0 4px rgba(0,40,175,.08);
}
.movo-header-search__icon { color: var(--neutral-text-soft); flex-shrink: 0; }
.movo-header-search input[type="search"] {
  border: none;
  background: transparent;
  outline: none;
  font-family: inherit;
  font-size: 13px;
  width: 100%;
  color: var(--neutral-text-strong);
}
.movo-header-search input::placeholder { color: var(--neutral-text-soft); }

@media (max-width: 1100px) { .movo-header-search { display: none; } }

/* ============ HEADER CTA ============ */

.movo-header-cta {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-left: 24px;
}

.movo-header-cta__login {
  color: var(--neutral-text-strong);
  font-weight: var(--font-weight-bold);
  font-size: 14px;
  text-decoration: none !important;
  padding: 8px 16px;
  border-radius: 100px;
  border: 1px solid transparent;
  transition: all .15s ease;
}
.movo-header-cta__login:hover {
  color: var(--brand-primary);
  border-color: var(--brand-primary);
}

.movo-header-cta__signup {
  background: var(--brand-primary);
  color: #FFFFFF !important;
  padding: 10px 24px;
  border-radius: 100px;
  font-weight: var(--font-weight-bold);
  font-size: 14px;
  text-decoration: none !important;
  transition: background .12s ease;
}
.movo-header-cta__signup:hover { background: var(--brand-primary-dark); }

/* ============ HEADER CART WIDGET ============ */

.movo-cart-widget {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  color: var(--neutral-text-strong);
  text-decoration: none !important;
  transition: color .12s ease, background .12s ease;
  margin-right: 4px;
}
.movo-cart-widget:hover {
  color: var(--brand-primary);
  background: var(--neutral-surface-3);
}
.movo-cart-widget__icon { display: block; }
.movo-cart-count {
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: var(--brand-primary);
  color: #FFFFFF;
  border-radius: 9px;
  font-size: 11px;
  font-weight: var(--font-weight-bold);
  line-height: 18px;
  text-align: center;
  pointer-events: none;
}
.movo-cart-count[data-count="0"] { display: none; }

/* ============ FOOTER (custom Movo 3-col) ============ */

/* Hide Blocksy default footer rows + WPML widget below footer.
 * NOTE: `.movo-footer + *` was previously here but it ate the Dokan
 * `#dokan-product-category-modal` (rendered as body > footer + div),
 * making the vendor category picker invisible after click. Specific
 * `.wpml-ls` rules below cover the actual WPML widget. */
.ct-footer,
.movo-footer ~ .wpml-ls,
body > .wpml-ls,
.site > .wpml-ls,
.ct-container ~ .wpml-ls { display: none !important; }

.movo-footer {
  background: var(--neutral-surface-3);
  padding: var(--space-2xl) 0 var(--space-md);
  margin-top: var(--space-2xl);
  border-top: 1px solid #E0E7FF;
}

.movo-footer__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
  gap: 48px;
  align-items: start;
}

.movo-footer__brand {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.movo-footer__logo img {
  max-height: 36px;
  width: auto;
}

.movo-footer__tagline {
  color: var(--neutral-text-muted);
  font-size: 13px;
  line-height: 1.6;
  margin: 0;
  max-width: 280px;
}

.movo-footer__address {
  font-style: normal;
  color: var(--neutral-text-muted);
  font-size: 13px;
  line-height: 1.7;
  margin: 12px 0 0;
}
.movo-footer__address a { color: var(--brand-primary); text-decoration: none; }
.movo-footer__address a:hover { text-decoration: underline; }

.movo-footer__lang {
  margin-top: 14px;
}
.movo-footer__lang .wpml-ls {
  display: inline-flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 12px;
}
.movo-footer__lang .wpml-ls-item { display: inline-flex; }
.movo-footer__lang .wpml-ls-link {
  font-size: 13px;
  color: var(--neutral-text-muted);
  padding: 4px 12px;
  border-radius: 100px;
  border: 1px solid #E0E7FF;
  text-decoration: none;
  transition: all .12s ease;
}
.movo-footer__lang .wpml-ls-current-language .wpml-ls-link,
.movo-footer__lang .wpml-ls-link:hover {
  color: #FFFFFF;
  background: var(--brand-primary);
  border-color: var(--brand-primary);
}

.movo-footer__col h4 {
  font-size: 14px;
  font-weight: var(--font-weight-extra);
  color: var(--brand-primary);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin: 0 0 16px;
}

/* Social icons row */
.movo-footer__social {
  display: flex;
  gap: 10px;
  margin-top: 8px;
}
.movo-footer__social-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: #FFFFFF;
  border: 1px solid #E0E7FF;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--neutral-text-muted);
  transition: all .12s ease;
}
.movo-footer__social-icon:hover { color: var(--brand-primary); border-color: var(--brand-primary); }

/* App download buttons */
.movo-footer__col--apps { display: flex; flex-direction: column; gap: 10px; }
.movo-app-btn {
  background: var(--brand-primary);
  color: #FFFFFF !important;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  border-radius: 10px;
  text-decoration: none !important;
  transition: background .12s ease;
  width: max-content;
  min-width: 180px;
}
.movo-app-btn:hover { background: var(--brand-primary-dark); }
.movo-app-btn svg {
  background: rgba(255,255,255,0.18);
  border-radius: 6px;
  padding: 4px;
  width: 30px;
  height: 30px;
  flex-shrink: 0;
}
.movo-app-btn span { display: flex; flex-direction: column; line-height: 1.1; }
.movo-app-btn span small { font-size: 9px; opacity: 0.85; letter-spacing: 1px; text-transform: uppercase; }

.movo-footer__col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.movo-footer__col a {
  color: var(--neutral-text-muted);
  font-size: 13px;
  text-decoration: none;
  transition: color .12s ease;
}
.movo-footer__col a:hover { color: var(--brand-primary); }

.movo-footer__lang {
  margin-top: 20px;
}
.movo-footer__lang ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 12px;
  font-size: 13px;
}
.movo-footer__lang a { color: var(--brand-primary); }

.movo-footer__bottom {
  max-width: var(--container-max);
  margin: 32px auto 0;
  padding: 24px var(--container-pad) 0;
  border-top: 1px solid #E0E7FF;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--neutral-text-soft);
  font-size: 12px;
  letter-spacing: 0.3px;
}
.movo-footer__bottom-links { display: inline-flex; gap: 24px; }
.movo-footer__bottom-links a { color: var(--neutral-text-soft); text-decoration: none; }
.movo-footer__bottom-links a:hover { color: var(--brand-primary); }

@media (max-width: 960px) {
  .movo-footer__inner {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }
  .movo-footer__brand { grid-column: 1 / -1; }
  .movo-footer__bottom { flex-direction: column; gap: 8px; text-align: center; }
}

@media (max-width: 480px) {
  .movo-footer__inner { grid-template-columns: 1fr; }
}

/* ============ WC + global button overrides ============ */

.woocommerce a.button,
.woocommerce button.button,
.woocommerce-page button.button,
.woocommerce input.button,
.wp-block-button__link {
  background: var(--brand-primary);
  color: #FFFFFF;
  font-weight: var(--font-weight-bold);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
}
.woocommerce a.button:hover,
.woocommerce button.button:hover { background: var(--brand-primary-dark); }

.woocommerce .price,
.woocommerce .product .price { color: var(--brand-primary); font-weight: var(--font-weight-bold); }

.woocommerce span.onsale { background: var(--brand-gradient-cta); color: #FFFFFF; }

/* ============ MY-ACCOUNT LOGIN / REGISTER ============ */

body.movo-account-loginpage { background: var(--neutral-surface-3); }
body.movo-account-loginpage .ct-container,
body.movo-account-loginpage .ct-main { background: transparent; }

body.movo-account-loginpage .woocommerce-account .woocommerce {
  max-width: 1240px;
  margin: 32px auto;
}

/* The WC col2-set: Login | Register side-by-side */
body.movo-account-loginpage .u-columns.col2-set {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin: 0;
}
body.movo-account-loginpage .u-columns.col2-set::before,
body.movo-account-loginpage .u-columns.col2-set::after { display: none; }

body.movo-account-loginpage .u-column1,
body.movo-account-loginpage .u-column2 {
  background: #FFFFFF;
  border-radius: var(--radius-lg);
  padding: 48px;
  box-shadow: 0 20px 60px -20px rgba(0,40,175,0.10);
  width: 100% !important;
  float: none !important;
}

body.movo-account-loginpage .woocommerce h2 {
  font-size: 28px;
  font-weight: var(--font-weight-extra);
  color: var(--brand-primary);
  margin: 0 0 24px;
}

/* ============ AUTH HERO PANEL (Figma 16:1049 / 16:891) ============ */
.movo-account-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: stretch;
  margin: 32px 0 0;
}

.movo-auth-hero {
  background: linear-gradient(135deg, #F4F7FF 0%, #F8FAFC 100%);
  border-radius: var(--radius-lg);
  padding: 56px 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 16px;
  min-height: 420px;
}
.movo-auth-hero__art-wrap {
  width: 100%;
  max-width: 480px;
  margin-bottom: 8px;
}
.movo-auth-hero__art {
  width: 100%;
  height: auto;
  display: block;
}
.movo-auth-hero__title {
  font-size: 30px;
  line-height: 1.26;
  font-weight: var(--font-weight-extra);
  color: var(--brand-primary);
  margin: 0;
  max-width: 420px;
}
.movo-auth-hero__lede {
  font-size: 18px;
  line-height: 1.5;
  color: var(--neutral-text-muted);
  margin: 0;
  max-width: 420px;
}

/* When the grid is active, the col2-set inside becomes a single column */
.movo-account-grid .u-columns.col2-set {
  grid-template-columns: 1fr;
}

/* Hide the inactive form column per ?action= */
body.movo-account-view--login .u-column2,
body.movo-account-view--register .u-column1 {
  display: none;
}

body.movo-account-loginpage .woocommerce-form-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
body.movo-account-loginpage .woocommerce-form-row label {
  font-size: 13px;
  font-weight: var(--font-weight-bold);
  color: var(--neutral-text-strong);
}
body.movo-account-loginpage .woocommerce-form input[type="text"],
body.movo-account-loginpage .woocommerce-form input[type="email"],
body.movo-account-loginpage .woocommerce-form input[type="password"],
body.movo-account-loginpage .woocommerce-form input[type="tel"] {
  padding: 12px 16px;
  border-radius: 12px;
  border: 1px solid #E0E7FF;
  background: var(--neutral-surface-3);
  font-size: 14px;
  width: 100%;
}
body.movo-account-loginpage .woocommerce-form button[type="submit"],
body.movo-account-loginpage .woocommerce-form button.button {
  width: 100%;
  padding: 14px 24px;
  background: var(--brand-primary);
  color: #FFFFFF;
  font-weight: var(--font-weight-bold);
  border-radius: 12px;
  border: none;
  font-size: 14px;
  margin-top: 12px;
  cursor: pointer;
}
body.movo-account-loginpage .woocommerce-form button[type="submit"]:hover { background: var(--brand-primary-dark); }

@media (max-width: 900px) {
  body.movo-account-loginpage .woocommerce { grid-template-columns: 1fr; }
  body.movo-account-loginpage .woocommerce::before,
  body.movo-account-loginpage .woocommerce::after { display: none; }
  .movo-account-grid { grid-template-columns: 1fr; gap: 24px; }
  .movo-auth-hero { padding: 40px 24px; min-height: 0; }
  .movo-auth-hero__title { font-size: 24px; }
  .movo-auth-hero__lede { font-size: 16px; }
}

/* ============ ROLE TOGGLE (Customer vs Vendor) ============ */

.movo-role-toggle {
  display: flex;
  background: var(--neutral-surface-3);
  border-radius: 100px;
  padding: 4px;
  margin: 0 0 24px;
}
.movo-role-toggle__btn {
  flex: 1;
  background: transparent;
  border: none;
  padding: 10px 16px;
  border-radius: 100px;
  font-weight: var(--font-weight-bold);
  font-size: 13px;
  color: var(--neutral-text-muted);
  cursor: pointer;
  transition: all .12s ease;
}
.movo-role-toggle__btn.is-active {
  background: var(--brand-primary);
  color: #FFFFFF;
  box-shadow: 0 4px 10px -2px rgba(0,40,175,.3);
}

/* ============ FLASH SALE SECTION ============ */

.movo-flash {
  background: var(--neutral-surface-3);
  border-radius: var(--radius-lg);
  padding: 48px;
  margin-top: 32px;
}

.movo-flash__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 32px;
  flex-wrap: wrap;
  gap: 16px;
}

.movo-flash__title-block { display: flex; flex-direction: column; gap: 8px; }

.movo-flash__tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--brand-accent-orange-3);
  font-size: 12px;
  font-weight: var(--font-weight-bold);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.movo-flash__tag::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand-accent-orange-3);
  display: inline-block;
  animation: movo-pulse 1.5s ease-in-out infinite;
}
@keyframes movo-pulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(1.4); }
}

.movo-flash__countdown {
  font-size: 40px;
  font-weight: var(--font-weight-extra);
  color: var(--neutral-text-strong);
}
.movo-flash__countdown small {
  font-size: 16px;
  font-weight: var(--font-weight-regular);
  color: var(--neutral-text-muted);
  margin-right: 12px;
}

.movo-flash__more {
  color: var(--brand-primary);
  font-weight: var(--font-weight-bold);
  font-size: 14px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.movo-flash__more:hover { color: var(--brand-primary-dark); }

.movo-flash__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.movo-product-card {
  background: #FFFFFF;
  border-radius: var(--radius-md);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform .15s ease, box-shadow .15s ease;
  display: flex;
  flex-direction: column;
}
.movo-product-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.movo-product-card__image {
  position: relative;
  background: var(--neutral-surface-3);
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.movo-product-card__image img { max-width: 80%; max-height: 80%; object-fit: contain; }
.movo-product-card__brand {
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(255,255,255,0.9);
  backdrop-filter: blur(8px);
  padding: 4px 10px;
  border-radius: 100px;
  font-size: 10px;
  font-weight: var(--font-weight-bold);
  color: var(--neutral-text-strong);
  letter-spacing: 0.5px;
}
.movo-product-card__body { padding: 16px; display: flex; flex-direction: column; gap: 6px; }
.movo-product-card__title-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.movo-product-card__name { font-size: 14px; font-weight: var(--font-weight-bold); line-height: 1.4; color: var(--neutral-text-strong); }
.movo-product-card__reward {
  flex-shrink: 0;
  background: var(--brand-gradient-cta);
  color: #FFFFFF;
  padding: 4px 8px;
  border-radius: 8px;
  font-size: 10px;
  font-weight: var(--font-weight-extra);
  letter-spacing: 0.5px;
}
.movo-product-card__price { font-size: 22px; font-weight: var(--font-weight-extra); color: var(--brand-primary); }
.movo-product-card__earn { font-size: 11px; color: var(--neutral-text-muted); }

@media (max-width: 960px) {
  .movo-flash { padding: 24px; }
  .movo-flash__grid { grid-template-columns: repeat(2, 1fr); }
  .movo-flash__countdown { font-size: 28px; }
}
@media (max-width: 480px) { .movo-flash__grid { grid-template-columns: 1fr; } }

/* ============ BRAND GRID (Recommended for you) ============ */

.movo-brands__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}

.movo-brand-card {
  aspect-ratio: 1.3;
  background: var(--neutral-surface-2);
  border: 1px solid #E0E7FF;
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-decoration: none !important;
  color: inherit;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.movo-brand-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--brand-primary); }
.movo-brand-card__logo {
  font-size: 22px;
  font-weight: var(--font-weight-extra);
  color: var(--neutral-text-strong);
  letter-spacing: -0.5px;
}
.movo-brand-card__cashback {
  font-size: 11px;
  color: var(--brand-accent-orange-3);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

@media (max-width: 960px) { .movo-brands__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .movo-brands__grid { grid-template-columns: repeat(2, 1fr); } }

/* Product Image 1:1 Lock (slice 96.4) — single product gallery main image only.
   Page-gated by body.single-product. Targets Blocksy gallery markup
   (.ct-product-gallery-container > .ct-media-container > img). Blocksy injects
   inline `style="aspect-ratio: 3/4"` on the img element, so !important is
   required to win the cascade. object-fit: cover is already Blocksy's default;
   we restate for clarity. */
body.single-product .ct-product-gallery-container .ct-media-container img {
  aspect-ratio: 1 / 1 !important;
  object-fit: cover;
  object-position: center;
}

/* Product Image 1:1 Lock (slice 96.4.a) — WooCommerce loop product cards.
   Covers /shop/, /product-category/*, search results, related products,
   upsells, cross-sells — any place rendering `ul.products li.product`.
   Same Blocksy `.ct-media-container > img` markup as the single-product
   gallery; same inline `aspect-ratio: 3/4` override required. */
ul.products li.product .ct-media-container img {
  aspect-ratio: 1 / 1 !important;
  object-fit: cover;
  object-position: center;
}

/* ============ ABOUT US PAGE — Figma 171:1844 ============ */

.movo-about-hero {
  display: flex;
  align-items: center;
  gap: 48px;
}
.movo-about-hero__content { flex: 1 1 52%; }
.movo-about-hero .movo-hero__badge {
  background: var(--neutral-surface-4);
  border: 0;
  color: var(--brand-primary);
}
.movo-about-hero__headline {
  font-size: 52px;
  line-height: 1.1;
  font-weight: var(--font-weight-extra);
  color: var(--neutral-text-strong);
  margin: 0 0 20px;
}
.movo-about-hero__sub {
  font-size: 17px;
  line-height: 1.6;
  color: var(--neutral-text-muted);
  max-width: 520px;
  margin: 0 0 32px;
}
.movo-about-hero__media { flex: 1 1 48%; }
.movo-about-hero__media img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  display: block;
}

.movo-section__heading--left { text-align: left; }

/* Why Choose Movo — 6-card grid */
.movo-about-why__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.movo-about-card {
  background: var(--neutral-surface-1);
  border: 1px solid var(--neutral-surface-4);
  border-radius: var(--radius-md);
  padding: 28px;
  transition: box-shadow .18s ease, transform .18s ease;
}
.movo-about-card:hover {
  box-shadow: var(--shadow-card);
  transform: translateY(-2px);
}
.movo-about-card__icon { font-size: 26px; display: block; margin-bottom: 14px; }
.movo-about-card__title {
  font-size: 18px;
  font-weight: var(--font-weight-bold);
  color: var(--neutral-text-strong);
  margin: 0 0 8px;
}
.movo-about-card__desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--neutral-text-muted);
  margin: 0;
}

/* Our Story */
.movo-about-story {
  display: flex;
  align-items: center;
  gap: 56px;
}
.movo-about-story__media { flex: 1 1 46%; }
.movo-about-story__media img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  display: block;
}
.movo-about-story__content { flex: 1 1 54%; }
.movo-about-story__lede {
  font-size: 16px;
  line-height: 1.6;
  color: var(--neutral-text-muted);
  margin: 0 0 24px;
}
.movo-about-story__point { margin-bottom: 20px; }
.movo-about-story__point h3 {
  font-size: 17px;
  font-weight: var(--font-weight-bold);
  color: var(--neutral-text-strong);
  margin: 0 0 6px;
}
.movo-about-story__point p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--neutral-text-muted);
  margin: 0;
}

/* Mission / Vision */
.movo-about-mv {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.movo-about-mv__card {
  border-radius: var(--radius-lg);
  padding: 40px;
  color: #FFFFFF;
}
.movo-about-mv__card--blue { background: var(--brand-primary); }
.movo-about-mv__card--orange { background: var(--brand-accent-orange-2, #F99112); }
.movo-about-mv__title {
  font-size: 22px;
  font-weight: var(--font-weight-extra);
  margin: 0 0 12px;
  color: #FFFFFF;
}
.movo-about-mv__body {
  font-size: 15px;
  line-height: 1.6;
  color: rgba(255,255,255,0.92);
  margin: 0;
}

/* CTA band */
.movo-about-cta__inner {
  background: var(--neutral-surface-4);
  border-radius: var(--radius-lg);
  padding: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}
.movo-about-cta__title {
  font-size: 30px;
  font-weight: var(--font-weight-extra);
  color: var(--neutral-text-strong);
  margin: 0 0 8px;
}
.movo-about-cta__sub {
  font-size: 15px;
  color: var(--neutral-text-muted);
  margin: 0;
  max-width: 560px;
}
.movo-about-cta__btn { flex: 0 0 auto; white-space: nowrap; }

@media (max-width: 980px) {
  .movo-about-hero,
  .movo-about-story { flex-direction: column; align-items: stretch; }
  .movo-about-why__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .movo-about-hero__headline { font-size: 38px; }
  .movo-about-why__grid,
  .movo-about-mv { grid-template-columns: 1fr; }
  .movo-about-cta__inner { flex-direction: column; align-items: flex-start; }
}
/* ============ /ABOUT US PAGE ============ */
