:root{--color-bg:#f8f9fc;--color-sidebar:#0f172a;--color-sidebar-hover:#1e293b;--color-sidebar-active:#334155;--color-primary:#6366f1;--color-primary-hover:#4f46e5;--color-accent:#8b5cf6;--color-accent-hover:#7c3aed;--color-surface:#fff;--color-text:#1e293b;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-border:#e2e8f0;--color-green:#10b981;--color-green-bg:#ecfdf5;--color-amber:#f59e0b;--color-amber-bg:#fffbeb;--color-red:#ef4444;--color-red-bg:#fef2f2;--color-blue:#3b82f6;--color-blue-bg:#eff6ff;--color-purple:#8b5cf6;--color-purple-bg:#f5f3ff;--radius:12px;--radius-sm:8px;--radius-lg:16px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #00000014,0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000a;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--transition:0.15s ease;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f8f9fc;background:var(--color-bg);color:#1e293b;color:var(--color-text);line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:inherit}.hidden{display:none}.loading-screen{align-items:center;color:#64748b;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.loading-spinner{animation:spin .7s linear infinite;border:3px solid #e2e8f0;border-top-color:#6366f1;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:36px;width:36px}.layout{display:flex;min-height:100vh}.sidebar{background:#0f172a;background:var(--color-sidebar);bottom:0;color:#e2e8f0;display:flex;flex-direction:column;left:0;position:fixed;top:0;transition:transform .15s ease;transition:transform var(--transition);width:260px;z-index:100}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:12px;padding:24px 20px 20px}.sidebar-logo-icon{color:#6366f1;color:var(--color-primary);flex-shrink:0}.sidebar-brand{color:#fff;font-size:1.05rem;font-weight:700;line-height:1.2}.sidebar-tagline{color:#94a3b8;color:var(--color-text-muted);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.sidebar-close{background:none;border:none;color:#94a3b8;cursor:pointer;display:none;margin-left:auto}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:16px 12px}.sidebar-link{align-items:center;border-radius:8px;border-radius:var(--radius-sm);color:#cbd5e1;display:flex;font-size:.9rem;font-weight:500;gap:12px;padding:10px 14px;transition:all .15s ease;transition:all var(--transition)}.sidebar-link:hover{background:#1e293b;background:var(--color-sidebar-hover);color:#fff}.sidebar-link--active{background:#334155;background:var(--color-sidebar-active);color:#fff;font-weight:600}.sidebar-link--active:before{background:#6366f1;background:var(--color-primary);border-radius:0 4px 4px 0;content:"";height:20px;left:0;position:absolute;width:3px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.sidebar-plan{align-items:center;display:flex;justify-content:space-between}.sidebar-plan-label{color:#94a3b8;color:var(--color-text-muted);font-size:.78rem}.sidebar-plan-badge{background:#ffffff1a;border-radius:999px;color:#fff;font-size:.72rem;font-weight:700;padding:3px 10px;text-transform:capitalize}.plan-color--free{background:#475569}.plan-color--pro{background:#3b82f6;background:var(--color-blue)}.plan-color--pro_plus{background:#8b5cf6;background:var(--color-accent)}.plan-color--advanced{background:#f97316}.sidebar-overlay{background:#00000080;display:none;inset:0;position:fixed;z-index:99}.main-area{display:flex;flex:1 1;flex-direction:column;margin-left:260px;min-height:100vh}.topbar{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd9;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);display:flex;gap:16px;padding:12px 32px;position:sticky;top:0;z-index:50}.topbar-menu{background:none;border:none;color:#1e293b;color:var(--color-text);cursor:pointer;display:none}.topbar-search{flex:1 1;max-width:420px;position:relative}.topbar-search-icon{color:#94a3b8;color:var(--color-text-muted);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.topbar-search input{background:#f8f9fc;background:var(--color-bg);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius);color:#1e293b;color:var(--color-text);font-size:.88rem;outline:none;padding:9px 12px 9px 38px;transition:border-color .15s ease,box-shadow .15s ease;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.topbar-search input:focus{border-color:#6366f1;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11f}.topbar-profile{align-items:center;display:flex;gap:10px;margin-left:auto}.topbar-avatar{background:#6366f1;background:var(--color-primary);border-radius:50%;color:#fff;display:grid;font-size:.82rem;font-weight:700;height:34px;place-items:center;width:34px}.topbar-username{color:#1e293b;color:var(--color-text);font-size:.88rem;font-weight:600}.search-results-dropdown{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;box-shadow:var(--shadow-lg);left:32px;max-height:320px;overflow-y:auto;position:absolute;top:60px;width:420px;z-index:60}.search-results-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);color:#64748b;color:var(--color-text-secondary);display:flex;font-size:.82rem;justify-content:space-between;padding:10px 16px}.search-results-header button{background:none;border:none;color:#94a3b8;color:var(--color-text-muted);cursor:pointer}.search-result-item{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);cursor:pointer;display:flex;font-size:.88rem;gap:10px;padding:10px 16px;transition:background .15s ease;transition:background var(--transition)}.search-result-item:hover{background:#f8f9fc;background:var(--color-bg)}.search-result-type{background:#6366f114;border-radius:4px;color:#6366f1;color:var(--color-primary);font-size:.7rem;font-weight:700;padding:2px 8px;text-transform:uppercase}.search-empty{color:#94a3b8;color:var(--color-text-muted);font-size:.88rem;padding:20px 16px;text-align:center}.page-content{flex:1 1;max-width:1200px;padding:32px;width:100%}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.page-title{color:#1e293b;color:var(--color-text);font-size:1.65rem;font-weight:750;line-height:1.2}.page-subtitle{color:#64748b;color:var(--color-text-secondary);font-size:.92rem;margin-top:4px}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:.88rem;font-weight:600;gap:6px;padding:9px 18px;transition:all .15s ease;transition:all var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn--primary{background:#6366f1;background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:#4f46e5;background:var(--color-primary-hover)}.btn--accent{background:#8b5cf6;background:var(--color-accent);color:#fff}.btn--accent:hover:not(:disabled){background:#7c3aed;background:var(--color-accent-hover)}.btn--ghost{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--color-border);color:#64748b;color:var(--color-text-secondary)}.btn--ghost:hover:not(:disabled){background:#f8f9fc;background:var(--color-bg);border-color:#94a3b8;border-color:var(--color-text-muted)}.btn--sm{font-size:.8rem;padding:6px 12px}.btn--full{justify-content:center;padding:12px;width:100%}.badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.72rem;font-weight:700;letter-spacing:.03em;padding:3px 10px;text-transform:uppercase}.badge--green{background:#ecfdf5;background:var(--color-green-bg);color:#059669}.badge--amber{background:#fffbeb;background:var(--color-amber-bg);color:#d97706}.badge--red{background:#fef2f2;background:var(--color-red-bg);color:#dc2626}.badge--blue{background:#eff6ff;background:var(--color-blue-bg);color:#2563eb}.badge--gray{background:#f1f5f9;color:#475569}.card{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:16px;border-radius:var(--radius-lg);overflow:hidden}.card-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:18px 22px}.card-header h3{font-size:.95rem;font-weight:700}.card-link{align-items:center;color:#6366f1;color:var(--color-primary);display:inline-flex;font-size:.82rem;font-weight:600;gap:4px}.card-link:hover{text-decoration:underline}.card-body{padding:18px 22px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:28px}.stats-grid--2{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.stat-card{align-items:center;background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius);display:flex;gap:16px;padding:20px;transition:box-shadow .15s ease;transition:box-shadow var(--transition)}.stat-card:hover{box-shadow:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000a;box-shadow:var(--shadow-md)}.stat-icon-wrap{border-radius:12px;border-radius:var(--radius);display:grid;flex-shrink:0;height:44px;place-items:center;width:44px}.stat-card--blue .stat-icon-wrap{background:#eff6ff;background:var(--color-blue-bg);color:#3b82f6;color:var(--color-blue)}.stat-card--purple .stat-icon-wrap{background:#f5f3ff;background:var(--color-purple-bg);color:#8b5cf6;color:var(--color-purple)}.stat-card--amber .stat-icon-wrap{background:#fffbeb;background:var(--color-amber-bg);color:#f59e0b;color:var(--color-amber)}.stat-card--green .stat-icon-wrap{background:#ecfdf5;background:var(--color-green-bg);color:#10b981;color:var(--color-green)}.stat-value{font-size:1.5rem;font-weight:800;line-height:1.2}.stat-label{color:#64748b;color:var(--color-text-secondary);font-size:.82rem;margin-top:2px}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(380px,1fr))}.data-table{border-collapse:collapse;font-size:.88rem;width:100%}.data-table th{color:#94a3b8;color:var(--color-text-muted);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:0 12px 12px 0;text-align:left;text-transform:uppercase}.data-table td{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border);padding:10px 12px 10px 0;vertical-align:middle}.td-bold{font-weight:600}.healthscore-bar,.healthscore-bar-lg{background:#e2e8f0;background:var(--color-border);border-radius:999px;overflow:hidden}.healthscore-bar{display:inline-block;height:6px;margin-right:8px;vertical-align:middle;width:60px}.healthscore-bar-lg{height:8px;margin:6px 0 4px;width:100%}.healthscore-fill{background:#10b981;background:var(--color-green);border-radius:999px;height:100%;transition:width .3s}.healthscore-value{color:#64748b;color:var(--color-text-secondary);font-size:.78rem;font-weight:700}.reminder-list{display:flex;flex-direction:column;gap:0;list-style:none}.reminder-item{align-items:flex-start;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);display:flex;gap:12px;padding:12px 0}.reminder-item:last-child{border-bottom:none}.reminder-dot{border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.reminder-dot--red{background:#ef4444;background:var(--color-red)}.reminder-dot--amber{background:#f59e0b;background:var(--color-amber)}.reminder-dot--green{background:#10b981;background:var(--color-green)}.reminder-content{flex:1 1;min-width:0}.reminder-message{font-size:.88rem;font-weight:500;margin-bottom:2px}.reminder-date{font-size:.78rem}.empty-state,.reminder-date{color:#94a3b8;color:var(--color-text-muted)}.empty-state{font-size:.88rem;padding:20px 0;text-align:center}.empty-state-card{align-items:center;background:#fff;background:var(--color-surface);border:2px dashed #e2e8f0;border:2px dashed var(--color-border);border-radius:16px;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:12px;margin-top:12px;padding:60px 24px;text-align:center}.empty-state-icon{color:#94a3b8;color:var(--color-text-muted)}.empty-state-card h3{font-size:1.1rem;font-weight:700}.empty-state-card p{color:#64748b;color:var(--color-text-secondary);font-size:.9rem;max-width:360px}.device-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.device-card{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius);display:flex;flex-direction:column;gap:14px;padding:20px;transition:box-shadow .15s ease,transform .15s ease;transition:box-shadow var(--transition),transform var(--transition)}.device-card:hover{box-shadow:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.device-card-header{align-items:center;display:flex;gap:12px}.device-icon-wrap{background:#eff6ff;background:var(--color-blue-bg);border-radius:8px;border-radius:var(--radius-sm);color:#3b82f6;color:var(--color-blue);display:grid;flex-shrink:0;height:40px;place-items:center;width:40px}.device-name{font-size:.95rem;font-weight:700}.device-meta{color:#94a3b8;color:var(--color-text-muted);font-size:.78rem}.device-card-header .badge{margin-left:auto}.device-details{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.device-detail{display:flex;flex-direction:column}.device-detail-label{color:#94a3b8;color:var(--color-text-muted);font-size:.72rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.device-detail span:last-child{font-size:.88rem}.device-health{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.device-health .healthscore-bar-lg{flex:1 1;min-width:80px}.device-residual{align-items:center;background:#f8f9fc;background:var(--color-bg);border-radius:8px;border-radius:var(--radius-sm);color:#64748b;color:var(--color-text-secondary);display:flex;font-size:.82rem;gap:6px;padding:8px 12px}.device-actions{display:flex;gap:8px;margin-top:auto}.reminders-list{display:flex;flex-direction:column;gap:10px}.reminder-card{align-items:flex-start;background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border-left:4px solid #e2e8f0;border:1px solid var(--color-border);border-left-width:4px;border-radius:12px;border-radius:var(--radius);display:flex;gap:16px;justify-content:space-between;padding:18px 20px;transition:box-shadow .15s ease;transition:box-shadow var(--transition)}.reminder-card:hover{box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm)}.reminder-card--high{border-left-color:#ef4444;border-left-color:var(--color-red)}.reminder-card--medium{border-left-color:#f59e0b;border-left-color:var(--color-amber)}.reminder-card--low{border-left-color:#10b981;border-left-color:var(--color-green)}.reminder-card-left{align-items:flex-start;display:flex;flex:1 1;gap:14px}.reminder-priority{border-radius:999px;flex-shrink:0;font-size:.7rem;font-weight:700;margin-top:2px;padding:3px 10px;text-transform:uppercase;white-space:nowrap}.reminder-priority--high{background:#fef2f2;background:var(--color-red-bg);color:#ef4444;color:var(--color-red)}.reminder-priority--medium{background:#fffbeb;background:var(--color-amber-bg);color:#f59e0b;color:var(--color-amber)}.reminder-priority--low{background:#ecfdf5;background:var(--color-green-bg);color:#10b981;color:var(--color-green)}.reminder-card-message{font-size:.92rem;font-weight:600;margin-bottom:6px}.reminder-card-meta{color:#64748b;color:var(--color-text-secondary);display:flex;flex-wrap:wrap;font-size:.8rem;gap:16px}.reminder-card-actions{flex-shrink:0}.subscription-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.subscription-card{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius);display:flex;flex-direction:column;gap:10px;padding:20px;transition:box-shadow .15s ease;transition:box-shadow var(--transition)}.subscription-card:hover{box-shadow:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000a;box-shadow:var(--shadow-md)}.subscription-card-header{align-items:center;display:flex;gap:10px}.subscription-icon-wrap{background:#f5f3ff;background:var(--color-purple-bg);border-radius:8px;border-radius:var(--radius-sm);color:#8b5cf6;color:var(--color-purple);display:grid;flex-shrink:0;height:36px;place-items:center;width:36px}.subscription-card-header h4{flex:1 1;font-size:.95rem;font-weight:700}.subscription-amount{color:#1e293b;color:var(--color-text);font-size:1.5rem;font-weight:800}.subscription-amount span{font-weight:500}.subscription-amount span,.subscription-renewal{color:#64748b;color:var(--color-text-secondary);font-size:.82rem}.subscription-renewal{align-items:center;display:flex;gap:6px}.subscription-source{color:#94a3b8;color:var(--color-text-muted);font-size:.78rem}.vault-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.vault-card{align-items:center;background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius);cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:22px 18px;text-align:center;transition:box-shadow .15s ease,transform .15s ease;transition:box-shadow var(--transition),transform var(--transition)}.vault-card:hover{box-shadow:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.vault-card-icon{background:#f8f9fc;background:var(--color-bg);border-radius:12px;border-radius:var(--radius);color:#6366f1;color:var(--color-primary);display:grid;height:56px;place-items:center;width:56px}.vault-card-name{font-size:.88rem;font-weight:700;word-break:break-word}.vault-card-meta{word-break:break-all}.vault-card-date,.vault-card-meta{color:#94a3b8;color:var(--color-text-muted);font-size:.75rem}.pricing-page-header{margin-bottom:36px;text-align:center}.pricing-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:28px}.pricing-card{background:#fff;background:var(--color-surface);border:2px solid #e2e8f0;border:2px solid var(--color-border);border-radius:16px;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:16px;padding:28px 24px 24px;position:relative;transition:box-shadow .15s ease,transform .15s ease;transition:box-shadow var(--transition),transform var(--transition)}.pricing-card:hover{box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.pricing-card--active{border-color:#6366f1;border-color:var(--color-primary)}.pricing-card--popular{background:linear-gradient(180deg,#f5f3ff,#fff 40%);background:linear-gradient(180deg,var(--color-purple-bg) 0,var(--color-surface) 40%);border-color:#8b5cf6;border-color:var(--color-accent)}.pricing-badge{align-items:center;background:#8b5cf6;background:var(--color-accent);border-radius:999px;color:#fff;display:inline-flex;font-size:.72rem;font-weight:700;gap:4px;left:20px;letter-spacing:.04em;padding:4px 14px;position:absolute;text-transform:uppercase;top:-13px}.pricing-badge--active{background:#6366f1;background:var(--color-primary)}.pricing-plan-name{font-size:1.1rem;font-weight:700}.pricing-price{align-items:baseline;display:flex;gap:2px}.pricing-amount{font-size:2rem;font-weight:800}.pricing-period{color:#64748b;color:var(--color-text-secondary);font-size:.92rem}.pricing-features{display:flex;flex:1 1;flex-direction:column;gap:8px;list-style:none}.pricing-features li{align-items:flex-start;color:#64748b;color:var(--color-text-secondary);display:flex;font-size:.88rem;gap:8px}.pricing-check{color:#6366f1;color:var(--color-primary);flex-shrink:0;margin-top:2px}.pricing-manage{margin-bottom:16px;text-align:center}.pricing-footer{color:#94a3b8;color:var(--color-text-muted);font-size:.82rem;text-align:center}.billing-alert{border-radius:12px;border-radius:var(--radius);font-size:.9rem;font-weight:600;margin-bottom:24px;padding:14px 20px}.billing-alert--success{background:#ecfdf5;background:var(--color-green-bg);color:#059669}.billing-alert--info{background:#eff6ff;background:var(--color-blue-bg);color:#2563eb}.billing-alert--error{background:#fef2f2;background:var(--color-red-bg);color:#dc2626}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;display:grid;inset:0;padding:20px;place-items:center;position:fixed;z-index:200}.modal{background:#fff;background:var(--color-surface);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;padding:28px;width:min(480px,100%)}.modal-title{font-size:1.15rem;font-weight:750;margin-bottom:22px}.form{gap:16px}.form,.form-group{display:flex;flex-direction:column}.form-group{flex:1 1;gap:5px}.form-group label{color:#64748b;color:var(--color-text-secondary);font-size:.8rem;font-weight:600}.form-group input,.form-group select{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-sm);color:#1e293b;color:var(--color-text);font-size:.88rem;outline:none;padding:9px 12px;transition:border-color .15s ease,box-shadow .15s ease;transition:border-color var(--transition),box-shadow var(--transition)}.form-group input:focus,.form-group select:focus{border-color:#6366f1;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11f}.form-row{display:flex;gap:12px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}@media (max-width:860px){.sidebar{transform:translateX(-100%)}.sidebar--open{transform:translateX(0)}.sidebar-close,.sidebar-overlay{display:block}.main-area{margin-left:0}.topbar-menu{display:block}.page-content{padding:20px 16px}.topbar{padding:12px 16px}.dashboard-grid,.device-grid{grid-template-columns:1fr}.pricing-grid{grid-template-columns:repeat(2,1fr)}.form-row{flex-direction:column}.stats-grid,.subscription-grid,.vault-grid{grid-template-columns:repeat(2,1fr)}.search-results-dropdown{left:16px;right:16px;width:auto}}@media (max-width:560px){:root{font-size:15px}.page-content{padding:16px 12px 80px}.topbar{gap:10px;padding:10px 12px}.topbar-username{display:none}.topbar-search input{font-size:.85rem;padding:8px 10px 8px 34px}.page-header{flex-direction:column;gap:10px;margin-bottom:20px}.page-title{font-size:1.35rem}.page-subtitle{font-size:.85rem}.stats-grid{gap:10px;grid-template-columns:1fr 1fr;margin-bottom:20px}.stat-card{gap:10px;padding:14px}.stat-icon-wrap{height:36px;width:36px}.stat-value{font-size:1.2rem}.stat-label{font-size:.75rem}.dashboard-grid{gap:14px}.card-body,.card-header{padding:14px 16px}.data-table{font-size:.82rem}.data-table th{font-size:.7rem}.device-grid{gap:12px;grid-template-columns:1fr}.device-card{gap:12px;padding:16px}.device-details{gap:6px;grid-template-columns:1fr 1fr}.device-actions{flex-wrap:wrap}.device-actions .btn{flex:1 1;font-size:.78rem;justify-content:center;padding:8px 10px}.reminders-list{gap:8px}.reminder-card{border-left-width:3px;flex-direction:column;gap:10px;padding:14px}.reminder-card-left{gap:10px}.reminder-card-meta{font-size:.75rem;gap:8px}.reminder-card-actions{align-self:flex-end}.subscription-grid{gap:12px;grid-template-columns:1fr}.subscription-card{padding:16px}.vault-grid{gap:10px;grid-template-columns:repeat(2,1fr)}.vault-card{padding:16px 12px}.vault-card-icon{height:44px;width:44px}.pricing-grid{gap:14px;grid-template-columns:1fr}.pricing-card{padding:22px 18px 18px}.modal-overlay{padding:12px}.modal{border-radius:12px;border-radius:var(--radius);padding:20px}.modal-title{font-size:1.05rem;margin-bottom:16px}.form-group input,.form-group select{padding:10px 12px}.search-results-dropdown{left:12px;right:12px;top:54px;width:auto}.mobile-nav{display:flex}}.mobile-nav{align-items:center;background:#fff;background:var(--color-surface);border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border);bottom:0;box-shadow:0 -2px 10px #0000000f;display:none;justify-content:space-around;left:0;padding:6px 0 max(6px,env(safe-area-inset-bottom));position:fixed;right:0;z-index:110}.mobile-nav-item{-webkit-tap-highlight-color:transparent;align-items:center;background:none;border:none;color:#94a3b8;color:var(--color-text-muted);cursor:pointer;display:flex;flex-direction:column;font-size:.65rem;font-weight:600;gap:2px;padding:4px 8px;text-decoration:none;transition:color .15s ease;transition:color var(--transition)}.mobile-nav-item--active,.mobile-nav-item:hover{color:#6366f1;color:var(--color-primary)}@media (hover:none) and (pointer:coarse){.btn{min-height:44px;min-width:44px}.sidebar-link{padding:12px 14px}.topbar-search input{min-height:42px}.device-card:hover,.pricing-card:hover,.subscription-card:hover,.vault-card:hover{box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow);transform:none}}@supports (padding:env(safe-area-inset-top)){.topbar{padding-top:max(12px,env(safe-area-inset-top))}.page-content{padding-bottom:max(80px,calc(70px + env(safe-area-inset-bottom)))}}.pull-refresh-indicator{align-items:center;color:#6366f1;color:var(--color-primary);display:flex;font-size:.85rem;font-weight:600;gap:8px;justify-content:center;opacity:0;padding:12px;transition:opacity .2s}.pull-refresh-indicator--visible{opacity:1}.install-banner{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000a;box-shadow:var(--shadow-md);color:#fff;display:flex;font-size:.88rem;font-weight:600;gap:12px;margin:0 12px 12px;padding:12px 16px}.install-banner-text{flex:1 1}.install-banner .btn{background:#fff;color:#6366f1;color:var(--color-primary);font-weight:700}.install-banner-close{background:none;border:none;color:#fffc;cursor:pointer;padding:4px}.auth-page{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 24px #00000014;max-width:440px;padding:40px;width:100%}.auth-header{margin-bottom:32px;text-align:center}.auth-logo{color:var(--accent);margin-bottom:12px}.auth-header h1{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0 0 8px}.auth-header p{color:var(--text-secondary);font-size:.9rem;margin:0}.auth-form{gap:18px}.auth-field,.auth-form{display:flex;flex-direction:column}.auth-field{gap:6px}.auth-field label{color:var(--text-primary);font-size:.85rem;font-weight:500}.auth-field input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:.95rem;padding:12px 14px;transition:border-color .2s}.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126;outline:none}.auth-password-wrapper{position:relative}.auth-password-wrapper input{padding-right:44px;width:100%}.auth-toggle-password{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.auth-totp-input{font-size:1.5rem!important;font-weight:600;letter-spacing:8px;max-width:200px;text-align:center}.auth-hint{color:var(--text-secondary);font-size:.8rem;margin:4px 0 0}.auth-actions-row{display:flex;justify-content:flex-end}.auth-link{color:var(--accent);font-size:.85rem;font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-submit{align-items:center;display:flex;font-size:1rem;font-weight:600;gap:8px;justify-content:center;margin-top:4px;padding:14px;width:100%}.auth-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#ef4444}.auth-error,.auth-success{font-size:.85rem;padding:10px 14px}.auth-success{background:#10b9811a;border:1px solid #10b9814d;border-radius:8px;color:#10b981;text-align:center}.auth-footer{border-top:1px solid var(--border-color);margin-top:24px;padding-top:20px;text-align:center}.auth-footer p{color:var(--text-secondary);font-size:.85rem}.topbar-profile{cursor:pointer;position:relative;-webkit-user-select:none;user-select:none}.topbar-dropdown{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 8px 24px #0000001f;margin-top:8px;min-width:180px;overflow:hidden;position:absolute;right:0;top:100%;z-index:100}.topbar-dropdown-item{align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:.85rem;gap:10px;padding:10px 16px;text-decoration:none;transition:background .15s;width:100%}.topbar-dropdown-item:hover{background:var(--bg-primary)}.topbar-dropdown-item--danger{color:#ef4444}.topbar-dropdown-item--danger:hover{background:#ef444414}.settings-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin-top:24px}.settings-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;padding:28px}.settings-card--wide{grid-column:1/-1}.settings-card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:10px;margin-bottom:20px;padding-bottom:14px}.settings-card-header h2{color:var(--text-primary);flex:1 1;font-size:1.05rem;font-weight:600;margin:0}.settings-badge{border-radius:20px;font-size:.75rem;font-weight:600;padding:4px 10px}.settings-badge--on{background:#10b98126;color:#10b981}.settings-badge--off{background:#9ca3af26;color:#9ca3af}.settings-success{background:#10b9811a;border:1px solid #10b9814d;border-radius:8px;color:#10b981}.settings-error,.settings-success{font-size:.85rem;margin-bottom:16px;padding:10px 14px}.settings-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#ef4444}.settings-card form{display:flex;flex-direction:column;gap:14px}.settings-card .btn{align-items:center;align-self:flex-start;display:flex;gap:6px;margin-top:6px}.settings-2fa-disable p,.settings-2fa-intro p,.settings-2fa-setup p,.settings-2fa-verify p{color:var(--text-secondary);font-size:.9rem;margin-bottom:16px}.settings-qr-container{display:flex;justify-content:center;margin:16px 0}.settings-qr-image{border:2px solid var(--border-color);border-radius:8px;height:200px;width:200px}.settings-2fa-secret{margin:12px 0 20px;text-align:center}.settings-2fa-secret code{background:var(--bg-primary);border-radius:8px;color:var(--accent);display:inline-block;font-size:.9rem;font-weight:600;letter-spacing:2px;margin-top:8px;padding:8px 16px}.settings-2fa-actions{display:flex;gap:12px}.btn--secondary{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-weight:500}.btn--danger,.btn--secondary{cursor:pointer;padding:10px 20px}.btn--danger{align-items:center;background:#ef4444;border:none;border-radius:10px;color:#fff;display:flex;font-weight:600;gap:6px}.btn--danger:hover{background:#dc2626}@media (max-width:860px){.settings-grid{grid-template-columns:1fr}.auth-card{padding:28px 20px}}@media (max-width:560px){.auth-card{border-radius:12px;padding:24px 16px}.settings-card{padding:20px}}.admin-page{margin:0 auto;max-width:1200px}.admin-denied{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:80px 24px;text-align:center}.admin-denied svg{color:#ef4444}.admin-header{margin-bottom:24px}.admin-header h1{align-items:center;color:var(--text-primary);display:flex;font-size:1.5rem;gap:10px}.admin-header p{color:var(--text-secondary);margin-top:4px}.admin-toast{animation:slideIn .3s ease;border-radius:8px;font-size:.875rem;font-weight:500;padding:12px 20px;position:fixed;right:20px;top:20px;z-index:9999}.admin-toast--success{background:#059669;color:#fff}.admin-toast--error{background:#ef4444;color:#fff}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.admin-tabs{border-bottom:2px solid var(--border);display:flex;gap:8px;margin-bottom:24px;padding-bottom:0}.admin-tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;margin-bottom:-2px;padding:10px 20px;transition:all .2s}.admin-tab--active,.admin-tab:hover{color:var(--primary)}.admin-tab--active{border-bottom-color:var(--primary)}.admin-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.admin-stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:20px;text-align:center}.admin-stat-card svg{color:var(--primary)}.admin-stat-value{color:var(--text-primary);font-size:2rem;font-weight:700;margin:8px 0 4px}.admin-stat-label{color:var(--text-secondary);font-size:.8rem;letter-spacing:.5px;text-transform:uppercase}.admin-stat-card--wide{grid-column:1/-1;text-align:left}.admin-stat-card--wide h4{color:var(--text-primary);margin-bottom:12px}.admin-plans-grid{display:flex;flex-wrap:wrap;gap:16px}.admin-plan-item{align-items:center;display:flex;gap:8px}.admin-plan-count{color:var(--text-primary);font-size:1.25rem;font-weight:600}.admin-plan-badge{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.admin-search-bar{align-items:center;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;display:flex;gap:10px;margin-bottom:16px;padding:8px 14px}.admin-search-bar input{background:none;border:none;color:var(--text-primary);flex:1 1;font-size:.9rem;outline:none}.admin-search-bar svg,.admin-search-clear{color:var(--text-secondary)}.admin-search-clear{background:none;border:none;cursor:pointer;display:flex}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;font-size:.875rem;width:100%}.admin-table th{border-bottom:2px solid var(--border);color:var(--text-secondary);font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:10px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.admin-table td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:12px;vertical-align:middle}.admin-table tbody tr:hover{background:#6366f10a}.admin-user-cell{align-items:center;display:flex;gap:10px}.admin-user-avatar{align-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-hover));border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.8rem;font-weight:600;height:32px;justify-content:center;width:32px}.admin-crown{color:#f59e0b}.admin-status{align-items:center;display:flex;font-size:.8rem;font-weight:500;gap:4px}.admin-status--active{color:#059669}.admin-status--inactive{color:#ef4444}.admin-actions{display:flex;gap:6px}.admin-action-btn{align-items:center;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.admin-action-btn:hover{border-color:var(--primary);color:var(--primary)}.admin-action-btn--danger:hover{border-color:#ef4444;color:#ef4444}.admin-pagination{align-items:center;display:flex;gap:16px;justify-content:center;margin-top:20px}.admin-pagination button{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:.85rem;padding:8px 16px}.admin-pagination button:disabled{cursor:default;opacity:.4}.admin-pagination span{color:var(--text-secondary);font-size:.85rem}.admin-loading{align-items:center;color:var(--text-secondary);display:flex;gap:10px;justify-content:center;padding:40px}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.admin-back{align-items:center;background:none;border:none;color:var(--primary);cursor:pointer;display:flex;font-size:.9rem;gap:6px;margin-bottom:20px;padding:0}.admin-back:hover{text-decoration:underline}.admin-detail-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.admin-detail-avatar{align-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-hover));border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.4rem;font-weight:700;height:56px;justify-content:center;width:56px}.admin-detail-header h2{color:var(--text-primary);margin:0}.admin-detail-email{color:var(--text-secondary);font-size:.9rem;margin:2px 0 8px}.admin-detail-actions{display:flex;gap:8px;margin-left:auto}.admin-badges{display:flex;flex-wrap:wrap;gap:6px}.admin-badge{align-items:center;border-radius:20px;display:flex;font-size:.7rem;font-weight:600;gap:4px;letter-spacing:.5px;padding:3px 10px;text-transform:uppercase}.admin-badge--super{background:#fef3c7;color:#92400e}.admin-badge--active{background:#d1fae5;color:#065f46}.admin-badge--inactive{background:#fee2e2;color:#991b1b}.admin-badge--verified{background:#dbeafe;color:#1e40af}.admin-badge--unverified{background:#f3f4f6;color:#6b7280}.admin-badge--2fa{background:#ede9fe;color:#5b21b6}.admin-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;padding:20px}.admin-card h3{align-items:center;color:var(--text-primary);display:flex;font-size:1rem;gap:8px;margin:0 0 16px}.admin-empty{color:var(--text-secondary);font-size:.875rem}.admin-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr;margin-bottom:16px}.admin-field label{color:var(--text-secondary);display:block;font-size:.8rem;font-weight:500;margin-bottom:4px}.admin-field input:not([type=checkbox]){background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.9rem;padding:8px 12px;width:100%}.admin-checkbox{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-size:.875rem;gap:8px}.admin-checkbox input[type=checkbox]{cursor:pointer;height:16px;width:16px}.admin-billing-info{align-items:center;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:.875rem;gap:16px;margin-bottom:14px}.admin-plan-change{align-items:center;display:flex;gap:10px}.admin-plan-change select{background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;padding:8px 12px}.admin-reset-pwd{align-items:center;display:flex;gap:10px}.admin-reset-pwd input{background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);flex:1 1;font-size:.9rem;padding:8px 12px}.health-badge{border-radius:12px;font-size:.75rem;font-weight:600;padding:2px 8px}.health-good{background:#d1fae5;color:#065f46}.health-mid{background:#fef3c7;color:#92400e}.health-low{background:#fee2e2;color:#991b1b}.sidebar-link--admin{border-top:1px solid var(--border);margin-top:8px;padding-top:12px}.sidebar-link--admin svg{color:#f59e0b}@media (max-width:768px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-form-grid{grid-template-columns:1fr}.admin-detail-header{flex-direction:column}.admin-detail-actions{margin-left:0}.admin-table{font-size:.8rem}.admin-table td,.admin-table th{padding:8px}}
/*# sourceMappingURL=main.aa04da90.css.map*/