:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{background-color:#f5f7fa;color:#333;line-height:1.4;font-size:14px}.App{height:100vh;width:100vw;display:flex;flex-direction:column;overflow:auto}.container{flex:1;width:100%;padding:.8rem;overflow:auto}.mode-selector{display:flex;justify-content:center;margin-bottom:1rem;gap:.6rem}.mode-btn{flex:1;max-width:200px;padding:.6rem;border-radius:5px;text-align:center;cursor:pointer;transition:all .2s ease;background-color:#fff;border:1px solid #ddd;box-shadow:0 1px 3px #0000000d}.mode-btn:hover{transform:translateY(-1px);box-shadow:0 2px 5px #0000001a}.mode-btn.active{border-width:2px}.mode-btn.active.vulnerable{border-color:#e74c3c}.mode-btn.active.secure{border-color:#2ecc71}.mode-btn span{font-size:.9rem;font-weight:600;display:block;margin-bottom:.1rem}.mode-btn small{font-size:.75rem;opacity:.8}.danger{color:#e74c3c}.safe{color:#2ecc71}.simulation-area{display:flex;gap:1rem;margin-bottom:1rem;flex:1;min-height:0}@media(max-width:900px){.simulation-area{flex-direction:column}}.left-panel,.right-panel{flex:1;min-width:0;display:flex;flex-direction:column}.card{background-color:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 6px #0000000f;flex-shrink:0;overflow:hidden}.card h2{color:#2c3e50;margin-bottom:.8rem;padding-bottom:.4rem;border-bottom:1px solid #f1f1f1;font-size:1.1rem}.form-group{margin-bottom:.8rem}.form-group label{display:block;margin-bottom:.3rem;font-weight:600;color:#34495e;font-size:.9rem}.form-group input{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3498db}.button-group{display:flex;gap:.6rem;margin-top:1rem}.btn{flex:1;padding:.6rem;border:none;border-radius:4px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.login-btn{background-color:#3498db;color:#fff}.login-btn:hover{background-color:#2980b9}.clear-btn{background-color:#95a5a6;color:#fff}.clear-btn:hover{background-color:#7f8c8d}.form-toggle{text-align:center;margin-top:1.5rem;font-size:.95rem;color:#34495e}.form-toggle p{margin:0}.toggle-link{color:#3498db;cursor:pointer;font-weight:600;text-decoration:none;margin-left:.3rem;transition:color .2s}.toggle-link:hover{color:#2980b9;text-decoration:underline}.message{padding:.6rem;border-radius:4px;margin-top:1rem;text-align:center;font-weight:600;font-size:.9rem}.message.warning{background-color:#fef5e7;border-left:3px solid #f39c12;color:#e67e22}.message.success{background-color:#eafaf1;border-left:3px solid #2ecc71;color:#27ae60}.message.error{background-color:#fdedec;border-left:3px solid #e74c3c;color:#c0392b}.attack-examples{margin-top:1.2rem}.attack-examples h3{margin-bottom:.6rem;color:#2c3e50;font-size:.95rem}.example-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}@media(max-width:480px){.example-buttons{grid-template-columns:1fr}}.example-btn{padding:.5rem;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s;font-weight:600}.example-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.example-btn.basic{background-color:#fddede;color:#c0392b}.example-btn.comment{background-color:#fdebd0;color:#e67e22}.example-btn.union{background-color:#d6eaf8;color:#2980b9}.example-btn.normal{background-color:#d5f4e6;color:#27ae60}.query-display{padding:.8rem;background-color:#2c3e50;color:#fff;border-radius:4px;font-family:Courier New,monospace;margin-bottom:1rem;overflow-x:auto;font-size:.85rem}.query-display.vulnerable{border-left:3px solid #e74c3c}.query-display.secure{border-left:3px solid #2ecc71}.explanation{font-size:.85rem}.explanation h3{font-size:.95rem;margin-bottom:.5rem}.explanation ul{padding-left:1.2rem}.explanation li{margin-bottom:.3rem;font-size:.85rem}.results-table{overflow-x:auto;margin-top:.8rem;font-size:.85rem}table{width:100%;border-collapse:collapse;font-size:.85rem}thead{background-color:#3498db;color:#fff}th,td{padding:.5rem;text-align:left;border-bottom:1px solid #ddd}tbody tr:hover{background-color:#f5f7fa}.no-results{text-align:center;padding:1.5rem;color:#7f8c8d;font-style:italic;font-size:.9rem}.history-list{max-height:150px;overflow-y:auto;font-size:.85rem}.history-item{padding:.5rem;margin-bottom:.3rem;border-radius:4px;border-left:3px solid #ddd;font-size:.85rem}.history-item.attack{background-color:#fddede;border-left-color:#e74c3c}.history-item.blocked{background-color:#d5f4e6;border-left-color:#2ecc71}.history-item.success{background-color:#eafaf1;border-left-color:#27ae60}.history-item.failed{background-color:#fef5e7;border-left-color:#f39c12}.history-item.info{background-color:#ebf5fb;border-left-color:#3498db}.mode-indicator{background-color:#f8f9fa;padding:.4rem;border-radius:3px;margin-bottom:.8rem;font-size:.85rem;transition:all .2s ease}.mode-indicator.vulnerable-mode{color:#e74c3c;background-color:#e74c3c1a;border-left:3px solid #e74c3c}.mode-indicator.secure-mode{color:#2ecc71;background-color:#2ecc711a;border-left:3px solid #2ecc71}.mode-indicator strong{font-size:1em}.result-count{font-weight:600;margin-bottom:.3rem;color:#2c3e50;font-size:.9rem}.login-success-container{text-align:center;padding:2rem 1rem}.success-icon{font-size:3rem;margin-bottom:1rem;animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.success-title{color:#2ecc71;font-size:1.5rem;margin-bottom:.5rem}.success-message{color:#7f8c8d;margin-bottom:1.5rem;font-size:1rem}.logged-in-user{background-color:#f8f9fa;padding:1rem;border-radius:8px;margin:1.5rem 0;text-align:left}.logged-in-user p{margin:.5rem 0;color:#2c3e50}.logout-btn{width:100%;padding:.8rem;background-color:#95a5a6;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:1rem}.logout-btn:hover{background-color:#7f8c8d;transform:translateY(-2px)}@media(max-width:768px){body{font-size:13px}.container{padding:.5rem}.card{padding:.8rem}.card h2{font-size:1rem}.mode-btn{padding:.5rem}.mode-btn span{font-size:.85rem}.mode-btn small{font-size:.7rem}.query-display{font-size:.8rem;padding:.6rem}th,td{padding:.4rem;font-size:.8rem}}@media(max-width:480px){body{font-size:12px}.simulation-area{gap:.8rem}.mode-selector{flex-direction:column;align-items:center}.mode-btn{max-width:100%;width:100%}.button-group{flex-direction:column}.example-buttons{grid-template-columns:1fr}}.left-panel>.card:last-child,.right-panel>.card:last-child{flex:1;overflow:auto}@media(max-height:700px){.history-list{max-height:120px}}@media(max-height:600px){.history-list{max-height:100px}}.App-header{background:linear-gradient(135deg,#1a2980,#26d0ce);color:#fff;padding:.5rem;text-align:center;box-shadow:0 2px 10px #0000001a}.subtitle{font-size:1.1rem;opacity:.9;margin-top:.5rem}.register-page-container{display:flex!important;justify-content:center;align-items:center;background-color:#f5f7fa;padding:2rem 1rem!important}.register-container{width:100%;max-width:480px;margin:0 auto}.register-card{padding:2.5rem 2rem;border-radius:12px;box-shadow:0 10px 30px #00000014;background:#fff;border-top:5px solid #3498db}.register-card h2{text-align:center;font-size:1.8rem;color:#2c3e50;margin-bottom:1.5rem;border-bottom:none;padding-bottom:0;font-weight:700}.register-card .form-group label{font-weight:600;color:#4a5568;margin-bottom:.5rem}.register-card .form-group input{padding:.8rem 1rem;font-size:1rem;border-radius:8px;background-color:#f8fafc;border:1px solid #cbd5e1;transition:all .3s ease}.register-card .form-group input:focus{background-color:#fff;border-color:#3498db;box-shadow:0 0 0 3px #3498db26}.register-card .button-group{margin-top:2rem}.register-card .login-btn{padding:.9rem;font-size:1.1rem;border-radius:8px;background:linear-gradient(135deg,#3498db,#2980b9);transition:all .3s ease;letter-spacing:.5px}.register-card .login-btn:hover{transform:translateY(-2px);box-shadow:0 6px 15px #3498db4d;background:linear-gradient(135deg,#2980b9,#2471a3)}.register-card .form-toggle{margin-top:1.5rem;color:#64748b;text-align:center;font-size:.95rem;padding-top:1.5rem;border-top:1px solid #f1f5f9}.intro-text{display:flex;gap:15px;background-color:#fff;border:1px solid #e2e8f0;border-left:4px solid #3b82f6;border-radius:6px;padding:20px;margin-bottom:25px;text-align:left;box-shadow:0 1px 3px #0000000d}.intro-text .callout-icon{flex-shrink:0;width:24px;height:24px;background-color:#3b82f6;color:#fff;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:Georgia,serif;font-size:14px;margin-top:2px}.intro-text .callout-content{color:#475569;font-size:.95rem;line-height:1.5}.intro-text .callout-content p{margin-bottom:12px}.intro-text .callout-content p:last-of-type{margin-bottom:0}.intro-text .callout-content b{color:#1e293b;font-weight:600}.intro-text .credentials-box{display:inline-block;border:1px solid #e2e8f0;border-radius:6px;padding:8px 16px;margin-top:15px;font-size:.95rem;color:#475569}.intro-text .credentials-box span{color:#1d4ed8;font-weight:600}
