/* ═══════════════════════════════════════════════════════ */
/* QejaVerse Website — Mobile-First Styles               */
/* ═══════════════════════════════════════════════════════ */

:root {
  --navy: #0f1c2e;
  --navy-light: #1a3a5c;
  --coral: #e67e51;
  --coral-hover: #d4673f;
  --green: #22c55e;
  --amber: #f59e0b;
  --red: #ef4444;
  --gray-50: #f8fafc;
  --gray-100: #f1f5f9;
  --gray-200: #e2e8f0;
  --gray-400: #94a3b8;
  --gray-500: #64748b;
  --gray-700: #334155;
  --gray-900: #1e293b;
  --white: #ffffff;
  --font: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --radius: 12px;
  --radius-sm: 8px;
  --shadow: 0 4px 24px rgba(0,0,0,.08);
  --shadow-lg: 0 12px 48px rgba(0,0,0,.12);
}

/* ─── FRAPPE OVERRIDES (escape default wrappers) ─── */
.navbar, .web-footer, .page-header-wrapper, .breadcrumb-container, .website-footer { display: none !important; }
.main-section { padding: 0 !important; max-width: none !important; }
.web-content, .container, .page-content-wrapper { max-width: none !important; padding: 0 !important; margin: 0 !important; }
[data-page-container] { padding: 0 !important; max-width: none !important; }
body > .container, .main-section > .container { max-width: none !important; padding: 0 !important; }

/* ─── RESET ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body { font-family: var(--font); color: var(--gray-900); line-height: 1.6; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, select { font-family: inherit; font-size: 1rem; }

/* ─── LAYOUT ─── */
.qv-container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }
.qv-container--narrow { max-width: 640px; }
.qv-section { padding: 5rem 0; }
.qv-section--dark { background: var(--navy); color: var(--white); }
.qv-section--gray { background: var(--gray-50); }
.qv-section--gradient { background: linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 100%); color: var(--white); }
.qv-section__title { font-size: 1.75rem; font-weight: 700; line-height: 1.2; margin-bottom: 1rem; color: var(--navy-light); }
.qv-section__subtitle { font-size: 1.1rem; color: var(--gray-500); margin-bottom: 2rem; }
.qv-section--dark .qv-section__title { color: var(--white); }
.qv-section--dark .qv-section__subtitle { color: var(--gray-400); }
.qv-highlight { color: var(--coral); }

