.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-main);position:relative}.login-theme-toggle{position:absolute;top:20px;right:24px;width:38px;height:38px;border-radius:50%;border:none;background:var(--bg-soft);color:var(--text-main);display:flex;align-items:center;justify-content:center;cursor:pointer}.login-card{width:100%;max-width:450px;background:var(--bg-card);border:1px solid var(--border-soft);border-radius:16px;padding:36px 32px;box-shadow:0 20px 40px #0000001f}.login-header{text-align:center;margin-bottom:28px}.login-header img{width:200px}.lock-icon{font-size:36px;margin-bottom:8px}.login-header h1{color:var(--text-main);font-size:24px;margin:6px 0}.login-header p{color:var(--text-soft);font-size:14px}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column}.form-group label{color:var(--text-soft);font-size:13px;margin-bottom:6px}.form-group input{background:var(--bg-soft);border:1px solid var(--border-soft);color:var(--text-main);padding:12px 14px;border-radius:10px;font-size:14px;outline:none}.form-group input::placeholder{color:#94a3b8}.form-group input:focus{border-color:var(--primary)}.login-btn{margin-top:8px;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border:none;padding:12px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{background:#ef444426;color:#b91c1c;border:1px solid rgba(239,68,68,.3);padding:10px;border-radius:8px;font-size:13px;margin-bottom:16px;text-align:center}.login-footer{margin-top:22px;text-align:center}.login-footer p{font-size:12px;color:var(--text-soft)}[data-theme=dark] .login-page{background:radial-gradient(circle at top,#1e293b,#020617)}[data-theme=dark] .login-card{background:#020617;box-shadow:0 20px 40px #0009}[data-theme=dark] .login-error{color:#fecaca}.input-wrapper{position:relative;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:12px;height:46px;display:flex;align-items:center}.input-wrapper input{width:100%;height:100%;background:transparent;border:none;outline:none;color:var(--text-main);font-size:14px;padding:0 46px 0 44px}.input-wrapper svg:first-child{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-soft)}.eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:8px;background:transparent;border:none;cursor:pointer;color:var(--text-soft);display:flex;align-items:center;justify-content:center}[data-theme=dark] .input-wrapper{background:#020617}[data-theme=dark] .eye-btn:hover{background:#ffffff14}.login-card svg{stroke:currentColor;fill:none;opacity:1}.login-card .input-wrapper svg,.login-card .eye-btn svg{color:#64748b}[data-theme=dark] .login-card .input-wrapper svg,[data-theme=dark] .login-card .eye-btn svg{opacity:1!important}[data-theme=dark] .login-card .eye-btn:hover{background:#ffffff14}.login-register{margin-top:16px;display:flex;justify-content:center;gap:6px;font-size:14px;color:var(--text-soft)}.login-register a{color:var(--primary);font-weight:500;text-decoration:none}.login-register a:hover{text-decoration:underline}.register-login{margin-top:16px;display:flex;justify-content:center;gap:6px;font-size:14px;color:var(--text-soft)}.register-login a{color:var(--primary);font-weight:500;text-decoration:none}.register-login a:hover{text-decoration:underline}.forgot-password-link{text-align:right;margin-top:6px}.forgot-password-link a{font-size:13px;color:var(--primary);text-decoration:none}.login-theme-home{position:absolute;top:20px;right:24px;left:24px;width:38px;height:38px;border-radius:50%;border:none;background:var(--bg-soft);color:var(--text-main);display:flex;align-items:center;justify-content:center;cursor:pointer}.twofa-modal{margin-top:20px;padding:20px;background:var(--bg-card);border:1px solid var(--border-soft);border-radius:14px;text-align:center}.twofa-modal h2{margin-bottom:10px}.twofa-input{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border-soft);text-align:center;font-size:16px;margin:14px 0;background:var(--bg-card)}.twofa-card p{margin-bottom:0}@media(max-width:768px){.primary-btn{width:40%!important;margin-top:0!important}}.dashboard-header{height:64px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border-bottom:1px solid var(--border-soft);flex-shrink:0}.header-left{display:flex;align-items:center}.search-box{display:flex;align-items:center;gap:10px;background:var(--bg-soft);padding:10px 14px;border-radius:12px;width:260px}.search-box input{background:none;border:none;outline:none;color:var(--text-main);width:100%}.header-right{display:flex;align-items:center;gap:14px}.icon-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-soft);border:none;display:flex;align-items:center;justify-content:center;color:var(--text-main);cursor:pointer}.avatar{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:999px;background:var(--bg-soft);cursor:pointer}.avatar img{width:32px;height:32px;border-radius:50%;object-fit:cover}.avatar-dropdown{position:absolute;right:0;top:48px;width:160px;background:var(--bg-main);border-radius:12px;padding:8px;border:1px solid var(--border-soft);z-index:1000}.avatar-dropdown button{width:100%;background:none;border:none;color:var(--text-main);padding:10px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:14px}.avatar-dropdown button:hover{background:var(--bg-soft)}.avatar-dropdown .danger{color:#ef4444}@media(max-width:768px){.search-box{width:180px;margin-left:40px}}.avatar-wrapper{position:relative}.avatar:hover{background:var(--bg-hover)}.avatar-dropdown button.danger,.sidebar-logout.danger{margin-top:4px;border-top:1px solid var(--border-soft);padding-top:12px}.notification-btn{position:relative}.notification-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:#ef4444;border-radius:50%;border:2px solid var(--bg-card)}.notification-wrapper{position:relative}.notification-dropdown{position:absolute;right:0;top:46px;width:280px;background:var(--bg-card);border:1px solid var(--border-soft);border-radius:14px;box-shadow:0 20px 40px #00000073;z-index:1000;overflow:hidden}.notification-header{padding:12px 14px;font-size:14px;font-weight:600;border-bottom:1px solid var(--border-soft)}.notification-item{padding:12px 14px;cursor:pointer}.notification-item:hover{background:var(--bg-soft)}.notification-item p{font-size:13px;margin-bottom:4px;color:var(--text-main)}.notification-item span{font-size:12px;color:var(--text-soft)}.notification-empty{padding:18px;font-size:13px;color:var(--text-soft);text-align:center}.role-badge.pending{background:#fef3c7;color:#92400e}.search-dropdown{position:absolute;top:50px;width:260px;background:var(--bg-main);border:1px solid var(--border-soft);border-radius:12px;z-index:999;overflow:hidden;box-shadow:0 12px 28px #0000001f}.search-title{padding:8px 14px;font-size:12px;font-weight:600;color:var(--text-muted)}.search-item{padding:10px 14px;cursor:pointer;font-size:14px}.search-item:hover{background:var(--bg-soft)}.search-empty{padding:14px;text-align:center;color:var(--text-muted)}.avatar-initials{display:flex;align-items:center;gap:6px;background:transparent;border:none;cursor:pointer}.avatar-circle{width:36px;height:36px;border-radius:50%;font-weight:600;font-size:15px;color:#fff;display:flex;align-items:center;justify-content:center}.animate-pop{animation:popIn .3s ease forwards}@keyframes popIn{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}.initials-avatar-btn{display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer}.initials-avatar-header{background:var(--primary);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px}svg.lucide.lucide-chevron-down{color:var(--text-main)!important}.dashboard-layout{display:flex;min-height:100vh;background:var(--bg-main)}.dashboard-main{flex:1;display:flex;flex-direction:column;min-height:100vh}.dashboard-content{padding:20px;flex:1;overflow-x:hidden}@media(max-width:768px){.dashboard-layout{display:block}.header-right{gap:5px;margin-left:10px}.users-search input{width:160px!important}}.vaults-page{padding:24px}.vaults-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.vaults-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.vault-card{background:linear-gradient(180deg,#1e2633,#141a24);border-radius:16px;padding:20px;color:#fff}.vault-title{font-size:18px;margin-bottom:14px}.vault-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.label{font-size:12px;color:#9aa4b2}.value{font-size:14px}.password-row{align-items:center}.password-text{font-family:inherit;font-size:14px;flex:1;text-align:right;margin-right:10px}.actions{display:flex;gap:8px}.actions button{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:none;border-radius:9999px;cursor:pointer;color:#fff;transition:background .2s ease,transform .15s ease}.actions button:hover{background:#ffffff2e;transform:scale(1.05)}.add-vault-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:linear-gradient(135deg,#2563eb,#3b82f6);border:none;border-radius:12px;color:#fff;font-size:14px;cursor:pointer}.add-vault-btn:hover{opacity:.9}.vault-table{width:100%;border-radius:16px;overflow:hidden;background:var(--bg-card);border:1px solid var(--border-soft)}.vault-table-header{display:grid;grid-template-columns:2fr 2fr 1fr 1fr 1fr;padding:14px 20px;font-size:12px;text-transform:uppercase;color:var(--text-soft);background:var(--bg-soft);font-weight:700}.vault-table-row{display:grid;grid-template-columns:2fr 2fr 1fr 1fr 1fr;align-items:center;padding:16px 20px;border-top:1px solid var(--border-soft);transition:background .2s ease}.vault-table-row:hover{background:var(--bg-soft)}.cell{font-size:14px;color:var(--text-main)}.cell.password{font-family:inherit}.cell.actions,.cell{display:flex;gap:10px}.cell.actions button,.cell button{width:34px;height:34px;border-radius:50%;border:none;background:var(--bg-soft);color:var(--text-main);cursor:pointer}.cell.actions button:hover{background:#3b82f626}[data-theme=dark] .vault-table{background:linear-gradient(180deg,#1e2633,#141a24)}[data-theme=dark] .vault-table-row:hover{background:#ffffff0a}@media(max-width:768px){.vault-table-header{display:none}.vault-table-row{grid-template-columns:1fr;gap:10px;padding:16px}.cell{display:flex;justify-content:start;font-size:13px}.cell:before{content:attr(data-label);color:#9aa4b2;font-size:12px}.cell.actions{justify-content:start}}.icon-btn{background:#ffffff0f;border:1px solid var(--border-soft);border-radius:10px;padding:6px;cursor:pointer;color:var(--text-main);transition:all .15s ease}.icon-btn:hover:not(.disabled){background:#ffffff1f}.tooltip-wrapper{position:relative;display:inline-flex}.tooltip{position:absolute;bottom:120%;left:50%;transform:translate(-50%);background:var(--bg-card);color:var(--text-main);padding:6px 10px;border-radius:8px;font-size:12px;white-space:nowrap;border:1px solid var(--border-soft);box-shadow:0 8px 24px #00000026;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:50}.tooltip-wrapper:hover .tooltip{opacity:1;transform:translate(-50%) translateY(-4px)}.icon-btn.disabled{opacity:.4;cursor:not-allowed}.vault-grid-admin{grid-template-columns:1fr 2fr 1fr 1fr 1fr}.vault-grid-user{grid-template-columns:1.5fr 2fr 1fr 1fr}.category-badge{margin-left:8px;padding:2px 6px;font-size:11px;background:#eef2ff;color:#3730a3;border-radius:6px}.category-select-wrapper{position:relative}.category-select-btn{width:100%;height:42px;padding:0 38px 0 14px;border-radius:10px;border:1px solid var(--border-soft);background:var(--bg-card);color:var(--text-main);font-size:14px;cursor:pointer;display:flex;align-items:center;text-align:left;position:relative}.category-select-label{flex:1}.category-select-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.category-select-options{position:absolute;margin-top:6px;width:100%;background:var(--bg-main);border:1px solid var(--border-color);border-radius:10px;overflow:hidden;z-index:50;box-shadow:var(--shadow-sm)}.category-select-option{padding:10px 14px;font-size:14px;cursor:pointer;display:flex;align-items:center;color:var(--text-main)}.category-select-option.active{background:var(--bg-hover)}.option-row{display:flex;width:100%;justify-content:space-between}.option-check{color:var(--accent-color)}.role-field{position:relative}.combobox-container{position:relative;width:100%}.combobox-trigger{position:relative;display:flex;align-items:center}.combobox-input{width:100%;height:42px;padding:0 40px 0 12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-main)}.combobox-button{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.combobox-options{position:absolute;top:calc(100% + 4px);left:0;width:100%;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;max-height:160px;overflow-y:auto;z-index:9999}.combobox-item{padding:8px 12px;cursor:pointer}.combobox-item.active{background:var(--accent-color);color:#fff}.unlock-backdrop{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999}.unlock-card{background:linear-gradient(180deg,#1e2633,#141a24);padding:32px;border-radius:18px;width:360px;text-align:center;color:#fff;box-shadow:0 20px 60px #0009;animation:scaleIn .2s ease}.unlock-icon{font-size:32px;margin-bottom:10px}.unlock-card h2{margin:0;font-size:20px}.unlock-card p{font-size:13px;color:#9aa4b2;margin:8px 0 18px}.unlock-card input,.unlock-card button{box-sizing:border-box}.unlock-card input{width:100%;color:var(--text-main)!important;background:var(--bg-card);padding:12px;border-radius:10px;border:none;outline:none;font-size:14px;margin-bottom:16px;box-sizing:border-box}.unlock-card button{width:100%;padding:12px;border-radius:12px;border:none;font-size:14px;font-weight:500;cursor:pointer;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;box-sizing:border-box}.unlock-card button:disabled{opacity:.6;cursor:not-allowed}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.initials-avatar{width:90px;height:90px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600}.avatar-section{text-align:center;margin-bottom:25px}.twofa-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.status-badge{padding:6px 14px;border-radius:10px;font-size:13px;font-weight:600}.status-badge.enabled{background:#22c55e26;color:#22c55e}.status-badge.disabled{background:#ef444426;color:#ef4444}.security-skeleton .skeleton-row{display:flex;justify-content:space-between;align-items:center}.skeleton-btn{width:120px;height:38px;background:var(--bg-soft);border-radius:12px;animation:pulse 1.4s infinite}.skeleton-status{width:80px;height:20px;background:var(--bg-soft);border-radius:20px;animation:pulse 1.4s infinite}@keyframes pulse{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.modal-backdrop{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center}.modal-card{width:450px;background:var(--bg-card);border-radius:18px;padding:28px;border:1px solid var(--border-soft);text-align:center}.twofa-qr-preview{width:180px;height:180px;margin:18px auto;display:block}.btn-primary{background:var(--primary);color:#fff;padding:11px 22px;border-radius:12px;border:none;font-weight:500;cursor:pointer}.btn-danger{background:#ef4444;color:#fff;padding:11px 22px;border-radius:12px;border:none;font-weight:500;cursor:pointer}.landing-wrapper{width:100%;padding:0;background:var(--bg-main);color:var(--text-main)}.landing-header{height:80px;padding:0 40px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-main);z-index:50}.landing-logo img{height:30px}.landing-nav{display:flex;align-items:center;gap:14px}.landing-login{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border:none;padding:12px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;margin-top:0!important}.landing-register-btn{padding:8px 18px;background:var(--accent-color);color:var(--text-main);border-radius:10px;border:none;cursor:pointer;font-weight:500;transition:.2s ease;font-size:15px}.landing-register-btn:hover{opacity:.85}.landing-toggle{width:38px;height:38px;border-radius:50%;border:none;background:var(--bg-soft);color:var(--text-main);display:flex;align-items:center;justify-content:center;cursor:pointer}.landing-toggle:hover{background:var(--border-hover)}.hero-section{padding:40px 20px 60px;text-align:center;max-width:900px;margin:auto}.hero-title{font-size:48px;font-weight:700;margin-bottom:14px;color:var(--text-main)}.hero-secured{color:var(--accent-color);font-size:22px;display:inline-block;margin-left:6px}.hero-subtitle{font-size:17px;color:var(--text-muted);margin:0 auto}.hero-cta{padding:12px 26px;font-size:16px;background:var(--accent-color);color:#fff;border-radius:12px;border:none;cursor:pointer;transition:.2s ease}.hero-cta:hover{opacity:.85}.hero-image-wrap{display:flex;justify-content:center}.hero-image{width:400px;max-width:95%;border-radius:20px}.features-section{padding:0 20px;max-width:1200px;margin:0 auto;text-align:center}.section-title{font-size:34px;font-weight:700;margin-bottom:10px;color:var(--text-main)}.section-subtitle{font-size:16px;color:var(--text-muted);margin-bottom:40px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px;margin-top:20px}.feature-card{background:var(--bg-card);border:1px solid var(--border-color);padding:28px 24px;border-radius:18px;text-align:left;transition:.25s ease;box-shadow:0 4px 16px #0000000a}.feature-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px #00000014;border-color:var(--accent-color)}.feature-icon{font-size:28px;margin-bottom:12px}.feature-card h3{margin-bottom:10px;font-size:20px;color:var(--text-main)}.feature-card p{color:var(--text-muted);line-height:1.5;font-size:15px}.security-section{padding:40px 20px 0;text-align:center}.security-title{font-size:28px;font-weight:700;margin-bottom:30px;color:var(--text-primary)}.security-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;max-width:900px;margin:0 auto}.security-badge{padding:10px 18px;border-radius:10px;background:var(--card-bg);color:var(--text-primary);font-size:15px;font-weight:500;display:flex;align-items:center;gap:6px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);transition:.2s ease}.security-badge:hover{transform:translateY(-3px);box-shadow:var(--card-shadow-hover)}.cta-section{text-align:center;padding:30px 20px;margin-top:60px;background:var(--bg-main)}.cta-title{font-size:2.4rem;font-weight:700;margin-bottom:12px;color:var(--text-main)}.cta-subtitle{max-width:620px;margin:0 auto 32px;font-size:1.1rem;color:var(--text-muted)}.cta-btn{padding:14px 28px;font-size:1.1rem;border-radius:12px}.faq-section{padding:30px 20px 60px;max-width:900px;margin:auto}.faq-title{text-align:center;font-size:2.2rem;font-weight:700;margin-bottom:40px;color:var(--text-main)}.faq-list{display:flex;flex-direction:column;gap:28px}.faq-item{background:var(--bg-card);border:1px solid var(--border-color);padding:22px;border-radius:14px}.faq-question{font-size:1.25rem;font-weight:600;margin-bottom:8px;color:var(--text-main)}.faq-answer{color:var(--text-muted);font-size:1rem;line-height:1.55}.landing-footer{padding:60px 20px 30px;background:var(--bg-card);border-top:1px solid var(--border-color)}.footer-top{max-width:1200px;margin:auto;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:30px}.footer-left{max-width:300px}.footer-logo{width:150px;opacity:.95;margin-bottom:12px}.footer-tagline{color:var(--text-muted);font-size:.95rem;line-height:1.5}.footer-links{display:flex;flex-direction:column;gap:10px}.footer-links a{color:var(--text-main);text-decoration:none;font-size:.95rem;transition:opacity .2s}.footer-links a:hover{opacity:.7}.footer-social{display:flex;gap:14px}.footer-social a{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--bg-secondary);border:1px solid var(--border-color);font-weight:600;color:var(--text-main);text-decoration:none;transition:.2s}.footer-social a:hover{background:var(--bg-hover)}.footer-bottom{margin-top:40px;text-align:center;color:var(--text-muted);font-size:.85rem}.logo-desktop{display:block}.logo-mobile{display:none;width:40px;height:40px!important}@media(max-width:768px){.logo-desktop{display:none}.logo-mobile{display:block}}.forgot-warning{background:var(--bg-card);padding:14px;border-radius:10px;font-size:14px;line-height:1.4;color:var(--text-main);border-left:4px solid #e63946;margin-bottom:20px}.forgot-warning span{color:#e63946;font-weight:600}.forgot-success{text-align:center;color:var(--text-main)}.forgot-success h3{margin-bottom:6px;font-size:20px}.forgot-success p{opacity:.7;margin-bottom:20px}.legal-page{min-height:100vh;background:var(--bg);display:flex;justify-content:center;padding:40px 16px;position:relative}.legal-theme-toggle{position:absolute;top:20px;right:20px;background:var(--card-bg);border:1px solid var(--border);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.legal-card{max-width:760px;width:100%;background:var(--card-bg);padding:32px;border-radius:16px;box-shadow:0 8px 28px #00000014}.legal-logo{width:160px;margin:0 auto 20px;display:block}.legal-footer-text{margin-top:30px;text-align:center;font-size:14px;opacity:.7}@media(max-width:600px){.legal-card{padding:24px;border-radius:12px}.legal-logo{width:130px}h1{font-size:22px}h2{font-size:18px}}html{font-size:15px;scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:Plus Jakarta Sans,system-ui,sans-serif;background:var(--bg-main);color:var(--text-main);transition:background .3s,color .3s}h1{font-size:28px;font-weight:600}p,span,label{font-size:14px}.primary-btn{background:linear-gradient(135deg,#2563eb,#3b82f6);border:none;color:#fff;padding:10px 18px;border-radius:12px;font-weight:500;cursor:pointer}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.secondary-btn{background:var(--bg-soft);border:1px solid var(--border-soft);color:var(--text-main);padding:10px 16px;border-radius:12px;cursor:pointer}.secondary-btn:hover{background:#0000000a}.login-btn.secondary{background:transparent;border:1px solid var(--border-soft);color:var(--text-main);margin-top:12px}.form-field{display:flex;flex-direction:column;margin-bottom:16px}.form-field label{font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.form-field input,.form-field select{width:100%;background:var(--bg-soft);border:1px solid var(--border-soft);color:var(--text-main);padding:12px 14px;border-radius:12px;font-size:14px;outline:none}.form-field input::placeholder{color:var(--text-muted);opacity:.75}.form-field input:focus,.form-field select:focus{border-color:var(--primary)}.eye-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted)}.modal-backdrop{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1300}[data-theme=dark] .modal-backdrop{background:#000000a6}.vault-modal{width:100%;max-width:420px;background:var(--bg-card);border-radius:18px;padding:26px;color:var(--text-main);border:1px solid var(--border-soft);box-shadow:0 30px 60px #00000040}[data-theme=dark] .vault-modal{background:linear-gradient(180deg,#1e293bf2,#0f172af2)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;margin-bottom:20px;border-bottom:1px solid var(--border-soft)}.modal-header h2{font-size:18px;font-weight:600}.modal-header button{background:none;border:none;cursor:pointer;color:var(--text-muted)}.modal-header button:hover{color:var(--text-main)}.modal-field{display:flex;flex-direction:column;margin-bottom:16px}.modal-field label{font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.modal-field input,.modal-field select{width:100%;background:var(--bg-soft);border:1px solid var(--border-soft);color:var(--text-main);padding:12px 14px;border-radius:12px;font-size:14px;outline:none}.modal-field input::placeholder{color:var(--text-muted);opacity:.75}.modal-field input:focus,.modal-field select:focus{border-color:var(--primary)}.password-wrapper{position:relative}.password-wrapper input{padding-right:42px}.eye-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center}.eye-btn:hover{color:var(--text-main)}[data-theme=dark] .eye-btn{color:#cbd5f5}[data-theme=dark] .eye-btn:hover{color:#fff}.modal-error{background:#ef444426;color:#b91c1c;border:1px solid rgba(239,68,68,.3);padding:10px;border-radius:10px;font-size:13px;margin-bottom:14px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:18px}.confirm-modal{max-width:420px}.confirm-body{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:10px 6px 20px}.confirm-body p{font-size:14px;color:var(--text-main);line-height:1.5}.danger-icon{color:#ef4444}.danger-btn{background:linear-gradient(135deg,#dc2626,#ef4444)}.danger-btn:hover{opacity:.95}.user-modal{max-width:450px}.user-modal .modal-subtitle{margin:12px 0 18px;font-size:14px;color:var(--text-muted)}.user-modal .input-icon{display:flex;align-items:center;gap:10px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:12px;padding:0 14px}.user-modal .input-icon input{border:none;background:none;padding:12px 0;color:var(--text-main);width:100%}.user-modal .input-icon input:focus{outline:none}.user-modal .input-icon svg{color:var(--text-muted)}.user-modal .permission-group{display:flex;gap:10px}.user-modal .perm-btn{flex:1;padding:10px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:12px;color:var(--text-main);cursor:pointer;font-size:14px}.user-modal .perm-btn.active{background:linear-gradient(135deg,#2563eb,#3b82f6);border-color:transparent;color:#fff}.user-modal .custom-date-input{position:relative}.user-modal .custom-date-input input{width:100%;padding:12px 36px 12px 14px;cursor:pointer}.user-modal .clear-date-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer}.user-modal .clear-date-btn:hover{color:var(--text-main)}.user-modal .quick-expiry{display:flex;gap:10px;margin-top:8px}.user-modal .quick-expiry button{flex:1;padding:8px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:10px;cursor:pointer;font-size:13px;color:var(--text-main)}.user-modal .quick-expiry button:hover{background:#3b82f61a}.user-modal .calendar-popup{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:2000;max-height:220px;overflow-y:auto;background:var(--bg-main);border:1px solid var(--border-soft);border-radius:12px;padding:8px;display:grid;grid-template-columns:repeat(2,1fr);gap:6px;box-shadow:0 10px 30px #00000026}.access-list{margin-top:12px;display:flex;flex-direction:column;gap:10px}.access-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:10px;background:var(--bg-soft)}.access-user{display:flex;gap:10px;align-items:center}.access-name{font-weight:600}.access-email{font-size:13px;color:var(--text-muted)}.icon-btn.danger{color:#ef4444}.tooltip-wrapper{position:relative}.tooltip{position:absolute;bottom:120%;left:50%;transform:translate(-50%);background:#020617;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;opacity:0;pointer-events:none;white-space:nowrap}.tooltip-wrapper:hover .tooltip{opacity:1}.dashboard-page{padding:12px}.dashboard-title{font-size:clamp(20px,4vw,28px);font-weight:600;margin-bottom:24px;color:var(--text-main)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.stat-card{background:var(--bg-card);border-radius:16px;padding:20px;display:flex;gap:16px;align-items:center;border:1px solid var(--border-soft)}.stat-card p{font-size:16px;color:var(--text-muted);margin-bottom:4px}.stat-card h2{font-size:26px;font-weight:600;color:var(--text-main)}.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-icon.blue{background:#3b82f626;color:#2563eb}.stat-icon.purple{background:#8b5cf626;color:#7c3aed}.stat-icon.yellow{background:#eab3082e;color:#ca8a04}[data-theme=dark] .stat-card{background:#ffffff0d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.chart-card{margin-top:32px;background:var(--bg-card);padding:22px;border-radius:14px;border:1px solid var(--border-soft)}.chart-card h3{margin-bottom:16px;font-size:15px;font-weight:600}.settings-title{font-size:24px;font-weight:600;margin-bottom:18px}.settings-card{background:var(--bg-card);border:1px solid var(--border-soft);border-radius:18px;padding:28px}.avatar-section{display:flex;align-items:center;gap:22px;margin-bottom:28px}.avatar-section img{width:96px;height:96px;border-radius:50%;object-fit:cover;border:1px solid var(--border-soft)}.avatar-upload{color:var(--primary);font-size:14px;cursor:pointer;font-weight:500}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-bottom:26px}.input-group label{display:block;font-size:13px;margin-bottom:6px;color:var(--text-soft)}.input-group input{width:100%;padding:11px 14px;border-radius:12px;border:1px solid var(--border-soft);background:var(--bg-main);color:var(--text-main)}.input-group input:disabled{opacity:.6;cursor:not-allowed}.primary-btn{background:var(--primary);color:#fff;padding:11px 22px;border-radius:12px;border:none;font-weight:500;cursor:pointer}.primary-btn:disabled{opacity:.7;cursor:not-allowed}.settings-loading{padding:30px;opacity:.7}.users-toolbar{display:flex;gap:14px;margin:18px 0}.users-search input{height:40px;padding:0 14px;border-radius:10px;border:1px solid var(--border-soft);background:var(--bg-card);color:var(--text-main);font-size:14px;outline:none}[data-theme=dark] .users-search input{background:var(--bg-card)}.users-search input{width:220px}.users-filter select{width:140px;cursor:pointer}.users-search input:focus,.users-filter select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #6366f11f}.role-select-trigger{height:40px;min-width:140px;padding:0 14px;border-radius:12px;border:1px solid var(--border-soft);background:var(--bg-card);color:var(--text-main);display:flex;justify-content:space-between;align-items:center}.role-select-content{background:var(--bg-card);border-radius:14px;border:1px solid var(--border-soft);padding:6px;box-shadow:0 20px 40px #00000073}.role-select-item{padding:8px 12px;border-radius:10px;cursor:pointer}.role-select-item[data-state=checked]{background:#6366f12e;color:#a5b4fc}[data-theme=dark] .role-select-content{background:#0b1220}.role-badge{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500}.role-badge.admin{background:#ef444426;color:#ef4444}.role-badge.user{background:#22c55e26;color:#22c55e}.pagination-root{display:flex;align-items:center;gap:10px;justify-content:center;margin-top:20px}.pagination-btn,.pagination-page{width:36px;height:36px;border-radius:10px;border:1px solid var(--border-soft);background:var(--bg-card);color:var(--text-main);display:flex;align-items:center;justify-content:center;cursor:pointer}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-page.active{background:var(--primary);color:#fff;border-color:var(--primary)}.w-40{width:40%}.w-60{width:60%}.w-80{width:80%}.w-50{width:50%}.w-100{width:100%}[data-theme=light] .role-select-item[data-state=checked]{background:var(--bg-soft);color:var(--text-main);font-weight:500}@media(max-width:768px){.settings-card{padding:20px;border-radius:14px}.avatar-section{flex-direction:column;align-items:center;text-align:center;gap:14px}.avatar-section img{width:110px;height:110px}.avatar-upload{padding:8px 14px;background:var(--bg-soft);border-radius:8px;font-size:14px}.form-grid{grid-template-columns:1fr!important;gap:16px}.input-group input{font-size:15px;padding:12px 14px}.primary-btn,.save-btn{width:100%;margin-top:10px;padding:12px 0;font-size:15px}}@media(max-width:1024px){.form-grid{grid-template-columns:1fr 1fr}.avatar-section{gap:18px}}.settings-skeleton .skeleton-line,.settings-skeleton .skeleton-circle{background:var(--border-soft);opacity:.35;border-radius:10px;animation:pulse 1.6s infinite ease-in-out}.skeleton-circle{width:96px;height:96px;border-radius:50%}.avatar-skel{margin-right:20px}@keyframes pulse{0%{opacity:.35}50%{opacity:.15}to{opacity:.35}}.sidebar{width:240px;background:var(--bg-main);border-right:1px solid var(--border-soft);padding:8px 18px;display:flex;flex-direction:column;color:var(--text-main)}.sidebar-logo{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;margin-bottom:30px}.sidebar-logo img{width:200px;padding:12px 10px}.sidebar-nav{display:flex;flex-direction:column;gap:6px}.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:var(--text-muted);text-decoration:none;font-size:14px}.sidebar-nav a.active{background:#2563eb26;color:var(--text-main)}.sidebar-logout{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:none;border:none;color:var(--danger);cursor:pointer}.sidebar-toggle{display:none;position:fixed;top:14px;left:14px;z-index:1200;background:var(--bg-soft);border:none;border-radius:10px;padding:8px;color:var(--text-main)}.sidebar-close{display:none;position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-main)}@media(max-width:768px){.sidebar{position:fixed;inset:0 auto 0 0;z-index:1100;transform:translate(-100%);transition:transform .3s ease;padding-top:60px}.sidebar.open{transform:translate(0)}.sidebar-toggle{display:flex}.sidebar-close{display:block}}.page{padding:16px}.page-title{font-size:clamp(22px,4vw,28px);font-weight:600;margin-bottom:24px;color:var(--text-main)}html{font-size:15px}body{margin:0;min-width:320px;min-height:100vh;font-family:Plus Jakarta Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-main);background:var(--bg-main);transition:background .3s ease,color .3s ease}h1{font-size:28px;font-weight:600;letter-spacing:-.01em}h2{font-size:22px;font-weight:600}h3{font-size:16px;font-weight:600}p,span,label{font-size:14px;font-weight:400}[data-theme=dark]{--bg-main: radial-gradient(circle at top, #1b2735, #090a0f);--bg-card: rgba(255, 255, 255, .04);--bg-soft: rgba(255, 255, 255, .08);--text-main: #e5e7eb;--text-muted: #9ca3af;--border-soft: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--primary: #3b82f6;--danger: #ef4444}[data-theme=light]{--bg-main: linear-gradient(180deg, #f4f6fb, #e9edf5);--bg-card: #ffffff;--bg-soft: rgba(0, 0, 0, .05);--text-main: #0f172a;--text-muted: #475569;--border-soft: rgba(0, 0, 0, .08);--border-strong: rgba(0, 0, 0, .16);--primary: #2563eb;--danger: #dc2626}*{box-sizing:border-box}button{font-family:inherit}input{font-family:inherit;color:inherit}::placeholder{color:var(--text-muted)}html{scroll-behavior:smooth}.skeleton{position:relative;overflow:hidden;background:var(--bg-card)}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:shimmer 1.3s infinite}@keyframes shimmer{to{transform:translate(100%)}}.skeleton-icon{width:40px;height:40px;border-radius:10px;background:var(--border-soft)}.skeleton-lines{flex:1}.skeleton-line{height:12px;background:var(--border-soft);border-radius:6px;margin-bottom:8px}.skeleton-line.short{width:40%}.skeleton-line.long{width:70%}.skeleton-line.title{width:160px;height:14px;margin-bottom:20px}.skeleton-chart{height:260px;border-radius:12px;background:var(--border-soft)}
