*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;font-synthesis:none;text-rendering:optimizeLegibility}#root{width:100%;min-height:100vh}.input-group{display:flex;flex-direction:column;gap:.5rem;width:100%;margin-bottom:1rem;text-align:left}.input-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.input-field{padding:.75rem 1rem;border-radius:.75rem;border:1px solid var(--glass-border);background:#0003;color:var(--text-primary);font-size:1rem;transition:all .2s ease;outline:none;font-family:inherit}.input-field:focus{border-color:var(--primary-color);background:#0000004d;box-shadow:0 0 0 2px rgba(var(--primary-rgb),.2)}.input-error{border-color:var(--error-color)}.input-error-message{font-size:.75rem;color:var(--error-color);margin-top:.25rem}.input-wrapper{position:relative;display:flex}.input-wrapper .input-field{width:100%}.input-wrapper-password .input-field{padding-right:2.75rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.password-toggle:hover{color:var(--text-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;border:none;gap:.5rem;font-family:inherit}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff;box-shadow:0 4px 6px -1px rgba(var(--primary-rgb),.3)}.btn-primary:not(:disabled):hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 8px -1px rgba(var(--primary-rgb),.4)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 4px 6px -1px #e74c3c40}.btn-danger:not(:disabled):hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 8px -1px #e74c3c59}.btn-secondary{background:var(--overlay-light);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:not(:disabled):hover{background:var(--overlay-medium)}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-outline:not(:disabled):hover{background:var(--overlay-subtle);border-color:var(--text-secondary)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:not(:disabled):hover{color:var(--text-primary);background:var(--overlay-subtle)}.btn-spinner{animation:spin 1s linear infinite}.loading-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f9fb,#eef0f4);z-index:9999}.loading-screen svg{width:280px;height:280px}@keyframes ls-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes ls-spin-reverse{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes ls-pulse{0%{r:68;opacity:.35}to{r:105;opacity:0}}@keyframes ls-pulse-delay{0%{r:68;opacity:.2}to{r:100;opacity:0}}@keyframes ls-shimmer{0%,to{opacity:.9}50%{opacity:1}}@keyframes ls-scan{0%,to{transform:translateY(0)}50%{transform:translateY(65px)}}@keyframes ls-bar{0%{width:0}50%{width:120px}to{width:0}}@keyframes ls-dots1{0%,25%{opacity:0}30%,to{opacity:1}}@keyframes ls-dots2{0%,45%{opacity:0}50%,to{opacity:1}}@keyframes ls-dots3{0%,65%{opacity:0}70%,to{opacity:1}}@keyframes ls-shackle{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.ls-ring-outer{transform-origin:150px 140px;animation:ls-spin 12s linear infinite}.ls-ring-inner{transform-origin:150px 140px;animation:ls-spin-reverse 8s linear infinite}.ls-pulse-1{transform-origin:150px 140px;animation:ls-pulse 2.5s ease-out infinite}.ls-pulse-2{transform-origin:150px 140px;animation:ls-pulse-delay 2.5s ease-out 1.2s infinite}.ls-shield{animation:ls-shimmer 3s ease-in-out infinite}.ls-scan{animation:ls-scan 3s ease-in-out infinite}.ls-bar-fill{animation:ls-bar 2.5s ease-in-out infinite}.ls-shackle{transform-origin:150px 120px;animation:ls-shackle 3s ease-in-out infinite}.ls-dot1{animation:ls-dots1 1.5s step-end infinite}.ls-dot2{animation:ls-dots2 1.5s step-end infinite}.ls-dot3{animation:ls-dots3 1.5s step-end infinite}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal-content{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideIn .2s ease-out}.modal-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.125rem;font-weight:600;margin:0}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:4px;transition:all .2s}.modal-close:hover{background-color:var(--bg-surface-hover);color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:.75rem;background-color:var(--bg-surface-hover);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.mfa-verification{width:100%;max-width:400px}.mfa-header{text-align:center;margin-bottom:24px}.mfa-header h2{margin:12px 0 4px;font-size:1.25rem;color:var(--text-primary)}.mfa-timer{font-size:.8rem;color:var(--text-tertiary)}.mfa-methods{display:flex;gap:8px;margin-bottom:16px}.mfa-method-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:1px solid var(--border-secondary);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s}.mfa-method-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.mfa-method-btn.active{border-color:var(--accent-primary);background:#6366f11a;color:var(--accent-primary)}.mfa-error{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;background:#ef44441a;color:#ef4444;font-size:.85rem;margin-bottom:16px}.mfa-input-group{margin-bottom:20px}.mfa-input-group label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.mfa-code-input{width:100%;padding:12px 16px;border:1px solid var(--border-secondary);border-radius:10px;background:var(--bg-primary);color:var(--text-primary);font-size:1.5rem;font-family:monospace;text-align:center;letter-spacing:8px;outline:none;transition:border-color .15s}.mfa-code-input.recovery{letter-spacing:2px;font-size:1.2rem}.mfa-code-input:focus{border-color:var(--accent-primary)}.mfa-code-input:disabled{opacity:.5}.mfa-resend-btn{display:block;margin-top:8px;background:none;border:none;color:var(--accent-primary);font-size:.8rem;cursor:pointer;text-decoration:underline}.mfa-resend-btn:disabled{opacity:.5;cursor:not-allowed}.mfa-actions{display:flex;gap:8px;margin-bottom:16px}.mfa-actions .mfa-submit-btn{flex:1}.mfa-footer{text-align:center}.mfa-link-btn{background:none;border:none;color:var(--text-tertiary);font-size:.8rem;cursor:pointer;text-decoration:underline}.mfa-link-btn:hover{color:var(--text-secondary)}.mfa-expired{text-align:center;padding:20px}.mfa-expired p{color:var(--text-secondary);margin:12px 0 16px}.spin{animation:spin 1s linear infinite}.totp-wizard{width:100%;max-width:420px}.totp-header{text-align:center;margin-bottom:20px}.totp-header h3{margin:8px 0 4px;font-size:1.1rem;color:var(--text-primary)}.totp-header p{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.totp-qr-container{display:flex;justify-content:center;padding:16px;margin-bottom:16px;background:#fff;border-radius:12px}.totp-qr-image{width:200px;height:200px}.totp-manual-entry{margin-bottom:20px}.totp-manual-entry p{font-size:.8rem;color:var(--text-tertiary);margin-bottom:6px}.totp-secret-row{display:flex;align-items:center;gap:8px}.totp-secret{flex:1;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:6px;font-size:.75rem;word-break:break-all;color:var(--text-primary)}.totp-copy-btn{padding:6px;border:1px solid var(--border-secondary);border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer}.totp-copy-btn:hover{color:var(--accent-primary);border-color:var(--accent-primary)}.totp-actions{display:flex;gap:8px;margin-top:16px}.recovery-codes-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.recovery-code-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:8px}.recovery-code-num{font-size:.75rem;color:var(--text-tertiary);min-width:18px}.recovery-code-item code{font-size:.85rem;font-family:monospace;color:var(--text-primary);letter-spacing:1px}.recovery-code-actions{display:flex;gap:12px;justify-content:center;margin-bottom:16px}.recovery-action-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border-secondary);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer}.recovery-action-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.mfa-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mfa-modal-content{background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:16px;padding:32px;max-width:440px;width:90%;max-height:90vh;overflow-y:auto}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background-color:var(--bg-primary);background-image:radial-gradient(ellipse 80% 60% at 50% -20%,rgba(108,92,231,.18),transparent),radial-gradient(ellipse 60% 50% at 80% 100%,rgba(168,85,247,.1),transparent);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(108,92,231,.08),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;animation:login-glow 8s ease-in-out infinite alternate}@keyframes login-glow{0%{opacity:.5;transform:translate(-50%,-50%) scale(1)}to{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}.login-content{width:100%;max-width:420px;position:relative;z-index:1;animation:login-fade-in .5s ease-out}@keyframes login-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.logo-icon{min-height:64px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}.login-brand-logo{max-width:280px;display:block}.login-logo-loading{height:64px;display:flex;align-items:center;justify-content:center}.login-logo-spinner{color:var(--text-muted);opacity:.4;animation:login-spin 1.5s linear infinite}@keyframes login-spin{to{transform:rotate(360deg)}}.login-brand{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--primary-color);margin-bottom:.75rem}.login-header h1{font-size:1.75rem;font-weight:700;margin-bottom:.4rem;letter-spacing:-.02em;color:var(--text-primary)}.login-header p{color:var(--text-secondary);font-size:.95rem}.login-card{padding:2rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-lg),0 0 0 1px #ffffff05 inset}.login-form{display:flex;flex-direction:column;gap:.25rem}.form-actions{display:flex;flex-direction:column;gap:1rem;margin-top:.25rem}.forgot-password-link{color:var(--text-muted);font-size:.85rem;text-align:right;text-decoration:none;transition:color var(--transition-fast)}.forgot-password-link:hover{color:var(--primary-color)}.login-button{width:100%;height:48px;font-size:1rem;border-radius:var(--radius-md)!important}.login-card .error-banner{background:#e74c3c14;border:1px solid rgba(231,76,60,.2);color:#f87171;padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:1.25rem;display:flex;align-items:center;gap:.75rem;font-size:.875rem;line-height:1.4}.login-card .error-banner svg{flex-shrink:0}.login-footer{text-align:center;margin-top:1.75rem;color:var(--text-muted);font-size:.9rem}.login-footer a{color:var(--primary-color);text-decoration:none;font-weight:500;transition:color var(--transition-fast)}.login-footer a:hover{color:var(--primary-hover)}.login-loading-text{text-align:center;color:var(--text-muted);font-size:.8rem;margin-top:.75rem;animation:login-pulse 1.5s ease-in-out infinite}@keyframes login-pulse{0%,to{opacity:.5}50%{opacity:1}}.external-providers-section{margin-top:1.5rem}.external-providers-divider{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}.external-providers-divider:before,.external-providers-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.external-providers-list{display:flex;flex-direction:column;gap:.5rem}.external-provider-btn{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.7rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.external-provider-btn:hover{background:var(--bg-hover);border-color:var(--primary-color)}.external-provider-logo{width:20px;height:20px;object-fit:contain;flex-shrink:0}.login-step-enter{animation:step-slide-in .3s ease-out}@keyframes step-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.identified-email{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:1rem}.back-to-identify{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.15rem;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);flex-shrink:0}.back-to-identify:hover{color:var(--primary-color);background:var(--bg-hover)}.identified-email-text{flex:1;font-size:.9rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.change-email-link{background:none;border:none;color:var(--primary-color);font-size:.8rem;cursor:pointer;padding:0;text-decoration:none;flex-shrink:0;transition:color var(--transition-fast)}.change-email-link:hover{text-decoration:underline}.domain-sso-section{margin-bottom:.5rem}.domain-sso-section .external-providers-list{margin-bottom:1rem}.domain-sso-btn{border-color:var(--primary-color);background:#6c5ce70f}.domain-sso-btn:hover{background:#6c5ce71f;border-color:var(--primary-hover)}@media(max-width:480px){.login-container{padding:1rem}.login-card{padding:1.5rem}.login-header h1{font-size:1.5rem}}.unlock-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background-color:var(--bg-primary);background-image:radial-gradient(ellipse 80% 60% at 50% -20%,rgba(108,92,231,.18),transparent),radial-gradient(ellipse 60% 50% at 80% 100%,rgba(168,85,247,.1),transparent)}.unlock-content{width:100%;max-width:420px;animation:unlock-fade-in .5s ease-out}@keyframes unlock-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.unlock-header{text-align:center;margin-bottom:1.5rem}.unlock-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.unlock-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5}.unlock-user-info{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;margin-bottom:1.25rem;font-size:.875rem;color:var(--text-secondary)}.unlock-email-label{color:var(--text-tertiary)}.unlock-email{color:var(--text-primary);font-weight:500;margin-left:auto}.unlock-form{display:flex;flex-direction:column;gap:1rem}.unlock-field{width:100%}.unlock-error{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:var(--bg-danger-subtle, rgba(239, 68, 68, .08));border:1px solid var(--border-danger, rgba(239, 68, 68, .2));border-radius:6px;color:var(--text-danger, #ef4444);font-size:.8125rem}.unlock-submit{width:100%}.unlock-cooldown{font-size:.8125rem;color:var(--text-warning, #f59e0b);text-align:center}.unlock-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--text-tertiary);font-size:.8125rem}.unlock-divider:before,.unlock-divider:after{content:"";flex:1;height:1px;background:var(--border)}.unlock-passkey-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.unlock-passkey-error{margin-top:.75rem}.unlock-footer{text-align:center;margin-top:1.5rem}.unlock-switch-link{background:none;border:none;color:var(--text-tertiary);font-size:.8125rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0}.unlock-switch-link:hover{color:var(--text-primary)}.network-error-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background-color:var(--bg-primary)}.network-error-content{text-align:center;max-width:400px;animation:network-error-fade-in .5s ease-out}@keyframes network-error-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.network-error-icon{color:var(--text-tertiary);margin-bottom:1.5rem}.network-error-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.network-error-message{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin:0 0 2rem}.network-error-actions{display:flex;flex-direction:column;align-items:center;gap:1rem}.network-error-retry{display:inline-flex;align-items:center;gap:.5rem}.network-error-logout{background:none;border:none;color:var(--text-tertiary);font-size:.8125rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0}.network-error-logout:hover{color:var(--text-primary)}.toast-container{position:fixed;top:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;pointer-events:none}.toast-item{pointer-events:auto;min-width:300px;max-width:450px;background-color:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-lg);animation:toastSlideIn .3s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toast-content{display:flex;align-items:center;gap:.75rem}.toast-message{font-size:.875rem;font-weight:500;color:var(--foreground)}.toast-icon.success{color:var(--success)}.toast-icon.error{color:var(--destructive)}.toast-icon.warning{color:#f59e0b}.toast-icon.info{color:var(--primary)}.toast-item.success{border-left:4px solid var(--success)}.toast-item.error{border-left:4px solid var(--destructive)}.toast-item.warning{border-left:4px solid #f59e0b}.toast-item.info{border-left:4px solid var(--primary)}.toast-close{background:none;border:none;cursor:pointer;color:var(--muted-foreground);padding:2px;border-radius:4px;display:flex;align-items:center;justify-content:center;margin-left:1rem;transition:all .2s}.toast-close:hover{background-color:var(--accent);color:var(--accent-foreground)}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}[data-theme=light] .toast-icon.warning{color:#b45309}.confirm-message{font-size:1rem;color:var(--foreground);line-height:1.5;margin:0}.confirm-footer{display:flex;justify-content:flex-end;gap:.75rem;width:100%}.sidebar{width:260px;min-width:260px;flex-shrink:0;height:100vh;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;position:relative;z-index:50}.sidebar-header{padding:20px 22px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);min-height:72px}.sidebar-header .logo-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-header .logo-text{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,#e8eaf0,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}[data-theme=light] .sidebar-header .logo-text{background:linear-gradient(135deg,#1a1a2e,#6c5ce7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.sidebar-header--branded{justify-content:center;align-items:center;padding:12px 20px}.sidebar-brand-logo{max-width:90%;max-height:56px;width:auto;height:auto;display:block;object-fit:contain}.sidebar-nav{padding:12px 10px;display:flex;flex-direction:column;gap:2px}.nav-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:.88rem;font-weight:500;transition:var(--transition-fast)}.nav-link:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.nav-link.active{background:var(--accent-glow);color:var(--accent-hover)}.nav-link.drag-over{background:var(--accent-soft);box-shadow:0 0 0 2px var(--accent-hover)}.nav-link.active svg{color:var(--accent)}.sidebar-folders{padding:4px 10px 8px;border-top:1px solid var(--border);flex:1;overflow-y:auto}.sidebar-section-title{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:10px 14px 6px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.btn-add-folder{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.btn-add-folder:hover{background:var(--bg-surface-hover);color:var(--accent)}.folder-tree-node{margin-bottom:2px}.folder-item{display:flex;align-items:center;gap:6px;width:100%;padding:7px 14px;border:none;background:transparent;color:var(--text-secondary);font-size:.84rem;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-fast);text-align:left;font-family:inherit;position:relative}.folder-icon{flex-shrink:0}.folder-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.folder-item.active{background:var(--accent-soft);color:var(--accent-hover);font-weight:500}.folder-item.drag-over{background:var(--accent-soft);box-shadow:0 0 0 2px var(--accent-hover);color:var(--accent-hover)}.folder-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.folder-actions button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;transition:var(--transition-fast);opacity:.7}.folder-actions button:hover{color:var(--text-primary);opacity:1}.folder-actions button.action-delete:hover{color:var(--danger)}.folder-edit-form{padding:4px 10px}.folder-add-form{padding:4px 14px 8px}.folder-edit-input{width:100%;background:var(--bg-body);border:1px solid var(--accent);color:var(--text-primary);font-size:.84rem;padding:4px 8px;border-radius:4px;outline:none;font-family:inherit}.folder-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-count{font-size:.7rem;color:var(--text-muted);min-width:16px;text-align:right;margin-left:4px}.folder-chevron{transition:transform var(--transition-fast);flex-shrink:0;opacity:.4;margin-left:-14px}.folder-chevron.expanded{transform:rotate(90deg);opacity:.7}.header{height:60px;background:var(--header-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-title{font-size:1.05rem;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.portal-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);border-radius:var(--radius-md, 10px);cursor:pointer;font-size:.82rem;font-weight:500;font-family:inherit;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.portal-toggle:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--accent)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-md, 10px);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.theme-toggle:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:10px;padding:6px 10px;border:none;background:transparent;border-radius:var(--radius-md, 8px);cursor:pointer;transition:background .15s}.user-menu-trigger:hover{background:var(--bg-surface-hover, rgba(255, 255, 255, .04))}.user-trigger-info{display:flex;flex-direction:column;align-items:flex-end;line-height:1.3}.user-name{font-size:.84rem;font-weight:600;color:var(--text-primary);font-family:inherit}.user-email{font-size:.75rem;color:var(--text-secondary);font-family:inherit}.user-avatar{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),#a084f5);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;flex-shrink:0}.user-avatar.large{width:36px;height:36px;font-size:.9rem}.menu-chevron{color:var(--text-muted);transition:transform .2s}.menu-chevron.open{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:240px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;animation:menuFadeIn .15s ease-out}@keyframes menuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.menu-user-info{display:flex;align-items:center;gap:12px;padding:14px 16px}.menu-user-name{font-size:.85rem;color:var(--text-primary);font-weight:600}.menu-user-email{font-size:.78rem;color:var(--text-secondary);font-weight:400}.menu-user-org{font-size:.72rem;color:var(--text-muted);margin-top:2px}.menu-divider{height:1px;background:var(--border);margin:0}.menu-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:.84rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s,color .15s;text-align:left}.menu-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.menu-item.danger:hover{color:var(--danger, #e74c3c);background:#e74c3c14}.password-generator{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-top:8px;box-shadow:0 4px 12px #0000001a}.pg-mode-switcher{display:flex;background:var(--bg-secondary);padding:3px;border-radius:var(--radius-sm);margin-bottom:16px}.pg-mode-btn{flex:1;border:none;background:transparent;color:var(--text-secondary);font-size:.75rem;font-weight:600;padding:6px;border-radius:calc(var(--radius-sm) - 1px);cursor:pointer;transition:all var(--transition-fast)}.pg-mode-btn.active{background:var(--bg-primary);color:var(--accent);box-shadow:0 2px 4px #0000001a}.pg-preview{display:flex;align-items:center;gap:8px;margin-bottom:16px;background:var(--bg-secondary);padding:4px;border-radius:var(--radius-md);border:1px solid var(--border)}.pg-preview-text{flex:1;padding:12px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.9rem;color:var(--text-primary);word-break:break-all;min-height:48px;display:flex;align-items:center}.pg-preview-actions{display:flex;gap:4px;padding-right:4px}.pg-preview-actions button{background:transparent;border:none;color:var(--text-secondary);width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.pg-preview-actions button:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.pg-preview-actions button.active{color:var(--accent)}.pg-controls{display:flex;flex-direction:column;gap:12px}.pg-row{display:flex;align-items:center;gap:12px}.pg-row label{font-size:.8rem;color:var(--text-secondary);min-width:70px}.pg-row input[type=range]{flex:1;accent-color:var(--accent)}.pg-row .pg-value{font-size:.85rem;font-weight:600;color:var(--accent);min-width:24px;text-align:right}.pg-row select{flex:1;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px;color:var(--text-primary);font-size:.8rem;outline:none}.pg-toggles{display:flex;gap:6px;flex-wrap:wrap;padding-top:4px}.pg-toggle{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.pg-toggle:hover{border-color:var(--accent-glow)}.pg-toggle.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-hover)}.pg-footer{margin-top:20px;display:flex;gap:10px}.pg-footer button{flex:1;padding:10px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.pg-btn-secondary{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary)}.pg-btn-secondary:hover{background:var(--bg-surface-hover)}.pg-btn-primary{background:var(--accent);border:none;color:#fff}.pg-btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.password-strength-meter{margin-top:8px;font-size:.75rem}.psm-progress-bg{height:4px;background:var(--bg-secondary);border-radius:2px;overflow:hidden;margin-bottom:6px}.psm-progress-bar{height:100%;transition:width .3s ease,background-color .3s ease}.psm-progress-bar.score-0{width:20%;background-color:#ef4444}.psm-progress-bar.score-1{width:40%;background-color:#f97316}.psm-progress-bar.score-2{width:60%;background-color:#f59e0b}.psm-progress-bar.score-3{width:80%;background-color:#3b82f6}.psm-progress-bar.score-4{width:100%;background-color:#10b981}.psm-info{display:flex;justify-content:space-between;align-items:center;color:var(--text-secondary)}.psm-label{font-weight:500}.psm-label.score-0{color:#ef4444}.psm-label.score-1{color:#f97316}.psm-label.score-2{color:#f59e0b}.psm-label.score-3{color:#3b82f6}.psm-label.score-4{color:#10b981}.psm-suggestions{margin-top:8px;padding:8px;background:rgba(var(--accent-rgb),.05);border-radius:4px;color:var(--text-secondary)}.psm-suggestions ul{margin:4px 0 0 16px;padding:0}.psm-suggestions li{margin-bottom:2px}[data-theme=light] .psm-label.score-0{color:#dc2626}[data-theme=light] .psm-label.score-1{color:#c2410c}[data-theme=light] .psm-label.score-2{color:#b45309}[data-theme=light] .psm-label.score-3{color:#2563eb}[data-theme=light] .psm-label.score-4{color:#059669}.member-search-container{display:flex;flex-direction:column;width:100%}.search-command-root{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-surface);box-shadow:var(--shadow-md);transition:border-color var(--transition-fast)}.search-command-root:focus-within{border-color:var(--accent)}.search-input-wrapper{display:flex;align-items:center;padding:0 16px;border-bottom:1px solid var(--border-light);background:var(--overlay-subtle)}.search-icon{color:var(--text-muted);margin-right:12px;flex-shrink:0}.search-input{flex:1;height:48px;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.88rem}.search-input::placeholder{color:var(--text-muted)}.search-list{max-height:300px;overflow-y:auto;padding:8px;background:var(--bg-surface)}.search-list::-webkit-scrollbar{width:4px}.search-empty{padding:32px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted)}.search-empty-icon{opacity:.3}.search-loading{padding:32px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--accent)}.search-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-bottom:4px}.search-item:last-child{margin-bottom:0}.search-item[aria-selected=true],.search-item:hover{background:var(--bg-surface-hover)}.search-item-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent-light, #8e82f3),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem;flex-shrink:0}.search-item-info{display:flex;flex-direction:column;min-width:0}.search-item-name{font-weight:600;font-size:.88rem;color:var(--text-primary);line-height:1.2}.search-item-email{font-size:.75rem;color:var(--text-muted);margin-top:1px}.role-avatar{background:linear-gradient(135deg,#f39c12,#e67e22)}.group-avatar{background:linear-gradient(135deg,#10b981,#059669)}.spin-icon{animation:spin 1s linear infinite}.share-form-container{display:flex;flex-direction:column;gap:20px}.share-form-header{display:flex;align-items:center;gap:12px}.share-form-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent);border:1px solid rgba(108,92,231,.2)}.share-form-title{display:flex;flex-direction:column}.share-form-title h3{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2}.share-form-subtitle{font-size:11px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.share-alert{padding:12px;border-radius:var(--radius-md);display:flex;align-items:center;gap:12px;font-size:.88rem;animation:slide-down .3s ease}@keyframes slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.share-alert-error{background:#e74c3c1a;border:1px solid rgba(231,76,60,.2);color:var(--danger)}.share-alert-success{background:#2ecc711a;border:1px solid rgba(46,204,113,.2);color:var(--success)}.share-alert-warning{background:#f39c121a;border:1px solid rgba(243,156,18,.2);color:#e67e22}.share-alert-close{background:none;border:none;color:inherit;cursor:pointer;padding:4px;opacity:.7;transition:opacity .2s;display:flex;align-items:center}.share-alert-close:hover{opacity:1}.share-field-group{display:flex;flex-direction:column;gap:8px}.share-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-left:4px}.selected-member-card{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.selected-member-card:hover{background:var(--bg-surface-hover);border-color:var(--accent-hover)}.member-info{display:flex;align-items:center;gap:12px;min-width:0}.member-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent-light, #8e82f3),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;box-shadow:inset 0 0 10px #0000001a}.member-avatar-group{background:linear-gradient(135deg,#10b981,#059669)}.member-text{display:flex;flex-direction:column;min-width:0}.member-name{font-weight:600;font-size:.88rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-email{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-member-change{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center}.btn-member-change:hover{background:var(--bg-surface-active);color:var(--text-primary)}.roles-grid{display:flex;flex-direction:column;gap:8px}.role-option{position:relative;display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal)}.role-option:hover{background:var(--bg-surface-hover);border-color:var(--text-muted)}.role-option.selected{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 0 15px #6c5ce71a}.role-icon-box{width:40px;height:40px;border-radius:var(--radius-md);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal);flex-shrink:0}.role-option.selected .role-icon-box{background:var(--accent);color:#fff}.role-details{display:flex;flex-direction:column;min-width:0}.role-label{font-weight:700;font-size:.88rem;color:var(--text-primary);line-height:1.2}.role-desc{font-size:.7rem;color:var(--text-muted);margin-top:2px;font-weight:500}.role-check-icon{width:20px;height:20px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;margin-left:auto;animation:zoom-in .2s cubic-bezier(.175,.885,.32,1.275)}@keyframes zoom-in{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.btn-share-submit{width:100%;padding:16px;background:var(--accent);border:none;border-radius:var(--radius-lg);color:#fff;font-weight:700;font-size:.88rem;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 15px #6c5ce733}.btn-share-submit:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #6c5ce74d}.btn-share-submit:active:not(:disabled){transform:translateY(0)}.btn-share-submit:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-share-trigger{width:100%;padding:14px 16px;background:#6c5ce70a;border:1.5px dashed rgba(108,92,231,.3);border-radius:var(--radius-lg);color:var(--accent);font-weight:600;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);margin-bottom:4px}.btn-share-trigger:hover{background:#6c5ce714;border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px #6c5ce71a}.btn-share-trigger:active{transform:translateY(0)}.btn-share-trigger svg{opacity:.8;transition:transform .2s ease}.btn-share-trigger:hover svg{transform:scale(1.1);opacity:1}.btn-cancel-search{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;width:32px;height:32px}.btn-cancel-search:hover{background:#e74c3c1a;border-color:#e74c3c4d;color:var(--danger);transform:rotate(90deg)}.share-input{width:100%;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);font-size:.9rem;outline:none;transition:all var(--transition-normal)}.share-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6c5ce71a}.share-input[type=date]{font-family:inherit;color-scheme:dark;cursor:pointer}.share-input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1) opacity(.6);cursor:pointer}.share-input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:6px;margin-left:4px}.access-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border)}.access-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);transition:background var(--transition-fast)}.access-item:hover{background:var(--bg-surface-hover)}.access-info{display:flex;align-items:center;gap:12px;min-width:0}.access-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent-light),var(--accent));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0;border:2px solid var(--bg-secondary);box-shadow:0 0 0 1px var(--border)}.access-details{display:flex;flex-direction:column;min-width:0}.access-name{font-weight:600;font-size:.9rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}.access-role{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:4px;margin-top:1px}.access-avatar-group{background:linear-gradient(135deg,#10b981,#059669)}.access-badge-you{background:var(--accent-soft);color:var(--accent);font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.02em}.access-badge-group{background:#10b9811f;color:#10b981;font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.02em}.access-role-tag{display:flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.role-owner{background:#e74c3c1a;color:#e74c3c}.role-editor{background:#f39c121a;color:#f39c12}.role-viewer{background:#3498db1a;color:#3498db}.btn-revoke{opacity:0;transition:all var(--transition-fast);color:var(--text-muted);background:transparent;border:none;cursor:pointer;padding:8px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.access-item:hover .btn-revoke{opacity:1}.btn-revoke:hover{background:#e74c3c1a;color:#e74c3c}.access-loading,.access-error,.access-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:.9rem;display:flex;flex-direction:column;align-items:center;gap:12px}.access-empty-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:4px}.access-role-select{padding:2px 8px;font-size:.75rem;border-radius:4px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;outline:none;transition:all .2s}.access-role-select:hover{border-color:var(--accent)}.access-role-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.2)}.access-meta-row{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:wrap}.access-expiration{margin-top:0}.access-date-input{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);padding:3px 6px;font-size:.7rem;font-family:inherit;color-scheme:dark;outline:none;transition:all .2s ease;cursor:pointer;width:100%}.access-date-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.2);background:var(--bg-surface)}.access-date-input:hover{border-color:var(--text-muted)}.access-date-input::-webkit-calendar-picker-indicator{filter:invert(1) opacity(.6);cursor:pointer}.access-date-input::-webkit-calendar-picker-indicator:hover{opacity:1}.access-expiration-read{font-size:.7rem;color:var(--text-muted);margin-top:4px;display:flex;align-items:center;gap:4px}.access-expiration-read:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.5}.attachment-section{display:flex;flex-direction:column;gap:16px;animation:slide-in-right .3s ease;padding:8px 0}.attachment-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px 0;color:var(--text-muted);font-size:.85rem}.attachment-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);color:var(--danger);font-size:.82rem}.storage-usage{padding:0}.storage-usage-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.storage-label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.storage-values{font-size:.72rem;color:var(--text-muted)}.storage-bar{height:4px;background:var(--bg-surface);border-radius:2px;overflow:hidden}.storage-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.storage-bar-fill.warning{background:#f59e0b}.storage-bar-fill.danger{background:var(--danger)}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 16px;border:2px dashed var(--border);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-muted);font-size:.82rem;cursor:pointer;transition:all .2s ease}.upload-zone:hover{border-color:var(--accent);background:var(--bg-surface-hover);color:var(--text-secondary)}.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.upload-zone.uploading{cursor:default;border-color:var(--accent)}.upload-progress{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;color:var(--accent);font-size:.82rem}.upload-progress-bar{width:100%;height:4px;background:var(--bg-surface);border-radius:2px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .2s ease}.attachment-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 0;color:var(--text-muted);font-size:.85rem}.attachment-list{display:flex;flex-direction:column;gap:2px}.attachment-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border);transition:all .15s ease}.attachment-row:hover{background:var(--bg-surface-hover);border-color:var(--border-hover, var(--border))}.attachment-icon{color:var(--text-muted);display:flex;align-items:center;flex-shrink:0}.attachment-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.attachment-name{font-size:.84rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-meta{font-size:.72rem;color:var(--text-muted)}.attachment-actions{display:flex;gap:4px;flex-shrink:0}.attachment-btn{background:none;border:1px solid transparent;color:var(--text-muted);padding:6px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.attachment-btn:hover{background:var(--bg-surface-hover);border-color:var(--border);color:var(--text-primary)}.attachment-btn:disabled{opacity:.5;cursor:not-allowed}.attachment-btn.danger:hover{color:var(--danger);border-color:#ef444433;background:#ef44440f}.staged-mode .attachment-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.staged-mode .attachment-header h3{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 4px}.staged-mode .batch-upload-hint{font-size:.78rem;color:var(--text-muted);margin:0}.staged-mode .upload-zone{border-style:dashed;margin-bottom:20px}.staged-mode .dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.attachment-row.staged{border-left:3px solid var(--accent)}.attachment-meta.pending{color:var(--accent);font-weight:500}.via-history-toggle{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;padding:8px 4px;cursor:pointer;color:var(--text-muted);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.via-history-toggle:hover{color:var(--text-secondary);background:var(--bg-surface)}.via-history-title{flex:1;text-align:left}.via-history-count{font-size:.68rem;font-weight:600;color:var(--accent);background:var(--accent-soft);padding:1px 7px;border-radius:10px}.via-history-lock{color:var(--text-muted);opacity:.6}.via-history-noperm{display:flex;align-items:center;justify-content:center;gap:6px}.via-history-body{padding:4px 0 0}.via-history-loading{display:flex;align-items:center;gap:8px;padding:16px 4px;color:var(--text-muted);font-size:.82rem}.via-history-empty{padding:16px 4px;color:var(--text-muted);font-size:.82rem;text-align:center}.via-timeline{display:flex;flex-direction:column;gap:0}.via-timeline-item{display:flex;align-items:flex-start;gap:10px;padding:8px 4px;position:relative}.via-timeline-item:not(:last-child):after{content:"";position:absolute;left:8px;top:24px;bottom:-8px;width:1px;background:var(--border)}.via-timeline-dot{width:17px;height:17px;border-radius:50%;flex-shrink:0;margin-top:1px;background:var(--bg-surface);border:2px solid var(--border)}.via-timeline-dot[data-category=Vault]{border-color:#a084f5}.via-timeline-dot[data-category=Authentication]{border-color:#5dade2}.via-timeline-dot[data-category=MFA]{border-color:#f59e0b}.via-timeline-dot[data-category=Sharing]{border-color:#6dd5a0}.via-timeline-dot[data-category=Attachments]{border-color:#e88d84}.via-timeline-content{display:flex;flex-direction:column;gap:2px;min-width:0}.via-timeline-action{font-size:.84rem;color:var(--text-primary);font-weight:500}.via-timeline-meta{font-size:.74rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.via-history-more{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px;margin-top:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.78rem;cursor:pointer;transition:all var(--transition-fast)}.via-history-more:hover:not(:disabled){background:var(--bg-surface-hover);color:var(--text-secondary)}.via-history-more:disabled{opacity:.5;cursor:not-allowed}.via-spin{animation:via-spin .7s linear infinite}@keyframes via-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.drawer-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;top:0;right:0;width:480px;max-width:100vw;height:100vh;background:var(--bg-secondary);border-left:1px solid var(--border);z-index:2001;display:flex;flex-direction:column;animation:slide-in .25s ease;box-shadow:-8px 0 30px #0000004d}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.drawer-header h3{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0}.drawer-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center}.drawer-close:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.drawer-body{padding:24px;overflow-y:auto;flex:1;display:flex;flex-direction:column}.drawer-footer{padding:1.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--bg-secondary)}.drawer-footer-actions{display:flex;gap:1rem}.owner-branding{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.8rem;background:var(--bg-surface-hover);padding:6px 10px;border-radius:6px;border:1px solid var(--border)}.owner-branding span{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.type-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg-surface);padding:4px;border-radius:var(--radius-md)}.type-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:8px 10px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.type-tab:hover{color:var(--text-secondary)}.type-tab.active{background:var(--accent);color:#fff}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.78rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.form-input{width:100%;padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.88rem;font-family:inherit;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.form-input::placeholder{color:var(--text-muted)}.form-input:disabled{opacity:.55;cursor:not-allowed;background:var(--bg-surface-muted, rgba(128, 128, 128, .08));color:var(--text-muted)}select.form-input:disabled{pointer-events:none}.toggle-switch:disabled{opacity:.45;cursor:not-allowed}.inline-edit-name{display:flex;align-items:center;gap:6px;min-width:0;flex:1;padding:2px 6px;border-radius:var(--radius-sm);border:1px solid transparent;transition:border-color var(--transition-fast),background var(--transition-fast)}.inline-edit-name-text{font-size:1.15rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inline-edit-pencil{color:var(--text-muted);opacity:0;flex-shrink:0;transition:opacity var(--transition-fast)}.inline-edit-name.editable{cursor:pointer}.inline-edit-name.editable:hover{border-color:var(--border);background:var(--bg-tertiary)}.inline-edit-name.editable:hover .inline-edit-pencil{opacity:1}.header-edit-input{flex:1;min-width:0;background:transparent;border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;outline:none;padding:2px 6px;box-shadow:0 0 0 2px var(--accent-soft);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.header-edit-input::placeholder{color:var(--text-muted);font-weight:400}.header-icon-upload-btn{position:absolute;bottom:-4px;right:-4px;width:20px;height:20px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-secondary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .15s ease,opacity .15s ease;opacity:.85}.header-icon-upload-btn:hover{transform:scale(1.15);opacity:1}.header-icon-remove-btn{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--danger, #e53e3e);border:2px solid var(--bg-secondary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:0;transition:opacity .15s ease,transform .15s ease}.detail-header-info:hover .header-icon-remove-btn{opacity:.85}.header-icon-remove-btn:hover{transform:scale(1.15);opacity:1}.activity-tab-content{overflow-y:auto;flex:1}textarea.form-input{resize:vertical;min-height:80px}select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23595d73' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.password-field{position:relative;display:flex;gap:0}.password-field .form-input{border-radius:var(--radius-sm) 0 0 var(--radius-sm);flex:1}.password-field-actions{display:flex}.password-field-actions button{background:var(--bg-surface);border:1px solid var(--border);border-left:none;color:var(--text-muted);padding:0 10px;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center}.password-field-actions button:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.password-field-actions button:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.form-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;cursor:pointer}.toggle-row span{font-size:.85rem;color:var(--text-secondary)}.toggle-switch{width:36px;height:20px;background:var(--border);border-radius:10px;position:relative;transition:background var(--transition-fast);cursor:pointer;border:none;padding:0}.toggle-switch.active{background:var(--accent)}.toggle-switch:after{content:"";position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform var(--transition-fast)}.toggle-switch.active:after{transform:translate(16px)}.generator-toggle{font-size:.8rem;color:var(--accent-hover);background:none;border:none;cursor:pointer;padding:4px 0;font-family:inherit;display:flex;align-items:center;gap:4px;margin-bottom:4px}.generator-toggle:hover{color:var(--accent)}.btn-save{padding:9px 24px;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--transition-fast)}.btn-save:hover{background:var(--accent-hover)}.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-cancel{padding:9px 18px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.btn-cancel:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.form-error{color:var(--danger);font-size:.8rem;margin-top:4px}.form-hint{font-size:.75rem;color:var(--accent);margin-top:4px}.drawer-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg-surface)}.drawer-tab{flex:1;padding:12px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:8px}.drawer-tab:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.drawer-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--bg-surface-active)}.sharing-tab-content{display:flex;flex-direction:column;gap:32px;animation:slide-in-right .3s ease;padding:8px 0}@keyframes slide-in-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.sharing-divider{position:relative;display:flex;align-items:center;justify-content:flex-start;height:20px}.divider-line{position:absolute;left:0;right:0;height:1px;background:var(--border-light);z-index:1}.divider-text{position:relative;z-index:2;background:var(--bg-secondary);padding-right:12px;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.access-section{display:flex;flex-direction:column;gap:16px}.access-section-header{display:flex;align-items:center;gap:8px;color:var(--text-primary)}.access-section-header h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin:0}.access-section-header svg{color:var(--accent)}.drawer-title{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0}.share-badge{display:flex;align-items:center;gap:4px;padding:2px 8px;background:var(--accent-soft);color:var(--accent);border-radius:12px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.folder-content-row{transition:all .2s ease}.folder-content-row:hover{background:var(--bg-surface-hover)!important;border-color:var(--border-hover)!important}.folder-content-row .row-actions{opacity:0;transition:opacity .2s ease}.folder-content-row:hover .row-actions{opacity:1}.text-accent{color:var(--accent)}.invisible-submit{display:none}.note-container{position:relative;width:100%}.masked-note-placeholder{width:100%;min-height:160px;background:var(--bg-surface);border:1px dashed var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.masked-note-placeholder:hover{background:var(--bg-surface-hover);border-color:var(--accent);color:var(--text-secondary)}.note-visibility-toggle{position:absolute;top:12px;right:12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.note-visibility-toggle:hover{color:var(--text-primary);background:var(--bg-surface-hover)}[data-theme=light] .type-tabs{background:var(--bg-primary);border:1px solid var(--border)}.card-brand-badge{padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:18px}.brand-visa{background:#1a1f71;color:#fff}.brand-mastercard{background:#eb001b;color:#fff}.brand-amex{background:#016fd0;color:#fff}.brand-discover{background:#ff6000;color:#fff}.brand-jcb{background:#003780;color:#fff}.brand-generic{background:var(--bg-surface-hover);color:var(--text-muted);border:1px solid var(--border)}.detail-drawer{border-top:3px solid var(--accent)}.detail-drawer .drawer-body{display:block}.detail-mode-badge{display:inline-flex;align-items:center;padding:1px 8px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:var(--accent-soft);border-radius:4px;flex-shrink:0}.detail-header-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.detail-header-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.detail-header-icon.login{background:#6c5ce71f;color:#a084f5}.detail-header-icon.note{background:#3498db1f;color:#5dade2}.detail-header-icon.card{background:#e74c3c1f;color:#e88d84}.detail-header-icon.identity{background:#2ecc711f;color:#6dd5a0}.detail-header-name{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-header-meta{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-muted);margin-top:2px}.detail-meta-dot{opacity:.5}.detail-field{margin-bottom:18px}.detail-field-label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.detail-encrypted-badge{font-size:.62rem;color:var(--accent);font-weight:400;letter-spacing:0;text-transform:none}.detail-field-value{display:flex;align-items:center;gap:6px;font-size:.88rem;color:var(--text-primary);padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-height:40px}.detail-field-value-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.detail-action-btn{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center;flex-shrink:0;text-decoration:none}.detail-action-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.detail-action-btn:disabled{opacity:.4;cursor:not-allowed}.detail-note-placeholder{min-height:120px;background:var(--bg-surface);border:1px dashed var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.detail-note-placeholder:hover{background:var(--bg-surface-hover);border-color:var(--accent);color:var(--text-secondary)}.detail-note-content{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px}.detail-note-text{font-family:inherit;font-size:.88rem;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;margin:0;min-height:80px}.detail-note-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px}.detail-drawer .btn-save{display:flex;align-items:center;gap:6px}.detail-drawer .drawer-footer-left{display:flex;align-items:center;gap:8px}[data-theme=light] .detail-header-icon.login{color:#7c3aed}[data-theme=light] .detail-header-icon.note{color:#0284c7}[data-theme=light] .detail-header-icon.card{color:#dc2626}[data-theme=light] .detail-header-icon.identity{color:#059669}.extension-login-prompt{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9998;width:340px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:.75rem;animation:promptSlideIn .3s cubic-bezier(.16,1,.3,1)}.extension-login-prompt.exiting{animation:promptSlideOut .3s cubic-bezier(.7,0,.84,0) forwards}.extension-prompt-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:background var(--transition-fast),color var(--transition-fast)}.extension-prompt-close:hover{background:var(--bg-surface-hover);color:var(--text-secondary)}.extension-prompt-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.extension-prompt-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.extension-prompt-desc{font-size:.8rem;color:var(--text-secondary);margin:.25rem 0 0;line-height:1.4}.extension-prompt-actions{display:flex;gap:.5rem;margin-top:.25rem}@keyframes promptSlideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes promptSlideOut{0%{transform:translateY(0);opacity:1}to{transform:translateY(20px);opacity:0}}.password-strength{margin-top:.5rem;width:100%}.strength-bars{display:flex;gap:4px;height:4px;margin-bottom:.5rem}.strength-bar{flex:1;border-radius:2px;background:var(--overlay-light);transition:background-color .3s ease}.filled-1,.filled-0{background-color:var(--error-color)}.filled-2{background-color:var(--warning-color)}.filled-3{background-color:var(--primary-color)}.filled-4{background-color:var(--success-color)}.strength-label{font-size:.75rem;color:var(--text-secondary);text-align:right}.strength-warning{color:var(--warning-color)}.forced-pw-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.forced-pw-card{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;width:100%;max-width:480px;box-shadow:0 25px 50px -12px #00000080;padding:32px;animation:modal-slide-up .3s ease-out}@keyframes modal-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.forced-pw-header{text-align:center;margin-bottom:32px}.forced-pw-icon{width:64px;height:64px;background:rgba(var(--primary-rgb),.1);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.forced-pw-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.forced-pw-header p{color:var(--text-secondary);font-size:.95rem;line-height:1.5}.forced-pw-form{display:flex;flex-direction:column;gap:20px}.forced-pw-field{display:flex;flex-direction:column;gap:8px}.forced-pw-field label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.forced-pw-input-wrapper{position:relative}.forced-pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:4px;transition:color .2s}.forced-pw-toggle:hover{color:var(--text-primary)}.forced-pw-actions{display:flex;align-items:center;gap:12px;margin-top:12px}.forced-pw-actions .submit-btn{flex:1;height:44px;font-weight:600}.forced-pw-actions .logout-btn{padding:0 16px;height:44px;color:var(--text-secondary)}.forced-pw-footer{margin-top:32px;padding-top:24px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:.825rem;line-height:1.4}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.initialization-info{display:flex;align-items:flex-start;gap:12px;background:rgba(var(--primary-rgb),.05);border:1px solid rgba(var(--primary-rgb),.2);border-radius:12px;padding:16px;margin-bottom:24px;color:var(--text-primary);font-size:.9rem;line-height:1.5}.initialization-info svg{color:var(--primary);flex-shrink:0;margin-top:2px}.recovery-card{max-width:520px;text-align:center}.recovery-desc{margin-top:12px;color:var(--text-secondary);font-size:.95rem;line-height:1.6}.recovery-key-box{background:var(--bg-secondary);border:2px dashed var(--border);border-radius:12px;padding:24px;margin:24px 0;cursor:pointer;position:relative;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:16px}.recovery-key-box:hover{border-color:var(--primary);background:rgba(var(--primary-rgb),.02)}.recovery-key-box code{font-family:var(--font-mono);font-size:1.25rem;font-weight:600;letter-spacing:.05em;color:var(--text-primary);word-break:break-all}.copy-btn{padding:8px;height:auto;color:var(--text-muted)}.warning-box{display:flex;align-items:flex-start;gap:12px;background:rgba(var(--warning-rgb),.1);border:1px solid rgba(var(--warning-rgb),.2);border-radius:12px;padding:16px;margin-bottom:24px;text-align:left;color:var(--warning);font-size:.875rem;font-weight:500}.warning-box svg{flex-shrink:0}.w-full{width:100%}.app-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.main-content-wrapper{flex:1;display:flex;flex-direction:column;min-height:100vh;min-width:0}.main-content{flex:1;overflow-y:auto;max-height:calc(100vh - 64px);padding:0}.admin-sidebar{width:220px;min-width:220px;flex-shrink:0;height:100vh;background-color:var(--sidebar-bg, #12141f);border-right:1px solid var(--border, #252840);display:flex;flex-direction:column;color:var(--text-primary);z-index:50;transition:width .22s cubic-bezier(.4,0,.2,1),min-width .22s cubic-bezier(.4,0,.2,1);overflow:hidden}.admin-sidebar.collapsed{width:52px;min-width:52px}.admin-sidebar-header{padding:20px 22px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);min-height:64px;flex-shrink:0}.admin-sidebar-header .logo-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-sidebar-header .logo-text{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,#e8eaf0,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}[data-theme=light] .admin-sidebar-header .logo-text{background:linear-gradient(135deg,#1a1a2e,#6c5ce7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.admin-sidebar-header--branded{justify-content:center;align-items:center;padding:12px 10px}.admin-brand-logo{max-width:90%;max-height:44px;width:auto;height:auto;display:block;object-fit:contain}.admin-brand-logo-sm{max-width:30px;max-height:30px;width:auto;height:auto;display:block;object-fit:contain}.admin-nav{padding:12px 8px;display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1}.admin-nav-group{display:flex;flex-direction:column}.admin-nav-group+.admin-nav-group{margin-top:6px}.admin-nav-section-heading{font-size:.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:5px 10px 3px;-webkit-user-select:none;user-select:none;white-space:nowrap}.admin-nav-section-heading--toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;cursor:pointer;font-family:inherit}.admin-nav-section-heading--toggle:hover{color:var(--text-secondary)}.admin-nav-group+.admin-nav-group .admin-nav-section-heading{border-top:1px solid var(--border-light);padding-top:8px}.admin-nav-group-chevron{flex-shrink:0;opacity:.5;transition:transform var(--transition-fast, .15s ease)}.admin-nav-group-chevron.expanded{transform:rotate(90deg);opacity:.8}.admin-nav-group-items{display:grid;grid-template-rows:0fr;transition:grid-template-rows .22s cubic-bezier(.4,0,.2,1)}.admin-nav-group-items.expanded{grid-template-rows:1fr}.admin-nav-group-items-inner{overflow:hidden;display:flex;flex-direction:column;gap:2px}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:7px;color:var(--text-secondary, #aaa);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;overflow:hidden;position:relative}.admin-nav-item:hover{background-color:var(--bg-surface-hover);color:var(--text-primary)}.admin-nav-item.active{background-color:var(--accent);color:#fff;box-shadow:0 4px 12px var(--accent-glow)}.admin-nav-item svg{flex-shrink:0}.admin-sidebar.collapsed .admin-nav-item{justify-content:center;padding:9px 0}.admin-sidebar.collapsed .admin-nav-item[data-tooltip]:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:var(--bg-elevated, #1e2035);color:var(--text-primary);padding:4px 10px;border-radius:6px;font-size:.78rem;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s;z-index:200;border:1px solid var(--border);box-shadow:0 4px 12px #0000004d}.admin-sidebar.collapsed .admin-nav-item[data-tooltip]:hover:after{opacity:1}.admin-sidebar-footer{flex-shrink:0;padding:8px;border-top:1px solid var(--border)}.admin-sidebar-collapse-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:7px;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:.8rem;font-weight:500;font-family:inherit;white-space:nowrap;overflow:hidden;transition:background .15s,color .15s}.admin-sidebar-collapse-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.admin-sidebar.collapsed .admin-sidebar-collapse-btn{justify-content:center;padding:8px 0}@keyframes sk-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.sk{background:linear-gradient(90deg,var(--bg-surface-hover, #1e1e1e) 25%,var(--bg-surface, #252525) 50%,var(--bg-surface-hover, #1e1e1e) 75%);background-size:200% 100%;animation:sk-shimmer 1.5s infinite;border-radius:8px}.page-loading-skeleton{padding:32px 28px;max-width:1200px;margin:0 auto}:root{--bg-primary: #0f1117;--bg-secondary: #161822;--bg-surface: #1c1e2e;--bg-surface-hover: #252840;--bg-surface-active: #2d3154;--sidebar-bg: #12141f;--header-bg: #161822;--bg-gradient: linear-gradient(135deg, #0f1117 0%, #1a1040 50%, #0f1117 100%);--text-primary: #e8eaf0;--text-secondary: #8b8fa3;--text-muted: #595d73;--primary-color: #6c5ce7;--primary-hover: #7e70f0;--primary-rgb: 108, 92, 231;--accent: #6c5ce7;--accent-hover: #7e70f0;--accent-glow: rgba(108, 92, 231, .15);--accent-soft: rgba(108, 92, 231, .1);--border: #252840;--border-light: #1e2035;--success: #2ecc71;--success-color: #2ecc71;--warning: #f1c40f;--warning-color: #f1c40f;--danger: #e74c3c;--error-color: #e74c3c;--favorite: #f39c12;--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .08);--glass-shadow: 0 4px 30px rgba(0, 0, 0, .15);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 14px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .35);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--overlay-subtle: rgba(255, 255, 255, .05);--overlay-light: rgba(255, 255, 255, .1);--overlay-medium: rgba(255, 255, 255, .15);--overlay-inset: rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-normal: .25s ease;--logo-filter: invert(1) hue-rotate(180deg) brightness(1.2);color-scheme:dark light}[data-theme=light]{--bg-primary: #f4f5f9;--bg-secondary: #ffffff;--bg-surface: #ffffff;--bg-surface-hover: #f0f1f5;--bg-surface-active: #e6e8ef;--sidebar-bg: #f9fafb;--header-bg: #ffffff;--text-primary: #1a1a2e;--text-secondary: #4e5068;--text-muted: #6b6f85;--accent: #5b4cdb;--accent-hover: #6c5ce7;--accent-glow: rgba(91, 76, 219, .12);--accent-soft: rgba(91, 76, 219, .08);--border: #e0e2ea;--border-light: #ecedf2;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 14px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .1);--overlay-subtle: rgba(0, 0, 0, .03);--overlay-light: rgba(0, 0, 0, .06);--overlay-medium: rgba(0, 0, 0, .1);--overlay-inset: rgba(0, 0, 0, .05);--logo-filter: none}.glass-panel{background:var(--glass-bg);border-radius:16px;box-shadow:var(--glass-shadow);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border)}a{color:var(--primary-color);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-hover)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
