:root{--dark:#021408;--cream:#dfe4e0;--danger:#e05252;--white:#fff;--accent:#021408;--gray:#8a9a90;--gray-bg:#f0f2f1;--font-heading:"Arial Black", sans-serif;--font-body:"Inter", sans-serif;--font-display:"Arial Black", sans-serif;--fq-green:#021408;--fq-dark:#021408;--fq-green-bg:#dfe4e0;--fq-danger:#e05252;--fq-success:#021408;--fq-card-bg:#fffffff2;--fq-card-border:#02140814;--fq-gray-400:#0214084d;--fq-accent-gold:#021408;--gradient-card:linear-gradient(145deg, #fffffff2, #dfe4e0e6);--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-full:9999px;--shadow-card:0 2px 12px #0214080f;--shadow-green:0 8px 32px #02140826;--ease-out:cubic-bezier(.4, 0, .2, 1);--ease-spring:cubic-bezier(.16, 1, .3, 1)}*,:before,:after{box-sizing:border-box;-webkit-font-smoothing:antialiased;margin:0;padding:0}html{height:100%;font-size:16px}body{font-family:var(--font-body);background:var(--cream);color:var(--dark);-webkit-tap-highlight-color:transparent;width:100vw;min-height:100vh;line-height:1.55;overflow-x:hidden}#app{width:100%;min-height:100vh;padding-bottom:90px;position:relative}.loading-screen{background:var(--cream);flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:100vh;display:flex}.loading-logo-img{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:220px;height:auto;margin:0 auto 12px;display:block}.loading-spinner{border:3px solid #02140826;border-top-color:var(--dark);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{transform:translateY(120%)}to{transform:translateY(0)}}@keyframes beamSweep{0%{opacity:0;top:5%}10%{opacity:1}90%{opacity:1}to{opacity:0;top:92%}}@keyframes pageIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scannerOpen{0%{opacity:0}to{opacity:1}}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes statusPulse{0%,to{box-shadow:0 0 #02140826}50%{box-shadow:0 0 0 20px #02140800}}@keyframes itemSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes scanPulse{0%{opacity:.6;width:130px;height:130px}to{opacity:0;width:220px;height:220px}}.auth-screen{min-height:100vh;background:var(--cream);min-height:100dvh;color:var(--dark);flex-direction:column;display:flex;overflow:hidden}.brand-header,.auth-brand-header{flex-direction:column;justify-content:center;align-items:center;padding:60px 24px 40px;display:flex;position:relative}.brand-logo,.auth-logo-img{filter:drop-shadow(0 10px 20px #02140826);width:auto;height:90px;animation:scaleIn .8s var(--ease-spring) forwards;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;margin-bottom:40px;display:block}.welcome-title,.auth-welcome{font-family:var(--font-heading);color:var(--dark);text-align:center;letter-spacing:1px;opacity:0;margin-bottom:12px;font-size:1.8rem;animation:.8s ease-out .1s forwards fadeUp}.welcome-sub,.auth-subtitle{color:var(--accent);text-align:center;opacity:0;font-size:1rem;font-weight:600;animation:.8s ease-out .2s forwards fadeUp}.form-pane,.auth-form{opacity:0;flex-direction:column;flex:1;width:100%;max-width:480px;margin:0 auto;padding:0 32px 40px;animation:.8s ease-out .3s forwards fadeUp;display:flex}.input-label,.auth-label{text-align:left;font-family:var(--font-body);color:var(--gray);text-transform:uppercase;letter-spacing:1.5px;margin-top:40px;margin-bottom:12px;font-size:.75rem;font-weight:700;display:block}.phone-wrap,.phone-input-group{background:0 0;border:1.5px solid #0214081a;border-radius:20px;transition:border-color .3s,box-shadow .3s;display:flex;overflow:hidden;box-shadow:inset 0 2px 4px #00000005}.phone-wrap:focus-within,.phone-input-group:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px #0214081a}.phone-prefix{font-family:var(--font-body);color:var(--dark);white-space:nowrap;background:#02140805;border-right:1.5px solid #0214081a;align-items:center;padding:18px 24px;font-size:1.1rem;font-weight:700;display:flex}.phone-input,.phone-input-group input,.phone-wrap input{font-family:var(--font-body);color:var(--dark);letter-spacing:1px;background:0 0;border:none;outline:none;flex:1;padding:18px;font-size:1.1rem}.phone-input::placeholder,.phone-input-group input::placeholder,.phone-wrap input::placeholder{color:#0214084d}.otp-grid,.otp-group{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:12px;display:grid}.otp-box{aspect-ratio:1;background:#02140805;border:1.5px solid #0214081a;border-radius:20px;justify-content:center;align-items:center;display:flex}.otp-dot{background:#02140826;border-radius:50%;width:10px;height:10px}.otp-input{aspect-ratio:1;text-align:center;width:100%;color:var(--dark);font-family:var(--font-heading);background:#02140805;border:1.5px solid #0214081a;border-radius:20px;outline:none;font-size:1.6rem;font-weight:700;transition:border-color .3s,box-shadow .3s}.otp-input:focus{border-color:var(--dark);box-shadow:0 0 0 4px #02140814}.otp-disabled{opacity:.4;pointer-events:none}.btn-primary{background:var(--accent);width:100%;color:var(--white);font-family:var(--font-body);cursor:pointer;border:none;border-radius:20px;justify-content:center;align-items:center;gap:10px;margin-top:24px;padding:18px;font-size:1rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 10px 20px #02140833}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;pointer-events:none}.btn-secondary{width:100%;color:var(--white);font-family:var(--font-body);cursor:default;pointer-events:none;background:#02140866;border:none;border-radius:20px;justify-content:center;align-items:center;gap:10px;margin-top:24px;padding:18px;font-size:1rem;font-weight:700;display:flex}.step-indicator,.auth-step-label{text-align:center;color:var(--gray);margin-top:auto;padding-top:40px;font-size:.8rem;font-weight:500}.auth-error{color:var(--danger);text-align:center;margin-top:12px;margin-bottom:12px;font-size:.75rem;font-weight:500}.auth-resend{color:#02140873;font-size:.78rem;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;gap:6px;margin-top:20px;padding:10px;transition:color .2s;display:flex}.auth-resend:hover{color:var(--dark)}.auth-resend:disabled{opacity:.5;pointer-events:none}.scanner-overlay{background:var(--dark);z-index:1000;animation:scannerOpen .35s var(--ease-out);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.scanner-overlay.scanner-embedded{z-index:1;min-height:100vh;position:relative}.scanner-header{z-index:10;background:linear-gradient(#021408e6 0%,#02140800 100%);flex-shrink:0;justify-content:space-between;align-items:center;padding:24px 20px;display:flex}.scanner-logo-img{object-fit:contain;filter:drop-shadow(0 4px 16px #0000004d);-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:auto;height:68px;display:block}.scan-body{background:#ffffff1f;border-top:1px solid #ffffff14;border-bottom:1px solid #ffffff14;flex-direction:column;flex:1;justify-content:center;align-items:center;margin:16px 0;padding:0 24px;display:flex}.scan-label{font-family:var(--font-heading);color:var(--cream);letter-spacing:3px;text-transform:uppercase;text-align:center;opacity:.7;margin-bottom:28px;font-size:.95rem}.viewfinder-frame{aspect-ratio:1;border-radius:12px;width:calc(100vw - 80px);max-width:380px;margin-bottom:28px;position:relative;overflow:hidden}.scan-window{background:#dfe4e009;border:1px solid #dfe4e00f;border-radius:20px;position:absolute;top:14px;bottom:14px;left:14px;right:14px;overflow:hidden}.qr-reader-container{z-index:1;border-radius:20px;position:absolute;top:14px;bottom:14px;left:14px;right:14px;overflow:hidden}.qr-reader-container video{border-radius:20px;object-fit:cover!important;width:100%!important;height:100%!important}#qr-reader__dashboard,#qr-reader__scan_region>img,#qr-reader__header_message{display:none!important}.corner{z-index:3;pointer-events:none;border-style:solid;border-color:#dfe4e073;width:40px;height:40px;position:absolute}.corner.tl{border-width:2.5px 0 0 2.5px;border-radius:12px 0 0;top:0;left:0}.corner.tr{border-width:2.5px 2.5px 0 0;border-radius:0 12px 0 0;top:0;right:0}.corner.bl{border-width:0 0 2.5px 2.5px;border-radius:0 0 0 12px;bottom:0;left:0}.corner.br{border-width:0 2.5px 2.5px 0;border-radius:0 0 12px;bottom:0;right:0}.scan-beam{z-index:5;background:linear-gradient(90deg,#0000 0%,#dfe4e0b3 30%,#dfe4e0e6 50%,#dfe4e0b3 70%,#0000 100%);border-radius:2px;height:1.5px;animation:2.8s ease-in-out infinite beamSweep;position:absolute;left:14px;right:14px;box-shadow:0 0 12px 3px #dfe4e026}.pulse-ring{pointer-events:none;z-index:2;border:1px solid #dfe4e00f;border-radius:50%;width:140px;height:140px;animation:3s ease-out infinite scanPulseRing;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes scanPulseRing{0%{opacity:.5;width:140px;height:140px}to{opacity:0;width:280px;height:280px}}.scan-hint{color:#dfe4e073;text-align:center;letter-spacing:.2px;flex-shrink:0;max-width:260px;margin:0 auto;font-size:.88rem;line-height:1.7}.scanner-bottom{flex-shrink:0;padding:20px 24px 0}.show-qr-btn{background:var(--cream);width:100%;color:var(--dark);font-family:var(--font-body);cursor:pointer;border:none;border-radius:20px;justify-content:center;align-items:center;gap:10px;padding:18px;font-size:1rem;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 8px 24px #0003}.show-qr-btn:active{transform:scale(.97)}.home-page{padding-bottom:120px}.hero{background:var(--dark);width:100vw;padding:56px 0 50px;position:relative;overflow:hidden}.hero-bg-glow{z-index:1;pointer-events:none;background:radial-gradient(circle,#dfe4e00f 0%,#02140800 70%);border-radius:50%;width:150vw;height:150vw;position:absolute;top:-40%;left:50%;transform:translate(-50%)}.hero-content{z-index:2;flex-direction:column;align-items:center;padding:0 24px;display:flex;position:relative}.logo-massive{filter:drop-shadow(0 10px 20px #0003);width:180px;height:auto;animation:fadeDown .8s var(--ease-spring) forwards;object-fit:contain;margin-bottom:32px}.hero-greeting{color:#dfe4e080;letter-spacing:.5px;text-transform:uppercase;animation:fadeUp .8s var(--ease-spring) .1s forwards;opacity:0;margin-bottom:6px;font-size:.9rem}.hero-name{font-family:var(--font-body);color:var(--cream);letter-spacing:.3px;animation:fadeUp .8s var(--ease-spring) .2s forwards;opacity:0;margin-bottom:28px;font-size:1.3rem;font-weight:600;line-height:1.3}.wallet-card{-webkit-backdrop-filter:blur(20px);width:calc(100% - 48px);animation:fadeUp .8s var(--ease-spring) .3s forwards;opacity:0;background:#dfe4e00a;border:1px solid #dfe4e014;border-radius:28px;margin:0 24px;padding:28px;position:relative;overflow:hidden}.wallet-card-bg{background:linear-gradient(90deg,#0000,#dfe4e008);border-radius:0 28px 28px 0;width:50%;position:absolute;top:0;bottom:0;right:0}.wallet-label{color:#dfe4e080;text-transform:uppercase;letter-spacing:2px;z-index:2;margin-bottom:10px;font-size:.7rem;position:relative}.wallet-amount{font-family:var(--font-heading);color:var(--white);letter-spacing:-1px;z-index:2;font-size:3rem;line-height:1;position:relative}.wallet-amount span{color:#dfe4e099;vertical-align:super;margin-right:4px;font-size:1.2rem}.wallet-sub{color:#dfe4e066;z-index:2;align-items:center;gap:6px;margin-top:12px;font-size:.8rem;display:flex;position:relative}.wallet-dot{background:#dfe4e04d;border-radius:50%;width:6px;height:6px}.section{z-index:10;background:var(--cream);border-radius:32px 32px 0 0;margin-top:-40px;padding:36px 0 0;position:relative}.quick-actions{animation:fadeUp .6s var(--ease-spring) .4s forwards;opacity:0;justify-content:space-between;margin-bottom:36px;padding:0 24px;display:flex}.action-item{cursor:pointer;flex-direction:column;align-items:center;gap:10px;text-decoration:none;display:flex}.action-circle{background:var(--cream);width:60px;height:60px;color:var(--dark);border:1.5px solid #02140814;border-radius:50%;justify-content:center;align-items:center;font-size:1.3rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 16px #0214080f}.action-circle:active{transform:scale(.92)}.action-circle.primary{background:var(--dark);color:var(--cream);box-shadow:0 6px 20px #02140833}.action-label{color:var(--dark);text-transform:uppercase;letter-spacing:.5px;text-align:center;font-size:.7rem;font-weight:700}.section-title{text-transform:none;letter-spacing:normal;font-size:1.1rem;font-weight:800}.section-link{color:var(--fast-green-dark,#02140866);cursor:pointer;font-size:.85rem;font-weight:600;text-decoration:none}.tx-feed{width:100%}.tx-row{border-bottom:1px solid #0214080f;align-items:center;padding:20px 24px;transition:background .3s;display:flex}.tx-row:active{background:#02140805}.tx-icon-wrap{border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;margin-right:16px;font-size:1.2rem;display:flex}.bg-out,.bg-in,.bg-payment,.bg-topup{color:var(--dark);background:#0214080f}.bg-fail{color:var(--danger);background:#e0525214}.tx-details{flex:1;min-width:0}.tx-title{color:var(--dark);margin-bottom:3px;font-size:1rem;font-weight:600}.tx-sub{color:#02140873;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.tx-right{text-align:right}.tx-amt{font-family:var(--font-heading);color:var(--dark);margin-bottom:3px;font-size:1.15rem}.tx-amt.credit{color:var(--dark)}.tx-time{color:#02140859;font-size:.75rem}.history-page{padding-bottom:120px}.hero-header{background:var(--dark);width:100vw;padding:50px 0 80px;position:relative;overflow:hidden}.hero-bg{pointer-events:none;z-index:1;background:radial-gradient(circle,#dfe4e014 0%,#02140800 70%);border-radius:50%;width:300px;height:300px;position:absolute;top:-50px;right:-50px}.header-top{z-index:2;justify-content:center;align-items:center;margin-bottom:40px;padding:0 24px;display:flex;position:relative}.logo-large{filter:drop-shadow(0 4px 10px #0000004d);object-fit:contain;height:56px}.icon-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;transition:all .2s;display:flex;position:relative}.summary-area{z-index:2;padding:0 24px;position:relative}.summary-label{color:#dfe4e080;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-size:.75rem}.summary-amount{font-family:var(--font-heading);color:var(--cream);letter-spacing:-1px;animation:fadeUp .8s var(--ease-spring) forwards;margin-bottom:24px;font-size:3.5rem;line-height:1}.summary-amount span{color:#dfe4e080;vertical-align:super;font-size:1.2rem}.filter-scroll{scroll-snap-type:x mandatory;scrollbar-width:none;z-index:2;gap:12px;padding:0 24px;display:flex;position:relative;overflow-x:auto}.filter-scroll::-webkit-scrollbar{display:none}.filter-chip.active{background:var(--white);color:var(--dark)}.filter-chip:not(.active){color:var(--cream);-webkit-backdrop-filter:blur(10px);background:#dfe4e014}.tx-list{z-index:10;background:var(--cream);border-radius:32px 32px 0 0;min-height:50vh;margin-top:-32px;padding:32px 0;position:relative}.date-divider{color:#02140859;text-transform:uppercase;letter-spacing:2px;padding:16px 24px 8px;font-size:.7rem;font-weight:700}.tx-list .tx-icon-wrap{border-radius:20px;width:56px;height:56px;font-size:1.3rem}.tx-list .tx-title{margin-bottom:4px;font-size:1.05rem}.tx-list .tx-amt{margin-bottom:4px;font-size:1.2rem}.wallet-page{padding-bottom:120px}.wallet-hero{padding:50px 0 40px}.balance-area{text-align:center;z-index:2;margin-bottom:32px;padding:0 24px;position:relative}.balance-amount span{color:#dfe4e080;vertical-align:super;margin-right:4px;font-size:1.3rem}.balance-sub{color:#dfe4e066;justify-content:center;align-items:center;gap:6px;margin-top:12px;font-size:.8rem;display:flex}.balance-dot{background:#dfe4e04d;border-radius:50%;width:6px;height:6px}.topup-card{z-index:2;-webkit-backdrop-filter:blur(20px);animation:fadeUp .8s var(--ease-spring) .2s forwards;opacity:0;background:#dfe4e00a;border:1px solid #dfe4e014;border-radius:24px;margin:0 24px;padding:24px;position:relative;overflow:hidden}.topup-card-bg{background:linear-gradient(90deg,#0000,#dfe4e005);border-radius:0 24px 24px 0;width:40%;position:absolute;top:0;bottom:0;right:0}.topup-card-title{color:#dfe4e080;text-transform:uppercase;letter-spacing:2px;z-index:2;margin-bottom:16px;font-size:.65rem;position:relative}.topup-entry{z-index:2;border-bottom:1px solid #dfe4e00f;justify-content:space-between;align-items:center;padding:10px 0;display:flex;position:relative}.topup-entry:last-child{border-bottom:none}.topup-source{color:#dfe4e0b3;font-size:.9rem}.topup-amt{font-family:var(--font-heading);color:var(--cream);font-size:1rem}.actions-row{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:36px;padding:0 24px;display:grid}.actions-row-3{grid-template-columns:1fr 1fr 1fr}.action-btn{font-family:var(--font-body);cursor:pointer;border:none;border-radius:20px;justify-content:center;align-items:center;gap:10px;padding:18px 16px;font-size:.95rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex}.action-btn:active{transform:scale(.96)}.action-btn.primary{background:var(--dark);color:var(--cream);box-shadow:0 8px 24px #02140833}.action-btn.secondary{background:var(--white);color:var(--dark);border:1.5px solid #02140814;box-shadow:0 4px 16px #0214080d}.breakdown-list{width:100%}.breakdown-row{border-bottom:1px solid #0214080f;align-items:center;padding:20px 24px;display:flex}.breakdown-icon{width:48px;height:48px;color:var(--dark);background:#0214080d;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;margin-right:16px;font-size:1.1rem;display:flex}.breakdown-details{flex:1}.breakdown-label{color:var(--dark);margin-bottom:3px;font-size:.95rem;font-weight:600}.breakdown-sub{color:#02140866;font-size:.8rem}.breakdown-amt{font-family:var(--font-heading);color:var(--dark);text-align:right;font-size:1.1rem}.profile-page{padding-bottom:120px}.profile-header{flex-direction:column;align-items:center;padding:60px 24px 40px;display:flex;position:relative}.profile-name{font-family:var(--font-heading);color:var(--dark);letter-spacing:1px;text-align:center;opacity:0;margin-bottom:6px;font-size:1.6rem;animation:.6s ease-out .1s forwards fadeUp}.profile-phone{color:#02140880;letter-spacing:.5px;opacity:0;font-size:.95rem;animation:.6s ease-out .15s forwards fadeUp}.profile-badge{color:#02140880;text-transform:uppercase;letter-spacing:1.5px;opacity:0;background:#0214080d;border-radius:100px;margin-top:12px;padding:6px 16px;font-size:.7rem;font-weight:700;animation:.6s ease-out .2s forwards fadeUp}.menu-section{opacity:0;padding:12px 24px 0;animation:.6s ease-out .25s forwards fadeUp}.menu-label{color:#02140859;text-transform:uppercase;letter-spacing:2px;padding:20px 0 12px;font-size:.65rem;font-weight:700}.menu-group{background:var(--white);border:1px solid #0214080a;border-radius:24px;overflow:hidden;box-shadow:0 4px 20px #0214080a}.menu-item{cursor:pointer;color:var(--dark);border-bottom:1px solid #0214080d;align-items:center;padding:20px;text-decoration:none;transition:background .3s;display:flex}.menu-item:last-child{border-bottom:none}.menu-item:active{background:#02140805}.menu-icon-wrap{width:44px;height:44px;color:var(--dark);background:#0214080a;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;margin-right:16px;font-size:1.1rem;display:flex}.menu-text{flex:1}.menu-title{color:var(--dark);margin-bottom:2px;font-size:1rem;font-weight:600}.menu-sub{color:#02140866;font-size:.8rem}.menu-chevron{color:#02140833;flex-shrink:0;font-size:.9rem}.signout-area{opacity:0;padding:24px 24px 0;animation:.6s ease-out .35s forwards fadeUp}.signout-btn{width:100%;color:var(--danger);font-family:var(--font-body);cursor:pointer;background:#e0525214;border:none;border-radius:20px;justify-content:center;align-items:center;gap:10px;padding:18px;font-size:1rem;font-weight:700;transition:transform .2s,background .2s;display:flex}.signout-btn:active{background:#e052521f;transform:scale(.97)}.version-text{text-align:center;color:#02140840;letter-spacing:.5px;padding:24px 0;font-size:.75rem}.checkout-page{min-height:100vh;background:var(--cream);flex-direction:column;min-height:100dvh;display:flex;overflow:hidden}.checkout-header{background:var(--dark);flex-direction:column;flex-shrink:0;align-items:center;padding:40px 24px 28px;display:flex;position:relative;overflow:hidden}.checkout-header:after{content:"";background:var(--cream);border-radius:24px 24px 0 0;height:24px;position:absolute;bottom:-1px;left:0;right:0}.checkout-header .header-bg-glow{pointer-events:none;background:radial-gradient(circle,#dfe4e014 0%,#0000 70%);border-radius:50%;width:200px;height:200px;position:absolute;top:-80px;right:-60px}.checkout-header .header-logo{object-fit:contain;z-index:2;filter:drop-shadow(0 4px 12px #0003);height:52px;margin-bottom:20px;position:relative}.checkout-header .merchant-name{font-family:var(--font-heading);color:var(--cream);letter-spacing:1.5px;text-align:center;z-index:2;margin-bottom:4px;font-size:1.15rem;position:relative}.checkout-header .merchant-type{color:#dfe4e073;letter-spacing:.5px;z-index:2;font-size:.8rem;position:relative}.products{scrollbar-width:none;flex-direction:column;flex:1;gap:12px;padding:8px 20px 220px;display:flex;overflow-y:auto}.products::-webkit-scrollbar{display:none}.product-row{background:var(--white);opacity:0;border:1px solid #0214080a;border-radius:20px;align-items:center;gap:16px;padding:16px;transition:transform .2s,box-shadow .2s;animation:.4s ease-out forwards fadeUp;display:flex;box-shadow:0 2px 8px #0214080a}.product-row:active{transform:scale(.99)}.product-row.selected{border-color:var(--dark);box-shadow:0 4px 16px #02140814}.prod-thumb{background:var(--cream);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.8rem;display:flex}.product-row.selected .prod-thumb{background:var(--dark)}.prod-info{flex:1;min-width:0}.prod-name{color:var(--dark);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:1rem;font-weight:700;overflow:hidden}.prod-price{font-family:var(--font-heading);color:#02140873;letter-spacing:.5px;font-size:.8rem}.qty-stepper{background:#0214080a;border-radius:14px;flex-shrink:0;align-items:center;gap:2px;padding:4px;display:flex}.qty-btn{width:34px;height:34px;color:var(--dark);cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;font-size:1.1rem;transition:all .15s;display:flex}.qty-btn:active{background:#02140814;transform:scale(.9)}.qty-btn.plus{background:var(--dark);color:var(--cream);border-radius:10px}.qty-btn.plus:active{opacity:.8}.qty-val{font-family:var(--font-heading);color:var(--dark);text-align:center;letter-spacing:.5px;min-width:28px;font-size:1rem}.qty-val.zero{color:#02140833}.checkout-dock{background:var(--dark);z-index:90;border-radius:28px;padding:20px 24px;animation:.5s cubic-bezier(.16,1,.3,1) .3s forwards slideUp;position:fixed;bottom:80px;left:16px;right:16px;transform:translateY(120%);box-shadow:0 -4px 30px #0003,0 10px 40px #0214084d}.dock-summary{justify-content:space-between;align-items:flex-end;margin-bottom:16px;display:flex}.dock-label{color:#dfe4e066;text-transform:uppercase;letter-spacing:2px;margin-bottom:6px;font-size:.6rem;font-weight:700}.dock-total{font-family:var(--font-heading);color:var(--white);letter-spacing:-1px;align-items:baseline;gap:6px;font-size:2.2rem;line-height:1;display:flex}.dock-currency{color:#dfe4e080;letter-spacing:1px;font-size:.85rem}.dock-items{color:var(--cream);text-transform:uppercase;letter-spacing:1px;background:#dfe4e014;border:1px solid #dfe4e01a;border-radius:100px;padding:8px 16px;font-size:.75rem;font-weight:700}.dock-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.pay-btn{font-family:var(--font-body);cursor:pointer;border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:15px 12px;font-size:.9rem;font-weight:700;transition:transform .2s;display:flex}.pay-btn:active{transform:scale(.96)}.pay-btn.wallet{background:var(--cream);color:var(--dark)}.pay-btn.mpesa{color:#dfe4e0cc;background:0 0;border:1.5px solid #dfe4e01f}.nav-blur{display:none}.bottom-nav .nav-scan{position:relative}.nav-scan .nav-label{margin-top:0}.top-bar-logo-img{object-fit:contain;width:130px;height:auto}.top-bar-wallet{border-radius:var(--radius-full);font-family:var(--font-heading);color:#dfe4e0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);letter-spacing:.5px;white-space:nowrap;background:#dfe4e026;border:1px solid #dfe4e033;align-items:center;gap:6px;padding:6px 14px;font-size:.78rem;font-weight:600;display:flex}.page{animation:pageIn .35s var(--ease-out);padding:12px 0}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.text-center{text-align:center}.text-sm{font-size:.82rem}.text-xs{font-size:.72rem}.text-muted{color:#02140873}.hidden{display:none!important}.btn{width:100%;font-family:var(--font-body);cursor:pointer;transition:all .3s var(--ease-spring);border:none;border-radius:20px;justify-content:center;align-items:center;gap:10px;padding:18px 24px;font-size:1rem;font-weight:700;display:flex;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;pointer-events:none}.btn.btn-primary{background:var(--dark);color:var(--white);box-shadow:0 10px 20px #02140826}.btn.btn-primary:hover{box-shadow:var(--shadow-green);transform:scale(1.02)}.btn.btn-mpesa{color:var(--dark);background:0 0;border:1.5px solid #02140826}.btn.btn-mpesa:hover{background:#0214080d}.btn.btn-wallet{background:var(--dark);color:var(--white)}.btn.btn-secondary{color:var(--white);pointer-events:none;cursor:default;background:#02140866}.merchant-header{align-items:center;gap:12px;margin-bottom:20px;padding:0 16px;display:flex}.merchant-icon{width:44px;height:44px;color:var(--dark);background:#0214080f;border-radius:12px;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.merchant-info h2{font-family:var(--font-heading);color:var(--dark);letter-spacing:.5px;font-size:1.15rem;font-weight:600}.merchant-info .sub{color:#02140873;font-size:.72rem}.live-badge{color:var(--danger);border-radius:var(--radius-full);letter-spacing:1px;text-transform:uppercase;background:#e0525226;align-items:center;gap:6px;margin-left:16px;padding:4px 12px;font-size:.65rem;font-weight:700;display:inline-flex}.live-badge .dot{background:var(--danger);border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite livePulse}.checkout-item{background:var(--gradient-card);border-top:1px solid var(--fq-card-border);border-bottom:1px solid var(--fq-card-border);animation:itemSlideIn .4s var(--ease-out) both;align-items:center;gap:12px;padding:14px 16px;display:flex}.checkout-item:nth-child(2){animation-delay:.1s}.checkout-item:nth-child(3){animation-delay:.2s}.item-icon{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;display:flex}.item-icon.food,.item-icon.drink,.item-icon.grocery,.item-icon.service{color:var(--dark);background:#0214080f}.item-details{flex:1}.item-name{color:var(--dark);font-size:.88rem;font-weight:600}.item-meta{color:#02140873;font-size:.7rem}.item-price{font-family:var(--font-heading);color:var(--dark);font-size:.88rem;font-weight:700}.item-qty{color:var(--dark);background:#02140814;border-radius:8px;padding:2px 8px;font-size:.65rem;font-weight:600}.total-card{text-align:center;background:var(--cream);border-top:2px solid var(--dark);border-bottom:1px solid #0214081a;margin-top:16px;padding:20px 16px}.total-card .total-label{color:#02140873;text-transform:uppercase;letter-spacing:1px;font-size:.75rem;font-weight:600}.total-card .total-amount{font-family:var(--font-heading);color:var(--dark);letter-spacing:1px;margin:6px 0;font-size:2.4rem;font-weight:700;display:block}.total-items{color:#02140873;font-size:.72rem}.page .pay-actions{flex-direction:column;gap:10px;margin-top:12px;padding:0 16px;display:flex}.product-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin:16px 0;padding:0 16px;display:grid}.product-card{background:var(--white);text-align:center;transition:all .3s var(--ease-out);cursor:pointer;opacity:0;border:1.5px solid #02140814;border-radius:24px;flex-direction:column;align-items:center;padding:20px 16px;animation:.4s ease-out forwards fadeUp;display:flex;position:relative;box-shadow:0 2px 8px #00000005}.product-card:hover{border-color:var(--dark);transform:translateY(-2px)}.product-card.in-cart{border-color:var(--dark);box-shadow:0 4px 16px #02140814}.product-emoji{filter:drop-shadow(0 4px 6px #0000001a);margin-bottom:12px;font-size:2.5rem;transition:transform .2s;display:block}.product-card:active .product-emoji{transform:scale(1.1)}.product-name{font-family:var(--font-body);color:var(--dark);margin-bottom:4px;font-size:.9rem;font-weight:700}.product-price{font-family:var(--font-heading);color:#02140880;letter-spacing:.5px;margin-bottom:16px;font-size:.85rem}.qty-controls{background:#0214080a;border-radius:100px;justify-content:space-between;align-items:center;width:100%;padding:4px;display:flex}.route-badge{color:var(--dark);border-radius:var(--radius-full);background:#0214080f;align-items:center;gap:6px;margin-bottom:16px;margin-left:16px;padding:6px 14px;font-size:.72rem;font-weight:600;display:inline-flex}.seat-grid{grid-template-columns:repeat(4,1fr);gap:8px;max-width:260px;margin:16px auto;display:grid}.seat{aspect-ratio:1;background:var(--white);width:100%;font-family:var(--font-display);color:#02140873;cursor:pointer;border:2px solid #02140814;border-radius:10px;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.seat:hover{border-color:var(--dark)}.seat.yours{background:var(--dark);border-color:var(--dark);color:#fff;box-shadow:0 0 12px #02140833}.seat.companion{color:var(--dark);background:#0214080f;border-color:#02140833}.seat.taken{color:#02140833;cursor:default;opacity:.4;background:#02140805;border-color:#02140814}.seat.aisle{visibility:hidden}.fare-info{text-align:center;margin:12px 0;padding:0 16px}.fare-amount{font-family:var(--font-heading);color:var(--dark);font-size:1.6rem;font-weight:700}.fare-label{color:#02140873;font-size:.7rem}.companion-section{border-radius:var(--radius-md);background:#0214080a;border:1px solid #02140814;margin:16px 16px 0;padding:14px}.companion-title{color:var(--dark);margin-bottom:6px;font-size:.78rem;font-weight:600}.companion-hint{color:#02140873;font-size:.68rem}.tab-round{margin-bottom:16px;padding:0 16px}.tab-round-header{color:#02140873;border-bottom:1px solid #0214080f;margin-bottom:8px;padding-bottom:4px;font-size:.72rem;font-weight:600}.tip-section{border-radius:var(--radius-md);background:#0214080a;border:1px solid #02140814;margin:16px 16px 0;padding:14px}.tip-label{color:var(--dark);margin-bottom:10px;font-size:.75rem;font-weight:600}.tip-options{gap:8px;display:flex}.tip-btn{background:var(--white);color:var(--dark);cursor:pointer;text-align:center;border:1px solid #02140814;border-radius:10px;flex:1;padding:8px;font-size:.75rem;font-weight:600;transition:all .2s}.tip-btn:hover,.tip-btn.active{border-color:var(--dark);color:var(--dark);background:#0214080d}.form-group{margin-bottom:16px;padding:0 16px}.form-label{color:#02140899;margin-bottom:6px;font-size:.72rem;font-weight:600;display:block}.form-input{background:var(--white);border-radius:var(--radius-md);width:100%;color:var(--dark);font-family:var(--font-body);border:1.5px solid #0214081a;outline:none;padding:12px 14px;font-size:.9rem;transition:border-color .3s}.form-input:focus{border-color:var(--dark)}.form-input::placeholder{color:#0214084d}.status-card{border-radius:var(--radius-md);margin-bottom:12px;padding:14px}.status-card.success{background:#0214080f;border:1px solid #0214081a}.status-card.pending{background:#0214080a;border:1px solid #02140814}.status-card.error{background:#e0525214;border:1px solid #e0525226}.timer-display{font-family:var(--font-heading);color:var(--dark);text-align:center;letter-spacing:2px;margin:20px 0;font-size:2.8rem;font-weight:700}.timer-label{text-align:center;color:#02140873;font-size:.72rem}.session-info{grid-template-columns:1fr 1fr;gap:10px;margin:16px 0;padding:0 16px;display:grid}.session-stat{background:var(--gradient-card);border:1px solid var(--fq-card-border);border-radius:var(--radius-md);text-align:center;padding:12px}.session-stat .label{color:#02140873;font-size:.65rem;display:block}.session-stat .value{font-family:var(--font-heading);color:var(--dark);margin-top:4px;font-size:1.1rem;font-weight:700;display:block}.active-badge{color:var(--dark);border-radius:var(--radius-full);text-transform:uppercase;background:#02140814;align-items:center;gap:6px;padding:4px 12px;font-size:.65rem;font-weight:700;display:inline-flex}.active-badge .dot{background:var(--dark);border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite livePulse}.fee-item{background:var(--gradient-card);border:1px solid var(--fq-card-border);cursor:pointer;border-radius:12px;align-items:center;gap:12px;margin-bottom:8px;padding:12px 14px;transition:all .2s;display:flex}.fee-item.selected{border-color:var(--dark);background:#0214080a}.fee-checkbox{color:#0000;border:2px solid #0214084d;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;transition:all .2s;display:flex}.fee-item.selected .fee-checkbox{background:var(--dark);border-color:var(--dark);color:#fff}.fee-item.paid{opacity:.5;pointer-events:none}.fee-item.paid .fee-checkbox{color:#02140866;background:#02140826;border-color:#02140833}.fee-details{flex:1}.fee-name{color:var(--dark);font-size:.8rem;font-weight:600}.fee-status{color:#02140873;font-size:.65rem}.fee-amount{font-family:var(--font-heading);color:var(--dark);font-size:.82rem;font-weight:700}.student-card{background:var(--gradient-card);border:1px solid var(--fq-card-border);border-radius:var(--radius-md);margin-bottom:16px;padding:16px}.student-card h3{font-family:var(--font-display);color:var(--dark);margin-bottom:8px;font-size:1rem;font-weight:600}.student-detail{border-bottom:1px solid #0214080d;justify-content:space-between;padding:4px 0;font-size:.75rem;display:flex}.student-detail .label{color:#02140873}.student-detail .value{color:var(--dark);font-weight:600}.fuel-types{gap:8px;margin:16px 0;display:flex}.fuel-type{text-align:center;border-radius:var(--radius-md);background:var(--white);cursor:pointer;color:var(--dark);border:1px solid #02140814;flex:1;padding:12px 8px;font-size:.75rem;font-weight:600;transition:all .2s}.fuel-type:hover,.fuel-type.active{border-color:var(--dark);color:var(--dark);background:#0214080d}.amount-input-group{background:var(--white);border-radius:var(--radius-md);border:1.5px solid #0214081a;align-items:center;margin:16px 0;transition:border-color .3s;display:flex;overflow:hidden}.amount-input-group:focus-within{border-color:var(--dark)}.amount-prefix{color:#02140899;background:#02140805;border-right:1px solid #02140814;padding:14px 12px;font-size:.9rem;font-weight:700}.amount-input-group input{color:var(--dark);font-family:var(--font-heading);letter-spacing:1px;background:0 0;border:none;outline:none;flex:1;padding:14px 12px;font-size:1.3rem;font-weight:700}.confirm-badge{border-radius:var(--radius-md);align-items:center;gap:8px;padding:10px 14px;font-size:.75rem;font-weight:600;display:flex}.confirm-badge.confirmed{color:var(--dark);background:#0214080f;border:1px solid #0214081a}.confirm-badge.waiting{color:#02140899;background:#0214080a;border:1px solid #02140814}.service-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin:16px 0;display:grid}.service-card{text-align:center;background:var(--gradient-card);border:1px solid var(--fq-card-border);cursor:pointer;border-radius:14px;padding:14px;transition:all .2s}.service-card:hover{border-color:var(--dark)}.service-card.selected{border-color:var(--dark);background:#0214080d}.service-card .emoji{margin-bottom:6px;font-size:1.5rem;display:block}.service-card .name{color:var(--dark);font-size:.78rem;font-weight:600}.service-card .price{color:var(--dark);margin-top:4px;font-size:.7rem;font-weight:700}.mode-toggle{border-radius:var(--radius-md);background:#02140808;margin-bottom:16px;display:flex;overflow:hidden}.mode-option{text-align:center;color:#02140880;cursor:pointer;border:1px solid #0000;flex:1;padding:10px;font-size:.75rem;font-weight:600;transition:all .2s}.mode-option.active{background:var(--dark);color:#fff;border-radius:var(--radius-md)}.payment-success-screen{background:var(--dark);z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow-y:auto}.payment-success-screen .bg-glow-top{pointer-events:none;z-index:0;background:radial-gradient(circle,#dfe4e012 0%,#0000 65%);border-radius:50%;width:140vw;height:140vw;position:fixed;top:-30%;left:50%;transform:translate(-50%)}.payment-success-screen .bg-glow-bottom{pointer-events:none;z-index:0;background:radial-gradient(circle,#dfe4e00a 0%,#0000 60%);border-radius:50%;width:120vw;height:120vw;position:fixed;bottom:-50%;left:50%;transform:translate(-50%)}.success-container{z-index:2;flex-direction:column;align-items:center;width:100%;max-width:420px;padding:0 32px;display:flex;position:relative}.success-logo{object-fit:contain;filter:drop-shadow(0 4px 12px #0003);opacity:0;height:48px;margin-bottom:48px;animation:.6s ease-out forwards fadeDown}.check-ring{opacity:0;border-radius:50%;width:110px;height:110px;margin-bottom:36px;animation:.5s cubic-bezier(.16,1,.3,1) .2s forwards scaleIn;position:relative;transform:scale(.5)}.check-ring-outer{border:2px solid #dfe4e01f;border-radius:50%;animation:2s ease-out .8s infinite ringPulse;position:absolute;top:0;bottom:0;left:0;right:0}@keyframes ringPulse{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.6)}}.check-ring-inner{-webkit-backdrop-filter:blur(12px);background:#dfe4e00f;border:1.5px solid #dfe4e026;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.check-icon{color:var(--cream);opacity:0;font-size:2.8rem;animation:.4s cubic-bezier(.16,1,.3,1) .5s forwards checkPop;transform:scale(0)}@keyframes checkPop{to{opacity:1;transform:scale(1)}}.success-title{font-family:var(--font-heading);color:var(--cream);letter-spacing:2px;text-align:center;opacity:0;margin-bottom:8px;font-size:1.4rem;animation:.6s ease-out .6s forwards fadeUp}.success-sub{color:#dfe4e073;text-align:center;letter-spacing:.3px;opacity:0;margin-bottom:40px;font-size:.9rem;animation:.6s ease-out .7s forwards fadeUp}.payment-success-screen .receipt-card{-webkit-backdrop-filter:blur(20px);opacity:0;background:#dfe4e00a;border:1px solid #dfe4e014;border-radius:24px;width:100%;margin-bottom:32px;padding:28px 24px;animation:.6s ease-out .8s forwards fadeUp}.receipt-amount-area{text-align:center;border-bottom:1px solid #dfe4e00f;margin-bottom:24px;padding-bottom:24px}.payment-success-screen .receipt-currency{color:#dfe4e066;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-size:.7rem}.receipt-amount{font-family:var(--font-heading);color:var(--white);letter-spacing:-1px;font-size:3.2rem;line-height:1}.payment-success-screen .receipt-row{border-bottom:none;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.payment-success-screen .receipt-label{color:#dfe4e066;font-size:.82rem}.payment-success-screen .receipt-value{color:var(--cream);text-align:right;font-size:.88rem;font-weight:600}.receipt-ref{font-family:var(--font-heading);letter-spacing:1px;font-size:.8rem}.receipt-divider{background:#dfe4e00f;width:100%;height:1px;margin:4px 0}.done-btn{background:var(--cream);width:100%;color:var(--dark);font-family:var(--font-body);cursor:pointer;opacity:0;border:none;border-radius:20px;justify-content:center;align-items:center;gap:10px;padding:18px;font-size:1rem;font-weight:700;transition:transform .2s;animation:.6s ease-out .9s forwards fadeUp;display:flex;box-shadow:0 8px 24px #0003}.done-btn:active{transform:scale(.97)}.share-btn{color:#dfe4e066;width:100%;font-family:var(--font-body);cursor:pointer;opacity:0;background:0 0;border:1.5px solid #dfe4e014;border-radius:16px;justify-content:center;align-items:center;gap:8px;margin-top:12px;padding:14px;font-size:.88rem;font-weight:600;transition:all .2s;animation:.6s ease-out 1s forwards fadeUp;display:flex}.share-btn:active{background:#dfe4e00a}.payment-status-screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:70vh;padding:32px;display:flex}.status-icon{border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:20px;font-size:2rem;display:flex}.status-icon.pending{color:var(--dark);background:#0214080f;animation:2s ease-in-out infinite statusPulse}.status-icon.success{color:var(--dark);background:#02140814}.status-icon.failed{color:var(--danger);background:#e052521a}.status-title{font-family:var(--font-heading);color:var(--dark);margin-bottom:8px;font-size:1.3rem;font-weight:700}.status-message{color:#02140899;margin-bottom:24px;font-size:.82rem;line-height:1.5}.landing{background:var(--cream);min-height:100vh;animation:pageIn .5s var(--ease-out);flex-direction:column;align-items:center;padding:0 20px 40px;display:flex}.landing-hero{text-align:center;margin-bottom:32px;padding-top:56px}.landing-logo-img{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:220px;height:auto;margin:0 auto 12px;display:block}.landing-tagline{font-family:var(--font-heading);color:var(--dark);letter-spacing:2px;margin-bottom:4px;font-size:1.15rem;font-weight:500}.landing-subtitle{color:#02140873;max-width:260px;margin:0 auto;font-size:.78rem;line-height:1.5}.scan-cta{margin:8px 0 36px;position:relative}.scan-btn{background:var(--dark);cursor:pointer;width:130px;height:130px;color:var(--cream);font-family:var(--font-display);letter-spacing:.5px;transition:all .3s var(--ease-spring);z-index:2;border:none;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:6px;font-size:.72rem;font-weight:700;display:flex;position:relative;box-shadow:0 8px 32px #02140840}.scan-btn:hover{transform:scale(1.06);box-shadow:0 12px 40px #02140859}.scan-btn:active{transform:scale(.95)}.scan-btn-icon{font-size:2.2rem;line-height:1}.scan-btn-label{text-transform:uppercase;letter-spacing:1.5px;opacity:.9;font-size:.68rem}.scan-pulse{z-index:1;border:2px solid #02140840;border-radius:50%;width:130px;height:130px;animation:2.5s ease-out infinite scanPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.scan-pulse:nth-child(2){animation-delay:.8s}.scan-pulse:nth-child(3){animation-delay:1.6s}.landing-features{gap:10px;width:100%;max-width:340px;margin-bottom:36px;display:flex}.feature-pill{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-align:center;background:#02140805;border:1px solid #0214080f;border-radius:16px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 8px;transition:all .3s;display:flex}.feature-pill:hover{background:#0214080a;border-color:#0214081f;transform:translateY(-2px)}.feature-pill-icon{font-size:1.3rem;display:block}.feature-pill-label{color:#02140899;font-size:.62rem;font-weight:600;line-height:1.3}.landing-demo{width:100%;max-width:340px}.demo-header{align-items:center;gap:8px;margin-bottom:14px;display:flex}.demo-line{background:linear-gradient(90deg,#0214080f,#0000);flex:1;height:1px}.demo-label{color:#0214084d;text-transform:uppercase;letter-spacing:2px;white-space:nowrap;font-size:.62rem;font-weight:600}.merchant-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;padding:0 12px;display:grid}.merchant-card{background:var(--white);text-align:center;cursor:pointer;transition:all .3s var(--ease-out);border:1px solid #0214080f;border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;text-decoration:none;display:flex;position:relative;overflow:hidden}.merchant-card:before{content:"";background:var(--dark);opacity:0;border-radius:16px 16px 0 0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.merchant-card:hover{border-color:#0214081f;transform:translateY(-3px);box-shadow:0 8px 24px #02140814}.merchant-card:hover:before{opacity:1}.merchant-card:active{transform:scale(.97)}.merchant-card[data-accent]:before{background:var(--dark)}.merchant-card-icon{background:#0214080f;border-radius:14px;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.merchant-card-icon i{color:var(--dark);font-size:1.2rem}.merchant-card-name{color:var(--dark);font-size:.78rem;font-weight:700;line-height:1.3}.merchant-card-type{color:#02140866;text-transform:uppercase;letter-spacing:.5px;font-size:.62rem;font-weight:500}.manual-entry-link{color:#02140873;cursor:pointer;justify-content:center;align-items:center;gap:6px;padding:12px;font-size:.72rem;text-decoration:none;transition:color .2s;display:flex}.manual-entry-link:hover{color:var(--dark)}.landing-footer{text-align:center;margin-top:auto;padding-top:24px}.landing-footer p{color:#0214084d;font-size:.58rem;line-height:1.6}.landing-footer .powered{color:#02140840;margin-top:8px;font-size:.55rem}.manual-entry-modal{background:var(--white);z-index:1020;animation:slideUp .35s var(--ease-out);border-radius:24px 24px 0 0;padding:24px 20px 40px;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 40px #00000080}.dock-total-label{color:#dfe4e080;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px;font-size:.65rem;font-weight:700}.dock-total-amount{font-family:var(--font-heading);color:var(--white);letter-spacing:-1px;align-items:baseline;gap:8px;font-size:2.2rem;line-height:1;display:flex}.dock-total-currency{color:var(--cream);letter-spacing:1px;font-size:.9rem}.dock-items-badge{color:var(--cream);font-family:var(--font-body);text-transform:uppercase;letter-spacing:1px;background:#dfe4e01a;border:1px solid #dfe4e033;border-radius:100px;padding:6px 16px;font-size:.8rem;font-weight:700}.dock-pay-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.btn-dock-pay{font-family:var(--font-body);cursor:pointer;border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:14px 10px;font-size:.9rem;font-weight:700;transition:transform .2s;display:flex}.btn-dock-pay:active{transform:scale(.96)}.btn-dock-wallet{background:var(--cream);color:var(--dark)}.btn-dock-mpesa{color:var(--white);background:0 0;border:1.5px solid #ffffff26}.catalog-browse{background:var(--cream);min-height:100vh;padding-bottom:120px}.catalog-header{background:var(--dark);border-radius:0 0 28px 28px;padding:48px 24px 24px}.catalog-header-top{align-items:center;gap:14px;margin-bottom:16px;display:flex}.catalog-back-btn{width:40px;height:40px;color:var(--cream);cursor:pointer;background:#dfe4e014;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.catalog-merchant-info{flex:1}.catalog-merchant-name{font-family:var(--font-heading);color:var(--cream);letter-spacing:.5px;font-size:1.1rem}.catalog-merchant-type{color:#dfe4e080;text-transform:uppercase;letter-spacing:1px;margin-top:2px;font-size:.65rem}.catalog-search-wrap{position:relative}.catalog-search-wrap i{color:#0214084d;font-size:.85rem;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.catalog-search{background:var(--cream);width:100%;font-family:var(--font-body);color:var(--dark);border:none;border-radius:14px;outline:none;padding:12px 12px 12px 40px;font-size:.85rem}.catalog-search::placeholder{color:#0214084d}.catalog-cats{scrollbar-width:none;gap:8px;padding:16px 24px;display:flex;overflow-x:auto}.catalog-cats::-webkit-scrollbar{display:none}.catalog-cat-chip{font-family:var(--font-body);color:#02140873;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background:#fff;border:1.5px solid #02140814;border-radius:12px;flex-shrink:0;padding:8px 16px;font-size:.72rem;font-weight:600;transition:all .2s}.catalog-cat-chip.active{background:var(--dark);color:var(--cream);border-color:var(--dark)}.catalog-items{padding:0 24px}.catalog-item-card{background:#fff;border-radius:18px;align-items:center;gap:12px;margin-bottom:10px;padding:14px;transition:transform .2s;display:flex;box-shadow:0 2px 10px #0214080a}.catalog-item-card:active{transform:scale(.98)}.catalog-item-emoji{background:#0214080a;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.4rem;display:flex}.catalog-item-info{flex:1;min-width:0}.catalog-item-name{font-family:var(--font-body);color:var(--dark);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;overflow:hidden}.catalog-item-cat{color:#02140866;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:.6rem}.catalog-item-right{text-align:right;flex-shrink:0}.catalog-item-price{font-family:var(--font-heading);color:var(--dark);letter-spacing:-.5px;margin-bottom:6px;font-size:.8rem}.catalog-add-btn{border:1.5px solid var(--dark);color:var(--dark);font-family:var(--font-body);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:4px;padding:6px 14px;font-size:.7rem;font-weight:700;transition:all .2s;display:flex}.catalog-add-btn:active{background:var(--dark);color:var(--cream)}.catalog-qty-ctrl{border:1.5px solid #0214081a;border-radius:10px;align-items:center;gap:0;display:flex;overflow:hidden}.catalog-qty-btn{width:30px;height:28px;color:var(--dark);cursor:pointer;background:#0214080a;border:none;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.catalog-qty-btn:active{background:var(--dark);color:var(--cream)}.catalog-qty-val{text-align:center;width:28px;font-family:var(--font-heading);color:var(--dark);font-size:.8rem}.catalog-cart-dock{background:var(--dark);z-index:80;border-radius:20px;justify-content:space-between;align-items:center;gap:12px;width:calc(100% - 48px);max-width:432px;padding:16px 20px;display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #0214084d}.catalog-cart-count{color:#dfe4e080;text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.catalog-cart-total{font-family:var(--font-heading);color:var(--cream);margin-top:2px;font-size:1.1rem}.catalog-checkout-btn{background:var(--cream);color:var(--dark);font-family:var(--font-body);cursor:pointer;border:none;border-radius:14px;flex-shrink:0;align-items:center;gap:8px;padding:12px 20px;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.catalog-checkout-btn:active{transform:scale(.96)}.catalog-empty{text-align:center;padding:60px 40px}.catalog-empty i{color:#0214081a;margin-bottom:12px;font-size:2.5rem}.catalog-empty p{color:#02140866;font-size:.85rem}.reorder-section{margin-bottom:24px}.reorder-carousel{scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:14px;padding:0 24px 12px;display:flex;overflow-x:auto}.reorder-carousel::-webkit-scrollbar{display:none}.reorder-card{scroll-snap-align:start;background:var(--white);border:1.5px solid #0214080f;border-radius:20px;flex-direction:column;flex:0 0 200px;gap:10px;padding:18px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 16px #0214080f}.reorder-card:active{transform:scale(.97)}.reorder-card-top{align-items:center;gap:10px;display:flex}.reorder-card-emoji{font-size:1.6rem}.reorder-card-name{color:var(--dark);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:700;overflow:hidden}.reorder-card-items{color:#02140873;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.72rem;line-height:1.4;display:-webkit-box;overflow:hidden}.reorder-card-bottom{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.reorder-card-price{font-family:var(--font-heading);color:var(--dark);font-size:.85rem}.reorder-card-btn{background:var(--dark);color:var(--cream);font-family:var(--font-body);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;border:none;border-radius:12px;padding:8px 16px;font-size:.72rem;font-weight:700;transition:transform .2s}.reorder-card-btn:active{transform:scale(.94)}.reorder-card-btn:disabled{opacity:.5}.places-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:32px;padding:0 24px;display:grid}.places-loading{grid-column:span 2;justify-content:center;padding:24px 0;display:flex}.places-empty{text-align:center;background:#02140805;border:1.5px dashed #0214081a;border-radius:20px;grid-column:span 2;padding:32px 24px}.places-empty p{color:#02140873;font-size:.85rem;line-height:1.6}.place-card{background:var(--white);text-align:center;cursor:pointer;opacity:0;border:1.5px solid #0214080f;border-radius:20px;flex-direction:column;align-items:center;padding:20px 16px;transition:transform .2s,box-shadow .2s,border-color .2s;animation:.4s ease-out forwards fadeUp;display:flex;box-shadow:0 4px 16px #0214080d}.place-card:active{transform:scale(.96)}.place-card:hover{border-color:#02140826;box-shadow:0 6px 24px #0214081a}.place-card-emoji{filter:drop-shadow(0 3px 6px #00000014);margin-bottom:10px;font-size:2rem}.place-card-name{color:var(--dark);white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-bottom:8px;font-size:.82rem;font-weight:700;line-height:1.3;overflow:hidden}.place-card-meta{flex-direction:column;align-items:center;gap:4px;display:flex}.place-visit-badge{color:var(--dark);text-transform:uppercase;letter-spacing:.5px;background:#0214080f;border-radius:100px;padding:3px 10px;font-size:.62rem;font-weight:700}.place-last-visit{color:#02140859;font-size:.62rem}.tab-detail-page{padding-bottom:120px}.tab-detail-header{background:var(--dark);align-items:center;gap:16px;padding:48px 24px 28px;display:flex}.tab-back-btn{width:42px;height:42px;color:var(--cream);cursor:pointer;background:#dfe4e014;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:background .2s;display:flex}.avatar{background:var(--dark-green);width:40px;height:40px;color:var(--fast-green);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.top-bar-logo{object-fit:contain;height:40px}.top-bar-right{position:relative}.avatar-dropdown{z-index:999;opacity:0;pointer-events:none;background:#fff;border-radius:16px;min-width:200px;padding:8px 0;transition:all .2s;position:absolute;top:calc(100% + 8px);right:0;transform:translateY(-8px);box-shadow:0 12px 32px #02140826}.avatar-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0)}.dropdown-item{color:var(--dark-green);cursor:pointer;align-items:center;gap:12px;padding:12px 20px;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .15s;display:flex}.dropdown-item:hover,.dropdown-item:active{background:#0214080a}.dropdown-item i{text-align:center;opacity:.7;width:20px;font-size:.95rem}.dropdown-divider{background:#02140814;height:1px;margin:4px 16px}.dropdown-logout{color:#dc2626}.home-greeting{padding:8px 16px 0}.tab-back-btn:active{background:#dfe4e026}.tab-header-info{flex:1;min-width:0}.tab-merchant-name{font-family:var(--font-heading);color:var(--cream);letter-spacing:.5px;white-space:nowrap;text-overflow:ellipsis;font-size:1.15rem;overflow:hidden}.tab-merchant-type{color:#dfe4e080;text-transform:uppercase;letter-spacing:1px;margin-top:3px;font-size:.7rem}.tab-detail-body{padding:24px 0 0}.tab-stats-row{gap:10px;margin-bottom:24px;padding:0 24px;display:flex}.tab-stat{background:var(--white);text-align:center;border:1px solid #0214080f;border-radius:16px;flex:1;padding:16px 12px;box-shadow:0 2px 8px #0214080a}.tab-stat-value{font-family:var(--font-heading);color:var(--dark);margin-bottom:4px;font-size:1rem}.tab-stat-label{color:#02140866;text-transform:uppercase;letter-spacing:.5px;font-size:.6rem;font-weight:600}.tab-usual-card{background:var(--white);border:1.5px solid #02140814;border-radius:20px;margin:0 24px 24px;overflow:hidden;box-shadow:0 4px 20px #0214080f}.tab-usual-header{font-family:var(--font-heading);color:var(--dark);letter-spacing:1px;text-transform:uppercase;background:#02140808;border-bottom:1px solid #0214080f;padding:16px 20px;font-size:.8rem}.tab-usual-items{padding:12px 20px}.tab-usual-item{color:var(--dark);border-bottom:1px solid #0214080a;justify-content:space-between;align-items:center;padding:8px 0;font-size:.88rem;display:flex}.tab-usual-item:last-child{border-bottom:none}.tab-usual-item-price{font-family:var(--font-heading);color:#02140899;font-size:.8rem}.tab-usual-footer{background:#02140805;border-top:1px solid #0214080f;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.tab-usual-total{font-family:var(--font-heading);color:var(--dark);font-size:1.2rem}.tab-usual-btn{background:var(--dark);color:var(--cream);font-family:var(--font-body);cursor:pointer;border:none;border-radius:14px;align-items:center;gap:8px;padding:12px 20px;font-size:.85rem;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 6px 16px #02140826}.activity-section .tx-list{z-index:auto;background:0 0;border-radius:0;min-height:auto;margin-top:0;padding:0}.tab-usual-btn:active{transform:scale(.96)}.tab-usual-btn:disabled{opacity:.5}.tab-section-title{font-family:var(--font-heading);color:var(--dark);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:16px;padding:0 24px;font-size:.8rem}.tab-timeline{padding:0 24px}.tab-timeline-loading{justify-content:center;padding:32px 0;display:flex}.tab-empty-timeline{text-align:center;color:#02140866;padding:32px;font-size:.88rem}.tab-session-card{background:var(--white);opacity:0;border:1px solid #0214080f;border-radius:16px;margin-bottom:12px;padding:16px;animation:.35s ease-out forwards fadeUp;box-shadow:0 2px 8px #0214080a}.tab-session-date{color:var(--dark);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.78rem;font-weight:600;display:flex}.tab-session-time{color:#02140859;font-size:.7rem;font-weight:400}.tab-session-items{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.tab-session-item{color:#02140899;background:#0214080a;border-radius:8px;padding:4px 10px;font-size:.7rem}.tab-session-footer{border-top:1px solid #0214080f;justify-content:space-between;align-items:center;padding-top:10px;display:flex}.tab-session-total{font-family:var(--font-heading);color:var(--dark);font-size:1rem}.tab-session-badges{gap:6px;display:flex}.tab-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:8px;padding:4px 10px;font-size:.6rem;font-weight:700}.tab-badge-method{color:var(--dark);background:#0214080f}.tab-badge-reorder{color:var(--dark);background:#02140814}.tab-actions{gap:10px;padding:24px;display:flex}.tab-action-btn{background:var(--white);color:var(--dark);font-family:var(--font-body);cursor:pointer;border:1.5px solid #02140814;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:6px;padding:14px 8px;font-size:.72rem;font-weight:700;transition:all .2s;display:flex}.tab-action-btn:active{background:#02140808;transform:scale(.96)}.tab-action-primary{background:var(--dark);color:var(--cream);border-color:var(--dark);box-shadow:0 4px 12px #02140826}.tab-action-primary:active{background:var(--dark);opacity:.9}.form-group{border-radius:var(--radius-lg,20px);background:#fff6;border:1px solid #0214080d;margin-bottom:24px;padding:20px;box-shadow:0 4px 12px #00000005}.form-group-header{color:var(--dark);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:10px;margin-bottom:16px;font-size:.85rem;font-weight:700;display:flex}.form-group-header i{color:var(--green);font-size:1.1rem}.input-wrapper{position:relative}.input-field{background:var(--cream);border-radius:var(--radius-md,12px);width:100%;font-family:var(--font-body);color:var(--dark);border:2px solid #0214081a;padding:14px 16px;font-size:1rem;font-weight:600;transition:all .2s}.input-field:focus{border-color:var(--green);background:#fff;outline:none;box-shadow:0 0 0 4px #22c55e1a}.location-box{border-radius:var(--radius-md,12px);background:#0214080a;align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;font-weight:500;display:flex}.location-box .icon-wrap{background:var(--dark);width:36px;height:36px;color:var(--cream);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.location-text{flex:1}.location-status{color:#02140880;margin-top:2px;font-size:.75rem}.toggle-row{justify-content:space-between;align-items:center;padding:8px 0;display:flex}.toggle-info{font-size:.9rem;font-weight:600}.toggle-sub{color:#02140880;margin-top:2px;font-size:.75rem;font-weight:400}.switch{width:50px;height:28px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#02140833;border-radius:34px;transition:all .3s;position:absolute;top:0;bottom:0;left:0;right:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:22px;height:22px;transition:all .3s;position:absolute;bottom:3px;left:3px;box-shadow:0 2px 4px #0003}input:checked+.slider{background-color:var(--green)}input:checked+.slider:before{transform:translate(22px)}.pin-grid{justify-content:space-between;gap:12px;margin-bottom:16px;display:flex}.pin-input{aspect-ratio:1;background:var(--cream);border-radius:var(--radius-md,12px);text-align:center;width:calc(25% - 9px);color:var(--dark);border:2px solid #0214081a;font-size:1.5rem;font-weight:800;transition:all .2s}.pin-input:focus{border-color:var(--green);background:#fff;outline:none}.pin-label{text-align:center;color:#02140899;margin-bottom:8px;font-size:.75rem;font-weight:600}.steps{justify-content:center;gap:8px;margin-bottom:30px;display:flex}.step-dot{background:#02140826;border-radius:4px;width:8px;height:8px;transition:all .3s}.step-dot.active{background:var(--green);width:24px}:root{--bg-cream:#dfe4e0;--bg-cream-dark:#cdd5d0;--dark-green:#021408;--dark-green-light:#0a3d1a;--fast-green:#22c55e;--fast-green-dark:#16a34a;--warning:#f59e0b;--font-heading:"Arial Black", sans-serif;--font-body:"Inter", sans-serif;--font-display:"Arial Black", sans-serif}.top-bar{justify-content:space-between;align-items:center;padding:16px 12px 8px;display:flex}.user-profile{align-items:center;gap:12px;display:flex}.avatar{background:var(--dark-green);width:44px;height:44px;color:var(--fast-green);border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:flex}.greeting{color:#02140899;font-size:.85rem;font-weight:600}.user-name{letter-spacing:-.5px;font-size:1.1rem;font-weight:800}.bell-btn{background:#fff6;border:1px solid #0214080d;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;display:flex;position:relative}.bell-badge{background:var(--danger);border:2px solid var(--bg-cream);border-radius:50%;width:8px;height:8px;position:absolute;top:10px;right:12px}.balance-card{background:var(--dark-green);color:var(--bg-cream);border-radius:var(--radius-lg);margin:12px;padding:24px;position:relative;overflow:hidden;box-shadow:0 12px 24px #02140826}.card-pattern{background:linear-gradient(135deg, var(--fast-green) 0%, transparent 100%);opacity:.2;filter:blur(20px);border-radius:50%;width:150px;height:150px;position:absolute;top:-50px;right:-50px}.balance-label{color:#ffffffb3;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.85rem;font-weight:500;display:flex}.balance-amount{letter-spacing:-1px;font-family:Arial Black,sans-serif;font-size:2.2rem;font-weight:800}.balance-amount span{vertical-align:top;margin-right:4px;font-size:1.2rem;font-weight:600}.card-actions{gap:12px;margin-top:24px;display:flex}.card-btn{color:#fff;border-radius:var(--radius-md);background:#ffffff1a;border:1px solid #fff3;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:.85rem;font-weight:600;display:flex}.quick-actions{justify-content:space-between;margin:24px 0 32px;padding:0 16px;display:flex}.action-item{cursor:pointer;flex-direction:column;align-items:center;gap:8px;display:flex}.action-circle{width:56px;height:56px;color:var(--dark-green);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;transition:transform .2s;display:flex;box-shadow:0 4px 12px #0214080d}.action-item:active .action-circle{background:var(--fast-green);transform:scale(.9)}.action-name{color:#021408b3;font-size:.75rem;font-weight:600}.activity-section{background:#fff;border-top-left-radius:30px;border-top-right-radius:30px;flex:1;padding:24px 12px;box-shadow:0 -4px 20px #00000008}.section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-title{font-size:1.1rem;font-weight:800}.section-link{color:var(--fast-green-dark);font-size:.85rem;font-weight:600;text-decoration:none}.tx-item{border-bottom:1px solid #0214080d;justify-content:space-between;align-items:center;padding:16px 0;display:flex}.tx-item:last-child{border-bottom:none}.tx-left{align-items:center;gap:12px;display:flex}.tx-icon{border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.tx-out{color:var(--dark-green);background:#0214080d}.tx-in{color:var(--fast-green-dark);background:#22c55e1a}.tx-title{font-size:.95rem;font-weight:700}.tx-time{color:#02140880;margin-top:2px;font-size:.75rem}.tx-amount{font-size:1rem;font-weight:800}.amount-out{color:var(--dark-green)}.amount-in{color:var(--fast-green-dark)}.tx-empty{text-align:center;color:#02140866;padding:48px 24px;font-size:.9rem}#qr-reader{z-index:2;border:none!important;width:100%!important;height:100%!important;position:absolute!important;top:0!important;bottom:0!important;left:0!important;right:0!important;overflow:hidden!important}#qr-reader>div{border:none!important;width:100%!important;height:100%!important;position:relative!important}#qr-reader video{object-fit:cover!important;width:auto!important;min-width:100%!important;height:auto!important;min-height:100%!important;position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}#qr-reader__scan_region{width:100%!important;height:100%!important;min-height:100%!important;position:absolute!important;top:0!important;left:0!important}#qr-reader__scan_region>img,#qr-reader__scan_region>br,#qr-reader__dashboard,#qr-reader__dashboard_section,#qr-reader__dashboard_section_csr,#qr-reader__dashboard_section_swaplink,#qr-reader__header_message,#qr-reader__status_span,#qr-reader>div:last-child:not(:first-child){display:none!important}#qr-reader canvas{opacity:0!important;pointer-events:none!important;position:absolute!important}#qr-reader .qr-shaded-region{display:none!important}.page-header{z-index:50;background:#fff;border-bottom-right-radius:24px;border-bottom-left-radius:24px;padding:24px 12px 16px;position:sticky;top:0;box-shadow:0 4px 12px #00000008}.header-title{font-size:1.4rem;font-weight:800;font-family:"Arial Black", var(--font-body);letter-spacing:-.5px;margin-bottom:16px}.tabs-wrapper{background:#0214080d;border-radius:12px;padding:4px;display:flex}.tab{text-align:center;cursor:pointer;color:#02140880;border-radius:8px;flex:1;padding:8px 0;font-size:.9rem;font-weight:700;transition:all .2s}.tab.active{color:var(--dark-green);background:#fff;box-shadow:0 2px 8px #0000000d}.content-area{flex:1;padding:24px 20px}.session-card{border-radius:var(--radius-md);background:#fff;border:1px solid #02140808;margin-bottom:16px;padding:20px;position:relative;overflow:hidden;box-shadow:0 4px 16px #00000008}.session-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.session-icon-wrap{align-items:center;gap:12px;display:flex}.session-icon{width:48px;height:48px;color:var(--dark-green);background:#0214080d;border-radius:12px;justify-content:center;align-items:center;font-size:1.3rem;display:flex}.session-icon.active-icon{color:var(--fast-green-dark);background:#22c55e1a}.session-title{font-size:1.05rem;font-weight:800}.session-merchant{color:#02140880;font-size:.8rem;font-weight:500}.status-badge{text-transform:uppercase;border-radius:4px;padding:4px 8px;font-size:.7rem;font-weight:700}.status-badge.active{color:var(--fast-green-dark);background:#22c55e26}.status-badge.warning{color:var(--warning);background:#f59e0b26}.status-badge.past{color:#02140899;background:#02140814}.session-details{background:var(--bg-cream);border-radius:8px;margin-bottom:16px;padding:12px}.detail-row{justify-content:space-between;margin-bottom:8px;font-size:.85rem;display:flex}.detail-row:last-child{border-top:1px dashed #0214081a;margin-bottom:0;padding-top:8px;font-size:1rem;font-weight:800}.detail-label{color:#02140899;font-weight:500}.session-actions{gap:12px;display:flex}.btn-session{cursor:pointer;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:.9rem;font-weight:700;display:flex}.btn-primary{background:var(--dark-green);color:#fff}.btn-secondary{color:var(--dark-green);background:#0214080d}.empty-state{text-align:center;color:#02140880;padding:40px 20px}.empty-icon{opacity:.5;margin-bottom:16px;font-size:3rem}.profile-hero{flex-direction:column;align-items:center;padding:10px 20px 30px;display:flex}.profile-avatar{background:var(--dark-green);width:80px;height:80px;color:var(--fast-green);border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;font-size:2.5rem;display:flex;position:relative;box-shadow:0 8px 24px #02140826}.avatar-edit-btn{width:28px;height:28px;color:var(--dark-green);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;display:flex;position:absolute;bottom:0;right:0;box-shadow:0 2px 8px #0000001a}.profile-name{letter-spacing:-.5px;font-size:1.4rem;font-weight:800}.profile-phone{color:#02140899;margin-top:4px;margin-bottom:16px;font-size:.95rem;font-weight:500}.kyc-badge{color:var(--fast-green-dark);background:#22c55e26;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:700;display:flex}.settings-section{background:#fff;border-top-left-radius:30px;border-top-right-radius:30px;flex:1;padding:30px 20px;box-shadow:0 -4px 20px #00000008}.settings-title{color:#02140880;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;padding-left:4px;font-size:.85rem;font-weight:800}.settings-card{border-radius:var(--radius-md);background:#fff;border:1px solid #0214080d;overflow:hidden;box-shadow:0 4px 12px #00000005}.settings-group{margin-bottom:30px}.group-title{color:#02140880;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;padding-left:4px;font-size:.85rem;font-weight:800}.settings-row,.setting-item{color:var(--dark-green);cursor:pointer;border-bottom:1px solid #0214080d;justify-content:space-between;align-items:center;padding:16px;text-decoration:none;transition:background .2s;display:flex}.settings-row:last-child,.setting-item:last-child{border-bottom:none}.settings-row:active,.setting-item:active{background:#02140805}.setting-left{align-items:center;gap:16px;display:flex}.settings-icon,.setting-icon{background:var(--bg-cream);width:40px;height:40px;color:var(--dark-green);border-radius:12px;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.settings-label,.setting-title{font-size:.95rem;font-weight:600}.setting-desc{color:#02140880;margin-top:2px;font-size:.75rem}.settings-arrow,.setting-right{color:#0214084d;align-items:center;font-size:1.2rem;display:flex}.toggle-switch{width:48px;height:28px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:#ccc;border-radius:30px;transition:all .3s;position:absolute;top:0;bottom:0;left:0;right:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:22px;height:22px;transition:all .3s;position:absolute;bottom:3px;left:3px;box-shadow:0 2px 4px #0003}input:checked+.toggle-slider{background-color:var(--fast-green)}input:checked+.toggle-slider:before{transform:translate(20px)}.logout-btn{width:100%;color:var(--danger);border-radius:var(--radius-md);cursor:pointer;background:#fef2f2;border:1px solid #ef444433;justify-content:center;align-items:center;gap:10px;margin-top:20px;padding:16px;font-size:1rem;font-weight:700;transition:all .2s;display:flex}.logout-btn:active{background:#fecaca}.version-text{text-align:center;color:#0214084d;margin-top:16px;font-size:.75rem;font-weight:500}.scanner-header{z-index:10;background:linear-gradient(#021408e6 0%,#02140800 100%);justify-content:space-between;align-items:center;padding:24px 20px;display:flex}.brand-wrap{letter-spacing:.5px;color:var(--dark-green);align-items:center;gap:8px;font-family:Arial Black,sans-serif;font-size:1.4rem;display:flex}.icon-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;transition:all .2s;display:flex}.icon-btn:active{background:#ffffff40;transform:scale(.95)}.camera-container{flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex;position:relative}.camera-bg{opacity:.4;z-index:1;background:url(https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&q=80) 50%/cover;position:absolute;top:0;bottom:0;left:0;right:0}.scan-frame-wrapper{z-index:5;justify-content:center;align-items:center;width:280px;height:280px;margin-bottom:60px;display:flex;position:relative}.scan-bracket{border-color:var(--fast-green);border-style:solid;border-width:0;border-radius:4px;width:40px;height:40px;position:absolute}.bracket-tl{border-top-width:4px;border-left-width:4px;top:0;left:0}.bracket-tr{border-top-width:4px;border-right-width:4px;top:0;right:0}.bracket-bl{border-bottom-width:4px;border-left-width:4px;bottom:0;left:0}.bracket-br{border-bottom-width:4px;border-right-width:4px;bottom:0;right:0}.scan-line{background:var(--fast-green);height:2px;box-shadow:0 0 15px 2px var(--fast-green);animation:2.5s linear infinite alternate scan;position:absolute;top:0;left:10px;right:10px}@keyframes scan{0%{opacity:0;top:10px}10%{opacity:1}90%{opacity:1}to{opacity:0;top:270px}}.instruction-text{z-index:5;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);letter-spacing:.5px;color:var(--bg-cream);background:#02140899;border:1px solid #ffffff1a;border-radius:30px;margin-top:-30px;padding:12px 24px;font-size:.95rem;font-weight:500;position:relative}.scanner-overlay,.scanner-overlay .brand-wrap{color:var(--bg-cream)}.camera-container{background:0 0;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.bottom-nav{background:var(--bg-cream);z-index:100;border-top-left-radius:24px;border-top-right-radius:24px;justify-content:space-around;align-items:center;padding:12px 10px 24px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #00000026}.nav-item{color:#02140866;flex-direction:column;flex:1;align-items:center;gap:4px;font-size:.75rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.nav-item i{margin-bottom:2px;font-size:1.4rem}.nav-item.active{color:var(--dark-green)}.nav-scan-btn{background:var(--dark-green);width:64px;height:64px;color:var(--fast-green);border:4px solid var(--bg-cream);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:2rem;transition:all .2s;display:flex;position:relative;top:-24px;box-shadow:0 8px 24px #02140866}.nav-scan-btn:active{transform:scale(.95)}.nav-icon{margin-bottom:2px;font-size:1.4rem}.nav-label{font-size:.75rem}.cc-top-header{background:var(--bg);z-index:50;justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex;position:sticky;top:0}.cc-back-btn{cursor:pointer;width:38px;height:38px;color:var(--text-dark);background:#fff;border:1px solid #0214080d;border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 2px 8px #0000000d}.cc-logo-text{letter-spacing:-.5px;color:var(--text-dark);align-items:center;gap:4px;font-size:20px;font-weight:800;display:flex}.cc-wallet-pill{background:#16a34a1a;border:1px solid #16a34a33;border-radius:20px;align-items:center;gap:4px;padding:6px 12px;display:flex}.cc-wallet-pill span{color:#16a34a;font-size:12px;font-weight:700}.cc-merchant-card{background:#021408;border-radius:20px;align-items:center;gap:12px;margin:4px 20px 16px;padding:16px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 20px #02140826}.cc-merchant-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#4ade8026 0%,#0000 70%);border-radius:50%;width:120px;height:120px;position:absolute;top:-50%;right:-10%}.cc-merchant-icon{z-index:2;background:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:24px;display:flex;box-shadow:0 4px 10px #0000001a}.cc-merchant-details{z-index:2;flex:1}.cc-merchant-name{color:#fff;letter-spacing:-.5px;margin-bottom:2px;font-size:18px;font-weight:800}.cc-merchant-status{color:#ffffffb3;align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.cc-status-dot{background:#4ade80;border-radius:50%;width:6px;height:6px;box-shadow:0 0 8px #4ade8080}.cc-sliding-search{z-index:10;justify-content:flex-end;align-items:center;width:44px;height:44px;transition:width .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.cc-sliding-search.active{width:calc(100% - 32px)}.cc-search-toggle-btn{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;transition:all .3s;display:flex;position:absolute;top:0;right:0}.cc-sliding-search.active .cc-search-toggle-btn{opacity:0;pointer-events:none}.cc-sliding-search-input{color:#021408;opacity:0;pointer-events:none;background:#fff;border:none;border-radius:22px;outline:none;width:100%;height:100%;padding:0 44px 0 20px;font-family:inherit;font-size:14px;transition:opacity .2s}.cc-sliding-search.active .cc-sliding-search-input{opacity:1;pointer-events:auto;box-shadow:0 4px 12px #0003}.cc-search-close-btn{color:#021408;cursor:pointer;opacity:0;pointer-events:none;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;display:flex;position:absolute;top:0;right:0}.cc-sliding-search.active .cc-search-close-btn{opacity:1;pointer-events:auto}.cc-categories-wrapper{scrollbar-width:none;padding:0 20px 16px;overflow-x:auto}.cc-categories-wrapper::-webkit-scrollbar{display:none}.cc-categories{gap:8px;width:max-content;display:flex}.cc-chip{color:#02140899;cursor:pointer;background:#fff;border:1px solid #0214080d;border-radius:20px;align-items:center;gap:4px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 6px #00000005}.cc-chip.active{color:#fff;background:#021408;border-color:#021408;box-shadow:0 4px 10px #02140826}.cc-grid-container{grid-template-columns:1fr 1fr;gap:12px;padding:0 20px 120px;display:grid}.cc-product-card{background:#fff;border:2px solid #0000;border-radius:16px;flex-direction:column;gap:8px;padding:8px;transition:all .2s;display:flex;position:relative;box-shadow:0 2px 10px #00000008}.cc-product-card.selected{border-color:#16a34a;transform:translateY(-2px);box-shadow:0 6px 16px #16a34a26}.cc-image-box{background:#f3f6f4;border-radius:12px;justify-content:center;align-items:center;width:100%;height:90px;font-size:32px;display:flex;position:relative;overflow:hidden}.cc-image-box img{object-fit:cover;width:100%;height:100%}.cc-prod-info{flex-direction:column;gap:2px;padding:0 4px;display:flex}.cc-prod-name{color:#021408;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;line-height:1.2;overflow:hidden}.cc-prod-price{color:#16a34a;font-size:13px;font-weight:800}.cc-action-container{height:32px;margin-top:auto}.cc-btn-add{color:#fff;cursor:pointer;background:#021408;border:none;border-radius:10px;justify-content:center;align-items:center;gap:4px;width:100%;height:100%;font-size:13px;font-weight:700;transition:all .2s;display:flex}.cc-btn-add:active{transform:scale(.96)}.cc-stepper{background:#16a34a1a;border:1px solid #16a34a33;border-radius:10px;justify-content:space-between;align-items:center;width:100%;height:100%;padding:0 2px;display:flex}.cc-stepper-btn{color:#16a34a;cursor:pointer;background:#fff;border:none;border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;font-size:14px;display:flex;box-shadow:0 2px 4px #0000000d}.cc-stepper-value{color:#021408;font-size:14px;font-weight:800}.cc-floating-footer{z-index:100;background:#021408;border-radius:20px;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;animation:.3s ease-out forwards ccSlideUp;display:flex;position:fixed;bottom:150px;left:20px;right:20px;box-shadow:0 16px 32px #02140840}@keyframes ccSlideUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.cc-footer-left{flex-direction:column;flex-shrink:0;gap:0;display:flex}.cc-footer-items{color:#fff9;letter-spacing:.5px;font-size:11px;font-weight:600}.cc-footer-total{color:#fff;font-size:18px;font-weight:800}.cc-footer-actions{flex:1;justify-content:flex-end;gap:8px;display:flex}.cc-btn-pay-mpesa{color:#fff;cursor:pointer;background:#52b848;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;max-width:120px;height:38px;padding:0 12px;font-size:13px;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 4px 12px #52b8484d}.cc-btn-pay-wallet{color:#021408;cursor:pointer;background:#fff;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;max-width:120px;height:38px;padding:0 12px;font-size:13px;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 4px 12px #ffffff1a}.cc-btn-pay-mpesa:active,.cc-btn-pay-wallet:active{transform:scale(.96)}.hist-v2-container{background-image:radial-gradient(circle at 50% 0,#fff 0%,#f4f5f7 100%);background-attachment:fixed;min-height:100vh}.hist-v2-header{z-index:50;-webkit-backdrop-filter:blur(24px);background:#f4f5f7cc;justify-content:space-between;align-items:center;padding:24px 24px 16px;display:flex;position:sticky;top:0}.hist-v2-logo{font-family:var(--font-outfit);letter-spacing:-.5px;color:#0f172a;align-items:center;gap:8px;font-size:24px;font-weight:800;display:flex}.hist-v2-logo i{color:#10b981}.hist-v2-tabs-container{z-index:40;background:linear-gradient(#f4f5f7cc 0%,#f4f5f700 100%);padding:10px 24px 20px;position:sticky;top:73px}.hist-v2-tabs-wrapper{background:#e2e8f0;border-radius:100px;padding:4px;display:flex;position:relative}.hist-v2-tab{text-align:center;color:#64748b;cursor:pointer;z-index:2;flex:1;padding:12px 0;font-size:13px;font-weight:600;transition:color .3s;position:relative}.hist-v2-tab.active{color:#0f172a}.hist-v2-tab-indicator{z-index:1;background:#fff;border-radius:100px;width:calc(50% - 4px);transition:transform .4s cubic-bezier(.34,1.56,.64,1);position:absolute;top:4px;bottom:4px;left:4px;box-shadow:0 2px 8px #0000000d}.hist-v2-session-card{cursor:pointer;background:#fff;border:1px solid #fffc;border-radius:24px;flex-direction:column;gap:20px;margin-bottom:16px;padding:20px;transition:transform .15s;animation:.6s cubic-bezier(.16,1,.3,1) backwards slideUp;display:flex;box-shadow:0 10px 30px #0000000a}.hist-v2-session-card:active{transform:scale(.98)}.v2-success-hero{flex-direction:column;align-items:center;margin-bottom:24px;display:flex}.v2-check-container{background:#ecfdf5;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:16px;display:flex;box-shadow:0 10px 20px #10b98126,inset 0 0 0 4px #fff}.v2-check-circle{stroke-dasharray:166;stroke-dashoffset:166px;stroke-width:4px;stroke:#10b981;fill:none;animation:.6s cubic-bezier(.65,0,.45,1) forwards stroke}.v2-check-path{transform-origin:50%;stroke-dasharray:48;stroke-dashoffset:48px;stroke:#10b981;stroke-width:6px;stroke-linecap:round;stroke-linejoin:round;fill:none;animation:.3s cubic-bezier(.65,0,.45,1) .6s forwards stroke}.v2-receipt-card{filter:drop-shadow(0 10px 15px #0000000d);background:#fff;border-radius:20px;width:100%;padding-bottom:20px;animation:.8s cubic-bezier(.16,1,.3,1) 1s backwards slideUp;position:relative;box-shadow:0 20px 40px #0000000f}.v2-receipt-card:after{content:"";background:inherit;height:16px;position:absolute;bottom:-8px;left:0;right:0;-webkit-mask-image:radial-gradient(circle at 8px 16px,#0000 8px,#000 9px);mask-image:radial-gradient(circle at 8px 16px,#0000 8px,#000 9px);-webkit-mask-position:bottom;mask-position:bottom;-webkit-mask-size:16px 16px;mask-size:16px 16px;-webkit-mask-repeat:repeat-x;mask-repeat:repeat-x}.v2-barcode{background:repeating-linear-gradient(90deg,#0f172a,#0f172a 3px,#0000 3px 6px,#0f172a 6px 10px,#0000 10px 14px,#0f172a 14px 16px,#0000 16px 22px);width:100%;height:40px}.hv3-top-header{z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:10px 14px 8px;display:flex;position:relative}.hv3-logo{align-items:center;gap:6px;display:flex}.hv3-logo-icon{color:#fff;background:#0f172a;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;display:flex}.hv3-logo-text{color:#0f172a;letter-spacing:-.5px;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:20px;font-weight:800}.hv3-header-right{align-items:center;gap:8px;display:flex}.hv3-header-btn{color:#334155;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;display:flex}.hv3-avatar{color:#fff;cursor:pointer;background:#0f172a;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:800;display:flex}.hv3-greeting{background:#fff;padding:6px 14px 14px}.hv3-greeting-sub{color:#94a3b8;font-size:12px;font-weight:500}.hv3-greeting-name{color:#0f172a;letter-spacing:-.5px;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:22px;font-weight:800}.hv3-wallet-card{background:#fff;border-radius:14px;margin:10px 6px 0;overflow:hidden;box-shadow:0 1px 3px #0f172a0a,0 4px 14px #0f172a0a}.hv3-wallet-top{background:#0f172a;padding:20px 18px 24px;position:relative;overflow:hidden}.hv3-wallet-top:after{content:"";background:#fff;border-radius:12px 12px 0 0;height:12px;position:absolute;bottom:-1px;left:0;right:0}.hv3-wallet-label{text-transform:uppercase;letter-spacing:1.5px;color:#fff6;margin-bottom:6px;font-size:9px;font-weight:700}.hv3-wallet-amount{align-items:flex-start;gap:5px;display:flex}.hv3-wallet-kes{color:#10b981;margin-top:6px;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:14px;font-weight:700}.hv3-wallet-value{color:#fff;letter-spacing:-2px;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:42px;font-weight:900;line-height:1}.hv3-wallet-divider{border:none;border-top:2px dashed #e2e8f0;margin:0 16px}.hv3-wallet-details{justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.hv3-wallet-detail-label{text-transform:uppercase;letter-spacing:1px;color:#94a3b8;margin-bottom:1px;font-size:9px;font-weight:700}.hv3-wallet-detail-value{color:#0f172a;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:13px;font-weight:700}.hv3-wallet-status{text-transform:uppercase;letter-spacing:.5px;color:#059669;background:#d1fae5;border-radius:20px;padding:4px 12px;font-size:10px;font-weight:800}.hv3-wallet-actions{gap:6px;padding:4px 8px 10px;display:flex}.hv3-wallet-btn{text-transform:uppercase;letter-spacing:.6px;cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;padding:12px;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:12px;font-weight:800;transition:all .15s;display:flex}.hv3-wallet-btn:active{transform:scale(.97)}.hv3-wallet-btn.dark{color:#fff;background:#0f172a}.hv3-wallet-btn.outline{color:#0f172a;background:0 0;border:1.5px solid #e2e8f0}.hv3-actions-row{justify-content:space-around;padding:14px 6px 4px;display:flex}.hv3-act{cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.hv3-act:active .hv3-act-icon{transform:scale(.9)}.hv3-act-icon{color:#fff;background:#0f172a;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;transition:transform .15s;display:flex}.hv3-act-icon.green{background:#10b981}.hv3-act-icon.outline{color:#0f172a;background:#fff;border:1.5px solid #e2e8f0;box-shadow:0 1px 3px #0f172a0a,0 4px 14px #0f172a0a}.hv3-act-name{color:#64748b;text-transform:uppercase;letter-spacing:.3px;font-size:10px;font-weight:700}.hv3-section-row{justify-content:space-between;align-items:center;padding:18px 14px 8px;display:flex}.hv3-section-label{text-transform:uppercase;letter-spacing:1.2px;color:#334155;font-size:10px;font-weight:800}.hv3-section-link{color:#10b981;cursor:pointer;font-size:11px;font-weight:700;text-decoration:none}.hv3-places-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding:0 6px 2px;display:flex;overflow-x:auto}.hv3-places-scroll::-webkit-scrollbar{display:none}.hv3-place-chip{scroll-snap-align:start;cursor:pointer;background:#fff;border-radius:12px;flex-shrink:0;min-width:calc(50% - 8px);padding:12px;transition:all .15s;box-shadow:0 1px 3px #0f172a0a,0 4px 14px #0f172a0a}.hv3-place-chip:active{transform:scale(.96)}.hv3-place-chip-top{align-items:center;gap:10px;margin-bottom:8px;display:flex}.hv3-place-icon{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;display:flex}.hv3-place-name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:13px;font-weight:800;line-height:1.2;overflow:hidden}.hv3-place-type{text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;font-size:9px;font-weight:600}.hv3-place-chip-stats{justify-content:space-between;align-items:center;display:flex}.hv3-place-visits{color:#10b981;text-transform:uppercase;letter-spacing:.3px;font-size:10px;font-weight:700}.hv3-place-ago{color:#94a3b8;font-size:10px;font-weight:500}.hv3-reorder-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding:0 6px 2px;display:flex;overflow-x:auto}.hv3-reorder-scroll::-webkit-scrollbar{display:none}.hv3-reorder-ticket{scroll-snap-align:start;cursor:pointer;background:#fff;border-radius:12px;flex-shrink:0;min-width:calc(68% - 4px);transition:all .15s;overflow:hidden;box-shadow:0 1px 3px #0f172a0a,0 4px 14px #0f172a0a}.hv3-reorder-ticket:active{transform:scale(.97)}.hv3-reorder-ticket-head{align-items:center;gap:10px;padding:12px 14px;display:flex}.hv3-reorder-ticket-icon{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;display:flex}.hv3-reorder-ticket-name{color:#0f172a;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:13px;font-weight:800}.hv3-reorder-ticket-sub{color:#94a3b8;font-size:10px;font-weight:500}.hv3-reorder-divider{border:none;border-top:2px dashed #e2e8f0;margin:0 12px}.hv3-reorder-ticket-body{padding:8px 14px 4px}.hv3-reorder-item-row{justify-content:space-between;align-items:center;padding:3px 0;display:flex}.hv3-reorder-item-qty{color:#334155;min-width:24px;font-size:12px;font-weight:800}.hv3-reorder-item-name{color:#0f172a;flex:1;font-size:12px;font-weight:500}.hv3-reorder-item-price{color:#0f172a;font-size:12px;font-weight:700}.hv3-reorder-ticket-foot{justify-content:space-between;align-items:center;padding:8px 14px 10px;display:flex}.hv3-reorder-total-label{text-transform:uppercase;letter-spacing:1px;color:#94a3b8;font-size:9px;font-weight:700}.hv3-reorder-total-amount{align-items:baseline;gap:3px;display:flex}.hv3-reorder-total-kes{color:#10b981;font-size:10px;font-weight:700}.hv3-reorder-total-val{color:#0f172a;letter-spacing:-.5px;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:20px;font-weight:900}.hv3-reorder-go-btn{color:#fff;text-transform:uppercase;letter-spacing:.8px;cursor:pointer;background:#0f172a;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:calc(100% - 20px);height:40px;margin:0 10px 10px;padding:0 12px;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:11px;font-weight:800;transition:all .15s;display:flex}.hv3-reorder-go-btn:active{transform:scale(.97)}.hv3-activity-list{flex-direction:column;gap:6px;padding:0 6px 100px;display:flex}.hv3-activity-card{cursor:pointer;background:#fff;border-radius:12px;transition:all .15s;overflow:hidden;box-shadow:0 1px 3px #0f172a0a,0 4px 14px #0f172a0a}.hv3-activity-card:active{transform:scale(.98)}.hv3-activity-card-top{align-items:center;gap:10px;padding:14px 14px 12px;display:flex}.hv3-activity-card-icon{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;display:flex}.hv3-activity-card-name{color:#0f172a;margin-bottom:1px;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:14px;font-weight:800}.hv3-activity-card-meta{text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;font-size:10px;font-weight:600}.hv3-activity-divider{border:none;border-top:2px dashed #e2e8f0;margin:0 12px}.hv3-activity-card-bottom{justify-content:space-between;align-items:flex-end;padding:10px 14px 12px;display:flex}.hv3-activity-date-label{text-transform:uppercase;letter-spacing:1px;color:#94a3b8;margin-bottom:1px;font-size:9px;font-weight:700}.hv3-activity-date-value{color:#0f172a;font-size:13px;font-weight:700}.hv3-activity-amount-block{text-align:right}.hv3-activity-amount-label{text-transform:uppercase;letter-spacing:1px;color:#94a3b8;margin-bottom:1px;font-size:9px;font-weight:700}.hv3-activity-amount-val{justify-content:flex-end;align-items:baseline;gap:3px;display:flex}.hv3-activity-kes{color:#10b981;font-size:11px;font-weight:700}.hv3-activity-number{color:#0f172a;letter-spacing:-.5px;font-family:Outfit,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:24px;font-weight:900;line-height:1}@keyframes hv3RiseIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.hv3-anim{animation:.4s cubic-bezier(.16,1,.3,1) both hv3RiseIn}.hv3-d1{animation-delay:20ms}.hv3-d2{animation-delay:40ms}.hv3-d3{animation-delay:60ms}.hv3-d4{animation-delay:80ms}.hv3-d5{animation-delay:.1s}.hv3-d6{animation-delay:.12s}.hv3-d7{animation-delay:.14s}.mkt-page{background:#f4f5f7;min-height:100vh}.mkt-header{z-index:50;background:#fff;padding:10px 16px 12px;position:sticky;top:0}.mkt-header-top{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.mkt-logo{align-items:center;gap:8px;display:flex}.mkt-logo-text{color:#0f172a;letter-spacing:-.5px;font-family:Outfit,Inter,sans-serif;font-size:20px;font-weight:800}.mkt-wallet-pill{background:#ecfdf5;border:1px solid #10b98133;border-radius:100px;align-items:center;gap:6px;padding:6px 14px;display:flex}.mkt-wallet-pill i{color:#10b981;font-size:13px}.mkt-wallet-pill span{color:#059669;font-size:12px;font-weight:800}.mkt-search{background:#f1f5f9;border-radius:12px;align-items:center;gap:10px;width:100%;padding:10px 14px;display:flex}.mkt-search i{color:#94a3b8;flex-shrink:0;font-size:14px}.mkt-search input{color:#0f172a;background:0 0;border:none;outline:none;flex:1;min-width:0;font-family:Inter,sans-serif;font-size:14px;font-weight:500}.mkt-search input::placeholder{color:#94a3b8}.mkt-tabs{scrollbar-width:none;gap:8px;padding:12px 16px 6px;display:flex;overflow-x:auto}.mkt-tabs::-webkit-scrollbar{display:none}.mkt-tab{cursor:pointer;color:#64748b;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;border-radius:100px;flex-shrink:0;padding:8px 16px;font-size:12px;font-weight:600;transition:all .2s}.mkt-tab.active{color:#fff;background:#0f172a;border-color:#0f172a}.mkt-section{padding:16px 16px 0}.mkt-section-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.mkt-section-label{color:#0f172a;text-transform:uppercase;letter-spacing:.8px;font-family:Outfit,Inter,sans-serif;font-size:14px;font-weight:700}.mkt-section-link{color:#10b981;cursor:pointer;font-size:12px;font-weight:600}.mkt-divider{border:none;border-top:1px dashed #cbd5e1;height:1px;margin:4px 16px 0}.mkt-merchants-scroll{scrollbar-width:none;gap:12px;padding:0 16px 12px;display:flex;overflow-x:auto}.mkt-merchants-scroll::-webkit-scrollbar{display:none}.mkt-merchant-card{cursor:pointer;background:#0f172a;border-radius:16px;flex-shrink:0;width:150px;padding:14px;transition:transform .2s;position:relative;overflow:hidden}.mkt-merchant-card:hover{transform:translateY(-2px)}.mkt-merchant-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#10b98133 0%,#0000 70%);border-radius:50%;width:80px;height:80px;position:absolute;top:-30px;right:-20px}.mkt-merchant-icon{background:#fff;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:10px;font-size:20px;display:flex;box-shadow:0 2px 8px #0000001a}.mkt-merchant-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-family:Outfit,sans-serif;font-size:14px;font-weight:700;overflow:hidden}.mkt-merchant-type{color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.mkt-merchant-stats{align-items:center;gap:8px;margin-top:8px;display:flex}.mkt-merchant-stat{color:#10b981;font-size:10px;font-weight:600}.mkt-merchant-dot{background:#ffffff4d;border-radius:50%;width:3px;height:3px}.mkt-freq-scroll{scrollbar-width:none;gap:12px;padding:0 16px 12px;display:flex;overflow-x:auto}.mkt-freq-scroll::-webkit-scrollbar{display:none}.mkt-freq-card{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:16px;flex-shrink:0;width:140px;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 1px 4px #0000000a}.mkt-freq-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.mkt-freq-card.selected{border-color:#10b981;box-shadow:0 4px 16px #10b98126}.mkt-freq-img{object-fit:cover;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);width:100%;height:90px}.mkt-freq-body{padding:8px 10px 10px}.mkt-freq-merchant{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:9px;font-weight:700}.mkt-freq-name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:12px;font-weight:700;overflow:hidden}.mkt-freq-row{justify-content:space-between;align-items:center;display:flex}.mkt-freq-price{color:#10b981;font-family:Outfit,sans-serif;font-size:14px;font-weight:800}.mkt-freq-price span{color:#94a3b8;margin-right:1px;font-size:9px}.mkt-grid{grid-template-columns:1fr 1fr;gap:10px;padding:0 16px 12px;display:grid}.mkt-product{background:#fff;border:2px solid #0000;border-radius:16px;flex-direction:column;transition:all .2s;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 4px #0000000a}.mkt-product:hover{box-shadow:0 4px 12px #00000014}.mkt-product.selected{border-color:#10b981;transform:translateY(-2px);box-shadow:0 4px 16px #10b98126}.mkt-product-img{object-fit:cover;cursor:pointer;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);width:100%;height:110px}.mkt-product-body{flex-direction:column;flex:1;padding:8px 10px;display:flex}.mkt-product-merchant{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1px;font-size:9px;font-weight:700}.mkt-go-merchant{cursor:pointer;align-items:center;gap:2px;padding:2px 0;transition:color .15s;display:flex}.mkt-go-merchant:hover{color:#10b981}.mkt-product-name{color:#0f172a;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:2px;font-size:13px;font-weight:700;line-height:1.2;display:-webkit-box;overflow:hidden}.mkt-product-footer{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.mkt-product-price{color:#10b981;font-family:Outfit,sans-serif;font-size:15px;font-weight:800}.mkt-product-price span{color:#94a3b8;font-size:9px}.mkt-action{height:32px}.mkt-add-btn{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:10px;justify-content:center;align-items:center;gap:4px;width:100%;height:100%;font-family:Inter,sans-serif;font-size:12px;font-weight:700;transition:all .2s;display:flex}.mkt-add-btn:active{transform:scale(.96)}.mkt-stepper{background:#10b9811a;border:1px solid #10b98140;border-radius:10px;justify-content:space-between;align-items:center;width:100%;height:100%;padding:0 2px;display:flex}.mkt-step-btn{color:#10b981;cursor:pointer;background:#fff;border:none;border-radius:7px;justify-content:center;align-items:center;width:26px;height:26px;font-size:14px;display:flex;box-shadow:0 1px 3px #0000000f}.mkt-step-btn:active{transform:scale(.9)}.mkt-step-val{color:#0f172a;font-size:14px;font-weight:800}.mkt-cart-float{z-index:110;background:#021408;border-radius:20px;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;animation:.3s ease-out forwards ccSlideUp;display:flex;position:fixed;bottom:100px;left:16px;right:16px;box-shadow:0 16px 32px #02140840}.mkt-checkout{z-index:60;padding:0 16px;animation:.3s ease-out forwards mktSlideUp;position:fixed;bottom:74px;left:0;right:0}@keyframes mktSlideUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.mkt-checkout-inner{background:#0f172a;border-radius:18px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex;box-shadow:0 12px 40px #0f172a59}.mkt-checkout-info{flex-shrink:0}.mkt-checkout-items{color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.mkt-checkout-total{color:#fff;font-family:Outfit,sans-serif;font-size:20px;font-weight:800}.mkt-checkout-total span{opacity:.6;font-size:11px;font-weight:600}.mkt-checkout-btns{gap:8px;display:flex}.mkt-btn-wallet,.mkt-btn-mpesa{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:6px;padding:10px 16px;font-family:Inter,sans-serif;font-size:12px;font-weight:700;transition:transform .15s;display:flex}.mkt-btn-wallet:active,.mkt-btn-mpesa:active{transform:scale(.95)}.mkt-btn-wallet{color:#0f172a;background:#fff}.mkt-btn-mpesa{color:#fff;background:#4caf50;box-shadow:0 4px 12px #4caf504d}.mkt-filter-trigger{color:#fff;cursor:pointer;background:#0f172a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;transition:transform .15s;display:flex}.mkt-filter-trigger:active{transform:scale(.9)}.mkt-filter-overlay{z-index:200;pointer-events:none;opacity:0;transition:opacity .3s;position:fixed;top:0;bottom:0;left:0;right:0}.mkt-filter-overlay.open{pointer-events:auto;opacity:1}.mkt-filter-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;position:absolute;top:0;bottom:0;left:0;right:0}.mkt-filter-drawer{background:#fff;border-radius:24px 24px 0 0;max-height:80vh;transition:transform .35s cubic-bezier(.22,1,.36,1);position:absolute;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%);box-shadow:0 -8px 32px #0000001f}.mkt-filter-overlay.open .mkt-filter-drawer{transform:translateY(0)}.mkt-filter-header{z-index:1;background:#fff;border-bottom:1px solid #f1f5f9;border-radius:24px 24px 0 0;justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex;position:sticky;top:0}.mkt-filter-title{color:#0f172a;font-family:Outfit,sans-serif;font-size:18px;font-weight:800}.mkt-filter-close{color:#64748b;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.mkt-filter-body{padding:16px 20px}.mkt-filter-group{margin-bottom:24px}.mkt-filter-group-label{color:#0f172a;text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:8px;margin-bottom:12px;font-size:12px;font-weight:700;display:flex}.mkt-filter-group-label i{color:#10b981;font-size:13px}.mkt-filter-price-row{align-items:center;gap:10px;display:flex}.mkt-filter-input{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;outline:none;flex:1;height:44px;padding:0 14px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;transition:border-color .2s}.mkt-filter-input:focus{border-color:#10b981}.mkt-filter-input::placeholder{color:#94a3b8;font-weight:500}.mkt-filter-dash{color:#cbd5e1;font-size:14px;font-weight:600}.mkt-filter-distance{padding:4px 0}.mkt-filter-range{-webkit-appearance:none;appearance:none;background:#e2e8f0;border-radius:3px;outline:none;width:100%;height:6px;margin-bottom:8px}.mkt-filter-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;cursor:pointer;background:#0f172a;border:3px solid #fff;border-radius:50%;width:22px;height:22px;box-shadow:0 2px 6px #00000026}.mkt-filter-range::-moz-range-thumb{cursor:pointer;background:#0f172a;border:3px solid #fff;border-radius:50%;width:22px;height:22px}.mkt-filter-range-labels{color:#94a3b8;justify-content:space-between;font-size:11px;font-weight:600;display:flex}.mkt-filter-range-labels span:nth-child(2){color:#0f172a;font-size:13px;font-weight:800}.mkt-filter-location-row{color:#64748b;cursor:pointer;background:#f1f5f9;border-radius:10px;align-items:center;gap:8px;margin-top:10px;padding:10px 14px;font-size:12px;font-weight:600;transition:background .15s;display:flex}.mkt-filter-location-row:hover{background:#e2e8f0}.mkt-filter-location-row i{color:#10b981;font-size:14px}.mkt-filter-chips{flex-wrap:wrap;gap:8px;display:flex}.mkt-filter-chip{color:#64748b;cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:100px;padding:8px 14px;font-size:12px;font-weight:600;transition:all .2s}.mkt-filter-chip.active{color:#fff;background:#0f172a;border-color:#0f172a}.mkt-filter-footer{background:#fff;border-top:1px solid #f1f5f9;gap:10px;padding:16px 20px;display:flex;position:sticky;bottom:0}.mkt-filter-reset{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex:1;height:46px;font-family:Inter,sans-serif;font-size:13px;font-weight:700}.mkt-filter-apply{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:12px;flex:2;height:46px;font-family:Inter,sans-serif;font-size:13px;font-weight:700;transition:background .15s}.mkt-filter-apply:active{background:#1e293b}:root{--ink:#292928;--muted:#6f6f6d;--muted-2:#9a9a98;--page:#fff;--flat:#f6f6f4;--line:#e7e7e5;--lime:#c3f832;--lavender:#e6d3f8;--red:#d05252;--font:"DM Sans", system-ui, sans-serif;--r-lg:24px;--r-md:18px;--ease:cubic-bezier(.16, 1, .3, 1)}html{font-size:17px}body{font-family:var(--font)}.qud.phone{background:var(--page);width:100%;max-width:100%;min-height:100vh;color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased;margin:0 auto;padding-bottom:108px;position:relative}.qud a{color:inherit}.qud .anim{opacity:0;animation:rise .55s var(--ease) forwards;transform:translateY(12px)}.qud .d1{animation-delay:20ms}.qud .d2{animation-delay:70ms}.qud .d3{animation-delay:.12s}.qud .d4{animation-delay:.17s}.qud .d5{animation-delay:.22s}.qud .d6{animation-delay:.27s}.qud .d7{animation-delay:.32s}.qud .d8{animation-delay:.37s}@keyframes rise{to{opacity:1;transform:none}}.qud .top-header{justify-content:space-between;align-items:center;padding:20px 20px 6px;display:flex}.qud .brand{align-items:center;gap:8px;display:flex}.qud .brand-word{letter-spacing:.05em;color:var(--ink);font-size:1.18rem;font-weight:800}.qud .header-right{align-items:center;gap:10px;display:flex;position:relative}.qud .icon-btn{border:1px solid var(--line);width:42px;height:42px;color:var(--ink);cursor:pointer;-webkit-backdrop-filter:none;background:#fff;border-radius:50%;place-items:center;font-size:.95rem;transition:none;display:grid;position:relative}.qud .icon-btn:active{background:#fff;transform:none}.qud .icon-btn .dot{background:var(--lime);border:1.5px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:9px;right:10px}.qud .avatar{background:var(--ink);color:#fff;letter-spacing:.02em;cursor:pointer;border-radius:50%;place-items:center;width:42px;height:42px;font-size:.8rem;font-weight:700;display:grid}.qud .greeting{color:var(--ink);padding:18px 22px;font-size:1rem;font-weight:400}.qud .greeting-sub{color:var(--muted);font-size:.85rem;font-weight:500}.qud .greeting-name{letter-spacing:-.02em;color:var(--ink);margin-top:2px;font-size:1.75rem;font-weight:700}.qud .page-title{padding:18px 22px 16px}.qud .page-title h1{letter-spacing:-.02em;font-size:1.75rem;font-weight:700}.qud .page-title p{color:var(--muted);margin-top:3px;font-size:.84rem;font-weight:500}.qud .wallet-card{background:var(--ink);border-radius:var(--r-lg);color:#fff;-webkit-backdrop-filter:none;border:none;width:auto;margin:0 16px;padding:22px 20px 18px;position:relative;overflow:visible}.qud .wallet-label{color:#ffffff8c;text-transform:none;letter-spacing:normal;margin-bottom:0;font-size:.84rem;font-weight:500;position:static}.qud .wallet-amount{font-family:var(--font);color:#fff;letter-spacing:normal;align-items:baseline;gap:8px;margin-top:8px;font-size:1rem;line-height:1.4;display:flex;position:static}.qud .wallet-amount .wallet-kes{color:var(--lime);vertical-align:baseline;margin-right:0;font-size:.9rem;font-weight:700}.qud .wallet-amount .wallet-value{letter-spacing:-.03em;color:#fff;vertical-align:baseline;margin-right:0;font-size:2.3rem;font-weight:700}.qud .wallet-amount .wallet-cents{color:#ffffff73;vertical-align:baseline;margin-right:0;font-size:1.15rem;font-weight:600}.qud .wallet-meta{align-items:flex-end;gap:34px;margin-top:18px;display:flex}.qud .meta-label{color:#ffffff73;font-size:.78rem;font-weight:500}.qud .meta-value{margin-top:3px;font-size:.88rem;font-weight:600}.qud .chip{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:6px 12px;font-size:.72rem;font-weight:700;display:inline-block}.qud .chip.lime{background:var(--lime);color:var(--ink)}.qud .chip.dark{background:var(--ink);color:var(--lime)}.qud .chip.neutral{color:var(--muted);background:#ececea}.qud .chip.lavender{background:var(--lavender);color:var(--ink)}.qud .wallet-card .chip.lime{margin-left:auto}.qud .wallet-actions{gap:10px;margin-top:18px;display:flex}.qud .btn{width:auto;font-family:var(--font);cursor:pointer;transition:transform .15s var(--ease);border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:13px 22px;font-size:.87rem;font-weight:600;display:inline-flex;position:relative;overflow:visible}.qud .btn:active{transform:scale(.97)}.qud .btn.white{color:var(--ink);background:#fff;border:none;flex:1}.qud .btn.ghost-dark{color:#fff;background:0 0;border:1px solid #ffffff47;flex:1}.qud .btn.dark{background:var(--ink);color:#fff;border:none}.qud .actions-row{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:0;padding:20px 16px 4px;display:grid}.qud .act{background:var(--flat);border-radius:var(--r-md);cursor:pointer;transition:transform .15s var(--ease);flex-direction:column;align-items:center;gap:9px;padding:15px 4px 13px;display:flex}.qud .act:active{transform:scale(.96)}.qud .act-icon{border:1px solid var(--line);width:40px;height:40px;color:var(--ink);background:#fff;border-radius:50%;place-items:center;font-size:.92rem;display:grid}.qud .act.primary .act-icon{background:var(--lime);border-color:var(--lime)}.qud .act-name{color:var(--ink);font-size:.78rem;font-weight:600}.qud .section{z-index:auto;background:0 0;border-radius:0;margin-top:0;padding:22px 20px 0;position:static}.qud .section-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.qud .section-title{letter-spacing:-.01em;text-transform:none;color:var(--ink);font-size:1.15rem;font-weight:700}.qud .section-link{color:var(--muted);cursor:pointer;font-size:.8rem;font-weight:600;text-decoration:none}.qud .places-scroll{scrollbar-width:none;gap:9px;padding:2px 20px 4px;display:flex;overflow-x:auto}.qud .places-scroll::-webkit-scrollbar{display:none}.qud .place-chip{background:var(--flat);cursor:pointer;border-radius:999px;flex-shrink:0;align-items:center;gap:9px;padding:7px 16px 7px 7px;display:flex}.qud .place-chip-icon{border:1px solid var(--line);width:34px;height:34px;color:var(--ink);background:#fff;border-radius:50%;place-items:center;font-size:.82rem;display:grid}.qud .place-chip-name{font-size:.8rem;font-weight:600}.qud .place-chip-sub{color:var(--muted);font-size:.72rem;font-weight:500}.qud .reorder-scroll{scrollbar-width:none;gap:10px;padding:2px 20px 4px;display:flex;overflow-x:auto}.qud .reorder-scroll::-webkit-scrollbar{display:none}.qud .reorder-card{background:var(--flat);border-radius:var(--r-md);flex-shrink:0;width:230px;padding:14px 14px 12px}.qud .reorder-head{align-items:center;gap:9px;margin-bottom:10px;display:flex}.qud .reorder-icon{border:1px solid var(--line);width:34px;height:34px;color:var(--ink);background:#fff;border-radius:50%;flex-shrink:0;place-items:center;font-size:.82rem;display:grid}.qud .reorder-name{font-size:.85rem;font-weight:600}.qud .reorder-sub{color:var(--muted);margin-top:1px;font-size:.72rem;font-weight:500}.qud .reorder-items{border-top:1px solid var(--line);flex-direction:column;gap:4px;padding-top:8px;display:flex}.qud .reorder-item-row{color:var(--muted);gap:6px;font-size:.78rem;font-weight:500;display:flex}.qud .reorder-item-qty{color:var(--ink);font-weight:700}.qud .reorder-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.qud .reorder-foot{justify-content:space-between;align-items:center;margin-top:10px;display:flex}.qud .reorder-total{font-size:.85rem;font-weight:700}.qud .reorder-total .kes{color:var(--muted);margin-right:3px;font-size:.7rem;font-weight:700}.qud .reorder-go-btn{background:var(--ink);color:#fff;font-family:var(--font);cursor:pointer;border:none;border-radius:999px;align-items:center;gap:6px;padding:8px 14px;font-size:.76rem;font-weight:600;display:inline-flex}.qud .reorder-go-btn:active{transform:scale(.97)}.qud .filter-row{gap:6px;margin-bottom:14px;display:flex}.qud .filter-row.standalone{margin-bottom:0;padding:20px 20px 14px}.qud .filter-btn{font-family:var(--font);cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:999px;padding:10px 18px;font-size:.82rem;font-weight:600}.qud .filter-btn.active{background:var(--ink);color:#fff}.qud .activity-list{flex-direction:column;gap:10px;display:flex}.qud .row-card{background:var(--flat);border-radius:var(--r-md);cursor:pointer;padding:16px}.qud .row-top{align-items:center;gap:8px;display:flex}.qud .row-name{font-size:.94rem;font-weight:600}.qud .row-arrow{color:var(--muted-2);font-size:.78rem}.qud .row-place{font-size:.94rem;font-weight:600}.qud .row-card .chip{flex-shrink:0;margin-left:auto}.qud .row-sub{color:var(--muted);margin-top:5px;font-size:.82rem;font-weight:500}.qud .row-foot{justify-content:space-between;align-items:baseline;gap:8px;margin-top:5px;display:flex}.qud .row-foot .row-sub{margin-top:0}.qud .row-amt{flex-shrink:0;font-size:.8rem;font-weight:700}.qud .open-card{border:1.5px solid var(--ink);cursor:pointer;background:#fff;border-radius:20px;padding:18px 16px 8px}.qud .open-head{align-items:baseline;gap:8px;display:flex}.qud .open-name{font-size:1rem;font-weight:700}.qud .open-sub{color:var(--muted);margin-top:4px;font-size:.82rem;font-weight:500}.qud .open-chip-row{justify-content:center;margin:16px 0 10px;display:flex}.qud .progress{background:#ececea;border-radius:999px;height:6px;overflow:hidden}.qud .progress-fill{background:var(--lime);border-radius:999px;width:58%;height:100%}.qud .open-meta{grid-template-columns:repeat(4,auto);justify-content:space-between;gap:8px;margin-top:16px;display:grid}.qud .open-meta .meta-label{color:var(--muted)}.qud .open-meta .meta-value{color:var(--ink);font-size:.85rem}.qud .merchant-row{border-top:1px solid var(--flat);align-items:center;gap:11px;margin-top:16px;padding-top:14px;display:flex}.qud .merchant-avatar{background:var(--flat);width:42px;height:42px;color:var(--ink);border-radius:50%;flex-shrink:0;place-items:center;font-size:.9rem;display:grid}.qud .merchant-label{color:var(--muted);font-size:.76rem;font-weight:500}.qud .merchant-name{font-size:.9rem;font-weight:600;font-family:var(--font);color:var(--ink);letter-spacing:normal;text-align:left;margin-top:1px;margin-bottom:0;position:static}.qud .merchant-btns{gap:8px;margin-left:auto;display:flex}.qud .circle-btn{border:1px solid var(--line);width:42px;height:42px;color:var(--ink);cursor:pointer;background:#fff;border-radius:50%;place-items:center;font-size:.85rem;display:grid}.qud .open-footer{border-top:1px solid var(--flat);justify-content:space-between;align-items:center;margin-top:6px;padding:12px 0;display:flex}.qud .open-footer-text{font-size:.84rem;font-weight:600}.qud .chev-btn{border:1px solid var(--line);width:36px;height:36px;color:var(--ink);cursor:pointer;background:#fff;border-radius:50%;place-items:center;font-size:.78rem;display:grid}.qud .open-cancel{border:none;border-top:1px solid var(--flat);width:100%;font-family:var(--font);color:var(--red);cursor:pointer;text-align:center;background:0 0;padding:12px 0;font-size:.84rem;font-weight:600;display:block}.qud .summary-card{background:var(--ink);border-radius:var(--r-lg);color:#fff;margin:0 16px;padding:22px 20px 18px}.qud .summary-label{color:#ffffff8c;text-transform:none;letter-spacing:normal;margin-bottom:0;font-size:.84rem;font-weight:500}.qud .summary-amount{font-family:var(--font);color:#fff;letter-spacing:normal;opacity:1;align-items:baseline;gap:8px;margin-top:8px;margin-bottom:0;font-size:1rem;line-height:1.4;animation:none;display:flex}.qud .summary-amount .summary-kes{color:var(--lime);vertical-align:baseline;font-size:.9rem;font-weight:700}.qud .summary-amount .summary-value{letter-spacing:-.03em;color:#fff;vertical-align:baseline;font-size:2.3rem;font-weight:700}.qud .summary-meta{align-items:flex-end;gap:34px;margin-top:18px;display:flex}.qud .summary-card .chip.lime{margin-left:auto}.qud .history{padding:0 20px}.qud .date-group{margin-bottom:22px}.qud .group-label{color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px;padding-left:2px;font-size:.76rem;font-weight:700}.qud .group-list{flex-direction:column;gap:10px;display:flex}.qud .profile-block{text-align:center;padding:26px 22px 4px}.qud .profile-avatar{background:var(--ink);color:#fff;letter-spacing:.02em;width:72px;height:72px;box-shadow:none;border-radius:50%;place-items:center;margin:0 auto 12px;font-size:1.25rem;font-weight:700;display:grid;position:static}.qud .profile-name{letter-spacing:-.01em;font-size:1.35rem;font-weight:700;font-family:var(--font);color:var(--ink);text-align:center;opacity:1;margin-bottom:0;animation:none}.qud .profile-phone{color:var(--muted);letter-spacing:normal;opacity:1;margin-top:3px;margin-bottom:0;font-size:.84rem;font-weight:500;animation:none}.qud .profile-block .chip{margin-top:12px}.qud .wallet-mini{background:var(--ink);border-radius:var(--r-lg);color:#fff;justify-content:space-between;align-items:center;gap:12px;margin:20px 16px 0;padding:20px;display:flex}.qud .wallet-mini .wallet-label{color:#ffffff8c;font-size:.8rem;font-weight:500}.qud .wallet-mini .wallet-amount{align-items:baseline;gap:6px;margin-top:5px;display:flex}.qud .wallet-mini .wallet-kes{color:var(--lime);font-size:.84rem;font-weight:700}.qud .wallet-mini .wallet-value{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.qud .wallet-mini .wallet-cents{color:#ffffff73;font-size:.95rem;font-weight:600}.qud .wallet-btns{flex-shrink:0;gap:8px;display:flex}.qud .wallet-btns .btn{flex:none;gap:6px;padding:10px 16px;font-size:.84rem}.qud .menu-group{padding:22px 16px 0}.qud .menu-group .group-label{margin:0 6px 9px;padding-left:0}.qud .menu-card{background:var(--flat);border-radius:var(--r-md);padding:4px 16px}.qud .menu-row{cursor:pointer;align-items:center;gap:13px;padding:13px 0;display:flex}.qud .menu-row+.menu-row{border-top:1px solid var(--line)}.qud .menu-icon{border:1px solid var(--line);width:40px;height:40px;color:var(--ink);background:#fff;border-radius:50%;flex-shrink:0;place-items:center;font-size:.9rem;display:grid}.qud .menu-name{font-size:.9rem;font-weight:600}.qud .menu-end{align-items:center;gap:10px;margin-left:auto;display:flex}.qud .menu-value{color:var(--muted);font-size:.8rem;font-weight:500}.qud .menu-chev{color:var(--muted-2);font-size:.78rem}.qud .toggle{cursor:pointer;background:#ececea;border-radius:999px;flex-shrink:0;width:46px;height:27px;padding:3px;transition:background .2s}.qud .toggle .knob{border:1px solid var(--line);width:21px;height:21px;transition:transform .2s var(--ease);background:#fff;border-radius:50%}.qud .toggle.on{background:var(--lime)}.qud .toggle.on .knob{border-color:#0000;transform:translate(19px)}.qud .signout{background:var(--flat);border-radius:var(--r-md);margin:22px 16px 0;padding:4px 16px}.qud .signout .menu-name,.qud .signout .menu-icon{color:var(--red)}.qud .version{text-align:center;color:var(--muted-2);padding:22px 0 6px;font-size:.78rem;font-weight:500}.qud .empty-note{text-align:center;color:var(--muted-2);width:100%;padding:20px 14px;font-size:.78rem;font-weight:500}.qud .empty-note i{opacity:.35;margin-bottom:8px;font-size:24px;display:block}.qud .avatar-dropdown{border:1px solid var(--line);z-index:999;opacity:0;pointer-events:none;background:#fff;border-radius:18px;min-width:200px;padding:8px 0;transition:all .2s;position:absolute;top:calc(100% + 8px);right:0;transform:translateY(-8px);box-shadow:0 12px 28px #2929281f}.qud .avatar-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0)}.qud .dropdown-item{color:var(--ink);cursor:pointer;font-size:.85rem;font-weight:600;font-family:var(--font);align-items:center;gap:12px;padding:12px 20px;text-decoration:none;transition:background .15s;display:flex}.qud .dropdown-item:hover,.qud .dropdown-item:active{background:var(--flat)}.qud .dropdown-item i{text-align:center;width:20px;color:var(--muted);opacity:1;font-size:.9rem}.qud .dropdown-divider{background:var(--line);height:1px;margin:4px 16px}.qud .dropdown-logout,.qud .dropdown-logout i{color:var(--red)}.qud.loading-screen{background:var(--page);min-height:100vh;color:var(--ink);font-family:var(--font);flex-direction:column;justify-content:center;align-items:center;gap:24px;display:flex}.qud.loading-screen .loading-spinner{border:3px solid var(--line);border-top-color:var(--ink);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.qud.loading-screen .loading-msg{color:var(--muted);font-size:.85rem;font-weight:500}.qud.error-screen{text-align:center;background:var(--page);min-height:100vh;color:var(--ink);font-family:var(--font);flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.qud.error-screen .error-logo{object-fit:contain;width:180px;height:auto;margin-bottom:24px}.qud.error-screen .error-title{letter-spacing:-.01em;color:var(--red);font-size:1.35rem;font-weight:700}.qud.error-screen .error-msg{max-width:280px;color:var(--muted);margin-top:12px;font-size:.85rem;font-weight:500;line-height:1.5}.qud.error-screen .btn.dark{margin-top:32px}.qud.bottom-nav{width:100%;max-width:100%;padding:10px 8px calc(14px + env(safe-area-inset-bottom));border-top:1px solid var(--line);box-shadow:none;z-index:50;font-family:var(--font);background:#fff;border-radius:0;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;right:auto;transform:translate(-50%)}.qud.bottom-nav .nav-item{color:var(--muted-2);cursor:pointer;flex-direction:column;flex:none;align-items:center;gap:4px;width:58px;font-size:1rem;font-weight:400;text-decoration:none;transition:none;display:flex}.qud.bottom-nav .nav-icon{border-radius:10px;place-items:center;width:38px;height:30px;margin-bottom:0;font-size:1rem;display:grid}.qud.bottom-nav .nav-item i{font-size:inherit;margin-bottom:0}.qud.bottom-nav .nav-item span{font-size:.66rem;font-weight:600}.qud.bottom-nav .nav-item .nav-icon{font-size:1rem}.qud.bottom-nav .nav-item.active{color:var(--ink)}.qud.bottom-nav .nav-item.active .nav-icon{background:var(--flat)}.qud.bottom-nav .nav-scan{background:var(--ink);width:56px;height:56px;color:var(--lime);cursor:pointer;border:4px solid #fff;border-radius:18px;flex-shrink:0;place-items:center;margin-top:-28px;font-size:1.3rem;display:grid;position:relative;top:0;box-shadow:0 6px 18px #29292838}.qud.bottom-nav .nav-scan:active{transform:scale(.95)}