/* ─── BUTTONS ─── */
.qv-btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; padding: .875rem 1.75rem; font-size: 1rem; font-weight: 600; border-radius: var(--radius-sm); transition: all .2s; }
.qv-btn--primary { background: var(--coral); color: var(--white); border: 2px solid var(--coral); transition: all .3s ease; }
.qv-btn--primary:hover { background: transparent; color: var(--white); border-color: var(--white); }
.qv-btn--lg { padding: 1rem 2rem; font-size: 1.1rem; }
.qv-btn--full { width: 100%; }
.qv-btn--ghost { background: transparent; color: var(--gray-500); border: 1px solid var(--gray-200); }
.qv-btn--outline { background: transparent; color: var(--coral); border: 1px solid var(--coral); }
.qv-btn--outline:hover { background: var(--coral); color: var(--white); }
.qv-btn--whatsapp { background: #25D366; color: var(--white); }
.qv-btn--whatsapp:hover { background: #1fb855; }
.qv-btn--nav { display: none; padding: .625rem 1.25rem; font-size: .875rem; background: var(--coral); color: var(--white); border: 2px solid var(--coral); border-radius: var(--radius-sm); transition: all .3s ease; }
.qv-btn--nav:hover { background: transparent; color: var(--white); border-color: var(--white); }

/* ─── NAVIGATION ─── */
.qv-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 1rem 1.5rem; background: transparent; transition: background .3s, box-shadow .3s; }
.qv-nav.scrolled { background: rgba(15,28,46,.97); backdrop-filter: blur(10px); box-shadow: 0 2px 20px rgba(0,0,0,.15); }
.qv-nav__inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; }
.qv-nav__logo { font-size: 1.5rem; font-weight: 700; color: var(--coral); text-decoration: none !important; transition: color .3s; }
.qv-nav__logo span { color: var(--coral); }
.qv-nav__logo:hover { color: var(--white); text-decoration: none !important; }
.qv-nav__logo:hover span { color: var(--coral); }
.qv-nav__links { display: none; }
.qv-nav__links a { color: var(--white); font-size: .9rem; opacity: .7; transition: opacity .3s, color .3s; text-decoration: none !important; position: relative; padding-bottom: 6px; }
.qv-nav__links a::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 2px; background: var(--coral); transition: width .3s ease; }
.qv-nav__links a:hover { opacity: 1; color: var(--coral); }
.qv-nav__links a:hover::after { width: 100%; }
.qv-nav__burger { display: flex; flex-direction: column; gap: 5px; padding: .5rem; }
.qv-nav__burger span { display: block; width: 24px; height: 2px; background: var(--white); border-radius: 2px; transition: transform .3s, opacity .3s; }
.qv-nav__burger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.qv-nav__burger.active span:nth-child(2) { opacity: 0; }
.qv-nav__burger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.qv-nav__mobile { display: none; flex-direction: column; gap: 1rem; padding: 1.5rem; background: var(--navy); border-radius: var(--radius); margin-top: 1rem; }
.qv-nav__mobile.open { display: flex; }
.qv-nav__mobile a { color: var(--white); font-size: 1.1rem; padding: .5rem 0; }

/* ─── HERO ─── */
.qv-hero { min-height: 100vh; min-height: 100dvh; display: flex; align-items: center; padding: 7rem 1.5rem 4rem; background: var(--navy); color: var(--white); position: relative; overflow: hidden; }
.qv-hero__bg { position: absolute; inset: 0; background: url('/assets/casahub_app/website/images/hero-nairobi-mobile.webp') center/cover no-repeat; opacity: .45; }
.qv-hero__bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(15,28,46,.7) 0%, rgba(15,28,46,.3) 50%, rgba(15,28,46,.5) 100%); }
.qv-hero__inner { position: relative; z-index: 1; max-width: 1200px; margin: 0 auto; width: 100%; display: flex; flex-direction: column; gap: 3rem; }
.qv-hero__content { max-width: 560px; }
.qv-hero__title { font-size: 2.5rem; font-weight: 700; line-height: 1.1; margin-bottom: 1.25rem; color: var(--white); }
.qv-nav__logo-icon { width: 36px; height: 36px; margin-right: .5rem; vertical-align: middle; display: inline-block; }

@media (min-width: 1024px) {
  .qv-nav__logo-icon { display: none; }
}
.qv-hero__sub { font-size: 1.15rem; color: rgba(255,255,255,.75); margin-bottom: 2rem; line-height: 1.5; }
.qv-hero__meta { margin-top: 2rem; display: flex; flex-direction: column; gap: .75rem; }
.qv-hero__badge { display: inline-block; font-size: .8rem; color: var(--coral); font-weight: 600; border: 1px solid rgba(232,103,60,.3); padding: .375rem .875rem; border-radius: 100px; background: rgba(232,103,60,.08); width: fit-content; }
.qv-hero__speed { font-size: .875rem; color: rgba(255,255,255,.5); }
.qv-hero__visual { display: none; }
.qv-hero-cube { width: 100%; max-width: 420px; aspect-ratio: 1; }
.qv-hero-cube__fallback { width: 100%; height: 100%; object-fit: contain; }

