:root{--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #eff6ff;--green: #16a34a;--green-light: #dcfce7;--yellow: #d97706;--yellow-light: #fef3c7;--red: #dc2626;--red-light: #fee2e2;--blue-light: #dbeafe;--text: #111827;--text-secondary: #4b5563;--muted: #6b7280;--border: #e5e7eb;--bg: #f9fafb;--bg-card: #ffffff;--dark: #0f172a;--dark-secondary: #1e293b;--dark-text: #e2e8f0;--dark-muted: #94a3b8;--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .05);--max-width: 1120px;--header-height: 60px}:root{--max-width: 1200px;--header-height: 64px;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #eff6ff;--text: #1f2937;--text-secondary: #4b5563;--bg: #ffffff;--bg-card: #ffffff;--border: #e5e7eb;--dark: #111827;--dark-secondary: #1f2937;--dark-muted: #9ca3af;--muted: #6b7280;--radius: 6px;--radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--red: #dc2626;--red-light: #fef2f2;--yellow: #d97706;--yellow-light: #fffbeb;--green: #16a34a;--green-light: #f0fdf4;--blue-light: #eff6ff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}.site-header{position:sticky;top:0;z-index:50;background:var(--dark);border-bottom:1px solid rgba(255,255,255,.08);height:var(--header-height)}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 24px;display:flex;align-items:center;height:100%;gap:32px}.header-logo{display:flex;align-items:center;gap:8px;color:#fff;font-weight:700;font-size:16px;text-decoration:none;flex-shrink:0}.logo-icon{color:var(--primary);font-size:18px}.header-nav{display:flex;align-items:center;gap:4px;flex:1}.header-link{padding:6px 14px;font-size:14px;font-weight:500;color:var(--dark-muted);border-radius:6px;transition:color .15s,background .15s;text-decoration:none;background:none;border:none;cursor:pointer}.header-link:hover{color:#fff;text-decoration:none}.header-link.active{color:#fff;background:#ffffff14}.header-right{margin-left:auto;display:flex;align-items:center;gap:12px}.mobile-menu-btn{display:none;background:none;border:none;color:var(--dark-muted);font-size:22px;cursor:pointer;padding:4px;margin-left:auto}.btn{display:inline-flex;align-items:center;justify-content:center;padding:9px 18px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;background:var(--bg-card);color:var(--text);transition:all .15s;text-decoration:none;line-height:1.4}.btn:hover{background:var(--bg);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-ghost{background:#000!important;color:#fff;border-color:#ffffff40}.btn-ghost:hover{border-color:#fff6}.btn-sm{padding:5px 12px;font-size:13px}.btn-lg{padding:12px 28px;font-size:15px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600;line-height:1;white-space:nowrap}.badge-success{background:var(--green-light);color:#15803d}.badge-warning{background:var(--yellow-light);color:#92400e}.badge-danger{background:var(--red-light);color:#b91c1c}.badge-info{background:var(--blue-light);color:#1d4ed8}.badge-neutral{background:#f3f4f6;color:var(--text-secondary)}.plan-badge{padding:3px 10px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.plan-free{background:#f3f4f6;color:var(--muted)}.plan-basic{background:var(--blue-light);color:#1d4ed8}.plan-pro{background:var(--yellow-light);color:#92400e}.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.form-field label{font-weight:500;font-size:14px}.form-field-inline{display:flex;align-items:center;gap:8px}.form-field-inline label{font-size:13px;font-weight:500;color:var(--text-secondary);white-space:nowrap}.input{padding:9px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit;background:var(--bg-card);color:var(--text);transition:border-color .15s,box-shadow .15s}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.input-error{border-color:var(--red)}.input-error:focus{border-color:var(--red);box-shadow:0 0 0 3px #dc26261f}.input-sm{padding:5px 10px;font-size:13px}.field-error{font-size:12px;color:var(--red)}.hero{background:linear-gradient(170deg,var(--dark) 0%,var(--dark-secondary) 100%);color:#fff;padding:80px 24px 88px}.hero-inner{max-width:680px;margin:0 auto;text-align:center}.hero-badge{display:inline-block;padding:5px 14px;background:#2563eb26;color:#93bbfd;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:24px;border:1px solid rgba(37,99,235,.25)}.hero h1{font-size:44px;font-weight:800;line-height:1.15;margin-bottom:16px;letter-spacing:-.5px}.hero-sub{font-size:17px;line-height:1.6;color:var(--dark-muted);margin-bottom:32px;max-width:560px;margin-left:auto;margin-right:auto}.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.section{padding:72px 24px}.section-alt{background:var(--bg-card);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.section-cta{background:var(--primary-light);border-top:1px solid #bfdbfe}.section-inner{max-width:var(--max-width);margin:0 auto}.section-title{font-size:28px;font-weight:700;margin-bottom:12px;letter-spacing:-.3px}.section-desc{font-size:16px;color:var(--text-secondary);max-width:600px;margin-bottom:40px}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;position:relative;overflow:hidden}.info-card h3{font-size:16px;font-weight:600;margin-bottom:8px}.info-card p{font-size:14px;color:var(--text-secondary);line-height:1.6}.info-card-accent{position:absolute;top:0;left:0;right:0;height:3px}.accent-red{background:var(--red)}.accent-yellow{background:var(--yellow)}.accent-blue{background:var(--primary)}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.feature-card{padding:32px 28px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg)}.feature-number{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;margin-bottom:16px}.feature-card h3{font-size:17px;font-weight:600;margin-bottom:8px}.feature-card p{font-size:14px;color:var(--text-secondary);line-height:1.6}.timeline{max-width:640px;display:flex;flex-direction:column;gap:0;position:relative;padding-left:28px}.timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--border)}.timeline-item{position:relative;padding:0 0 28px 20px}.timeline-marker{position:absolute;left:-24px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--border);border:2px solid var(--bg)}.timeline-item.next .timeline-marker{background:var(--primary);box-shadow:0 0 0 4px #2563eb33}.timeline-item.past .timeline-marker{background:var(--muted)}.timeline-item.past .timeline-content{opacity:.5}.timeline-date{font-size:13px;color:var(--muted);font-weight:500}.timeline-content strong{display:block;margin:2px 0 4px;font-size:15px}.timeline-content p{font-size:14px;color:var(--text-secondary);margin:0}.page-pricing{padding-top:40px}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;text-align:left}.pricing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px;position:relative;display:flex;flex-direction:column}.pricing-featured{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary),var(--shadow-md)}.pricing-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);padding:4px 14px;background:var(--primary);color:#fff;font-size:12px;font-weight:600;border-radius:12px;white-space:nowrap}.pricing-name{font-size:18px;font-weight:600;margin-bottom:8px}.pricing-price{margin-bottom:24px}.pricing-amount{font-size:36px;font-weight:800;letter-spacing:-1px}.pricing-period{font-size:15px;color:var(--muted);margin-left:2px}.pricing-features{list-style:none;padding:0;margin:0 0 28px;flex:1}.pricing-features li{padding:7px 0;font-size:14px;color:var(--text-secondary);border-bottom:1px solid var(--border)}.pricing-features li:last-child{border-bottom:none}.pricing-features li:before{content:"✓";color:var(--green);font-weight:700;margin-right:8px}.pricing-note{margin-top:32px;font-size:13px;color:var(--muted)}.pricing-success-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:0 auto 24px;max-width:560px;padding:14px 20px;background:var(--green-light);border:1px solid var(--green);color:#15803d;border-radius:var(--radius-lg);text-align:left;box-shadow:0 4px 6px -1px #0000001a}.pricing-success-banner p{margin:0;font-size:14px;color:var(--text)}.pricing-success-banner .btn{flex-shrink:0}.page-login{min-height:calc(100vh - var(--header-height) - 200px);display:flex;align-items:center;justify-content:center;padding:48px 24px}.login-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px;box-shadow:var(--shadow-md)}.login-card h1{font-size:22px;font-weight:700;margin-bottom:6px}.login-card>p{color:var(--text-secondary);font-size:14px;margin-bottom:28px}.login-help{margin-top:20px;font-size:13px;color:var(--muted);text-align:center}.success-card{text-align:center;padding:48px 32px;background:var(--bg-card);border:1px solid var(--green);border-radius:var(--radius-lg);box-shadow:0 4px 12px #16a34a1a;max-width:480px;width:100%}.success-icon{width:64px;height:64px;background:var(--green-light);color:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 24px}.link-button{background:none;border:none;padding:0;font:inherit;color:var(--primary);cursor:pointer;text-decoration:none}.link-button:hover{text-decoration:underline}.page-dashboard,.page-plugins,.page-vulnerabilities{width:100%;max-width:var(--max-width);margin:0 auto;padding:32px 24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}.page-title{font-size:24px;font-weight:700;color:var(--text);margin:0}.page-header-actions{display:flex;gap:12px;align-items:center}.dash-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.dash-upgrade-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:14px 20px;background:var(--primary-light);border:1px solid #bfdbfe;border-radius:var(--radius-lg);margin-bottom:24px;font-size:14px}.dash-upgrade-banner strong{color:var(--text)}.dash-upgrade-banner span{color:var(--text-secondary)}.dash-api-key-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:24px}.dash-api-key-block h3{font-size:16px;font-weight:600;margin-bottom:6px}.dash-api-key-desc{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.dash-api-key-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.dash-api-key-value{flex:1;min-width:200px;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:ui-monospace,monospace;word-break:break-all}.dash-header h1{font-size:24px;font-weight:700}.page-desc{color:var(--text-secondary);font-size:14px;margin-bottom:24px}.dash-meta{font-size:13px;color:var(--muted);margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}.stat-value{font-size:32px;font-weight:800;color:var(--primary);line-height:1.2}.stat-danger{color:var(--red)}.stat-warning{color:var(--yellow)}.stat-label{font-size:13px;color:var(--muted);margin-top:4px}.dash-actions{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}.action-card{display:flex;flex-direction:column;gap:4px;padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--text);transition:border-color .15s,box-shadow .15s}.action-card:hover{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary);text-decoration:none}.action-card strong{font-size:15px}.action-card span{font-size:13px;color:var(--muted)}.dash-limits{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.dash-limits h3{font-size:15px;font-weight:600;margin-bottom:12px}.limits-table{width:100%;font-size:14px}.limits-table td{padding:6px 0;border-bottom:1px solid var(--border)}.limits-table td:last-child{text-align:right;font-weight:500}.limits-table tr:last-child td{border-bottom:none}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.data-table th{text-align:left;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:12px 16px;background:var(--bg);border-bottom:1px solid var(--border)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border)}.data-table tr:last-child td{border-bottom:none}.filter-bar{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.vuln-list{display:flex;flex-direction:column;gap:10px}.vuln-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.vuln-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.vuln-title{flex:1;font-size:14px}.vuln-meta{display:flex;gap:16px;margin-top:8px;font-size:13px;color:var(--muted)}.vuln-actions{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.empty-state{text-align:center;padding:48px 24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.empty-state p{margin-bottom:4px}.page-loading{display:flex;align-items:center;justify-content:center;padding:64px 24px;color:var(--muted);font-size:15px}.page-error{text-align:center;padding:48px 24px;color:var(--red)}.text-muted{color:var(--muted);font-size:13px}.site-footer{background:var(--dark);color:var(--dark-muted);padding:48px 24px 32px;margin-top:auto}.footer-inner{max-width:var(--max-width);margin:0 auto}.footer-logo{font-weight:700;font-size:15px;color:var(--dark-text)}.footer-tagline{font-size:14px;margin-top:6px;max-width:360px}.footer-links{display:flex;gap:20px;margin-top:20px}.footer-links a{color:var(--dark-muted);font-size:14px;text-decoration:none}.footer-links a:hover{color:var(--dark-text);text-decoration:none}.footer-bottom{margin-top:28px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);font-size:13px}@media(max-width:768px){.mobile-menu-btn{display:block}.header-nav{display:none;position:absolute;top:var(--header-height);left:0;right:0;background:var(--dark);flex-direction:column;padding:12px 24px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.header-nav.open{display:flex}.header-right{margin-left:0;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08);width:100%;justify-content:center}.hero{padding:48px 24px 56px}.hero h1{font-size:30px}.hero-sub{font-size:15px}.info-grid,.feature-grid,.pricing-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.dash-actions{grid-template-columns:1fr}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.legal-content{color:var(--text);line-height:1.7}.legal-content h1{font-size:32px;font-weight:800;margin-bottom:8px;letter-spacing:-.5px}.legal-content h2{font-size:20px;font-weight:700;margin-top:32px;margin-bottom:12px;color:var(--text)}.legal-content p{margin-bottom:16px;color:var(--text-secondary)}.legal-content ul{margin-bottom:24px;padding-left:24px;color:var(--text-secondary)}.legal-content li{margin-bottom:8px}.legal-content strong{color:var(--text);font-weight:600}.app-root{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1;display:flex;flex-direction:column}.site-footer{background:var(--dark);color:#fff;padding:48px 24px;border-top:1px solid rgba(255,255,255,.1);margin-top:auto}.footer-inner{max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:32px}.footer-brand{max-width:300px}.footer-logo{font-weight:700;font-size:16px;margin-bottom:12px;display:block;color:#fff}.footer-tagline{font-size:14px;color:var(--dark-muted);line-height:1.5}.footer-links{display:flex;gap:24px;align-items:flex-start}.footer-links a{color:var(--dark-muted);font-size:14px;transition:color .15s}.footer-links a:hover{color:#fff;text-decoration:none}.footer-bottom{grid-column:1 / -1;padding-top:32px;margin-top:32px;border-top:1px solid rgba(255,255,255,.1);font-size:13px;color:var(--dark-muted);text-align:center}@media(max-width:640px){.footer-inner{grid-template-columns:1fr;text-align:center}.footer-brand{max-width:none;margin:0 auto}.footer-links{justify-content:center;flex-wrap:wrap}}
