*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f2f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{cursor:pointer}a{color:inherit;text-decoration:none}:root{--bg-primary:#f5f5f5;--bg-secondary:#fff;--text-primary:#1a2340;--text-secondary:#5a627a;--border-color:#e6eaf3;--card-shadow:0 4px 24px #3c48641a;--header-bg:#1a1a1a;--header-text:#fff;--progress-bg:#f0f0f0;--progress-fill:linear-gradient(90deg,#2196f3 60%,#6dd5fa);--button-bg:#0a2540;--button-hover:#2196f3;--button-text:#fff;--card-gradient:linear-gradient(135deg,#f8fafc 60%,#e3e9f7);--card-hover-border:#b3c0e6;--badge-bg:#e6f4ea;--badge-text:#219653;--badge-intermediate-bg:#fffbe6;--badge-intermediate-text:#bfa100;--badge-advanced-bg:#ffeaea;--badge-advanced-text:#d7263d;--nav-active:#4caf50;--nav-hover:#4caf50;--quiz-bg:#fff;--quiz-border:#e6eaf3;--quiz-option-bg:#f8fafc;--quiz-option-border:#e6eaf3;--quiz-option-hover:#e3e9f7;--quiz-correct-bg:#e6f4ea;--quiz-correct-border:#219653;--quiz-incorrect-bg:#ffeaea;--quiz-incorrect-border:#d7263d;--simulation-bg:#f5f7fa;--simulation-border:#e4e8f0;--input-bg:#fff;--input-border:#e0e0e0;--input-text:#333;--accordion-bg:#fff;--accordion-header-bg:#f8f9fa;--accordion-header-hover:#e9ecef;--accordion-header-active:#e3f2fd}.dark-theme{--bg-primary:#1a1a1a;--bg-secondary:#2d2d2d;--text-primary:#fff;--text-secondary:#b3b3b3;--border-color:#404040;--card-shadow:0 4px 24px #0000004d;--header-bg:#000;--header-text:#fff;--progress-bg:#404040;--progress-fill:linear-gradient(90deg,#2196f3 60%,#6dd5fa);--button-bg:#2196f3;--button-hover:#1769aa;--button-text:#fff;--card-gradient:linear-gradient(135deg,#2d2d2d 60%,#1a1a1a);--card-hover-border:#2196f3;--badge-bg:#1a3d2a;--badge-text:#4caf50;--badge-intermediate-bg:#3d3a1a;--badge-intermediate-text:gold;--badge-advanced-bg:#3d1a1a;--badge-advanced-text:#f44;--nav-active:#4caf50;--nav-hover:#4caf50;--quiz-bg:#2d2d2d;--quiz-border:#404040;--quiz-option-bg:#1a1a1a;--quiz-option-border:#404040;--quiz-option-hover:#2d2d2d;--quiz-correct-bg:#1a3d2a;--quiz-correct-border:#4caf50;--quiz-incorrect-bg:#3d1a1a;--quiz-incorrect-border:#f44;--simulation-bg:#1a1a1a;--simulation-border:#404040;--input-bg:#2d2d2d;--input-border:#404040;--input-text:#fff;--accordion-bg:#2d2d2d;--accordion-header-bg:#1a1a1a;--accordion-header-hover:#2d2d2d;--accordion-header-active:#1a3d2a}.theme-toggle{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1.5rem;justify-content:center;margin-left:1rem;padding:.5rem;transition:background-color .3s}.theme-toggle:hover{background-color:#ffffff1a}.module-card{border-color:#e6eaf3;border-color:var(--border-color)}.progress-bar{background:#f0f0f0;background:var(--progress-bg)}.progress{background:linear-gradient(90deg,#2196f3 60%,#6dd5fa);background:var(--progress-fill)}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{background-color:#f5f5f5;background-color:var(--bg-primary);flex:1 1;padding:2rem}.dashboard{margin:0 auto;max-width:1200px;padding:2rem}.dashboard-header{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.modules-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.module-card{border:1.5px solid #e6eaf3;border:1.5px solid var(--border-color);border-radius:18px;box-shadow:0 4px 24px #3c48641a;box-shadow:var(--card-shadow);min-height:270px;padding:2.2rem 1.7rem 1.7rem;transition:box-shadow .22s cubic-bezier(.4,2,.6,1),transform .18s cubic-bezier(.4,2,.6,1)}.module-card:hover{border-color:#b3c0e6;border-color:var(--card-hover-border);box-shadow:0 8px 32px #3c486429,0 2px 8px #3c48641a;transform:translateY(-7px) scale(1.025)}.module-card .module-icon{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #3c486412;display:flex;font-size:2.5rem;justify-content:center;margin-bottom:1.1rem;padding:.7rem 1.1rem}.module-card .module-title{color:#1a2340;color:var(--text-primary);font-size:1.25rem;font-weight:700;letter-spacing:.01em;margin-bottom:.5rem}.module-card .module-desc{color:#5a627a;color:var(--text-secondary);font-size:1.04rem;font-weight:400;margin-bottom:1.2rem;min-height:48px}.module-card .module-meta{color:#5a627a;color:var(--text-secondary);display:flex;font-size:.98rem;font-weight:500;gap:1.1rem;margin-bottom:1.1rem}.module-card .progress-label{font-size:.97rem;font-weight:500}.module-card .continue-module,.module-card .review-module,.module-card .start-module{border-radius:9px;box-shadow:0 2px 8px #3c486412;font-size:1.08rem;font-weight:700;letter-spacing:.01em;padding:1rem 0;transition:background .18s,box-shadow .18s,transform .18s}.module-card .continue-module:hover,.module-card .review-module:hover,.module-card .start-module:hover{box-shadow:0 4px 16px #3c486421;transform:translateY(-2px) scale(1.01)}.progress-circle{align-items:center;background:#4caf50;border-radius:50%;color:#fff;display:flex;font-weight:700;height:60px;justify-content:center;position:relative;width:60px}.overall-progress{align-items:center;display:flex;flex-direction:column;gap:.5rem}.overall-progress p{color:#666;font-size:.9rem;margin:0}.header{align-items:center;background-color:#1a1a1a;background-color:var(--header-bg);box-shadow:0 2px 4px #0000001a;color:#fff;color:var(--header-text);display:flex;justify-content:space-between;padding:1rem 2rem}.logo h1{font-size:1.5rem;margin:0}.logo a{color:#fff;text-decoration:none}.nav ul{display:flex;gap:2rem;list-style:none;margin:0;padding:0}.nav a{color:#fff;color:var(--header-text);font-size:1rem;text-decoration:none;transition:color .2s ease}.nav a:hover{color:#4caf50;color:var(--nav-hover)}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:1rem;text-align:center}.modules-grid{grid-template-columns:1fr}.header{flex-direction:column;padding:1rem}.header,.nav ul{gap:1rem}}.sidebar{background-color:#f5f5f5;border-right:1px solid #ddd;padding:1rem;width:250px}.module-item{border-radius:4px;margin-bottom:1rem;padding:.5rem}.module-item a:hover{color:#4caf50}.recent-activity{background-color:#f5f5f5;border-radius:8px;padding:1.5rem}.recent-activity ul{list-style:none;padding:0}.recent-activity li{border-bottom:1px solid #ddd;padding:.5rem 0}.simulation-page{background:#f5f7fa;background:var(--simulation-bg);border-radius:16px;box-shadow:0 4px 20px #00000014;margin:0 auto;max-width:1200px;padding:2rem}.simulation-page h1{color:#1a2340;color:var(--text-primary);font-size:2.2rem;font-weight:800;letter-spacing:-.02em;margin-bottom:1.5rem;text-align:center}.simulation-page p{color:#5a627a;color:var(--text-secondary);font-size:1.1rem;line-height:1.6;margin-bottom:2rem;text-align:center}.simulation-buttons{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.simulation-button,.try-payload-button,.xss-version-btn{background:#0a2540;background:var(--button-bg);border:none;border-radius:6px;box-shadow:0 2px 8px #3c486412;color:#fff;color:var(--button-text);cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.01em;padding:.7rem 1.2rem;transition:background .18s,box-shadow .18s,transform .18s}.simulation-button:hover,.try-payload-button:hover,.xss-version-btn:hover{background:#2196f3;background:var(--button-hover)}.xss-version-btn.active{background:#43a047;color:#fff}.xss-version-btn.secure.active{background:#1976d2;color:#fff}.nav a.active{color:#4caf50;color:var(--nav-active);font-weight:700}.module-content{color:#1a2340;color:var(--text-primary);max-width:1200px;padding:2rem}.module-section{background:#fff;background:var(--quiz-bg);border-color:#e6eaf3;border-color:var(--quiz-border);border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:2rem}.module-section h2{border-bottom:2px solid #e6eaf3;border-bottom:2px solid var(--border-color);color:#1a2340;color:var(--text-primary);font-size:1.8rem;margin-bottom:1.5rem;padding-bottom:.5rem}.content-block p{margin-bottom:1rem}.content-block ol,.content-block ul{margin:1rem 0;padding-left:2rem}.content-block li{margin-bottom:.5rem}.interactive-section{margin-top:2rem;padding:2rem}.interactive-section h2{color:#1a2340;color:var(--text-primary);margin-bottom:1.5rem}.simulation-container{background:#fff;background:var(--quiz-bg);border-color:#e6eaf3;border-color:var(--quiz-border);border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}.simulation-container h3{color:#1a2340;color:var(--text-primary);margin-bottom:1rem}.quiz{align-items:stretch;background:#fff;background:var(--quiz-bg);border:1.5px solid #e6eaf3;border:1.5px solid var(--quiz-border);border-radius:18px;box-shadow:0 4px 24px #3c48641a,0 1.5px 4px #3c48640f;display:flex;flex-direction:column;margin:2rem auto;max-width:600px;padding:2.5rem 2rem 2rem}.quiz-progress-bar{background:#e6eaf3;border-radius:5px;height:8px;margin-bottom:2rem;overflow:hidden;position:relative;width:100%}.quiz-progress{background:linear-gradient(90deg,#2196f3 60%,#6dd5fa);background:var(--progress-fill);border-radius:5px;height:100%;max-width:100%;min-width:0;transition:width .3s}.quiz-step-indicator{display:flex;gap:.5rem;justify-content:center;margin-bottom:1.5rem}.quiz-step{background:#e6eaf3;border-radius:50%;height:12px;transition:background .2s;width:12px}.quiz-step.active{background:#2196f3}.quiz .question h3{color:#1a2340;color:var(--text-primary);font-size:1.18rem;font-weight:700;letter-spacing:.01em;margin-bottom:1.2rem}.quiz .options{display:flex;flex-direction:column;gap:1.1rem}.quiz .option{align-items:center;background:#f8fafc;background:var(--quiz-option-bg);border:2px solid #e6eaf3;border:2px solid var(--quiz-option-border);border-radius:12px;box-shadow:0 1.5px 4px #3c48640a;color:#1a2340;color:var(--text-primary);cursor:pointer;display:flex;font-size:1.08rem;font-weight:500;gap:.7rem;outline:none;padding:1rem 1.2rem;position:relative;text-align:left;transition:all .18s cubic-bezier(.4,2,.6,1)}.quiz .option.selected{background:#e3e9f7;border-color:#2196f3;color:#2196f3}.quiz .option.correct{background:#e6f4ea;background:var(--quiz-correct-bg);border-color:#219653;border-color:var(--quiz-correct-border);color:#219653;color:var(--badge-text)}.quiz .option.incorrect{background:#ffeaea;background:var(--quiz-incorrect-bg);border-color:#d7263d;border-color:var(--quiz-incorrect-border);color:#d7263d;color:var(--badge-advanced-text)}.quiz .option:disabled{cursor:not-allowed;opacity:.7}.quiz .option .quiz-icon{align-items:center;display:inline-flex;font-size:1.2rem;justify-content:center}.quiz .feedback{align-items:center;background:#f8fafc;background:var(--quiz-option-bg);border-radius:12px;box-shadow:0 1.5px 4px #3c48640a;display:flex;gap:1rem;margin-top:1.5rem;padding:1.2rem}.quiz .feedback .quiz-icon{font-size:1.5rem}.quiz .feedback p{color:#1a2340;color:var(--text-primary);font-size:1.05rem;line-height:1.5;margin-bottom:0}.quiz .next-button,.quiz .retry-button{background:#2196f3;border:none;border-radius:9px;box-shadow:0 2px 8px #3c486412;color:#fff;cursor:pointer;font-size:1.08rem;font-weight:700;letter-spacing:.01em;margin-top:1.5rem;padding:.9rem 0;transition:background .18s,box-shadow .18s,transform .18s;width:100%}.quiz .next-button:hover,.quiz .retry-button:hover{background:#1769aa;box-shadow:0 4px 16px #3c486421;transform:translateY(-2px) scale(1.01)}.quiz-results{background:#fff;border:1.5px solid #e6eaf3;border-radius:18px;box-shadow:0 4px 24px #3c48641a,0 1.5px 4px #3c48640f;margin:0 auto;max-width:600px;padding:2rem 1.5rem;text-align:center}.quiz-results h3{color:#1a2340;font-size:1.4rem;font-weight:700;margin-bottom:1rem}.quiz-results p{color:#5a627a;font-size:1.15rem;margin-bottom:1.5rem}.password-checker{background:#fff;background:var(--quiz-bg);border-color:#e6eaf3;border-color:var(--quiz-border);border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}.checker-container{margin:0 auto;max-width:500px}.checker-container input{border:2px solid #e0e0e0;border:2px solid var(--input-border);border-radius:8px;margin-bottom:1rem;padding:.8rem}.strength-meter{border-radius:4px;height:8px}.strength-bar{transition:width .3s ease,background-color .3s ease}.xss-demo{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}.demo-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin:2rem 0}.secure-section,.vulnerable-section{background:#f8f9fa;border-radius:8px;padding:1.5rem}.input-group{display:flex;gap:1rem;margin-bottom:1rem}.input-group input{border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:1rem;padding:.8rem}.input-group button{background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:.8rem 1.5rem;transition:background-color .3s ease}.input-group button:hover{background:#45a049}.result-box{border-radius:8px;margin:1rem 0;min-height:100px;padding:1rem}.vulnerable{background:#fff3f3;border:1px solid #ffcdd2}.secure{background:#f1f8e9;border:1px solid #c5e1a5}.module-section{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.home{margin:0 auto;max-width:1200px;padding:2rem}.hero-section{background:linear-gradient(135deg,#1a1a1a,#2c3e50);border-radius:12px;color:#fff;margin-bottom:3rem;padding:4rem 2rem;text-align:center}.hero-section h1{font-size:2.5rem;margin-bottom:1rem}.hero-section p{font-size:1.2rem;opacity:.9}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:4rem}.feature-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem;text-align:center;transition:transform .3s ease}.feature-card:hover{transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h2{color:#2c3e50;margin-bottom:1rem}.feature-card p{color:#666;margin-bottom:1.5rem}.feature-button{background:#4caf50;border-radius:6px;color:#fff;display:inline-block;padding:.8rem 1.5rem;text-decoration:none;transition:background-color .3s ease}.feature-button:hover{background:#45a049}.quick-start{background:#f8f9fa;border-radius:12px;padding:3rem 2rem}.quick-start h2{color:#2c3e50;margin-bottom:2rem;text-align:center}.steps{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.step{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;text-align:center}.step-number{align-items:center;background:#4caf50;border-radius:50%;color:#fff;display:flex;font-weight:700;height:40px;justify-content:center;margin:0 auto 1rem;width:40px}.step h3{color:#2c3e50;margin-bottom:.5rem}.step p{color:#666;font-size:.9rem}@media (max-width:768px){.hero-section{padding:3rem 1rem}.hero-section h1{font-size:2rem}.features-grid,.steps{grid-template-columns:1fr}}.user-progress{align-items:center;color:#fff;display:flex;gap:1rem}.progress-circle.small{align-items:center;background:#ffffff1a;border-radius:50%;display:flex;height:40px;justify-content:center;position:relative;width:40px}.progress-circle.small:before{background:#1a1a1a;border-radius:50%;bottom:4px;content:"";left:4px;position:absolute;right:4px;top:4px}.progress-circle.small span{color:#fff;font-size:.9rem;font-weight:700;position:relative;z-index:1}.user-progress span{font-size:.9rem;opacity:.9}.dashboard,.modules-container{margin:0 auto;max-width:1200px;padding:2.5rem 1rem}.dashboard h1,.modules-container h1{color:#1a2340;color:var(--text-primary);font-size:2.2rem;font-weight:700;margin-bottom:2rem}.module-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.module-card{align-items:flex-start;background:linear-gradient(135deg,#f8fafc 60%,#e3e9f7);background:var(--card-gradient);border-radius:16px;box-shadow:0 4px 16px #00000012;display:flex;flex-direction:column;min-height:260px;padding:2rem 1.5rem 1.5rem;position:relative;transition:box-shadow .2s}.module-card:hover{box-shadow:0 8px 24px #00000021}.module-card .module-icon,.module-card img{border-radius:8px;height:48px;margin-bottom:1rem;object-fit:cover;width:48px}.module-card .badge-wrapper{position:absolute;right:1.2rem;top:1.2rem;z-index:2}.module-card .progress-bar{background:#f0f0f0;background:var(--progress-bg);border-radius:4px;height:8px;margin-bottom:.7rem;overflow:hidden;position:relative;width:100%}.module-card .progress{background:linear-gradient(90deg,#2196f3 60%,#6dd5fa);background:var(--progress-fill);border-radius:4px;height:100%;max-width:100%;min-width:0;transition:width .3s}.module-card .progress-label{color:#5a627a;color:var(--text-secondary);font-size:.95rem;margin-bottom:.7rem}.module-card .continue-module,.module-card .review-module,.module-card .start-module{background:#0a2540;background:var(--button-bg);border:none;border-radius:8px;color:#fff;color:var(--button-text);cursor:pointer;font-size:1rem;font-weight:600;margin-top:auto;padding:.9rem 0;transition:background .2s;width:100%}.module-card .continue-module:hover,.module-card .review-module:hover,.module-card .start-module:hover{background:#2196f3;background:var(--button-hover)}.dashboard-header{align-items:flex-start;background:none;box-shadow:none;display:flex;gap:2rem;margin-bottom:2.5rem;padding:0}.dashboard-header .achievements,.dashboard-header .next-module,.dashboard-header .progress-summary{background:#fff;background:var(--bg-secondary);border:1.5px solid #e6eaf3;border:1.5px solid var(--border-color);border-radius:16px;box-shadow:0 4px 24px #3c48641a;box-shadow:var(--card-shadow);color:#1a2340;color:var(--text-primary);flex:1 1;min-width:220px;padding:1.5rem 2rem}.dashboard-header .achievements h2,.dashboard-header .next-module h2,.dashboard-header .progress-summary h2{color:#1a2340;color:var(--text-primary)}.dashboard-header .progress-bar{background:#f0f0f0;background:var(--progress-bg);border-radius:4px;height:8px;margin:.7rem 0 .2rem;overflow:hidden;position:relative;width:100%}.dashboard-header .progress{background:linear-gradient(90deg,#2196f3 60%,#6dd5fa);background:var(--progress-fill);border-radius:4px;height:100%;max-width:100%;min-width:0;transition:width .3s}.dashboard-header .progress-label{color:#5a627a;color:var(--text-secondary);font-size:1rem;font-weight:600}.dashboard-header .achievements{text-align:center}.dashboard-header .next-module{text-align:right}.modules-filters{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.modules-filters input,.modules-filters select{border:1px solid #ddd;border-radius:8px;font-size:1rem;padding:.5rem 1rem}.modules-filters button{background:#f0f0f0;border:none;border-radius:8px;color:#333;cursor:pointer;font-size:1rem;padding:.5rem 1.2rem}.modules-filters button:hover{background:#e0e0e0}@media (max-width:900px){.module-grid{grid-template-columns:1fr 1fr}.dashboard-header{flex-direction:column;gap:1rem}}@media (max-width:600px){.module-grid{grid-template-columns:1fr}.dashboard,.modules-container{padding:1rem .2rem}}.badge{background:#e6f4ea;background:var(--badge-bg);border-radius:999px;box-shadow:0 1px 4px #0000000a;color:#219653;color:var(--badge-text);font-size:.95rem;font-weight:600;letter-spacing:.02em;padding:.3rem 1.1rem;transition:background .2s,color .2s}.badge.intermediate{background:#fffbe6;background:var(--badge-intermediate-bg);color:#bfa100;color:var(--badge-intermediate-text)}.badge.advanced{background:#ffeaea;background:var(--badge-advanced-bg);color:#d7263d;color:var(--badge-advanced-text)}.badge.completed{background:#e6f4ea;background:var(--badge-bg);border:1px solid #219653;border:1px solid var(--badge-text);color:#219653;color:var(--badge-text)}.email-container{background:#fff;background:var(--bg-secondary);border:1.5px solid #e6eaf3;border:1.5px solid var(--border-color);border-radius:12px;box-shadow:0 4px 24px #3c48641a;box-shadow:var(--card-shadow);color:#1a2340;color:var(--text-primary);margin:1.5rem 0;padding:1.5rem}.email-header{border-bottom:1px solid #e6eaf3;border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:1rem}.email-content,.email-header{color:#5a627a;color:var(--text-secondary)}.email-content{font-family:monospace;line-height:1.5;white-space:pre-wrap}.email-content strong,.email-header strong{color:#1a2340;color:var(--text-primary)}.simulation-controls{display:flex;gap:1rem;margin-bottom:1.5rem}.simulation-button.active{background:linear-gradient(135deg,#4caf50,#45a049)}.simulation-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin:1.5rem 0}.input-section,.output-section{background:#fff;background:var(--quiz-bg);border-color:#e6eaf3;border-color:var(--quiz-border);border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.input-section textarea{color:#333;color:var(--input-text);font-family:monospace;padding:1rem;resize:vertical}.input-section textarea,.output-frame{background:#fff;background:var(--input-bg);border:2px solid #e0e0e0;border:2px solid var(--input-border);border-radius:8px;margin:1rem 0;width:100%}.output-display,.output-frame{min-height:200px}.output-display{background:#fff;background:var(--input-bg);border:2px solid #e0e0e0;border:2px solid var(--input-border);border-radius:8px;color:#333;color:var(--input-text);margin:1rem 0;overflow-x:auto;padding:1rem;white-space:pre-wrap;word-break:break-word}.simulation-info{background:#fff;background:var(--quiz-bg);border-radius:12px;margin:1.5rem 0;padding:1.5rem}.simulation-info code{background:#e9ecef;border-radius:4px;font-family:monospace;padding:.2rem .4rem}.progress-text{color:#666;margin-top:1rem;text-align:center}@media (max-width:768px){.simulation-container{grid-template-columns:1fr}.simulation-controls{flex-direction:column}}.explanation-box{background:#fff;background:var(--quiz-bg);border-left:4px solid #2196f3;border-radius:0 8px 8px 0;margin-top:1rem;padding:1rem}.explanation-box h4{color:#2196f3;margin:0 0 .5rem}.explanation-box p{color:#666;line-height:1.5;margin:0}.payload-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.payload-item{align-items:center;background:#fff;background:var(--quiz-bg);border:1px solid #e0e0e0;border:1px solid var(--input-border);border-radius:8px;display:flex;gap:1rem;padding:1rem}.payload-item code{background:#fff;background:var(--input-bg);border-radius:4px;color:#1a2340;color:var(--text-primary);flex:1 1;font-family:monospace;font-size:1rem;padding:.2rem .5rem}.try-payload-button{background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:background .2s}.try-payload-button:hover{background:#1976d2}.simulation-button:disabled{background:#ccc;cursor:not-allowed;transform:none}.simulation-button:disabled:hover{box-shadow:none;transform:none}.simulation-card{align-items:flex-start;background:linear-gradient(135deg,#f8fafc 60%,#e3e9f7);background:var(--card-gradient);border:1.5px solid #e6eaf3;border:1.5px solid var(--border-color);border-radius:14px;box-shadow:0 4px 24px #3c48641a;box-shadow:var(--card-shadow);display:flex;flex-direction:column;margin-bottom:1.5rem;min-height:220px;overflow:hidden;padding:2.5rem 1.7rem 2rem;position:relative;transition:box-shadow .22s cubic-bezier(.4,2,.6,1),transform .18s cubic-bezier(.4,2,.6,1)}.simulation-card,.simulation-card h2{color:#1a2340;color:var(--text-primary)}.simulation-card h2{font-size:1.35rem;font-weight:700;letter-spacing:.01em;margin-bottom:.7rem}.simulation-card p{color:#5a627a;color:var(--text-secondary);font-size:1.08rem;font-weight:400;line-height:1.6;margin-bottom:1.7rem}.simulation-button{background:#0a2540;background:var(--button-bg);color:#fff;color:var(--button-text)}.simulation-button:hover{background:#2196f3;background:var(--button-hover)}.simulations-container h1{color:#1a2340;font-size:2.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:3rem;text-align:center}.feedback{border-radius:8px;font-size:1.1rem;font-weight:600;margin:20px 0;padding:15px 20px}.feedback.correct{background-color:#e6f4ea;background-color:var(--quiz-correct-bg);border-left:4px solid #219653;border-left:4px solid var(--quiz-correct-border);color:#219653;color:var(--badge-text)}.feedback.incorrect{background-color:#ffeaea;background-color:var(--quiz-incorrect-bg);border-left:4px solid #d7263d;border-left:4px solid var(--quiz-incorrect-border);color:#d7263d;color:var(--badge-advanced-text)}.explanation-details{background-color:#f8fafc;background-color:var(--quiz-option-bg);border-left:4px solid #0a2540;border-left:4px solid var(--button-bg);border-radius:8px;color:#1a2340;color:var(--text-primary);margin:15px 0;padding:20px}.progress{background-color:#fff;background-color:var(--quiz-bg);border-radius:8px;margin-top:20px;padding:15px;text-align:center}.progress p{color:#666;font-size:.9rem;margin:5px 0}.button-container{display:flex;gap:15px;justify-content:center;margin:20px 0}.button-container button{background-color:#0a2540;background-color:var(--button-bg);border-radius:6px;color:#fff;color:var(--button-text);cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .2s ease}.button-container button:first-child{background-color:#f44336;border:none;color:#fff}.button-container button:last-child{background-color:#4caf50;border:none;color:#fff}.button-container button:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.accordion{background:#fff;background:var(--accordion-bg);border:1px solid #e6eaf3;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:16px;overflow:hidden}.accordion-header{align-items:center;background:#f8f9fa;background:var(--accordion-header-bg);border:none;color:#1a2340;color:var(--text-primary);cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;justify-content:space-between;padding:16px 20px;text-align:left;transition:all .3s ease;width:100%}.accordion-header:hover{background:#e9ecef;background:var(--accordion-header-hover)}.accordion-header.expanded{background:#e3f2fd;background:var(--accordion-header-active);border-bottom:1px solid #e6eaf3;border-bottom:1px solid var(--border-color)}.accordion-icon{color:#2196f3;font-size:1.5rem;transition:transform .3s ease}.accordion-content{color:#1a2340;color:var(--text-primary);max-height:0;overflow:hidden;padding:0 20px;transition:max-height .3s ease-out}.accordion-content.expanded{max-height:2000px;padding:20px}.module-content{margin:0 auto;max-width:800px;padding:20px}.module-section{margin-bottom:30px}.content-block{color:#1a2340;color:var(--text-primary);line-height:1.6}.content-block p{margin-bottom:12px}.interactive-section{background:#f8fafc;background:var(--quiz-option-bg);border-color:#e6eaf3;border-color:var(--quiz-border);border-radius:8px;margin-top:40px;padding:20px}.password-checker{margin-bottom:30px}.checker-container{margin-top:15px}.checker-container input{background:#fff;background:var(--input-bg);border:1px solid #e0e0e0;border:1px solid var(--input-border);border-radius:4px;color:#333;color:var(--input-text);font-size:1rem;margin-bottom:10px;padding:12px;width:100%}.strength-meter{background:#f0f0f0;background:var(--progress-bg);border-radius:2px;height:4px;overflow:hidden}.strength-bar{background:#4caf50;height:100%;transition:width .3s ease;width:0}.quiz-container{margin-top:30px}.csrf-demo-container{background:#fff;background:var(--quiz-bg);border:1.5px solid #e6eaf3;border:1.5px solid var(--border-color);border-radius:16px;box-shadow:0 4px 24px #3c48641a;box-shadow:var(--card-shadow);color:#1a2340;color:var(--text-primary);margin:2rem auto;max-width:900px;padding:2.5rem 1.5rem}.csrf-demo-container h1{color:#1a2340;color:var(--text-primary);margin-bottom:2rem;text-align:center}.csrf-toggle-row{justify-content:center}.csrf-panels,.csrf-toggle-row{display:flex;margin-bottom:2rem}.csrf-panels{flex-wrap:wrap;gap:2rem}.csrf-panel{background:#fff;background:var(--bg-secondary);border:1.5px solid #e6eaf3;border:1.5px solid var(--border-color);border-radius:12px;box-shadow:0 4px 24px #3c48641a;box-shadow:var(--card-shadow);flex:1 1 320px;min-width:300px;padding:1.5rem}.bank-panel h2,.malicious-panel h2{color:#1a2340;color:var(--text-primary);margin-bottom:1rem}.csrf-email{color:#2196f3;color:var(--button-hover);font-family:monospace}.csrf-form{display:flex;flex-direction:column;gap:.7rem;margin-top:1rem}.csrf-form input[type=email]{background:#fff;background:var(--input-bg);border:1.5px solid #e0e0e0;border:1.5px solid var(--input-border);border-radius:6px;color:#333;color:var(--input-text);font-size:1rem;padding:.6rem}.csrf-form button{background:#0a2540;background:var(--button-bg);border:none;border-radius:6px;color:#fff;color:var(--button-text);cursor:pointer;font-size:1rem;font-weight:600;padding:.7rem 1.2rem;transition:background .18s}.csrf-form button:hover{background:#2196f3;background:var(--button-hover)}.malicious-btn{background:#d7263d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1.2rem;padding:.7rem 1.2rem;transition:background .18s}.malicious-btn:hover{background:#a61b2b}.csrf-feedback{color:#1a2340;color:var(--text-primary);font-weight:600;margin:1.5rem auto 0;max-width:600px;padding:1rem 1.5rem;text-align:center}.csrf-explanation,.csrf-feedback{background:#f8fafc;background:var(--quiz-option-bg);border:1.5px solid #e6eaf3;border:1.5px solid var(--border-color);border-radius:8px}.csrf-explanation{color:#5a627a;color:var(--text-secondary);margin-top:2.5rem;padding:1.2rem 1.5rem}.csrf-explanation h3{color:#1a2340;color:var(--text-primary);margin-bottom:.7rem}@media (max-width:900px){.csrf-panels{flex-direction:column;gap:1.5rem}}.csrf-request-visual{display:flex;justify-content:center;margin-bottom:1.5rem}.request-box{background:#fff;background:var(--accordion-bg);border:2px solid #e6eaf3;border:2px solid var(--border-color);border-radius:10px;box-shadow:0 2px 8px #3c486412;color:#1a2340;color:var(--text-primary);font-size:1rem;margin:0 auto;max-width:420px;min-width:320px;padding:1.2rem 1.5rem;position:relative;text-align:left}.request-box.safe{border-color:#4caf50}.request-box.attack{border-color:#d7263d}.req-url{color:#2196f3;color:var(--button-hover);font-family:monospace}.req-token-status{font-weight:700;margin-top:.7rem}.csrf-feedback.safe{background:#e6f4ea;border:1.5px solid #219653;color:#219653}.csrf-feedback.fail{background:#ffeaea;border:1.5px solid #d7263d;color:#d7263d}.xss-request-visual{background:#fff;background:var(--accordion-bg);border:2px solid #e6eaf3;border:2px solid var(--border-color);border-radius:10px;color:#1a2340;color:var(--text-primary);font-size:1rem;margin-bottom:1.2rem;margin-left:auto;margin-right:auto;max-width:500px;padding:1.2rem 1.5rem}.xss-request-visual.vulnerable{border-color:#d7263d}.xss-request-visual.secure{border-color:#4caf50}.xss-input-box,.xss-output-box{background:#fff;background:var(--input-bg);border:1.5px solid #e0e0e0;border:1.5px solid var(--input-border);border-radius:6px;color:#333;color:var(--input-text);font-family:monospace;font-size:.98rem;margin:.3rem 0 .7rem;padding:.5rem .7rem;white-space:pre-wrap}.xss-rendered-box{background:#f8fafc;background:var(--quiz-option-bg);border:2px solid #d7263d;border-radius:6px;color:#1a2340;color:var(--text-primary);font-size:1.05rem;margin:.3rem 0 .7rem;min-height:32px;padding:.7rem 1rem}.xss-request-visual.secure .xss-rendered-box{border-color:#4caf50}.xss-token-status{font-weight:700;margin-top:.7rem}.simulation-info h3,.simulation-page h2,.sqlidemo-container{color:#1a2340;color:var(--text-primary)}.sqlidemo-container{background:#fff;background:var(--quiz-bg);border:1.5px solid #e6eaf3;border:1.5px solid var(--border-color);border-radius:16px;box-shadow:0 4px 24px #3c48641a;box-shadow:var(--card-shadow);margin:2rem auto;max-width:600px;padding:2.5rem 1.5rem}.sqlidemo-container h1{color:#1a2340;color:var(--text-primary);margin-bottom:2rem;text-align:center}.sqlidemo-form{display:flex;flex-direction:column;gap:1.1rem;margin-bottom:1.5rem}.sqlidemo-form label{color:#1a2340;color:var(--text-primary);font-weight:500}.sqlidemo-form input[type=password],.sqlidemo-form input[type=text]{background:#fff;background:var(--input-bg);border:1.5px solid #e0e0e0;border:1.5px solid var(--input-border);border-radius:6px;color:#333;color:var(--input-text);font-size:1rem;margin-top:.3rem;padding:.7rem}.sqlidemo-form button{background:#0a2540;background:var(--button-bg);border:none;border-radius:6px;color:#fff;color:var(--button-text);cursor:pointer;font-size:1rem;font-weight:600;padding:.7rem 1.2rem;transition:background .18s}.sqlidemo-form button:hover{background:#2196f3;background:var(--button-hover)}.sqlidemo-payloads{margin-bottom:1.5rem}.sqlidemo-payloads h3{color:#1a2340;color:var(--text-primary);margin-bottom:.7rem}.sqlidemo-query-visual{display:flex;justify-content:center;margin-bottom:1.2rem}.sqlidemo-query-box{background:#fff;background:var(--accordion-bg);border:2px solid #e6eaf3;border:2px solid var(--border-color);border-radius:10px;box-shadow:0 2px 8px #3c486412;color:#1a2340;color:var(--text-primary);font-size:1rem;margin:0 auto;max-width:420px;min-width:320px;overflow-x:auto;padding:1.2rem 1.5rem;position:relative;text-align:left}.sqlidemo-query-box.vulnerable{border-color:#d7263d}.sqlidemo-query-box.secure{border-color:#4caf50}.sqlidemo-query-status{font-weight:700;margin-top:.7rem}.sqlidemo-feedback.safe{background:#e6f4ea;border:1.5px solid #219653;border-radius:8px;color:#219653}.sqlidemo-feedback.fail,.sqlidemo-feedback.safe{font-weight:600;margin-top:1.2rem;padding:1rem 1.5rem;text-align:center}.sqlidemo-feedback.fail{background:#ffeaea;border:1.5px solid #d7263d;border-radius:8px;color:#d7263d}.sqli-highlight{background:#fff3cd;border-radius:3px;color:#b8860b;font-weight:700;padding:0 2px}.sqlidemo-explanation{color:#5a627a;color:var(--text-secondary);font-size:1.02rem;margin-top:.7rem}.sqlidemo-query-box pre{background:#fff;background:var(--input-bg);border-radius:4px;color:#333;color:var(--input-text);font-family:monospace;font-size:1rem;margin:.7rem 0 .5rem;max-width:100%;overflow-x:auto;padding:.5rem .7rem;white-space:pre;word-break:break-all}.query-toggle-btn{background:#0a2540;background:var(--button-bg);border:none;border-radius:6px;box-shadow:0 1px 4px #3c486412;color:#fff;color:var(--button-text);cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:.7rem;padding:.5rem 1.1rem;transition:background .18s,color .18s}.query-toggle-btn:hover{background:#2196f3;background:var(--button-hover);color:#fff;color:var(--button-text)}.sqlidemo-shield{color:#4caf50;font-size:1.5rem;vertical-align:middle}.sqlidemo-secure-visual{align-items:center;background:#e6f4ea;border-radius:6px;display:inline-flex;padding:.3rem .8rem}.sqlidemo-barrier{margin:.7rem 0;text-align:center}.sqlidemo-barrier-label{background:#e6f4ea;border-radius:4px;color:#219653;display:inline-block;font-size:.98rem;font-weight:600;padding:.2rem .7rem}.sqlidemo-step-explanation{background:#f8fafc;background:var(--quiz-option-bg);border-radius:6px;color:#5a627a;color:var(--text-secondary);font-size:.98rem;margin-top:1rem;padding:.7rem 1rem}.sqlidemo-step-explanation ol{margin:0;padding-left:1.2rem}.sqlidemo-step-explanation li{margin-bottom:.4rem}.sqlidemo-params-array{align-items:flex-start;display:flex;gap:.7rem;margin:.7rem 0}.sqlidemo-params-label{color:#219653;font-size:1rem;font-weight:600;margin-top:.2rem}.sqlidemo-params{background:#fff;background:var(--input-bg);border-radius:4px;color:#333;color:var(--input-text);font-family:monospace;font-size:1rem;margin:0;padding:.2rem .7rem}
/*# sourceMappingURL=main.deaa1af6.css.map*/