/* ─── PROBLEM CARDS (horizontal scroll on mobile) ─── */
.qv-cards--scroll { display: flex; gap: 1rem; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; padding-bottom: 1rem; margin: 0 -1.5rem; padding-left: 1.5rem; padding-right: 1.5rem; }
.qv-cards--scroll::-webkit-scrollbar { display: none; }
.qv-scroll-hint { display: block; text-align: center; font-size: .7rem; color: var(--gray-400); margin-top: .5rem; letter-spacing: .1em; }
.qv-scroll-hint--light { color: rgba(255,255,255,.3); }
.qv-card { flex: 0 0 280px; scroll-snap-align: start; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--radius); padding: 1.5rem; }
.qv-card__icon { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; background: rgba(232,103,60,.15); border-radius: 50%; margin-bottom: 1rem; color: var(--coral); }
.qv-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: .5rem; color: var(--white); }
.qv-card p { font-size: .9rem; color: var(--gray-400); line-height: 1.4; }

/* ─── MARKET STATS ─── */
.qv-stats { padding: 4rem 0; }
.qv-stats__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; margin-bottom: 2rem; }
.qv-stat { text-align: center; }
.qv-stat__number { font-size: 3rem; font-weight: 700; color: var(--white); line-height: 1; }
.qv-stat__suffix { font-size: 1.5rem; font-weight: 700; color: var(--coral); }
.qv-stat__label { display: block; font-size: .8rem; color: var(--gray-400); margin-top: .5rem; text-transform: uppercase; letter-spacing: .05em; }
.qv-stats__quote { font-size: 1.1rem; font-style: italic; color: var(--gray-400); text-align: center; max-width: 600px; margin: 0 auto; }

/* ─── SOLUTION PILLARS ─── */
.qv-pillars { display: flex; flex-direction: column; gap: 1.5rem; }
.qv-pillar { display: flex; gap: 1rem; align-items: flex-start; padding: 1.5rem; background: var(--gray-50); border-radius: var(--radius); }
.qv-pillar__num { flex-shrink: 0; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: var(--coral); color: var(--white); font-weight: 700; border-radius: var(--radius-sm); }
.qv-pillar h3 { font-size: 1.1rem; font-weight: 600; margin-bottom: .25rem; color: var(--navy-light); }
.qv-pillar p { font-size: .9rem; color: var(--gray-500); }

/* ─── AVAILABILITY GRID ─── */
.qv-grid-feature { display: flex; flex-direction: column; gap: 2rem; }
.qv-grid-feature__text .qv-section__title { margin-bottom: .75rem; }
.qv-grid-feature__text p { color: var(--gray-500); margin-bottom: 1.5rem; }
.qv-grid-feature__embed { font-size: .9rem; font-weight: 500; color: var(--gray-700); margin-bottom: 1.5rem !important; }
.qv-legend { display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: 1.5rem; }
.qv-legend__item { display: flex; align-items: center; gap: .375rem; font-size: .8rem; font-weight: 500; }
.qv-legend__item::before { content: ''; width: 12px; height: 12px; border-radius: 3px; }
.qv-legend__item--available::before { background: var(--green); }
.qv-legend__item--reserved::before { background: var(--amber); }
.qv-legend__item--booked::before { background: var(--coral); }
.qv-legend__item--sold::before { background: var(--navy); }
.qv-cube-container { width: 100%; max-width: 400px; aspect-ratio: 1; margin: 0 auto; position: relative; }
.qv-cube-fallback { width: 100%; height: 100%; object-fit: contain; }

