/* numpipe-wallet — wallet.numpipe.com */

@font-face { font-family:'Kantumruy Pro'; src:url('/fonts/kantumruy-pro-latin.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; font-weight:300 800; font-style:normal; font-display:swap; }

@font-face { font-family:'Kantumruy Pro'; src:url('/fonts/kantumruy-pro-latin-ext.woff2') format('woff2'); unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF; font-weight:300 800; font-style:normal; font-display:swap; }

@font-face { font-family:'Kantumruy Pro'; src:url('/fonts/kantumruy-pro-khmer.woff2') format('woff2'); unicode-range:U+1780-17FF,U+200C,U+25CC; font-weight:300 800; font-style:normal; font-display:swap; }

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

:root { --green:#16a34a; --red:#dc2626; --yellow:#d97706; --orange:#ea580c; --gray-50:#f8fafc; --gray-100:#f1f5f9; --gray-200:#e2e8f0; --gray-400:#94a3b8; --gray-500:#64748b; --gray-700:#334155; --gray-900:#0f172a; --accent:#6366f1; --radius:14px; --shadow:0 1px 3px rgba(0,0,0,.07),0 4px 14px rgba(0,0,0,.06); --nav-h:60px; }

html,body { height:100%; }

body { font-family:'Kantumruy Pro',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; background:var(--gray-50); color:var(--gray-900); min-height:100dvh; -webkit-font-smoothing:antialiased; -webkit-tap-highlight-color:transparent; }

:lang(km) { font-family:'Kantumruy Pro',sans-serif; }

.login-wrap { min-height:100dvh; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:1.5rem; }

.login-logo { font-size:2rem; font-weight:900; letter-spacing:-1px; color:var(--gray-900); margin-bottom:.25rem; line-height:1; text-align:center; }

.login-logo span { color:var(--green); }

.login-logo sup { font-size:.35em; vertical-align:super; font-weight:400; }

.login-tagline { font-size:.82rem; color:var(--gray-500); text-align:center; margin-bottom:2rem; }

.login-card { width:100%; max-width:460px; background:#fff; border-radius:20px; box-shadow:var(--shadow); padding:2rem 1.5rem; }

.login-title { font-size:1.15rem; font-weight:800; color:var(--gray-900); margin-bottom:.35rem; }

.login-sub { font-size:.82rem; line-height:1.55; color:var(--gray-500); margin-bottom:1.5rem; }

.social-btns { width:100%; display:flex; flex-direction:column; gap:.85rem; }

.social-btns > * { width:100%; }

.social-btns a { width:100%; display:block; }

.btn-social { width:100%; display:grid; grid-template-columns:24px 1fr 24px; align-items:center; min-height:58px; padding:1rem 1.1rem; border-radius:14px; font-size:.96rem; font-weight:700; font-family:inherit; text-decoration:none; cursor:pointer; box-sizing:border-box; transition:transform .12s ease,box-shadow .18s ease,filter .18s ease; }

.btn-social svg { justify-self:start; flex-shrink:0; }

.btn-social span:not(.soon-badge) { text-align:center; }

.btn-social:active { transform:scale(.985); }

.btn-social:disabled { opacity:.45; pointer-events:none; cursor:not-allowed; }

.btn-google { background:#fff; color:#3c4043; border:1.5px solid #dadce0; box-shadow:0 1px 3px rgba(0,0,0,.08); }

.btn-google:hover { background:#f8f9fa; box-shadow:0 4px 12px rgba(0,0,0,.12); }

.btn-facebook { background:#1877f2; color:#fff; border:none; box-shadow:0 4px 14px rgba(24,119,242,.28); }

.btn-facebook:hover { filter:brightness(1.03); box-shadow:0 6px 18px rgba(24,119,242,.35); }

.btn-web3 { background:var(--gray-100); color:var(--gray-400); border:1.5px solid var(--gray-200); }

.soon-badge { justify-self:end; font-size:.62rem; font-weight:700; background:var(--gray-200); color:var(--gray-500); border-radius:5px; padding:.15rem .42rem; letter-spacing:.06em; text-transform:uppercase; }

.email-toggle { width:100%; background:none; border:none; display:flex; align-items:center; justify-content:center; gap:.4rem; padding:.95rem 0 0; font-size:.82rem; font-weight:600; font-family:inherit; color:var(--gray-500); cursor:pointer; transition:color .15s; }

.email-toggle:hover { color:var(--gray-700); }

.email-toggle svg { transition:transform .2s; }

.email-toggle.open svg { transform:rotate(180deg); }

.email-section { overflow:hidden; max-height:0; opacity:0; margin-top:0; transition:max-height .3s ease,opacity .25s ease,margin .25s ease; }

.email-section.open { max-height:320px; opacity:1; margin-top:.9rem; }

.divider-or { display:flex; align-items:center; gap:.75rem; margin:1.2rem 0; color:var(--gray-400); font-size:.74rem; letter-spacing:.02em; text-transform:uppercase; }

.divider-or::before,.divider-or::after { content:''; flex:1; height:1px; background:var(--gray-200); }

.form-group { display:flex; flex-direction:column; gap:.35rem; margin-bottom:1rem; }

.form-label { font-size:.78rem; font-weight:600; color:var(--gray-700); }

.form-input { width:100%; padding:.8rem .9rem; border-radius:10px; border:1.5px solid var(--gray-200); background:var(--gray-50); font-size:.92rem; font-family:inherit; color:var(--gray-900); outline:none; transition:border-color .15s,background .15s; }

.form-input:focus { border-color:var(--green); background:#fff; }

.btn-primary { width:100%; min-height:52px; padding:.85rem 1rem; background:var(--green); color:#fff; border:none; border-radius:12px; font-size:.96rem; font-weight:700; font-family:inherit; cursor:pointer; transition:opacity .15s,transform .1s; }

.btn-primary:hover { opacity:.92; }

.btn-primary:active { transform:scale(.985); }

.btn-secondary { width:100%; padding:.75rem; background:#fff; color:var(--gray-700); border:1.5px solid var(--gray-200); border-radius:10px; font-size:.85rem; font-weight:600; font-family:inherit; cursor:pointer; }

.error-msg,.success-msg { display:none; border-radius:10px; padding:.7rem .9rem; font-size:.82rem; margin-bottom:.9rem; }

.error-msg { background:#fef2f2; border:1px solid #fecaca; color:#991b1b; }

.success-msg { background:#f0fdf4; border:1px solid #bbf7d0; color:#166534; }

.error-msg.show,.success-msg.show { display:block; }

.otp-step { display:none; }

.otp-step.show { display:block; }

.otp-row { display:flex; justify-content:center; gap:.5rem; margin:.75rem 0 1rem; }

.otp-digit { width:48px; height:56px; border-radius:10px; border:1.5px solid var(--gray-200); background:var(--gray-50); text-align:center; font-size:1.4rem; font-weight:700; font-family:monospace; outline:none; transition:border-color .15s,background .15s; }

.otp-digit:focus { border-color:var(--green); background:#fff; }

.back-link { display:inline-flex; align-items:center; gap:.25rem; margin-bottom:1rem; background:none; border:none; cursor:pointer; color:var(--gray-500); font-size:.8rem; font-family:inherit; }

.back-link:hover { color:var(--gray-900); }

#toast { position:fixed; bottom:1rem; left:50%; transform:translateX(-50%) translateY(10px); background:var(--gray-900); color:#fff; padding:.6rem 1rem; border-radius:10px; font-size:.82rem; font-weight:600; white-space:nowrap; opacity:0; pointer-events:none; transition:opacity .2s,transform .2s; z-index:100; }

#toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

.lang-select { min-height:36px; padding:.3rem .55rem; border-radius:8px; border:1.5px solid var(--gray-200); background:var(--gray-50); color:var(--gray-700); font-size:.78rem; font-weight:600; font-family:inherit; cursor:pointer; outline:none; }