.app-wrapper{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.app{display:flex;justify-content:center;align-items:center;flex:1;padding:20px;width:100%}.container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;max-width:600px;width:100%}.header{text-align:center;margin-bottom:32px}.header h1{font-size:2.5rem;color:#333;margin-bottom:8px}.subtitle{color:#666;font-size:1rem}.form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:12px}.form-group-row{flex-direction:row;gap:20px;align-items:flex-start}.form-group-inline{display:flex;flex-direction:column;gap:12px;flex:1}.form-group label{font-weight:600;color:#333;font-size:.95rem;display:flex;align-items:center;gap:8px}.limit-badge{background:#667eea;color:#fff;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.premium-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600;margin-left:8px}.premium-text{color:#667eea;font-weight:500}.link-btn{background:none;border:none;color:#667eea;text-decoration:underline;cursor:pointer;font-size:inherit;padding:0;margin-left:4px;font-weight:600}.link-btn:hover{color:#5568d3}.limit-text{color:#ff4757;font-size:.85rem;font-weight:500;margin-top:-4px}.limit-reached{display:flex;align-items:center;gap:12px;margin-top:8px;flex-wrap:wrap}.upgrade-btn-inline{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;white-space:nowrap}.upgrade-btn-inline:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.upgrade-btn-inline:disabled{opacity:.6;cursor:not-allowed;transform:none}input[type=email],input[type=text],input[type=time],select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;width:100%}input[type=email]:focus,input[type=text]:focus,input[type=time]:focus,select:focus{outline:none;border-color:#667eea}select{background:#fff;cursor:pointer}select:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.help-text{color:#666;font-size:.85rem;margin-top:-8px}input:disabled{background-color:#f5f5f5;cursor:not-allowed}.input-group{display:flex;gap:8px;align-items:center}.input-group input{flex:1}.remove-btn{background:#ff4757;color:#fff;border:none;border-radius:6px;width:32px;height:32px;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background-color .2s;flex-shrink:0}.remove-btn:hover:not(:disabled){background:#ff3838}.remove-btn:disabled{opacity:.5;cursor:not-allowed}.add-btn{background:#667eea;color:#fff;border:none;border-radius:8px;padding:10px 16px;cursor:pointer;font-size:.95rem;font-weight:500;transition:background-color .2s;align-self:flex-start}.add-btn:hover:not(:disabled){background:#5568d3}.add-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:14px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.message{padding:12px 16px;border-radius:8px;font-size:.95rem;text-align:center}.message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;padding:32px;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideUp .3s ease-out}.modal-content.modal-large{max-width:600px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h2{margin:0 0 16px;color:#333;font-size:1.5rem}.modal-content p{margin:0 0 12px;color:#666;line-height:1.6}.modal-content p:last-of-type{margin-bottom:24px}.plan-features{background:#f8f9fa;border-radius:8px;padding:16px;margin:16px 0}.plan-features h3{margin:0 0 12px;color:#333;font-size:1rem}.plan-features ul{margin:0;padding-left:20px;color:#666}.plan-features li{margin:8px 0;line-height:1.5}.upgrade-form{display:flex;flex-direction:column;gap:20px}.upgrade-form .form-group{margin-bottom:0}.plan-select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;width:100%;background:#fff;cursor:pointer}.plan-select:focus{outline:none;border-color:#667eea}.plan-select:disabled{background-color:#f5f5f5;cursor:not-allowed}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.modal-btn-secondary:hover{background:#e0e0e0}@media (max-width: 640px){.container{padding:24px}.header h1{font-size:2rem}.modal-content{padding:24px}.modal-actions{flex-direction:column}.modal-btn-primary,.modal-btn-secondary{width:100%}.form-group-row{flex-direction:column;gap:20px}.form-group-inline{width:100%}}.footer{background:#2c3e50;color:#ecf0f1;padding:24px 20px;margin-top:auto;width:100%}.footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:12px}.footer-links{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}.footer-links a{color:#ecf0f1;text-decoration:none;font-size:.9rem;transition:color .2s}.footer-links a:hover{color:#667eea;text-decoration:underline}.footer-separator{color:#7f8c8d}.footer-copyright{text-align:center;font-size:.85rem;color:#bdc3c7}.footer-copyright p{margin:0}@media (max-width: 640px){.footer{padding:20px 16px}.footer-links{flex-direction:column;gap:8px}.footer-separator{display:none}}.legal-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:flex-start;z-index:2000;padding:20px;overflow-y:auto;animation:fadeIn .2s ease-out}.legal-modal-content{background:#fff;border-radius:16px;padding:40px;max-width:800px;width:100%;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideUp .3s ease-out;margin:20px auto}.legal-modal-content h1{color:#333;font-size:2rem;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e0e0e0}.legal-modal-content h2{color:#333;font-size:1.3rem;margin-top:32px;margin-bottom:12px}.legal-modal-content h3{color:#555;font-size:1.1rem;margin-top:20px;margin-bottom:8px}.legal-modal-content section{margin-bottom:24px}.legal-modal-content p{color:#666;line-height:1.8;margin-bottom:12px}.legal-modal-content address{font-style:normal;color:#666;line-height:1.8;margin:12px 0}.legal-modal-content ul{color:#666;line-height:1.8;margin:12px 0;padding-left:24px}.legal-modal-content li{margin-bottom:8px}.legal-modal-actions{display:flex;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:2px solid #e0e0e0}.modal-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.modal-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.modal-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-btn-secondary{background:#f5f5f5;color:#333;border:none;border-radius:8px;padding:12px 24px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.modal-btn-secondary:hover:not(:disabled){background:#e0e0e0}.modal-btn-secondary:disabled{opacity:.5;cursor:not-allowed}.modal-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:1.5rem;color:#666;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s,color .2s}.modal-close:hover{background:#f5f5f5;color:#333}.change-password-modal{max-width:500px}.change-password-form{display:flex;flex-direction:column;gap:20px}.change-password-form .form-group{display:flex;flex-direction:column;gap:12px}.change-password-form .form-group label{font-weight:600;color:#333;font-size:.95rem}.change-password-form .form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;width:100%}.change-password-form .form-group input:focus{outline:none;border-color:#667eea}.change-password-form .form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.change-password-form .message{padding:12px 16px;border-radius:8px;font-size:.95rem;text-align:center}.change-password-form .message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.change-password-form .message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width: 768px){.legal-modal-content{padding:24px;margin:10px}.legal-modal-content h1{font-size:1.5rem}.legal-modal-content h2{font-size:1.2rem}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px}.auth-box{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;max-width:450px;width:100%}.auth-box h1{text-align:center;font-size:2rem;color:#333;margin-bottom:8px}.auth-subtitle{text-align:center;color:#666;font-size:.95rem;margin-bottom:32px}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-form .form-group{display:flex;flex-direction:column;gap:12px}.auth-form .form-group label{font-weight:600;color:#333;font-size:.95rem}.auth-form .form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;width:100%}.auth-form .form-group input:focus{outline:none;border-color:#667eea}.auth-form .form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.auth-error{background:#f8d7da;color:#721c24;padding:12px 16px;border-radius:8px;font-size:.9rem;border:1px solid #f5c6cb}.auth-submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:14px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-switch{margin-top:24px;text-align:center;color:#666;font-size:.9rem}.auth-switch .link-btn{background:none;border:none;color:#667eea;text-decoration:underline;cursor:pointer;font-size:inherit;padding:0;font-weight:600}.auth-switch .link-btn:hover{color:#5568d3}@media (max-width: 640px){.auth-box{padding:24px}.auth-box h1{font-size:1.5rem}}.navigation{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100;width:100%}.nav-container{max-width:1200px;margin:0 auto;padding:16px 20px;display:flex;justify-content:space-between;align-items:center}.nav-brand h2{margin:0;font-size:1.5rem;color:#333}.nav-menu{position:relative}.nav-user-menu{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px 16px;border-radius:8px;transition:background-color .2s}.nav-user-menu:hover{background:#f5f5f5}.nav-user-info{display:flex;flex-direction:column;align-items:flex-end}.nav-user-name{font-weight:600;color:#333;font-size:.9rem}.nav-user-plan{font-size:.75rem;color:#667eea;text-transform:uppercase;font-weight:600}.nav-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem}.nav-dropdown-icon{font-size:.7rem;color:#666;transition:transform .2s}.nav-user-menu:hover .nav-dropdown-icon{transform:rotate(180deg)}.nav-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:8px;box-shadow:0 8px 24px #00000026;min-width:220px;overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.nav-dropdown button{width:100%;padding:12px 16px;border:none;background:#fff;text-align:left;cursor:pointer;font-size:.9rem;color:#333;transition:background-color .2s;display:flex;align-items:center;gap:8px}.nav-dropdown button:hover{background:#f5f5f5}.nav-divider{height:1px;background:#e0e0e0;margin:4px 0}.nav-logout{color:#ff4757!important}.nav-logout:hover{background:#fff5f5!important}@media (max-width: 640px){.nav-container{padding:12px 16px}.nav-brand h2{font-size:1.2rem}.nav-user-name,.nav-user-plan{display:none}}.landing-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#333;display:flex;flex-direction:column}.hero-section{display:flex;align-items:center;justify-content:space-between;padding:80px 40px;max-width:1400px;margin:0 auto;gap:60px}.hero-content{flex:1;max-width:600px;color:#fff}.hero-title{font-size:4rem;font-weight:800;margin-bottom:16px;line-height:1.1;background:linear-gradient(135deg,#fff,#f0f0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.5rem;font-weight:600;margin-bottom:20px;color:#fffffff2}.hero-description{font-size:1.1rem;line-height:1.8;margin-bottom:40px;color:#ffffffe6}.hero-cta{display:flex;gap:16px;flex-wrap:wrap}.cta-primary{background:#fff;color:#667eea;border:none;border-radius:12px;padding:16px 32px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px #0003}.cta-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0000004d}.cta-primary.large{padding:20px 48px;font-size:1.2rem}.cta-secondary{background:transparent;color:#fff;border:2px solid white;border-radius:12px;padding:16px 32px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .2s}.cta-secondary:hover{background:#ffffff1a;transform:translateY(-2px)}.hero-visual{flex:1;position:relative;height:500px;width:100%;min-height:500px}.floating-card{position:absolute;background:#fff;border-radius:16px;padding:20px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;gap:12px;animation:float 3s ease-in-out infinite;max-width:300px;width:100%;border-left:4px solid #667eea;z-index:1}.floating-card.threat-summary{align-items:flex-start;text-align:left}.threat-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:8px}.threat-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.threat-badge.critical{background:#fee;color:#c00}.threat-badge.high{background:#ffe5cc;color:#e65100}.threat-badge.medium{background:#fff3cd;color:#856404}.threat-date{font-size:.75rem;color:#999;font-weight:500}.threat-title{font-size:1rem;font-weight:700;color:#333;margin:0 0 8px;line-height:1.4}.threat-excerpt{font-size:.875rem;color:#666;line-height:1.6;margin:0 0 12px}.threat-tags{display:flex;gap:8px;flex-wrap:wrap}.threat-tags .tag{background:#f0f0f0;color:#667eea;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600}.card-1{top:50px;left:0;animation-delay:0s;z-index:2}.card-2{top:250px;right:0;left:auto;animation-delay:1s;z-index:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.features-section{background:#fff;padding:100px 40px}.container{max-width:1200px;margin:0 auto}.section-title{font-size:3rem;font-weight:800;text-align:center;margin-bottom:60px;color:#333;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px}.feature-card{background:#f8f9fa;border-radius:16px;padding:32px;transition:transform .2s,box-shadow .2s;border:2px solid transparent}.feature-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px #667eea33;border-color:#667eea}.feature-icon{font-size:3rem;margin-bottom:16px}.feature-title{font-size:1.3rem;font-weight:700;margin-bottom:12px;color:#333}.feature-description{font-size:1rem;line-height:1.7;color:#666}.how-it-works-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:100px 40px}.steps{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}.step{display:flex;flex-direction:column;align-items:center;gap:16px;flex:1;min-width:250px;max-width:300px}.step-number{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;box-shadow:0 4px 20px #667eea66}.step-content{text-align:center}.step-content h3{font-size:1.3rem;font-weight:700;margin-bottom:8px;color:#333}.step-content p{font-size:1rem;color:#666;line-height:1.6}.step-connector{width:60px;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);flex-shrink:0}@media (max-width: 768px){.step-connector{width:3px;height:40px}}.cta-section{background:linear-gradient(135deg,#667eea,#764ba2);padding:100px 40px;text-align:center}.cta-title{font-size:2.5rem;font-weight:800;margin-bottom:20px;line-height:1.2;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3)}.cta-description{font-size:1.2rem;margin-bottom:40px;color:#fff;max-width:600px;margin-left:auto;margin-right:auto;text-shadow:0 1px 4px rgba(0,0,0,.2)}@media (max-width: 1024px){.hero-section{flex-direction:column;text-align:center;padding:60px 20px}.hero-visual{width:100%;height:600px;min-height:600px;margin-top:40px}.floating-card{max-width:280px}.card-1{top:50px;left:20px}.card-2{top:300px;right:20px;left:auto}.hero-title{font-size:3rem}.section-title{font-size:2.5rem}}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.2rem}.hero-description{font-size:1rem}.hero-cta{flex-direction:column}.cta-primary,.cta-secondary{width:100%}.hero-visual{height:700px;min-height:700px}.floating-card{width:calc(100% - 40px);max-width:300px;padding:18px}.threat-title{font-size:.9rem}.threat-excerpt{font-size:.8rem}.card-1{top:50px;left:20px;z-index:2}.card-2{top:350px;left:20px;right:auto;z-index:1}.features-section,.how-it-works-section,.cta-section{padding:60px 20px}.section-title{font-size:2rem}.features-grid{grid-template-columns:1fr}.steps{flex-direction:column}.step-connector{width:3px;height:40px}.cta-title{font-size:2rem}.cta-description{font-size:1rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;margin:0;padding:0}#root{min-height:100vh;width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