/* ─── BEFORE / AFTER ─── */
.qv-compare { display: flex; flex-direction: column; gap: 1.5rem; }
.qv-compare__row { display: grid; gap: 1rem; }
.qv-compare__before, .qv-compare__after { padding: 1rem 1.25rem; border-radius: var(--radius-sm); font-size: .95rem; line-height: 1.5; display: flex; gap: .75rem; }
.qv-compare__before { background: #fef2f2; color: #991b1b; }
.qv-compare__after { background: #f0fdf4; color: #166534; }
.qv-compare__x { color: var(--red); font-weight: 700; flex-shrink: 0; }
.qv-compare__check { color: var(--green); font-weight: 700; flex-shrink: 0; }

/* ─── HOW IT WORKS (JOURNEY) ─── */
.qv-journey { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.qv-journey__step { position: relative; padding: 1.25rem; padding-left: 4rem; }
.qv-journey__num { position: absolute; left: 0; top: 1.25rem; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: var(--coral); color: var(--white); font-size: .875rem; font-weight: 700; border-radius: 50%; }
.qv-journey__step h3 { font-size: 1rem; font-weight: 600; margin-bottom: .25rem; color: var(--navy-light); }
.qv-journey__step p { font-size: .9rem; color: var(--gray-500); }

/* ─── WHO IT'S FOR (ROLES) ─── */
.qv-roles { display: flex; gap: 1rem; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; margin: 0 -1.5rem; padding: 0 1.5rem 1rem; }
.qv-roles::-webkit-scrollbar { display: none; }
.qv-role { flex: 0 0 280px; scroll-snap-align: start; padding: 1.5rem; background: var(--gray-50); border-radius: var(--radius); }
.qv-role__icon { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; background: rgba(232,103,60,.1); color: var(--coral); border-radius: 50%; margin-bottom: 1rem; }
.qv-role h3 { font-size: 1rem; font-weight: 600; margin-bottom: .5rem; color: var(--navy-light); }
.qv-role p { font-size: .9rem; color: var(--gray-500); line-height: 1.5; }

/* ─── PDF DOWNLOADS ─── */
.qv-downloads { margin-top: 2rem; display: flex; flex-direction: column; gap: .75rem; }
.qv-download { display: flex; align-items: center; gap: .75rem; padding: 1rem 1.25rem; background: var(--gray-50); border: 1px solid var(--gray-200); border-radius: var(--radius-sm); font-weight: 500; transition: border-color .2s, background .2s; }
.qv-download:hover { border-color: var(--coral); background: var(--white); }
.qv-download svg { color: var(--coral); flex-shrink: 0; }

/* ─── WHAT HAPPENS NEXT ─── */
.qv-steps { display: flex; flex-direction: column; gap: 1.5rem; margin-bottom: 1.5rem; }
.qv-step { display: flex; align-items: center; gap: 1rem; }
.qv-step__num { flex-shrink: 0; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: var(--navy); color: var(--white); font-weight: 700; border-radius: 50%; }
.qv-step p { font-size: 1rem; font-weight: 500; }
.qv-steps__note { font-size: .9rem; color: var(--gray-500); text-align: center; }

/* ─── BUYER WAITLIST ─── */
.qv-waitlist-form { display: flex; flex-direction: column; gap: .75rem; max-width: 400px; margin: 0 auto; position: relative; }
.qv-waitlist-form input[type="email"] { padding: .875rem 1rem; border: 1px solid rgba(255,255,255,.2); border-radius: var(--radius-sm); background: rgba(255,255,255,.1); color: var(--white); font-size: 1rem; }
.qv-waitlist-form input::placeholder { color: var(--gray-400); }

/* ─── FOUNDING PARTNERS ─── */
.qv-founding { text-align: center; }
.qv-founding__counter { font-size: 1.25rem; font-weight: 700; margin-bottom: 2rem; padding: 1rem; background: var(--gray-50); border-radius: var(--radius-sm); display: inline-block; }
.qv-founding__spots { color: var(--coral); font-size: 2rem; }
.qv-founding__list { text-align: left; max-width: 400px; margin: 0 auto 2rem; }
.qv-founding__list li { padding: .5rem 0; padding-left: 1.5rem; position: relative; font-size: .95rem; color: var(--gray-700); }
.qv-founding__list li::before { content: '✓'; position: absolute; left: 0; color: var(--coral); font-weight: 700; }
.qv-founding__quote { margin-top: 3rem; font-style: italic; color: var(--gray-500); font-size: 1rem; max-width: 600px; margin-left: auto; margin-right: auto; text-align: center; border-left: 3px solid var(--coral); padding-left: 1.5rem; text-align: left; }

/* ─── DEMO FORM ─── */
.qv-form { position: relative; }
.qv-form__step { display: none; flex-direction: column; gap: 1rem; }
.qv-form__step--active { display: flex; }
.qv-form input, .qv-form select, .qv-form textarea { padding: .875rem 1rem; border: 1px solid var(--gray-200); border-radius: var(--radius-sm); font-size: 1rem; background: var(--white); transition: border-color .2s; width: 100%; font-family: inherit; }
.qv-form input:focus, .qv-form select:focus, .qv-form textarea:focus { outline: none; border-color: var(--coral); }
.qv-section--dark .qv-form input, .qv-section--dark .qv-form select { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.2); color: var(--white); }
.qv-section--dark .qv-form input::placeholder { color: var(--gray-400); }
.qv-section--dark .qv-form select { color: var(--gray-400); }
.qv-section--dark .qv-form__alt span { color: rgba(255,255,255,.4); }
.qv-form__alt { text-align: center; margin-top: 1.5rem; }
.qv-form__alt span { display: block; color: var(--gray-400); margin-bottom: .75rem; font-size: .9rem; }
.qv-form__proof { text-align: center; margin-top: 1.5rem; font-size: .85rem; color: var(--gray-500); }
.qv-form__success { text-align: center; padding: 2rem 0; }
.qv-form__success h3 { color: var(--green); margin-bottom: .5rem; }
.qv-form__success p { color: var(--gray-500); margin-bottom: 1rem; }

/* ─── CONTACT GRID (2 column) ─── */
.qv-contact-grid { display: flex; flex-direction: column; gap: 2.5rem; }
.qv-contact-grid__form { flex: 1; padding: 2rem; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.08); border-radius: 1.25rem; position: relative; overflow: hidden; }
.qv-contact-grid__form::before { content: ''; position: absolute; top: -50%; right: -30%; width: 300px; height: 300px; background: radial-gradient(circle, rgba(230,126,81,.06) 0%, transparent 70%); pointer-events: none; }
.qv-contact-grid__side { flex: 1; display: flex; flex-direction: column; gap: 1.25rem; }
.qv-contact-side__block { padding: 1.75rem; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 1rem; position: relative; overflow: hidden; transition: border-color .3s; }
.qv-contact-side__block:hover { border-color: rgba(230,126,81,.3); }
.qv-contact-side__block::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--coral), rgba(230,126,81,.2), transparent); }

