@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg: #f4f4f8;--bg-surface: #ffffff;--bg-elevated: #f9f9fc;--bg-input: #f4f4f8;--bg-hover: #ebebf0;--bg-card: #ffffff;--bg-primary: #f4f4f8;--bg-secondary: #ffffff;--bg-overlay: rgba(0,0,0,.04);--border: rgba(0,0,0,.09);--border-focus: #6366f1;--border-card: rgba(0,0,0,.07);--text-primary: #111116;--text-secondary:#3c3c45;--text-muted: #71717a;--text-dim: #a1a1aa;--text: #111116;--text-dark: #71717a;--accent: #6366f1;--accent-dim: #4f52d8;--bg-accent: #6366f1;--success: #16a34a;--danger: #dc2626;--warning: #d97706;--shadow: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--shadow-card: 0 1px 4px rgba(0,0,0,.06);--radius: 8px;--radius-sm: 6px;--radius-lg: 12px;--font-primary: "Inter", system-ui, sans-serif;--font-sans: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--transition: .15s ease;--transition-fast: .1s ease}[data-theme=dark]{--bg: #0c0c0f;--bg-surface: #13131a;--bg-elevated: #1c1c24;--bg-input: #1c1c24;--bg-hover: #242430;--bg-card: #13131a;--bg-primary: #0c0c0f;--bg-secondary: #13131a;--bg-overlay: rgba(255,255,255,.04);--border: rgba(255,255,255,.08);--border-focus: #6366f1;--border-card: rgba(255,255,255,.06);--text-primary: #e8e8ec;--text-secondary:#b4b4be;--text-muted: #7c7c8a;--text-dim: #48484f;--text: #e8e8ec;--text-dark: #7c7c8a;--accent: #6366f1;--accent-dim: #4f52d8;--bg-accent: #6366f1;--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--shadow: 0 4px 24px rgba(0,0,0,.45);--shadow-lg: 0 8px 40px rgba(0,0,0,.55);--shadow-card: 0 1px 8px rgba(0,0,0,.35);--radius: 8px;--radius-sm: 6px;--radius-lg: 12px;--font-primary: "Inter", system-ui, sans-serif;--font-sans: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--transition: .15s ease;--transition-fast: .1s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden}html,body,#root{height:100%;font-family:var(--font-primary);font-size:16px;line-height:1.6;color:var(--text-secondary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{max-width:100vw}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-dim);text-decoration:underline}.auth-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.auth-header-section{flex:0 0 auto;padding:1.5rem 2rem;border-bottom:1px solid var(--border)}.auth-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.auth-subtitle{font-size:.875rem;color:var(--text-muted);margin-top:.25rem}.auth-main{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:2.5rem 1.5rem}.auth-content{width:100%;max-width:1000px;display:grid;grid-template-columns:1fr 380px;gap:2.5rem;align-items:start}.auth-left{display:flex;flex-direction:column;gap:1.5rem}.auth-right{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:2rem}.auth-header{margin-bottom:1.5rem}.auth-header .auth-title{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.step-indicator{display:flex;align-items:flex-start;justify-content:center;gap:0;margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.step-item{display:flex;flex-direction:column;align-items:center;position:relative;flex:1}.step-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;font-family:var(--font-mono);border:1.5px solid var(--border);background:var(--bg-input);color:var(--text-muted);transition:background var(--transition),border-color var(--transition),color var(--transition);position:relative;z-index:1}.step-item.done .step-circle{background:var(--success);border-color:var(--success);color:#fff}.step-item.active .step-circle{background:var(--accent);border-color:var(--accent);color:#fff}.step-label{font-size:10px;color:var(--text-muted);margin-top:5px;text-align:center;white-space:nowrap}.step-item.active .step-label{color:var(--accent)}.step-item.done .step-label{color:var(--success)}.step-line{position:absolute;top:14px;left:50%;width:100%;height:1px;background:var(--border);z-index:0}.step-item.done .step-line{background:var(--success)}.auth-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;display:flex;flex-direction:column;gap:1.1rem}.form-section{margin-bottom:1.25rem}.form-section:last-child{margin-bottom:0}.form-section-title{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.form-section-title:before{content:"";width:3px;height:14px;background:var(--accent);border-radius:2px;flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.1rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-muted);letter-spacing:.01em}input[type=text],input[type=password],input[type=email]{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-primary);font-size:.9375rem;padding:.625rem .875rem;outline:none;transition:border-color .15s}input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f126}input::placeholder{color:var(--text-dim)}.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:500;color:var(--text-muted);cursor:pointer;padding:.25rem 0;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.checkbox-label:hover{background:var(--bg-hover)}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.checkbox-help{font-size:.75rem;color:var(--text-dim);margin-top:.25rem}.totp-input{font-family:var(--font-mono);font-size:1.5rem;letter-spacing:.25em;text-align:center;font-weight:600;color:var(--accent)}.totp-confirm-prompt{margin-top:.75rem;padding:.875rem 1rem;background:#6366f10f;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:.5rem}.totp-confirm-prompt label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.totp-confirm-prompt .totp-input{font-size:1.5rem;letter-spacing:.3em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;font-family:var(--font-primary);font-size:.9rem;font-weight:500;padding:.575rem 1rem;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:not(:disabled):hover{background:var(--accent-dim);border-color:var(--accent-dim)}.btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border-color:var(--border)}.btn-secondary:not(:disabled):hover{background:var(--bg-hover)}.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost:not(:disabled):hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{color:var(--danger)!important}.btn-danger-solid{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.25);padding:.5rem .875rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;font-family:var(--font-primary);transition:background .12s}.btn-danger-solid:hover:not(:disabled){background:#ef44442e}.btn-danger-solid:disabled{opacity:.5;cursor:not-allowed}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn-sm{font-size:.8125rem;padding:.375rem .75rem}.btn-full{width:100%}.btn-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit;font-family:inherit;padding:0;text-decoration:underline}.btn-link:hover{opacity:.8}.alert{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;border:1px solid;margin-bottom:1rem}.alert-error{background:#ef444414;border-color:#ef444440;color:#fca5a5}.alert-success{background:#22c55e14;border-color:#22c55e40;color:#86efac}.alert-info{background:#6366f114;border-color:#6366f140;color:#a5b4fc}.alert-close{background:none;border:none;cursor:pointer;color:inherit;font-size:1.1rem;line-height:1;opacity:.6;padding:0;transition:opacity var(--transition-fast)}.alert-close:hover{opacity:1}.image-picker{display:flex;flex-direction:column;gap:.6rem}.image-picker-label{font-size:.8125rem;font-weight:500;color:var(--text-muted)}.drop-zone{border:1.5px dashed var(--border);border-radius:var(--radius);background:var(--bg-input);cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:120px;transition:border-color var(--transition),background var(--transition);overflow:hidden}.drop-zone:hover{border-color:var(--accent);background:var(--bg-hover)}.drop-zone.has-preview{min-height:160px}.drop-hint{display:flex;flex-direction:column;align-items:center;gap:.35rem;color:var(--text-muted);font-size:.875rem;-webkit-user-select:none;user-select:none}.drop-icon{font-size:1.75rem;color:var(--accent)}.drop-sub{font-size:.75rem;color:var(--text-dim)}.preview-img{width:100%;height:160px;object-fit:cover;display:block;border-radius:var(--radius)}.hash-display{display:flex;align-items:center;gap:.6rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.8125rem}.hash-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:#6366f11a;padding:.15rem .4rem;border-radius:3px}.hash-value{font-family:var(--font-mono);font-size:.8125rem;color:var(--text);flex:1}.hash-filename{color:var(--text-muted);font-size:.75rem;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.picker-note{font-size:.775rem;color:var(--text-dim);line-height:1.5}.photo-blur-toggle{display:flex;align-items:center;gap:.5rem;margin-top:.625rem;cursor:pointer;-webkit-user-select:none;user-select:none;width:fit-content}.photo-blur-toggle input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.photo-blur-toggle span{font-size:.8rem;color:var(--text-muted);transition:color .15s}.photo-blur-toggle:hover span{color:var(--text-primary)}.picker-status{font-size:.85rem;color:var(--text-muted)}.webcam-wrap{display:flex;flex-direction:column;align-items:center;gap:.875rem}.webcam-outer{position:relative;width:260px;height:260px;display:flex;align-items:center;justify-content:center}.webcam-progress-ring{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.webcam-frame{position:relative;width:220px;height:220px;border-radius:50%;overflow:hidden;border:2px solid var(--border);background:#000}.webcam-frame.active{border-color:var(--accent);box-shadow:0 0 0 3px #6366f133}.webcam-frame.success{border-color:var(--success);box-shadow:0 0 0 3px #22c55e33}.webcam-frame.error{border-color:var(--danger)}.webcam-video{width:100%;height:100%;object-fit:cover;display:block;transform:scaleX(-1)}.webcam-canvas,.webcam-ring{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.webcam-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080;border-radius:50%}.webcam-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.webcam-success-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#22c55e26;border-radius:50%}.webcam-checkmark{font-size:3rem;color:var(--success);animation:pop .3s ease}@keyframes pop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.webcam-status{font-size:.8375rem;color:var(--text-muted);text-align:center;min-height:1.4em;font-weight:500}.webcam-status.error{color:var(--danger)}.webcam-status.success{color:var(--success)}.webcam-status.warn{color:var(--warning)}.webcam-guide-oval{position:absolute;top:50%;left:50%;transform:translate(-50%,-52%);width:58%;height:78%;border:2px dashed rgba(255,255,255,.35);border-radius:50%;pointer-events:none;transition:border-color .25s ease,border-style .25s ease}.form-divider{display:flex;align-items:center;gap:.75rem;color:var(--text-dim);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;margin:1rem 0}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--border)}.form-divider span{background:var(--bg-card);padding:0 .5rem;position:relative;z-index:1}.totp-qr-wrap{display:flex;justify-content:center;padding:.75rem;background:#fff;border-radius:var(--radius);border:1px solid var(--border)}.totp-qr{width:180px;height:180px;display:block}.totp-manual{font-size:.8125rem;color:var(--text-muted);margin-top:.75rem}.totp-manual summary{cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.totp-manual summary:hover{background:var(--bg-hover)}.totp-secret{display:block;font-family:var(--font-mono);font-size:.8125rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem .75rem;margin-top:.5rem;letter-spacing:.1em;word-break:break-all;color:var(--text)}.auth-switch{text-align:center;font-size:.875rem;color:var(--text-muted)}.step-description{font-size:.875rem;color:var(--text-muted);line-height:1.6}.step-description strong{color:var(--text)}.loading-text{font-size:.875rem;color:var(--text-muted);text-align:center;padding:1rem}.muted{color:var(--text-muted);font-size:.875rem}.verification-methods{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.verification-methods button{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.9rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background var(--transition);font-family:var(--font-primary);text-align:left}.verification-methods button:hover{background:var(--bg-hover)}.update-options{display:flex;flex-direction:column;gap:1rem}.update-options .form-group{display:flex;flex-direction:column;gap:.35rem}.update-options button{margin-top:.5rem}.dashboard-page{min-height:100vh;background:var(--bg)}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:56px;border-bottom:1px solid var(--border);background:var(--bg-card);position:sticky;top:0;z-index:50}.dashboard-logo{font-weight:700;font-size:1.0625rem;letter-spacing:-.02em;color:var(--text-primary)}.dashboard-user{display:flex;align-items:center;gap:1rem;font-size:.875rem;color:var(--text-muted)}.dashboard-main{max-width:900px;margin:0 auto;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:2rem}.dashboard-welcome h2{font-size:1.375rem;font-weight:600;color:var(--text-primary);margin-bottom:.35rem}.dashboard-welcome p{color:var(--text-muted)}.dashboard-tabs{display:flex;border-bottom:1px solid var(--border);gap:0}.tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:.75rem 1.125rem;font-size:.875rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color .12s,border-color .12s;font-family:var(--font-primary);margin-bottom:-1px}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.dashboard-tab-content{min-height:300px}.tab-panel{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.section-title{font-size:1rem;font-weight:500;margin-bottom:1rem;color:var(--text-primary)}.factor-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.factor-card{display:flex;align-items:center;gap:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;transition:border-color var(--transition)}.factor-card.active{border-color:#22c55e4d}.factor-card.inactive{border-color:#ef444433;opacity:.7}.factor-icon{font-size:1.5rem;flex-shrink:0}.factor-info{display:flex;flex-direction:column;gap:.15rem;flex:1}.factor-info strong{font-size:.9rem;font-weight:500;color:var(--text-primary)}.factor-info span{font-size:.775rem;color:var(--text-muted)}.factor-badge{font-size:.75rem;font-weight:500;padding:.25rem .6rem;border-radius:20px;white-space:nowrap}.factor-badge.enrolled{background:#22c55e1f;color:#86efac}.factor-badge.missing{background:#ef44441a;color:#fca5a5}.profile-card{display:flex;align-items:center;gap:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;flex-shrink:0}.profile-info{flex:1}.profile-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .15rem}.profile-email{color:var(--text-muted);font-size:.875rem;margin:0 0 .5rem}.profile-meta{display:flex;align-items:center;gap:.5rem;font-size:.775rem;color:var(--text-dim)}.meta-separator{opacity:.4}.profile-security-badge{display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:.25rem}.toaster{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:360px;width:calc(100vw - 3rem);pointer-events:none}.toast{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;border-radius:10px;font-size:.875rem;font-weight:500;box-shadow:0 4px 20px #00000059;animation:toastIn .22s cubic-bezier(.16,1,.3,1);pointer-events:all}@keyframes toastIn{0%{transform:translate(calc(100% + 1.5rem));opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:#14532d;border:1px solid rgba(34,197,94,.3);color:#86efac}.toast-error{background:#450a0a;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.toast-info{background:#1e1b4b;border:1px solid rgba(99,102,241,.3);color:#a5b4fc}.toast-icon{font-size:.85rem;font-weight:700;flex-shrink:0}.toast-msg{flex:1;line-height:1.4}.toast-close{background:none;border:none;color:inherit;opacity:.55;cursor:pointer;font-size:1.2rem;padding:0 2px;flex-shrink:0;line-height:1}.toast-close:hover{opacity:1}@media (max-width: 480px){.toaster{right:.75rem;left:.75rem;width:auto;max-width:none}}.alert-banner{display:flex;align-items:center;gap:.75rem;border-radius:var(--radius-sm);padding:1rem 1.25rem}.alert-banner-warning{background:#d9770614;border:1px solid rgba(217,119,6,.22)}.alert-banner-info{background:#6366f114;border:1px solid rgba(99,102,241,.22)}.alert-banner-content p{margin:.25rem 0 0;font-size:.85rem;color:var(--text-muted)}.alert-banner-content strong{font-size:.9rem;color:var(--text-primary)}.server-wake-banner{margin-bottom:1.25rem;animation:fadeIn .4s ease}.server-wake-spinner{display:inline-block;width:18px;height:18px;min-width:18px;border:2px solid rgba(217,119,6,.2);border-top-color:var(--warning);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.settings-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1rem}.settings-section .section-title{margin-top:0}.settings-form{display:flex;gap:.75rem;align-items:flex-end}.settings-form .form-group{flex:1;margin-bottom:0}.text-warning{color:var(--warning);font-weight:600}.danger-zone{border-color:#ef444440!important;background:#ef44440a!important}.danger-title{color:var(--danger)}.delete-confirm{margin-top:1rem}.delete-confirm-label{font-size:.875rem;margin-bottom:.5rem;color:var(--text-muted)}.account-details-section{margin-top:2rem}.details-grid{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;border-bottom:1px solid var(--border)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:.85rem;color:var(--text-muted)}.detail-value{font-size:.85rem;font-weight:500;color:var(--text-primary)}.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--text-muted)}.empty-state p{margin:.25rem 0}.recovery-codes-display{margin:1rem 0}.recovery-codes-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;background:var(--bg-input);border-radius:var(--radius-sm);padding:1rem;font-family:var(--font-mono);font-size:1rem;border:1px solid var(--border)}.recovery-code-item{padding:.25rem .5rem;letter-spacing:.05em;color:var(--text-primary)}.login-history h3{font-size:1rem;font-weight:500;margin-bottom:1rem;color:var(--text-primary)}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm)}.history-table{width:100%;min-width:480px;border-collapse:collapse;font-size:.8375rem}.history-table th{text-align:left;padding:.5rem .875rem;color:var(--text-muted);font-weight:500;font-size:.775rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.history-table td{padding:.625rem .875rem;border-bottom:1px solid var(--border);color:var(--text-muted)}.history-table tr:last-child td{border-bottom:none}.history-table tr.success td:first-child{color:var(--text-primary)}.ip-cell{font-family:var(--font-mono);font-size:.775rem}.current-session-row td{background:#6366f10a}.history-table tr.suspicious-row{background:#f59e0b0a}.history-table tr.suspicious-row td:first-child{border-left:3px solid #f59e0b;padding-left:calc(.75rem - 3px)}.suspicious-tag{display:inline-flex;align-items:center;gap:3px;margin-left:6px;font-size:.68rem;font-weight:700;color:#f59e0b;background:#f59e0b1f;border:1px solid rgba(245,158,11,.25);border-radius:4px;padding:1px 5px;vertical-align:middle}.badge{font-size:.7rem;font-weight:600;padding:.2rem .55rem;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}.badge-success{background:#22c55e1f;color:#86efac}.badge-error{background:#ef44441a;color:#fca5a5}.badge-warning{background:#eab3081f;color:#fde68a}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-line{border-radius:4px;background:linear-gradient(90deg,var(--border) 25%,rgba(255,255,255,.05) 50%,var(--border) 75%);background-size:400px 100%;animation:shimmer 1.4s ease infinite;display:block}.skeleton-card{display:flex;align-items:center;gap:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem}.skeleton-card-body{display:flex;flex-direction:column;gap:.4rem;flex:1}.skeleton-table{width:100%}.skeleton-table-header{display:flex;gap:1.5rem;padding:.5rem .875rem;border-bottom:1px solid var(--border);margin-bottom:.25rem}.skeleton-table-row{display:flex;gap:1.5rem;padding:.625rem .875rem;border-bottom:1px solid var(--border);align-items:center}.skeleton-detail-grid{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.skeleton-detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;border-bottom:1px solid var(--border)}.skeleton-detail-row:last-child{border-bottom:none}.image-capture{display:flex;flex-direction:column;gap:.6rem}.capture-idle{border:1.5px dashed var(--border);border-radius:var(--radius);background:var(--bg-input);cursor:pointer;min-height:120px;display:flex;align-items:center;justify-content:center;transition:border-color var(--transition),background var(--transition)}.capture-idle:hover{border-color:var(--accent);background:var(--bg-hover)}.capture-idle-inner{display:flex;flex-direction:column;align-items:center;gap:.35rem;color:var(--text-muted);font-size:.875rem}.capture-cam-icon{font-size:1.75rem}.capture-sub{font-size:.75rem;color:var(--text-dim)}.capture-viewfinder{position:relative;width:100%;border-radius:var(--radius);overflow:hidden;background:#000;aspect-ratio:4/3;border:1.5px solid var(--border)}.capture-video{width:100%;height:100%;object-fit:cover;display:block;transform:scaleX(-1)}.capture-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080}.capture-controls{position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.btn-capture{width:56px;height:56px;border-radius:50%;background:#ffffff26;border:3px solid #fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}.btn-capture:hover{background:#ffffff40}.btn-capture:active{transform:scale(.95)}.btn-capture-inner{width:38px;height:38px;border-radius:50%;background:#fff}.capture-hint-overlay{position:absolute;top:10px;left:0;right:0;display:flex;justify-content:center}.capture-hint-overlay span{background:#0009;color:#fff;font-size:.75rem;padding:.25rem .75rem;border-radius:20px}.capture-preview-wrap{position:relative;border-radius:var(--radius);overflow:hidden;border:1.5px solid var(--success)}.capture-preview{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}.capture-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#22c55e26;display:flex;align-items:center;justify-content:center}.capture-check{background:#0009;color:#86efac;font-size:.875rem;font-weight:500;padding:.35rem .9rem;border-radius:20px}.capture-retake{position:absolute;bottom:10px;right:10px}.photo-key-auto{display:flex;align-items:center;gap:.875rem;background:#22c55e0f;border:1px solid rgba(34,197,94,.18);border-radius:var(--radius);padding:.875rem 1rem}.photo-key-icon{font-size:1.4rem;flex-shrink:0}.photo-key-info{display:flex;flex-direction:column;gap:.15rem;flex:1}.photo-key-info strong{font-size:.875rem;color:var(--text)}.photo-key-info span{font-size:.775rem;color:var(--text-muted)}.forget-device-btn{font-size:.72rem;color:var(--text-muted);flex-shrink:0;margin-left:auto;padding:.1rem 0;opacity:.7;transition:color .15s,opacity .15s}.forget-device-btn:hover{color:var(--error);opacity:1}.biometric-toggle{display:flex;gap:0;background:var(--bg-input);border-radius:var(--radius);padding:3px;margin-bottom:1rem;border:1px solid var(--border)}.toggle-btn{flex:1;padding:.55rem .75rem;border:none;border-radius:calc(var(--radius) - 2px);background:transparent;color:var(--text-muted);font-family:var(--font-sans);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.toggle-btn.active{background:var(--accent);color:#fff}.toggle-btn:hover:not(.active){color:var(--text-primary)}.token-lifetime-section{border-left:3px solid var(--accent)!important}.token-lifetime-header{margin-bottom:1.25rem}.token-lifetime-row{display:flex;flex-direction:column;gap:.625rem;padding:1rem 0;border-top:1px solid var(--border)}.token-lifetime-row:first-of-type{border-top:none;padding-top:0}.token-lifetime-label{display:flex;flex-direction:column;gap:2px;margin-bottom:.5rem}.tlabel-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.tlabel-sub{font-size:.775rem;color:var(--text-muted)}.refresh-token-options{display:flex;gap:.5rem;flex-wrap:wrap}.refresh-token-option{display:flex;flex-direction:column;align-items:center;gap:2px;padding:.6rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s;min-width:72px}.refresh-token-option:hover:not(:disabled){border-color:var(--accent);color:var(--text-primary)}.refresh-token-option.active{border-color:var(--accent);background:#6366f11a;color:var(--accent)}.refresh-token-option:disabled{opacity:.5;cursor:not-allowed}.rto-label{font-size:.875rem;font-weight:600}.rto-sub{font-size:.7rem;color:inherit;opacity:.7}.passkey-promo{display:flex;align-items:center;gap:.75rem;background:#6366f10f;border:1px solid rgba(99,102,241,.18);border-radius:var(--radius);padding:.875rem 1rem;margin-bottom:1rem}.passkey-icon{font-size:1.4rem;flex-shrink:0}.passkey-info{display:flex;flex-direction:column;gap:.15rem;flex:1}.passkey-info strong{font-size:.875rem;color:var(--text)}.passkey-info span{font-size:.775rem;color:var(--text-muted)}.passkey-login-prompt{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:1.5rem 0}.passkey-icon-large{font-size:3rem;filter:grayscale(.2)}.theme-toggle{width:2rem;height:2rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.auth-page .theme-toggle{position:fixed;top:1rem;right:1rem;z-index:1000}.dashboard-header .theme-toggle{position:static;margin:0 .5rem}.session-countdown{font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:var(--text-muted);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.25rem .6rem;letter-spacing:.04em;transition:color .3s,background .3s,border-color .3s}.session-countdown.expiring{color:var(--warning);background:#d9770614;border-color:#d977064d;animation:pulse-warning 1.5s ease-in-out infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.65}}.auth-info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem}.auth-info-card h3{font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.auth-info-card>p{font-size:.875rem;color:var(--text-muted);margin-bottom:1.5rem;line-height:1.6}.auth-factor-list{display:flex;flex-direction:column;gap:1rem}.auth-factor-item{display:flex;align-items:flex-start;gap:.875rem}.auth-factor-num{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:var(--font-mono);display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-factor-num.done{background:#22c55e1f;border-color:#22c55e59;color:var(--success)}.auth-factor-num.active{background:#6366f11f;border-color:#6366f159;color:#818cf8}.auth-factor-body strong{display:block;font-size:.875rem;color:var(--text-primary);margin-bottom:.2rem}.auth-factor-body span{font-size:.8125rem;color:var(--text-muted);line-height:1.5}.auth-security-note{background:var(--bg-elevated);border-radius:var(--radius-sm);padding:.875rem;font-size:.8125rem;color:var(--text-dim);line-height:1.6;margin-top:1.5rem}.register-progress-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.register-progress-item{display:flex;align-items:center;gap:.875rem;padding:.625rem .75rem;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.register-progress-item.current{background:var(--bg-elevated)}.register-progress-dot{width:10px;height:10px;border-radius:50%;background:var(--border);flex-shrink:0;transition:background var(--transition)}.register-progress-item.done .register-progress-dot{background:var(--success)}.register-progress-item.current .register-progress-dot{background:#818cf8}.register-progress-item span{font-size:.875rem;color:var(--text-muted);transition:color var(--transition)}.register-progress-item.done span{color:var(--text-secondary)}.register-progress-item.current span{color:var(--text-primary);font-weight:500}.landing-page{min-height:100vh;display:flex;flex-direction:column;background:#0c0c0f}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:1.125rem 3rem;position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.06);background:#0c0c0fd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.landing-nav-logo{font-size:1.1875rem;font-weight:700;letter-spacing:-.02em;color:#fff;text-decoration:none}.landing-nav-actions{display:flex;align-items:center;gap:.75rem}.btn-nav-ghost{background:transparent;border:1px solid rgba(255,255,255,.15);color:#ffffffbf;padding:.5rem 1.125rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;font-family:var(--font-primary);text-decoration:none;display:inline-flex;align-items:center;transition:background .12s,border-color .12s,color .12s}.btn-nav-ghost:hover{background:#ffffff14;border-color:#ffffff4d;color:#fff;text-decoration:none}.btn-nav-primary{background:#6366f1;border:none;color:#fff;padding:.5rem 1.125rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;font-family:var(--font-primary);text-decoration:none;display:inline-flex;align-items:center;transition:background .12s}.btn-nav-primary:hover{background:#4f52d8;color:#fff;text-decoration:none}.landing-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:6rem 2rem 5rem;position:relative;background:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(99,102,241,.18) 0%,transparent 70%),#0c0c0f}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:#6366f11f;border:1px solid rgba(99,102,241,.3);border-radius:100px;padding:.3rem .875rem;font-size:.78rem;font-weight:600;color:#a5b4fc;text-transform:uppercase;letter-spacing:.07em;margin-bottom:1.75rem}.landing-hero h1{font-size:clamp(2.5rem,5.5vw,4rem);font-weight:800;line-height:1.1;letter-spacing:-.04em;color:#f0f0f4;max-width:820px;margin:0 auto 1.25rem}.landing-hero h1 em{font-style:normal;color:#818cf8}.landing-hero p{font-size:1.0625rem;color:#ffffff8c;max-width:520px;margin:0 auto 2.5rem;line-height:1.75}.hero-cta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center}.btn-hero-primary{background:#6366f1;color:#fff;border:none;padding:.875rem 2rem;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;font-family:var(--font-primary);text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:background .15s}.btn-hero-primary:hover{background:#4f52d8;text-decoration:none;color:#fff}.btn-hero-ghost{background:transparent;color:#ffffffbf;border:1px solid rgba(255,255,255,.2);padding:.875rem 2rem;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;font-family:var(--font-primary);text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:background .15s,border-color .15s,color .15s}.btn-hero-ghost:hover{border-color:#fff6;color:#fff;background:#ffffff0d;text-decoration:none}.landing-features{padding:5rem 2rem;background:#111118}.features-inner{max-width:1100px;margin:0 auto}.features-header{text-align:center;margin-bottom:3.5rem}.features-header h2{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:700;letter-spacing:-.03em;color:#f0f0f4;margin-bottom:.75rem}.features-header p{color:#ffffff80;font-size:1.0625rem;max-width:480px;margin:0 auto;line-height:1.6}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.feature-card{background:#16161e;border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);padding:1.75rem;transition:border-color .15s}.feature-card:hover{border-color:#6366f159}.feature-icon-wrap{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.375rem;margin-bottom:1.25rem}.feature-icon-wrap.purple{background:#6366f126}.feature-icon-wrap.red{background:#ef44441f}.feature-icon-wrap.green{background:#22c55e1f}.feature-icon-wrap.blue{background:#3b82f61f}.feature-icon-wrap.orange{background:#f59e0b1f}.feature-icon-wrap.teal{background:#14b8a61f}.feature-card h3{font-size:1.0625rem;font-weight:600;color:#f0f0f4;margin-bottom:.5rem}.feature-card p{font-size:.9375rem;color:#ffffff80;line-height:1.6}.landing-how{padding:5rem 2rem;background:#0c0c0f}.how-inner{max-width:900px;margin:0 auto;text-align:center}.how-inner h2{font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;letter-spacing:-.03em;color:#f0f0f4;margin-bottom:.75rem}.how-inner>p{color:#ffffff80;margin-bottom:3.5rem;font-size:1rem}.how-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;text-align:left}.how-step{display:flex;flex-direction:column;gap:.75rem}.how-step-num{width:40px;height:40px;border-radius:50%;background:#6366f126;border:1px solid rgba(99,102,241,.3);color:#818cf8;font-size:.875rem;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);flex-shrink:0}.how-step h3{font-size:1rem;font-weight:600;color:#f0f0f4;margin:0}.how-step p{font-size:.9rem;color:#ffffff80;line-height:1.6;margin:0}.landing-cta{background:#111118;padding:5rem 2rem;text-align:center}.landing-cta h2{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:700;color:#f0f0f4;margin-bottom:1rem;letter-spacing:-.03em}.landing-cta p{color:#ffffff8c;font-size:1.0625rem;margin-bottom:2.5rem;max-width:440px;margin-left:auto;margin-right:auto}.landing-footer{padding:1.5rem 3rem;background:#0c0c0f;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;font-size:.8125rem;color:#ffffff59}.portal-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:2rem}.portal-page-title{font-size:1.375rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 .375rem}.portal-page-subtitle{font-size:.875rem;color:var(--text-muted);line-height:1.65;max-width:560px;margin:0}.portal-new-app-btn{flex-shrink:0;margin-top:.25rem}.portal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.375rem 1.5rem;margin-bottom:1rem}.portal-card--form{margin-bottom:1.5rem}.portal-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.25rem;flex-wrap:wrap}.portal-card-title-wrap{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.portal-card-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.portal-card-name-input{font-size:1rem;font-weight:600;padding:.25rem .5rem;width:220px}.portal-card-badges{display:flex;align-items:center;gap:.375rem}.portal-card-actions{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}.portal-card-meta{font-size:.8rem;color:var(--text-muted);margin:0 0 1rem}.portal-status-dot-wrap{display:inline-flex;align-items:center;gap:.3rem}.portal-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.portal-status-label{font-size:.725rem;font-weight:600;text-transform:uppercase;letter-spacing:.055em}.portal-tier-badge{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border:1px solid;border-radius:4px;padding:1px 6px;vertical-align:middle}.portal-notice{font-size:.8375rem;line-height:1.55;border-radius:var(--radius-sm);padding:.625rem .875rem;margin-bottom:1rem;border:1px solid}.portal-notice-warning{background:#d9770612;border-color:#d9770640;color:var(--warning)}.portal-notice-warning strong{color:var(--warning)}.portal-notice-danger{background:#ef444412;border-color:#ef444440;color:var(--danger)}.portal-notice-danger strong{color:var(--danger)}.portal-credentials{border-top:1px solid var(--border);padding-top:1rem;margin-top:.25rem;display:flex;flex-direction:column;gap:.75rem}.portal-mono-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.portal-mono-row--block{align-items:flex-start;flex-direction:column;gap:.375rem}.portal-mono-label{font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.065em;color:var(--text-muted);white-space:nowrap;flex-shrink:0;min-width:96px}.portal-mono-row--block .portal-mono-label{min-width:0}.portal-mono-value-wrap{display:flex;align-items:center;gap:.5rem;flex:1;flex-wrap:wrap;min-width:0}.portal-mono-value{font-family:var(--font-mono);font-size:.8125rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px;word-break:break-all;flex:1;min-width:0;transition:filter .2s;color:var(--text-primary)}.portal-copy-btn{font-size:.75rem;min-width:54px}.portal-rotate-note{font-size:.775rem;color:var(--text-muted)}.portal-secret-saved-btn{font-size:.78rem;margin-top:.3rem}.portal-uri-list{display:flex;flex-direction:column;gap:.3rem;width:100%}.portal-uri-item{font-family:var(--font-mono);font-size:.8125rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px;display:block;word-break:break-all;color:var(--text-primary)}.portal-uri-editor{width:100%;display:flex;flex-direction:column;gap:.4rem}.portal-uri-row{display:flex;gap:.5rem}.portal-uri-row input{flex:1}.portal-add-uri-btn{align-self:flex-start;margin-top:.125rem}.portal-stats-section{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem}.portal-stats-toggle{background:none;border:none;padding:0;font-family:var(--font-primary);font-size:.8125rem;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:.4rem;transition:color .12s}.portal-stats-toggle:hover{color:var(--text-primary)}.portal-stats-chevron{font-size:.6rem;opacity:.6}.portal-stats-body{margin-top:.875rem;display:flex;flex-direction:column;gap:.75rem}.portal-stats-grid{display:flex;gap:2rem;flex-wrap:wrap}.portal-stat-cell{display:flex;flex-direction:column;gap:.2rem}.portal-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.portal-stat-value{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.portal-sparkline-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:0}.portal-sparkline{display:flex;align-items:flex-end;gap:2px;height:36px}.portal-sparkline-bar{flex:1;border-radius:2px;transition:height .25s}.portal-usage-bar-wrap{display:flex;flex-direction:column;gap:.35rem}.portal-usage-bar-header{display:flex;justify-content:space-between;align-items:center;font-size:.775rem}.portal-usage-count{font-weight:600}.portal-usage-track{background:var(--border);border-radius:4px;height:5px;overflow:hidden}.portal-usage-fill{height:100%;border-radius:4px;transition:width .4s}.portal-usage-note{font-size:.775rem;color:var(--danger);margin:0}.portal-form-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0 0 1.25rem}.portal-field-hint{font-size:.8rem;color:var(--text-muted);margin:-.25rem 0 .5rem}.portal-form-actions{display:flex;gap:.5rem;margin-top:1.25rem}.portal-empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3.5rem 2rem;border:1px dashed var(--border);border-radius:var(--radius-lg);margin-bottom:1rem;gap:.5rem}.portal-empty-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0}.portal-empty-desc{font-size:.875rem;color:var(--text-muted);margin:0 0 .75rem;max-width:340px;line-height:1.6}.portal-limit-note{margin-bottom:1.5rem}.portal-guide-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);margin-top:.5rem}.portal-guide-toggle{width:100%;background:none;border:none;padding:1.125rem 1.5rem;font-family:var(--font-primary);font-size:.875rem;font-weight:600;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:color .12s;text-align:left;border-radius:var(--radius-lg)}.portal-guide-toggle:hover{color:var(--text-primary)}.portal-guide-toggle-title{flex:1}.portal-guide-chevron{font-size:.6rem;opacity:.5}.portal-guide-body{padding:0 1.5rem 1.5rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1.5rem}.portal-guide-intro{font-size:.875rem;color:var(--text-muted);line-height:1.65;margin:1rem 0 0}.portal-guide-step{display:flex;gap:1rem;align-items:flex-start}.portal-guide-step-num{width:24px;height:24px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);font-size:.75rem;font-weight:700;font-family:var(--font-mono);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.125rem}.portal-guide-step-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.portal-guide-server-note{font-weight:400;font-size:.8rem;color:var(--text-muted)}.portal-guide-returns{font-size:.8125rem;color:var(--text-muted);margin:.5rem 0 0}.portal-code-block{display:block;font-family:var(--font-mono);font-size:.8rem;line-height:1.7;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;word-break:break-all;white-space:pre-wrap;color:var(--text-primary);margin-bottom:.5rem}.portal-code-inline{font-family:var(--font-mono);font-size:.8125rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;padding:1px 6px;color:var(--text-primary)}.not-found-page{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:2rem;position:relative}.not-found-inner{text-align:center;max-width:420px}.not-found-logo{display:inline-flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--text-primary);text-decoration:none;margin-bottom:2.5rem}.not-found-code{font-size:5rem;font-weight:800;letter-spacing:-.04em;color:var(--border);line-height:1;margin:0 0 .5rem;font-family:var(--font-mono)}.not-found-title{font-size:1.375rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin:0 0 .75rem}.not-found-desc{font-size:.9rem;color:var(--text-muted);line-height:1.65;margin:0 0 2rem}.not-found-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.db-rename-btn{font-size:.72rem;padding:.15rem .5rem}.db-codes-warning{font-size:.8375rem;color:var(--warning);border:1px solid rgba(217,119,6,.25);background:#d9770612;border-radius:var(--radius-sm);padding:.6rem .875rem;margin:0 0 .75rem;line-height:1.55}.db-approval-list{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.db-approval-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.875rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius)}.db-approval-info{flex:1;min-width:180px;display:flex;flex-direction:column;gap:.15rem}.db-approval-device{font-weight:600;font-size:.9rem;color:var(--text-primary)}.db-approval-meta{font-size:.8rem;color:var(--text-muted)}.db-approval-actions{display:flex;gap:.5rem}.db-link-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;max-width:420px;margin-top:.75rem}.db-link-card--approve{border-color:#6366f166;max-width:440px}.db-link-card-label{font-size:.775rem;font-weight:700;text-transform:uppercase;letter-spacing:.065em;color:var(--text-muted);margin:0 0 .4rem}.db-link-code{font-family:var(--font-mono);font-size:2.2rem;font-weight:900;letter-spacing:.15em;color:var(--accent);text-align:center;padding:.5rem 0}.db-link-expires{font-size:.8rem;text-align:center;margin:.25rem 0 1rem}.db-link-cancel{display:block;margin:0 auto}.db-link-approve-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}.db-device-fingerprint{display:grid;grid-template-columns:auto 1fr;gap:.25rem .75rem;font-size:.875rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;margin-bottom:1.25rem}.db-device-fp-label{color:var(--text-muted)}.db-device-fp-ip{font-family:var(--font-mono);font-size:.8rem}.db-code-input{width:100%;font-family:var(--font-mono);font-size:1.4rem;font-weight:700;letter-spacing:.15em;text-align:center;padding:.5rem;margin-bottom:.4rem}.db-code-error{font-size:.8rem;color:var(--danger);text-align:center;margin:0 0 .5rem}.db-link-approve-actions{display:flex;gap:.75rem;margin-top:.5rem}.db-link-approve-btn{flex:2}.db-link-approve-actions>.btn-danger-solid{flex:1}.portal-upgrade-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;border-top:1px solid var(--border);margin-top:.75rem;padding-top:.875rem;flex-wrap:wrap}.portal-upgrade-text{font-size:.8125rem;color:var(--text-muted)}.portal-upgrade-sent{font-size:.8125rem;color:var(--success);border-top:1px solid var(--border);margin-top:.75rem;padding-top:.875rem}.skip-nav{position:fixed;top:-100%;left:1rem;z-index:10000;padding:.5rem 1.25rem;background:#6366f1;color:#fff;border-radius:0 0 8px 8px;font-weight:600;font-size:.875rem;text-decoration:none;transition:top .15s ease;white-space:nowrap;box-shadow:0 4px 16px #00000040}.skip-nav:focus-visible{top:0;outline:none}:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.btn:focus-visible,.btn-danger-solid:focus-visible,.btn-capture:focus-visible,.btn-nav-ghost:focus-visible,.btn-nav-primary:focus-visible,.btn-hero-primary:focus-visible,.btn-hero-ghost:focus-visible,.theme-toggle:focus-visible{outline:2px solid #6366f1;outline-offset:2px;box-shadow:0 0 0 4px #6366f133}.tab-btn:focus-visible{outline:2px solid #6366f1;outline-offset:-2px;border-radius:4px 4px 0 0}.toggle-btn:focus-visible{outline:2px solid #6366f1;outline-offset:-1px}.btn-link:focus-visible,.btn-ghost:focus-visible{outline:2px solid #6366f1;outline-offset:2px;border-radius:4px}.toast-close:focus-visible{outline:2px solid rgba(255,255,255,.8);outline-offset:1px;border-radius:4px}@media (max-width: 1024px){.auth-content{grid-template-columns:1fr;gap:2rem}.auth-right{position:static}.landing-nav{padding:1rem 1.5rem}.landing-footer{flex-direction:column;gap:.5rem;text-align:center}}@media (max-width: 768px){.auth-header-section{padding:1.25rem 1rem}.auth-main{padding:1.5rem 1rem}.auth-form{padding:1.5rem}.step-indicator{gap:0}.verification-methods,.update-options{grid-template-columns:1fr}.landing-hero{padding:3.5rem 1.5rem 3rem}.landing-features,.landing-how,.landing-cta{padding:3.5rem 1.5rem}.features-grid,.how-steps{grid-template-columns:1fr}}@media (max-width: 640px){.profile-card{flex-direction:column;text-align:center}.profile-meta{justify-content:center;flex-wrap:wrap}.dashboard-tabs{overflow-x:auto}}@media (max-width: 520px){.settings-form{flex-direction:column}.recovery-codes-grid{grid-template-columns:1fr}.auth-card{padding:1.75rem 1.25rem}.step-label{display:none}.dashboard-header{padding:0 1rem}.factor-status-grid{grid-template-columns:1fr}}@media (max-width: 480px){.auth-form{padding:1.25rem}.btn{padding:.5rem .875rem}.totp-qr{width:160px;height:160px}.webcam-outer{width:220px;height:220px}.webcam-frame{width:185px;height:185px}}.auth-profile-notice{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.85rem;line-height:1.5}.auth-profile-notice--strict{background:color-mix(in srgb,#ef4444 10%,var(--bg-secondary));border:1px solid color-mix(in srgb,#ef4444 30%,transparent);color:var(--text-primary)}.auth-profile-notice--fast{background:color-mix(in srgb,#3b82f6 10%,var(--bg-secondary));border:1px solid color-mix(in srgb,#3b82f6 30%,transparent);color:var(--text-primary)}.auth-profile-notice-icon{font-size:1.1rem;flex-shrink:0;margin-top:.05rem}.auth-profile-notice strong{display:block;margin-bottom:.15rem}.auth-profile-notice p{margin:0;color:var(--text-muted)}.portal-profile-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.portal-profile-badge--standard{background:color-mix(in srgb,var(--text-muted) 15%,var(--bg-secondary));color:var(--text-muted)}.portal-profile-badge--fast{background:color-mix(in srgb,#3b82f6 18%,var(--bg-secondary));color:#3b82f6}.portal-profile-badge--strict{background:color-mix(in srgb,#ef4444 18%,var(--bg-secondary));color:#ef4444}.portal-profile-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:.4rem}@media (max-width: 600px){.portal-profile-cards{grid-template-columns:1fr}}.portal-profile-card{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;border-radius:var(--radius);border:2px solid var(--border);background:var(--bg-secondary);cursor:pointer;transition:border-color .15s,background .15s;text-align:left}.portal-profile-card:hover{border-color:var(--primary)}.portal-profile-card--selected{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 8%,var(--bg-secondary))}.portal-profile-card input[type=radio]{display:none}.portal-profile-card-label{font-weight:600;font-size:.85rem;color:var(--text-primary);display:flex;align-items:center;gap:.4rem}.portal-profile-card-desc{font-size:.75rem;color:var(--text-muted);line-height:1.45}
