/* ══ TOAST ══ */
.toast-msg{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(12px);background:rgba(26,29,31,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;padding:10px 18px;border-radius:24px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;box-shadow:0 6px 20px rgba(0,0,0,.22);opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;z-index:1010;white-space:nowrap;max-width:90vw}
.toast-msg.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast-msg svg{width:16px;height:16px;flex-shrink:0;stroke-width:2;fill:none}
.toast-success svg{stroke:#22C55E}
.toast-error svg{stroke:#EF4444}

/* ══ AUTH MODAL ══ */
#authModalOverlay{align-items:center;justify-content:flex-end;flex-direction:column;z-index:1000;background:rgba(10,14,20,.60);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.auth-sheet{width:100%;max-width:var(--mw);background:#fff;border-radius:28px 28px 0 0;padding:10px 0 0;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .4s cubic-bezier(.32,0,.15,1);position:relative;overflow:hidden;overflow-y:auto;max-height:95vh}
.auth-sheet::-webkit-scrollbar{display:none}
#authModalOverlay.active .auth-sheet{transform:translateY(0)}
.auth-sheet::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p) 0%,#6EA3FF 50%,var(--p) 100%);background-size:200% 100%;animation:shimmerLine 2.5s ease-in-out infinite}
@keyframes shimmerLine{0%,100%{background-position:0% 0%}50%{background-position:100% 0%}}
.auth-inner{padding:0 22px calc(env(safe-area-inset-bottom,0px) + 20px)}
.auth-drag-handle{width:40px;height:4px;background:#E2E8F0;border-radius:2px;margin:12px auto 16px;flex-shrink:0}
.floating-close-btn{width:44px;height:44px;background:#1A1D1F;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .25s ease,transform .2s;box-shadow:0 4px 16px rgba(0,0,0,.30);margin-bottom:12px;z-index:1010;border:none;outline:none}
.floating-close-btn:active{transform:scale(0.9)}
#authModalOverlay.active .floating-close-btn{opacity:1;pointer-events:auto}
.floating-close-btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:2.5;fill:none}
.auth-title{font-size:22px;font-weight:800;color:var(--ink);text-align:center;margin-bottom:4px;letter-spacing:-.3px}
.auth-subtitle{font-size:14px;color:var(--ink-muted);font-weight:500;text-align:center;margin-bottom:18px;line-height:1.55}
.auth-subtitle b{color:var(--ink);font-weight:700}
.auth-field{position:relative;margin-bottom:10px}
.auth-field-label{font-size:11px;font-weight:700;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:6px;display:block}
.auth-field-wrap{position:relative;display:flex;align-items:center}
.auth-field-icon{position:absolute;left:14px;width:18px;height:18px;stroke:var(--ink-muted);stroke-width:2;fill:none;transition:stroke .2s;pointer-events:none}
.auth-field-input{width:100%;height:54px;border:1.5px solid var(--bdr);border-radius:14px;padding:0 44px 0 42px;font-size:15px;font-weight:600;color:var(--ink);outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s;background:#FAFBFC}
.auth-field-input:focus{border-color:var(--p);box-shadow:0 0 0 3.5px rgba(0,82,234,.09);background:#fff}
.auth-field-wrap:focus-within .auth-field-icon{stroke:var(--p)}
.auth-field-input.valid{border-color:#22C55E}
.auth-field-input.error{border-color:#EF4444}
.auth-field-status{position:absolute;right:14px;width:18px;height:18px;opacity:0;transition:opacity .2s;pointer-events:none}
.auth-field-input.valid+.auth-field-status{opacity:1}
.auth-field-hint{font-size:11.5px;font-weight:500;color:#EF4444;margin-top:4px;min-height:14px;display:block}
.otp-sub{font-size:14px;color:var(--ink-muted);text-align:center;margin-bottom:20px;line-height:1.6}
.otp-sub b{color:var(--ink);font-weight:700}
.otp-container{display:flex;gap:8px;justify-content:center;margin-bottom:8px}
.otp-box{width:44px;height:54px;border:1.5px solid var(--bdr);border-radius:14px;text-align:center;font-size:24px;font-weight:800;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s,transform .1s,background .15s;background:#FAFBFC;caret-color:var(--p);-webkit-tap-highlight-color:transparent}
.otp-box:focus{border-color:var(--p);box-shadow:0 0 0 3.5px rgba(0,82,234,.09);background:#fff;transform:translateY(-1px)}
.otp-box.otp-filled{background:var(--p-soft);border-color:var(--p);color:var(--p)}
.otp-box.otp-error{border-color:#EF4444;background:#FEF2F2;animation:otpShake .4s cubic-bezier(.36,.07,.19,.97)}
@keyframes otpShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-4px)}60%{transform:translateX(4px)}80%{transform:translateX(-2px)}}
.otp-attempts-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding:0 2px}
.otp-attempts-dots{display:flex;gap:5px}
.otp-dot{width:8px;height:8px;border-radius:50%;background:var(--bdr);transition:background .3s}
.otp-dot.used{background:#EF4444}
.otp-resend-info{font-size:12px;font-weight:600;color:var(--ink-muted)}
.otp-resend-link{font-size:12px;font-weight:700;color:var(--p);background:none;border:none;cursor:pointer;padding:0;font-family:inherit;text-decoration:underline;text-underline-offset:2px}
.otp-resend-link:disabled{color:var(--ink-muted);text-decoration:none;cursor:default}
.spam-notice{background:#FFFBEB;border:1px solid #FDE68A;border-radius:10px;padding:9px 12px;display:flex;align-items:flex-start;gap:8px;margin-bottom:14px;font-size:12px;font-weight:500;color:#92400E;line-height:1.5}
.spam-notice svg{width:14px;height:14px;stroke:#D97706;fill:none;stroke-width:2;flex-shrink:0;margin-top:1px}
.auth-security-badge{display:flex;align-items:center;justify-content:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--ink-muted);margin-bottom:12px}
.auth-security-badge svg{width:13px;height:13px;stroke:#22C55E;fill:none;stroke-width:2}
.auth-remember{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer;margin-bottom:14px;padding:9px 12px;background:var(--bg-muted);border-radius:12px;user-select:none;-webkit-tap-highlight-color:transparent}
.auth-remember input[type="checkbox"]{display:none !important;}
.auth-remember .chk-box{width:20px;height:20px;border:2px solid var(--bdr);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;flex-shrink:0}
.auth-remember input:checked+.chk-box{background:var(--p);border-color:var(--p)}
.auth-remember input:checked+.chk-box::after{content:'';width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px)}
.auth-primary-btn{width:100%;height:54px;background:var(--p);color:#fff;font-size:16px;font-weight:800;border-radius:14px;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .15s,transform .1s;cursor:pointer;margin-bottom:10px;border:none;outline:none;letter-spacing:.2px;position:relative;overflow:hidden}
.auth-primary-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,transparent 50%);pointer-events:none}
.auth-primary-btn:active:not(:disabled){opacity:.85;transform:scale(.985)}
.auth-primary-btn:disabled{opacity:.45;cursor:not-allowed}
.btn-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;display:none}
.auth-primary-btn.loading .btn-spinner{display:block}
.auth-primary-btn.loading .btn-label{display:none}
.auth-text-btn{width:100%;font-size:14px;font-weight:700;color:var(--ink-light);padding:10px;background:none;border:none;cursor:pointer;font-family:inherit;transition:color .15s}
.auth-text-btn:hover{color:var(--ink)}
.auth-terms{text-align:center;font-size:11px;color:var(--ink-muted);font-weight:500;line-height:1.7;margin-top:4px}
.auth-terms a{color:var(--p);font-weight:600}
.lockout-banner{background:#FEF2F2;border:1px solid #FECACA;border-radius:12px;padding:14px 16px;display:none;align-items:center;gap:10px;margin-bottom:18px;font-size:13px;font-weight:600;color:#991B1B}
.lockout-banner.show{display:flex}
.lockout-banner svg{width:18px;height:18px;stroke:#EF4444;fill:none;stroke-width:2;flex-shrink:0}
.lockout-timer{font-weight:800;color:#EF4444;font-variant-numeric:tabular-nums}
.onboard-title{font-size:22px;font-weight:800;color:var(--ink);margin-bottom:4px}
.onboard-sub{font-size:14px;color:var(--ink-muted);margin-bottom:16px;font-weight:500;line-height:1.55}
.phone-input-wrap{display:flex;align-items:center;width:100%;height:54px;border:1.5px solid var(--bdr);border-radius:14px;background:#FAFBFC;overflow:hidden;transition:border-color .2s,box-shadow .2s;margin-bottom:8px}
.phone-input-wrap.focus{border-color:var(--p);box-shadow:0 0 0 3.5px rgba(0,82,234,.09);background:#fff}
.phone-input-wrap.valid{border-color:#22C55E}
.phone-input-wrap.error{border-color:#EF4444}
.country-code{display:flex;align-items:center;gap:6px;padding:0 12px;background:var(--bg-muted);height:100%;font-weight:700;color:var(--ink);font-size:14px;user-select:none;border-right:1px solid var(--bdr);flex-shrink:0}
.country-code img{border-radius:2px}
.phone-input-wrap input{flex:1;height:100%;border:none;outline:none;padding:0 14px;font-size:16px;font-weight:600;color:var(--ink);font-family:inherit;letter-spacing:1.5px;background:transparent}
.phone-input-wrap input::placeholder{letter-spacing:normal;font-weight:500;color:var(--ink-muted)}
.phone-hint{font-size:11.5px;font-weight:500;color:var(--ink-muted);margin-top:6px;margin-bottom:20px;padding-left:4px;min-height:16px}
@keyframes successPop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
.auth-success-icon{width:64px;height:64px;background:#DCFCE7;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:8px auto 20px;animation:successPop .4s ease forwards}
.auth-success-icon svg{width:30px;height:30px;stroke:#16A34A;stroke-width:2.5;fill:none}
.auth-step{animation:stepIn .3s ease forwards}
@keyframes stepIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
@supports (padding-bottom:env(safe-area-inset-bottom)){.auth-inner{padding-bottom:calc(28px + env(safe-area-inset-bottom))}}
/* ── Internet Status Banner ── */
.net-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:#EF4444;color:#fff;font-size:13px;font-weight:700;text-align:center;padding:10px 16px;transform:translateY(-100%);transition:transform .3s ease;pointer-events:none}
.net-banner.show{transform:translateY(0)}
.net-banner.online{background:#16A34A}

/* ── Action Fail Inline ── */
.net-inline-error{display:none;align-items:flex-start;gap:10px;background:#FEF2F2;border:1px solid #FECACA;border-radius:12px;padding:14px 16px;margin-bottom:18px;font-size:13px;color:#991B1B}
.net-inline-error.show{display:flex}
.net-inline-error svg{width:18px;height:18px;stroke:#EF4444;fill:none;stroke-width:2;flex-shrink:0;margin-top:1px}
.net-inline-error__body{flex:1}
.net-inline-error__title{font-weight:700;margin-bottom:2px}
.net-inline-error__sub{font-weight:500;color:#B91C1C;margin-bottom:8px}
.net-inline-error__retry{background:#EF4444;color:#fff;border:none;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:700;cursor:pointer;transition:background .2s}
.net-inline-error__retry:hover{background:#DC2626}