@media (min-width: 768px) {
  .qv-contact-grid { flex-direction: row; gap: 3rem; align-items: stretch; }
  .qv-contact-grid__form { flex: 1.1; }
  .qv-contact-grid__side { flex: 0.9; justify-content: center; }
}

/* ─── FAQ ─── */
.qv-faq { display: flex; flex-direction: column; gap: 0; }
.qv-faq__item { border-bottom: 1px solid var(--gray-200); }
.qv-faq__item summary { padding: 1.25rem 0; font-weight: 600; font-size: 1rem; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; }
.qv-faq__item summary::after { content: '+'; font-size: 1.5rem; color: var(--gray-400); transition: transform .2s; }
.qv-faq__item[open] summary::after { content: '−'; }
.qv-faq__item p { padding: 0 0 1.25rem; color: var(--gray-500); font-size: .95rem; }

/* ─── FOOTER ─── */
.qv-footer { background: var(--navy); color: var(--white); padding: 4rem 0 2rem; }
.qv-footer__grid { display: grid; gap: 2rem; margin-bottom: 3rem; text-align: center; }
.qv-footer__brand { margin-bottom: 1rem; }
.qv-footer__col h4 { font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; color: var(--gray-400); margin-bottom: .75rem; }
.qv-footer__col a { display: block; color: var(--gray-400); font-size: .9rem; padding: .25rem 0; transition: color .2s; }
.qv-footer__col a:hover { color: var(--white); }
.qv-footer__bottom { border-top: 1px solid rgba(255,255,255,.1); padding-top: 1.5rem; text-align: center; }
.qv-footer__bottom p { font-size: .85rem; color: var(--gray-500); }

/* ─── STICKY MOBILE CTA ─── */
.qv-sticky-cta { position: fixed; bottom: 0; left: 0; right: 0; z-index: 90; padding: .75rem 1rem; background: var(--white); border-top: 1px solid var(--gray-200); box-shadow: 0 -4px 12px rgba(0,0,0,.08); transform: translateY(100%); transition: transform .3s; }
.qv-sticky-cta.visible { transform: translateY(0); }

/* ─── FEATURE CARDS (white bg variant) ─── */
.qv-card--feature { background: var(--white); border: 1px solid var(--gray-200); transition: border-color .3s, box-shadow .3s; }
.qv-card--feature:hover { border-color: rgba(230,126,81,.3); box-shadow: 0 4px 20px rgba(30,58,95,.08); }
.qv-card--feature h3 { color: var(--navy-light); }
.qv-card--feature p { color: var(--gray-500); }
.qv-card__icon--gradient { background: linear-gradient(135deg, #1e3a5f, #e67e51) !important; color: var(--white) !important; border-radius: var(--radius-sm); }
.qv-features-grid { gap: 1rem; }

/* ─── ROLE TABS ─── */
.qv-role-tabs__nav { display: flex; gap: .5rem; margin-bottom: 1.5rem; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: .25rem; }
.qv-role-tabs__nav::-webkit-scrollbar { display: none; }
.qv-role-tabs__btn { flex-shrink: 0; padding: .625rem 1.25rem; border-radius: var(--radius-sm); font-size: .875rem; font-weight: 500; color: var(--gray-500); border: 1px solid var(--gray-200); background: var(--white); transition: all .2s; }
.qv-role-tabs__btn:hover { border-color: var(--navy); color: var(--navy); }
.qv-role-tabs__btn--active, .qv-role-tabs__btn--active:hover { background: var(--navy) !important; color: var(--white) !important; border-color: var(--navy) !important; box-shadow: 0 4px 12px rgba(15,28,46,.2); }
.qv-role-tabs__panel { display: none; padding: 1.5rem; border: 1px solid var(--gray-200); border-radius: var(--radius); background: var(--white); box-shadow: var(--shadow); }
.qv-role-tabs__panel--active { display: block; }
.qv-role-tabs__header { display: flex; align-items: center; gap: .75rem; margin-bottom: 1.25rem; }
.qv-role-tabs__icon { width: 44px; height: 44px; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; color: var(--white); background: linear-gradient(135deg, #1e3a5f, #e67e51); flex-shrink: 0; }
.qv-role-tabs__header h3 { font-size: 1.25rem; font-weight: 700; color: var(--navy-light); }
.qv-role-tabs__list { display: grid; grid-template-columns: 1fr; gap: .5rem; }
.qv-role-tabs__list li { display: flex; align-items: flex-start; gap: .625rem; padding: .625rem .75rem; background: var(--gray-50); border: 1px solid var(--gray-100); border-radius: var(--radius-sm); font-size: .9rem; color: var(--gray-700); line-height: 1.4; }
.qv-role-tabs__list li::before { content: ''; width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237ba591' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpolyline points='22 4 12 14.01 9 11.01'/%3E%3C/svg%3E"); background-size: contain; background-repeat: no-repeat; }

/* ─── MARKETPLACE GRID ─── */
.qv-marketplace-grid { gap: 1rem; }

/* ─── HOW IT WORKS (4-step variant) ─── */
.qv-steps--four { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.qv-steps--four .qv-step { flex-direction: column; align-items: center; text-align: center; gap: .75rem; }
.qv-steps--four .qv-step h4 { font-size: .95rem; font-weight: 600; color: var(--navy-light); margin-top: .25rem; }
.qv-steps--four .qv-step p { font-size: .85rem; color: var(--gray-500); }

/* ─── PRICING ─── */
.qv-pricing { display: grid; grid-template-columns: 1fr; gap: 1.25rem; max-width: 900px; margin: 0 auto; }
.qv-pricing__card { padding: 1.75rem; border-radius: var(--radius); border: 1px solid var(--gray-200); background: var(--white); position: relative; }
.qv-pricing__card--primary { background: linear-gradient(135deg, #1e3a5f 0%, #2d5a8e 100%); border: none; box-shadow: 0 12px 40px rgba(30,58,95,.35); color: var(--white); transform: scale(1.03); }
.qv-pricing__card--primary h3 { color: var(--white) !important; font-size: 1.25rem !important; }
.qv-pricing__card--primary .qv-pricing__price { color: var(--coral) !important; font-size: 1.75rem !important; }
.qv-pricing__card--primary .qv-pricing__price span { color: rgba(255,255,255,.6) !important; }
.qv-pricing__card--primary ul li { color: var(--white) !important; }
.qv-pricing__card--primary ul li::before { border-color: var(--coral) !important; }
.qv-pricing__card--primary .qv-pricing__note { color: rgba(255,255,255,.5); }
.qv-pricing__badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); padding: .25rem .75rem; background: var(--coral); color: var(--white); font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; border-radius: 100px; }
.qv-pricing__icon { width: 40px; height: 40px; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.qv-pricing__card h3 { font-size: 1.1rem; font-weight: 700; color: var(--navy-light); margin-bottom: .25rem; }
.qv-pricing__price { font-size: 1.5rem; font-weight: 800; color: var(--navy-light); margin-bottom: 1rem; }
.qv-pricing__price span { font-size: .85rem; font-weight: 400; color: var(--gray-400); }
.qv-pricing__price--highlight { color: var(--coral); }
.qv-pricing__price--highlight span { color: rgba(255,255,255,.5); }
.qv-pricing__card ul { margin: 0; padding: 0; }
.qv-pricing__card ul li { padding: .375rem 0; padding-left: 1.5rem; position: relative; font-size: .9rem; color: var(--gray-500); }
.qv-pricing__card ul li::before { content: ''; position: absolute; left: 0; top: .625rem; width: 14px; height: 14px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237ba591' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpolyline points='22 4 12 14.01 9 11.01'/%3E%3C/svg%3E"); background-size: contain; background-repeat: no-repeat; }
.qv-pricing__note { margin-top: .75rem; font-size: .8rem; font-style: italic; color: var(--gray-400); }

/* ─── TRUST SIGNALS ─── */
.qv-trust { display: grid; grid-template-columns: 1fr; gap: 2rem; }
.qv-trust__item { text-align: center; padding: 1rem; }
.qv-trust__icon { width: 48px; height: 48px; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem; color: var(--coral); background: rgba(230,126,81,.12); border: 1px solid rgba(230,126,81,.2); }
.qv-trust__item h3 { font-size: 1rem; font-weight: 600; color: var(--white); margin-bottom: .5rem; }
.qv-trust__item p { font-size: .9rem; color: rgba(255,255,255,.5); line-height: 1.5; }

/* ─── FLOATING WHATSAPP ─── */
.qv-whatsapp-float { position: fixed; bottom: 5.5rem; right: 1rem; z-index: 80; width: 56px; height: 56px; background: #25D366; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 12px rgba(37,211,102,.4); transition: transform .2s; }
.qv-whatsapp-float:hover { transform: scale(1.1); }

/* ═══════════════════════════════════════════════════════ */
/* TABLET (768px+)                                       */
/* ═══════════════════════════════════════════════════════ */
@media (min-width: 768px) {
  .qv-section { padding: 6rem 0; }
  .qv-section__title { font-size: 2.25rem; }
  .qv-hero { padding: 8rem 2rem 5rem; }
  .qv-hero__title { font-size: 3rem; }
  .qv-hero__visual { display: block; }
  .qv-stats__grid { grid-template-columns: repeat(4, 1fr); }
  .qv-stat__number { font-size: 3.5rem; }
  .qv-compare__row { grid-template-columns: 1fr 1fr; }
  .qv-journey { grid-template-columns: repeat(2, 1fr); }
  .qv-steps { flex-direction: row; justify-content: center; gap: 2rem; }
  .qv-steps--four { grid-template-columns: repeat(4, 1fr); }
  .qv-footer__grid { grid-template-columns: 2fr 1fr 1fr 1fr; text-align: left; }
  .qv-waitlist-form { flex-direction: row; }
  .qv-waitlist-form .qv-btn { white-space: nowrap; }
  .qv-sticky-cta { display: none; }
  .qv-scroll-hint { display: none; }
  .qv-whatsapp-float { bottom: 2rem; right: 2rem; }
  .qv-role-tabs__list { grid-template-columns: 1fr 1fr; }
  .qv-role-tabs__nav { justify-content: center; }
  .qv-pricing { grid-template-columns: repeat(3, 1fr); }
  .qv-trust { grid-template-columns: repeat(3, 1fr); }
  .qv-marketplace-grid { flex-wrap: wrap; overflow: visible; margin: 0; padding-left: 0; padding-right: 0; }
  .qv-marketplace-grid .qv-card { flex: 1 1 280px; }
}

/* ═══════════════════════════════════════════════════════ */
/* DESKTOP (1024px+)                                     */
/* ═══════════════════════════════════════════════════════ */
@media (min-width: 1024px) {
  .qv-section { padding: 7rem 0; }
  .qv-section__title { font-size: 2.75rem; }
  .qv-hero { padding: 0 3rem; }
  .qv-hero__inner { flex-direction: row; align-items: center; gap: 4rem; }
  .qv-hero__content { flex: 1; max-width: 560px; }
  .qv-hero__title { font-size: 3.75rem; }
  .qv-hero__visual { display: flex; flex: 1; align-items: center; justify-content: center; }
  .qv-hero-cube { max-width: 480px; }
  .qv-hero__bg { background-image: url('/assets/casahub_app/website/images/hero-nairobi.webp'); }

  /* Nav desktop */
  .qv-nav__links { display: flex; gap: 2rem; }
  .qv-nav__burger { display: none; }
  .qv-btn--nav { display: inline-flex; }

  /* Cards: no scroll on desktop */
  .qv-cards--scroll { flex-wrap: wrap; overflow: visible; margin: 0; padding-left: 0; padding-right: 0; }
  .qv-card { flex: 1 1 200px; }
  .qv-features-grid .qv-card { flex: 1 1 320px; }

  /* Pillars horizontal */
  .qv-pillars { flex-direction: row; }
  .qv-pillar { flex: 1; flex-direction: column; text-align: center; align-items: center; }

  /* Grid feature: side by side */
  .qv-grid-feature { flex-direction: row; align-items: center; }
  .qv-grid-feature__text { flex: 1; }
  .qv-grid-feature__cube { flex: 1; max-width: 500px; }
  .qv-cube-container { max-width: 500px; }

  /* Roles: no scroll on desktop */
  .qv-roles { flex-wrap: wrap; overflow: visible; margin: 0; padding: 0; }
  .qv-role { flex: 1 1 300px; }

  /* Downloads horizontal */
  .qv-downloads { flex-direction: row; }

  /* Journey 3-col */
  .qv-journey { grid-template-columns: repeat(3, 1fr); }

  /* Floating WhatsApp - hide on desktop (it's in the form section) */
  .qv-whatsapp-float { display: none; }
}
