: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;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}}.simulation-header{background:#fff;padding:1.2rem;border-radius:10px;box-shadow:0 3px 10px #0000001a}.header-content{display:flex;flex-direction:column;gap:.4rem}.help-toggle{align-self:flex-start;background:#3498db;color:#fff;border:none;padding:.4rem .8rem;border-radius:5px;cursor:pointer;font-size:.8rem;margin-top:.4rem}.simulation-layout{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:1.2rem}.login-details-panel{background:#fff;padding:1.2rem;border-radius:10px;box-shadow:0 3px 10px #0000001a;height:fit-content;max-height:580px;overflow-y:auto}.login-details-panel h3{margin-top:0;color:#2c3e50;font-size:1.1rem;display:flex;align-items:center;gap:.4rem}.panel-description{color:#666;margin-top:.5rem;margin-bottom:1rem;font-size:.9rem}.table-container{overflow-x:auto}.details-table{width:100%;border-collapse:collapse;font-size:.85rem}.details-table th,.details-table td{padding:.6rem;text-align:left;border-bottom:1px solid #eee}.details-table th{background-color:#f8f9fa;font-weight:600;color:#2c3e50;position:sticky;top:0}.details-table tr:hover{background-color:#f9f9f9}.success-row{background-color:#f0f9f4}.success-row:hover{background-color:#e8f5ed}.status-badge.success{background-color:#27ae60;color:#fff;padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600;display:inline-block}.time-cell{color:#666;font-family:monospace;font-size:.75rem}.user-cell{font-weight:600;color:#2c3e50}.no-data{text-align:center;color:#999;padding:1.5rem;font-style:italic}.role-privileges{background:#f8f9fa;padding:.8rem;border-radius:6px;border-left:3px solid #9b59b6;margin:.8rem 0}.role-privileges h4{margin-bottom:.4rem;color:#2c3e50;font-size:.8rem}.role-privileges ul{list-style:none;padding:0;margin:0}.privilege-item{padding:.3rem 0;font-size:.75rem;color:#2c3e50}.role-badge{padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:600}.status.active{color:#27ae60;font-weight:600}.status.inactive{color:#e74c3c;font-weight:600}.schema-table.users-table h4{background:#9b59b6}.user-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.4rem;margin-top:.4rem}.detail-item{font-size:.7rem}.detail-label{font-weight:600;color:#2c3e50}.detail-value{color:#7f8c8d;word-break:break-word}.app-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 1.5rem;box-shadow:0 2px 15px #0000001a;display:flex;justify-content:space-between;align-items:center}.app-header h1{color:#2c3e50;font-size:1.5rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.panel-navigation{background:#fff;padding:1rem 1.5rem;display:flex;gap:1rem;border-bottom:2px solid #e1e8ed;box-shadow:0 2px 8px #0000000d}.panel-btn{background:none;border:2px solid #e1e8ed;padding:.8rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;color:#666;transition:all .3s;display:flex;align-items:center;gap:.5rem}.panel-btn:hover{background:#f8f9fa;border-color:#3498db;color:#3498db}.panel-btn.active{background:#3498db;border-color:#2980b9;color:#fff}.panel-header{background:#fff;padding:1.5rem;border-radius:10px;margin-bottom:1.5rem;box-shadow:0 3px 10px #00000014}.panel-header h2{color:#2c3e50;margin:0;font-size:1.3rem;display:flex;align-items:center;gap:.5rem}.panel-subtitle{color:#666;margin-top:.5rem;font-size:.95rem}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #e1e8ed;padding-bottom:.5rem;flex-wrap:wrap}.tab-btn{background:none;border:none;padding:.8rem 1.2rem;border-radius:6px;cursor:pointer;font-weight:500;color:#666;transition:all .3s;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.tab-btn:hover{background:#f8f9fa;color:#333}.tab-btn.active{background:#3498db;color:#fff}.tab-content{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 3px 10px #00000014;min-height:500px}.success-banner{background:#d5f4e6;color:#27ae60;padding:1rem;border-radius:8px;margin-bottom:1.5rem;border:1px solid #27ae60;font-weight:500}.registration-form-container{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}.form-card,.info-card{background:#f8f9fa;border-radius:8px;padding:1.5rem;border:1px solid #e1e8ed}.form-card h3,.info-card h3{color:#2c3e50;margin-bottom:1rem;font-size:1.1rem}.registration-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group input,.form-group select{padding:.6rem;border:2px solid #e1e8ed;border-radius:6px;font-size:.85rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db}.form-group input.error,.form-group select.error{border-color:#e74c3c}.password-requirements-card{background:#f8f9fa;padding:1rem;border-radius:6px;border:1px solid #e1e8ed;margin:1rem 0}.password-requirements-card h4{color:#2c3e50;margin-bottom:.8rem;font-size:.9rem}.requirements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;margin-top:.5rem}.req-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:4px;font-size:.8rem}.req-item.met{background:#d5f4e6;color:#27ae60}.req-item.unmet{background:#fdeaea;color:#e74c3c}.req-icon{font-size:.9rem}.privileges-display{margin:1rem 0;padding:1rem;background:#e8f4fd;border-radius:8px;border-left:4px solid #3498db}.privileges-display h4{color:#2c3e50;margin-bottom:.8rem;font-size:.9rem}.privileges-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.privilege-tag{background:#fff;color:#3498db;padding:.4rem .8rem;border-radius:15px;font-size:.75rem;font-weight:500;border:1px solid #3498db}.register-btn{background:#27ae60;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;width:100%;margin-top:1rem;transition:background .3s}.schema-preview{margin-top:1rem}.schema-table h4{background:#34495e;color:#fff;padding:.8rem;margin:0;font-size:.9rem}.field{display:flex;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid #ecf0f1;font-size:.8rem}.field span:first-child{font-weight:600;color:#2c3e50}.field span:last-child{color:#7f8c8d;text-align:right}.policies-container{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}.policy-form-card,.policy-summary-card{background:#f8f9fa;border-radius:8px;padding:1.5rem;border:1px solid #e1e8ed}.policy-section{margin-bottom:2rem;padding:1rem;background:#fff;border-radius:8px;border-left:4px solid #3498db}.policy-section h4{color:#2c3e50;margin-bottom:1rem;font-size:.95rem}.policy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.policy-item{display:flex;flex-direction:column;gap:.5rem}.policy-item input[type=number]{padding:.5rem;border:2px solid #e1e8ed;border-radius:4px;width:80px}.update-policies-btn{background:#3498db;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;margin-top:1rem;transition:background .3s}.update-policies-btn:hover{background:#2980b9}.summary-grid{display:grid;grid-template-columns:1fr;gap:.8rem}.summary-item{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #e1e8ed}.summary-label{font-weight:600;color:#555;font-size:.85rem}.summary-value{color:#2c3e50;font-weight:500;font-size:.85rem}.database-operations-view{max-height:500px;overflow-y:auto}.database-operations-view h3{color:#2c3e50;margin-bottom:1rem;font-size:1.1rem}.no-operations{text-align:center;color:#999;padding:2rem;font-style:italic}.database-entry{border:1px solid #e1e8ed;border-left:3px solid #3498db;border-radius:5px;padding:.8rem;background:#f8f9fa;margin-bottom:.8rem;animation:slideIn .3s ease-out}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;font-size:.75rem}.timestamp{color:#999;font-size:.7rem}.query-display{background:#2c3e50;color:#fff;padding:.8rem;border-radius:4px;margin:.5rem 0;font-family:monospace;font-size:.8rem}.query-header{font-size:.75rem;opacity:.8;margin-bottom:.3rem}.query-text{word-break:break-all;line-height:1.3}.entry-data{display:flex;flex-direction:column;gap:.3rem;margin:.5rem 0}.field-value{color:#7f8c8d;font-family:monospace;max-width:60%;text-align:right;word-break:break-all}.entry-result{font-size:.7rem;color:#27ae60;font-weight:600;text-align:right}.entry-result.success{color:#27ae60}.entry-result.found{color:#3498db}.entry-result.not_found{color:#e74c3c}.login-container{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.login-card{background:#f8f9fa;padding:1.5rem;border-radius:8px;border:1px solid #e1e8ed}.login-card h3{color:#2c3e50;margin-bottom:1.5rem;font-size:1.1rem}.already-logged-in{text-align:center}.user-info-card{background:#fff;padding:1rem;border-radius:6px;margin:1rem 0;text-align:left}.user-info-card h4{color:#2c3e50;margin-bottom:.8rem;font-size:.9rem}.user-details{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.detail-item{display:flex;flex-direction:column;gap:.2rem}.detail-label{font-weight:600;color:#555;font-size:.8rem}.detail-value{color:#2c3e50;font-size:.85rem}.role-badge{padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:600;display:inline-block}.role-badge.administrator{background:#e74c3c;color:#fff}.role-badge.manager{background:#3498db;color:#fff}.role-badge.user{background:#2ecc71;color:#fff}.login-buttons{display:flex;gap:1rem;margin-top:1rem}.login-btn,.simulate-btn{flex:1;border:none;padding:.8rem;border-radius:6px;font-weight:600;cursor:pointer;transition:background .3s}.login-btn{background:#27ae60;color:#fff}.simulate-btn{background:#3498db;color:#fff}.simulate-btn:hover{background:#2980b9}.test-credentials{margin-top:1.5rem;padding:1rem;background:#fff9e6;border-radius:6px;border-left:4px solid #f1c40f}.test-credentials h4{color:#2c3e50;margin-bottom:.5rem;font-size:.9rem}.test-credentials ul{margin:.5rem 0 0;padding-left:1rem}.test-credentials li{font-size:.85rem;margin-bottom:.3rem;line-height:1.3}.database-preview{background:#fff;padding:1.5rem;border-radius:8px;border:1px solid #e1e8ed;box-shadow:0 2px 8px #0000000d}.database-preview h3{color:#2c3e50;margin-bottom:1rem;font-size:1.1rem}.users-table-preview{border:1px solid #e1e8ed;border-radius:6px;overflow:hidden;margin-top:1rem}.users-table-preview .table-header{display:grid;grid-template-columns:.5fr 1fr 1fr 1fr 1fr;gap:.8rem;background:#34495e;color:#fff;padding:.8rem;font-weight:600;font-size:.8rem}.users-table-preview .table-row{display:grid;grid-template-columns:.5fr 1fr 1fr 1fr 1fr;gap:.8rem;padding:.8rem;border-bottom:1px solid #e1e8ed;align-items:center;font-size:.8rem}.users-table-preview .table-row:last-child{border-bottom:none}.preview-note{font-size:.8rem;color:#666;text-align:center;margin-top:.5rem}.simulation-container{display:grid;grid-template-columns:1fr 2fr;gap:1.5rem}.control-card,.database-operations-card{background:#f8f9fa;padding:1.5rem;border-radius:8px;border:1px solid #e1e8ed}.control-card h3,.database-operations-card h3{color:#2c3e50;margin-bottom:1rem;font-size:1.1rem}.simulation-buttons{display:flex;flex-direction:column;gap:.8rem;margin-top:1rem}.simulate-btn.primary,.reset-btn{padding:.8rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.simulate-btn.primary{background:#27ae60;color:#fff}.simulate-btn.primary:disabled{background:#bdc3c7;cursor:not-allowed}.reset-btn:disabled{background:#bdc3c7;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.result-banner{padding:1rem;border-radius:6px;margin-top:1rem;font-weight:500}.result-banner.success{background:#d5f4e6;color:#27ae60;border:1px solid #27ae60}.result-banner.error{background:#fdeaea;color:#e74c3c;border:1px solid #e74c3c}.op-item{display:flex;align-items:center;gap:1rem;padding:.5rem;border-bottom:1px solid #e1e8ed;font-size:.8rem}.op-time{color:#666;min-width:60px;font-size:.7rem}.op-type{padding:.2rem .5rem;border-radius:3px;font-weight:600;font-size:.7rem}.op-type.select{background:#3498db;color:#fff}.op-type.insert{background:#27ae60;color:#fff}.op-type.update{background:#f39c12;color:#fff}.op-type.delete{background:#e74c3c;color:#fff}.op-table{color:#666;font-style:italic;font-size:.75rem}.op-result{font-weight:600;font-size:.7rem}.op-result.success{color:#27ae60}.op-result.found{color:#3498db}.op-result.not_found{color:#e74c3c}.steps-visualization{display:flex;flex-direction:column;gap:.8rem;max-height:600px;overflow-y:auto;padding:1rem}.no-simulation{text-align:center;color:#999;padding:2rem;font-style:italic}.step{border:2px solid #e1e8ed;border-radius:8px;padding:1rem;transition:all .3s;cursor:pointer}.step:hover{border-color:#3498db;background:#f8fafc}.step.selected{border-color:#3498db;background:#f8fafc;box-shadow:0 3px 6px #3498db33}.step.active{border-color:#3498db;background:#f8fafc}.step-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.6rem}.step-icon{font-size:1.2rem}.step-status{font-size:1rem;font-weight:600;width:20px;text-align:center}.step-details{margin-top:.8rem;padding-top:.8rem;border-top:1px solid #e1e8ed}.database-visualization{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.schema-view h3,.data-visualization h3{color:#2c3e50;margin-bottom:1rem;font-size:1.1rem}.schema-tables{display:flex;flex-direction:column;gap:1rem;max-height:500px;overflow-y:auto}.data-visualization .stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:#f8f9fa;border:1px solid #e1e8ed;border-radius:8px;padding:1rem;text-align:center}.stat-value{font-size:2rem;font-weight:700;color:#3498db;margin-bottom:.5rem}.stat-label{font-size:.85rem;color:#666;font-weight:500}.recent-operations{background:#f8f9fa;padding:1rem;border-radius:8px;border:1px solid #e1e8ed}.recent-operations h4{color:#2c3e50;margin-bottom:1rem;font-size:.95rem}.operations-timeline{max-height:300px;overflow-y:auto}.timeline-item{display:flex;align-items:flex-start;gap:1rem;padding:.8rem;border-bottom:1px solid #e1e8ed;position:relative}.timeline-item:last-child{border-bottom:none}.timeline-time{font-size:.7rem;color:#666;min-width:60px}.timeline-dot{width:12px;height:12px;border-radius:50%;background:#3498db;margin-top:.2rem;flex-shrink:0}.timeline-dot.select{background:#3498db}.timeline-dot.insert{background:#27ae60}.timeline-dot.update{background:#f39c12}.timeline-dot.delete{background:#e74c3c}.timeline-content{flex:1}.timeline-op{font-size:.8rem;font-weight:600;color:#2c3e50;margin-bottom:.2rem}.timeline-query{font-size:.7rem;color:#666;font-family:monospace;word-break:break-all}.logs-container{max-height:600px;overflow-y:auto}.logs-container h3{color:#2c3e50;margin-bottom:1rem;font-size:1.1rem}.logs-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e1e8ed}.logs-stats{display:flex;gap:1.5rem;font-size:.85rem;color:#666}.logs-stats span{padding:.3rem .6rem;background:#f8f9fa;border-radius:4px}.no-logs{text-align:center;color:#999;padding:2rem;font-style:italic}.logs-list{display:flex;flex-direction:column;gap:.5rem}.log-entry{display:grid;grid-template-columns:80px 1fr 1fr auto 2fr;gap:1rem;padding:.8rem;border-radius:6px;font-size:.8rem;align-items:center;animation:slide-in .3s ease-out}.log-entry.info{background:#e8f4fd;border-left:3px solid #3498db}.log-time{font-family:monospace;color:#666;font-size:.7rem}.log-event{font-weight:600;color:#2c3e50}.log-user{color:#666;font-style:italic}.log-status{padding:.2rem .6rem;border-radius:15px;font-weight:600;font-size:.7rem;text-align:center}.log-status.info{background:#3498db;color:#fff}.log-message{color:#555;font-size:.75rem;word-break:break-word}@media(max-width:1024px){.registration-form-container,.policies-container,.login-container,.simulation-container,.database-visualization{grid-template-columns:1fr}.panel-navigation{flex-wrap:wrap}.app-header{flex-direction:column;gap:1rem;text-align:center}.session-info{flex-direction:column;gap:.5rem}}@media(max-width:768px){.form-row,.user-details,.users-table-preview .table-header,.users-table-preview .table-row,.log-entry{grid-template-columns:1fr}.tabs{flex-direction:column}.tab-btn{width:100%;justify-content:center}.policy-grid,.requirements-grid{grid-template-columns:1fr}.logs-stats{flex-direction:column;gap:.5rem}.stat-card{padding:.8rem}.stat-value{font-size:1.5rem}}@media(max-width:480px){.panel-navigation{flex-direction:column}.panel-btn{width:100%;justify-content:center}.main-content,.tab-content,.form-card,.info-card,.policy-form-card,.policy-summary-card,.control-card,.database-operations-card,.login-card,.database-preview{padding:1rem}.step-header{flex-wrap:wrap}.timeline-item{flex-direction:column;gap:.5rem}.timeline-dot{position:absolute;left:0;top:.8rem}.timeline-time{padding-left:1.5rem}}.tab-content.compact{padding:1rem;max-height:calc(100vh - 300px);overflow-y:auto}.card-header{margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #e1e8ed}.card-header h3{margin:0;font-size:1rem;color:#2c3e50}.card-subtitle{margin:.2rem 0 0;font-size:.75rem;color:#666}.form-group.compact{gap:.3rem}.form-group.compact label{font-size:.75rem;margin-bottom:.2rem}.form-group.compact input,.form-group.compact select{padding:.5rem;font-size:.8rem;height:36px}.compact-select{height:36px;padding:.4rem;font-size:.8rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:.8rem}.password-strength-indicator{margin:.8rem 0}.strength-label{font-size:.75rem;margin-bottom:.3rem;display:flex;justify-content:space-between}.strength-meter{height:4px;background:#ecf0f1;border-radius:2px;overflow:hidden}.selected-policy-summary{background:#f8f9fa;padding:.8rem;border-radius:6px;margin:.8rem 0;border-left:3px solid #3498db}.selected-policy-summary h4{margin:0 0 .5rem;font-size:.85rem;color:#2c3e50}.policy-highlights{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.highlight-item{display:flex;justify-content:space-between;font-size:.75rem}.highlight-label{color:#666}.highlight-value{color:#2c3e50;font-weight:500}.registration-actions{display:flex;gap:.8rem;margin-top:1rem}.register-btn.compact{flex:2;padding:.6rem;font-size:.85rem}.view-details-btn{flex:1;background:#f8f9fa;border:1px solid #3498db;color:#3498db;padding:.6rem;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .3s}.view-details-btn:hover{background:#3498db;color:#fff}.form-card.compact,.info-card.compact,.policy-form-card.compact,.policy-summary-card.compact{padding:1rem}.info-card.compact{max-height:400px;overflow-y:auto}.policy-preview{display:flex;flex-direction:column;gap:.5rem}.policy-item{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid #f0f0f0;font-size:.75rem}.policy-label{color:#666}.policy-value{color:#2c3e50;font-weight:500;text-align:right}.policy-presets{margin-bottom:1.5rem}.policy-presets h4{margin-bottom:.5rem;font-size:.9rem;color:#2c3e50}.preset-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem;margin-bottom:1rem}.preset-btn{background:#f8f9fa;border:1px solid #e1e8ed;border-radius:6px;padding:.6rem;text-align:left;cursor:pointer;transition:all .3s}.preset-btn:hover{border-color:#3498db;background:#e8f4fd}.preset-btn.active{background:#3498db;border-color:#2980b9;color:#fff}.preset-name{font-weight:600;font-size:.8rem;margin-bottom:.2rem}.preset-desc{font-size:.7rem;opacity:.8}.preset-btn.active .preset-name,.preset-btn.active .preset-desc{color:#fff}.policy-section.compact{margin-bottom:1rem;padding:.8rem}.policy-section.compact h4{font-size:.9rem;margin-bottom:.8rem}.policy-grid.compact{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem}.policy-item.compact{gap:.3rem}.policy-item.compact label{font-size:.75rem}.policy-item.compact input[type=number]{width:70px;padding:.4rem;font-size:.8rem}.policy-item.checkbox.compact{flex-direction:row;align-items:center;gap:.5rem}.policy-item.checkbox.compact label{margin:0}.policy-actions{display:flex;gap:.8rem;margin-top:1rem}.update-policies-btn.compact{flex:1;padding:.6rem;font-size:.85rem}.back-to-registration-btn{flex:1;background:#f8f9fa;border:1px solid #95a5a6;color:#7f8c8d;padding:.6rem;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .3s}.back-to-registration-btn:hover{background:#ecf0f1;border-color:#7f8c8d}.summary-grid.compact{gap:.5rem}.summary-item.compact{padding:.4rem 0;font-size:.75rem}.summary-label.compact,.summary-value.compact{font-size:.75rem}.database-operations-view.compact{max-height:400px}.operations-list.compact{max-height:300px;overflow-y:auto}.database-entry.compact{padding:.6rem;margin-bottom:.6rem}.entry-header{font-size:.7rem}.query-display.compact{padding:.5rem;margin:.3rem 0}.query-text{font-size:.7rem;line-height:1.2}.entry-result{font-size:.65rem}.policy-description{display:block;margin-top:.2rem;font-size:.7rem;color:#666;line-height:1.2}@media(max-width:1024px){.registration-form-container,.policies-container{grid-template-columns:1fr;gap:1rem}.form-row{grid-template-columns:1fr}.preset-buttons{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.tab-content.compact{max-height:calc(100vh - 350px)}.registration-actions,.policy-actions{flex-direction:column}.preset-buttons,.policy-grid.compact,.policy-highlights{grid-template-columns:1fr}}@media(max-width:480px){.panel-navigation{padding:.8rem}.panel-btn{padding:.6rem 1rem;font-size:.8rem}.tabs{overflow-x:auto;flex-wrap:nowrap}.tab-btn{white-space:nowrap;padding:.6rem .8rem}.form-card,.info-card,.policy-form-card,.policy-summary-card{padding:.8rem}}.authentication-simulation{display:flex;flex-direction:column;gap:1rem;padding:.5rem;width:100%}.simulation-header{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center}.header-content p{margin:0;color:#666;font-size:.9rem}.help-toggle{background:#3498db;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.8rem}.help-panel{background:#e8f4fd;border:1px solid #3498db;border-radius:8px;padding:1rem}.help-content h3{margin-top:0;color:#2c3e50;font-size:1rem}.help-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.8rem;margin-top:.8rem}.help-icon{font-size:1.2rem;flex-shrink:0}.failure-banner{background:#fdeaea;border:2px solid #e74c3c;border-radius:8px;padding:.8rem;display:flex;align-items:center;gap:.8rem;animation:shake .5s ease-in-out}.failure-content{display:flex;align-items:center;gap:.8rem;flex:1}.failure-icon{font-size:1.5rem;flex-shrink:0}.retry-btn{background:#e74c3c;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.8rem;white-space:nowrap}.simulation-layout{display:grid;grid-template-columns:1fr 1.5fr 1fr;gap:1rem;min-height:600px}.control-panel{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.login-test-form{display:flex;flex-direction:column;gap:1rem}.simulation-buttons{display:flex;flex-direction:column;gap:.5rem}.button-group{display:flex;gap:.5rem}.button-group button{flex:1;padding:.5rem;font-size:.8rem}.manual-nav{display:flex;gap:.5rem}.manual-nav button{flex:1;padding:.4rem;font-size:.75rem}.auth-log-panel{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;max-height:300px;overflow-y:auto}.log-entries{display:flex;flex-direction:column;gap:.4rem}.log-entry{display:grid;grid-template-columns:60px 1fr 1fr auto;gap:.6rem;padding:.5rem;border-radius:4px;font-size:.7rem;align-items:center}.log-status{padding:.2rem .4rem;border-radius:10px;font-weight:600;font-size:.65rem;text-align:center}.steps-container{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;max-height:700px;overflow-y:auto}.steps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.progress-bar{width:100px;height:4px;background:#ecf0f1;border-radius:2px;overflow:hidden}.step{border:2px solid #e1e8ed;border-radius:6px;padding:.8rem;transition:all .3s}.step.active{border-color:#3498db;background:#f8fafc;box-shadow:0 2px 4px #3498db33}.step.failed{border-color:#e74c3c;background:#fdeaea}.step.pending{opacity:.6}.step-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.5rem;flex-wrap:wrap}.step-icon{font-size:1rem}.step-number{width:30px;height:30px;background:#3498db;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem}.step-title{font-weight:600;font-size:.9rem;flex:1;color:#2c3e50}.step-status{font-size:1rem}.step-description{color:#666;margin-bottom:.5rem;line-height:1.3;font-size:.8rem}.step-explanation{background:#f8f9fa;padding:.5rem;border-radius:4px;margin-bottom:.5rem;font-size:.8rem;line-height:1.3;border-left:3px solid #3498db}.step-error{background:#e74c3c;color:#fff;padding:.5rem;border-radius:4px;margin-bottom:.5rem;font-size:.8rem;border-left:3px solid #c0392b}.step-code{background:#2c3e50;color:#ecf0f1;padding:.6rem;border-radius:4px;font-family:Courier New,monospace;font-size:.7rem;overflow-x:auto}.code-header{font-weight:600;margin-bottom:.3rem;color:#bdc3c7;font-size:.7rem}.database-schema{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;max-height:700px;overflow-y:auto}.schema-description{color:#666;margin-bottom:1rem;font-size:.8rem}.schema-tables{display:flex;flex-direction:column;gap:1rem}.current-user-preview{background:#f8f9fa;padding:1rem;border-radius:6px;border:1px solid #e1e8ed}.user-info-item{display:flex;justify-content:space-between;padding:.3rem 0;font-size:.8rem}.user-info-item span:first-child{color:#666}.no-user-selected{text-align:center;color:#999;padding:1rem;font-style:italic;font-size:.8rem}@media(max-width:1200px){.simulation-layout{grid-template-columns:1fr 1fr}.database-schema{grid-column:1 / -1}}@media(max-width:768px){.simulation-layout{grid-template-columns:1fr}.log-entry{grid-template-columns:1fr;gap:.2rem}.step-header{gap:.4rem}.help-grid{grid-template-columns:1fr}}@media(max-width:480px){.authentication-simulation{padding:.5rem}.simulation-header{padding:.8rem}.header-content{flex-direction:column;gap:.5rem;align-items:flex-start}.control-panel,.auth-log-panel,.steps-container,.database-schema{padding:.8rem}.button-group,.manual-nav{flex-direction:column}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333;font-size:14px}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.75rem 1.5rem;box-shadow:0 2px 15px #0000001a;display:flex;justify-content:space-between;align-items:center}.app-header h1{color:#2c3e50;font-size:1.5rem;font-weight:600}.header-info,.user-info{display:flex;align-items:center;gap:.75rem}.logout-btn{background:#e74c3c;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .3s}.system-status{display:flex;align-items:center;gap:.4rem;color:#27ae60;font-weight:500;font-size:.85rem}.status-indicator{width:8px;height:8px;background:#27ae60;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.navigation{background:#ffffffe6;padding:.75rem 1.5rem;display:flex;gap:.75rem;border-bottom:1px solid #e1e8ed}.navigation button{background:none;border:2px solid transparent;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s;color:#666;font-size:.85rem}.navigation button:hover{background:#f8f9fa;color:#333}.navigation button.active{background:#3498db;color:#fff;border-color:#2980b9}.main-content{flex:1;padding:1.5rem;width:100%}.authentication-simulation{display:flex;flex-direction:column;gap:1.2rem;padding:.8rem;width:100%}.simulation-header{background:#fff;padding:1rem 1.5rem;border-radius:10px;box-shadow:0 3px 10px #0000001a}.header-content{display:flex;flex-direction:row;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.simulation-header h2{color:#2c3e50;margin:0;font-size:1.3rem}.simulation-header p{color:#666;margin:0;font-size:.9rem}.help-toggle{background:#3498db;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:background .2s}.help-toggle:hover{background:#2980b9}@media(max-width:768px){.simulation-header{padding:1rem}.header-content{flex-direction:column;align-items:flex-start;gap:.75rem}.help-toggle{width:100%;justify-content:center}}.help-panel{background:#e8f4fd;border:1px solid #3498db;border-radius:10px;padding:1.2rem}.help-content h3{margin-top:0;color:#2c3e50;font-size:1.1rem}.help-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.8rem;margin-top:.8rem}.help-item{display:flex;gap:.8rem;align-items:flex-start}.help-icon{font-size:1.3rem;flex-shrink:0}.help-text{font-size:.8rem;line-height:1.3}.simulation-layout{display:grid;grid-template-columns:1fr 1.4fr .8fr;gap:1.2rem}.simulation-controls{display:flex;flex-direction:column;gap:1.2rem}.control-panel,.tips-panel,.auth-log-panel{background:#fff;padding:1.2rem;border-radius:10px;box-shadow:0 3px 10px #0000001a}.control-panel h3,.tips-panel h3,.auth-log-panel h3{margin-top:0;color:#2c3e50;font-size:1.1rem;display:flex;align-items:center;gap:.4rem}.login-test-form{display:flex;flex-direction:column;gap:1.2rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-weight:600;color:#555;font-size:.85rem}.form-group input{padding:.6rem;border:2px solid #e1e8ed;border-radius:6px;font-size:.85rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#3498db}.input-hint{font-size:.75rem;color:#666;margin-top:.2rem}.simulation-buttons{display:flex;flex-direction:column;gap:.8rem}.simulate-btn{padding:.6rem 1.2rem;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s;font-size:.85rem}.simulate-btn.primary{background:#27ae60;color:#fff;padding:.8rem;display:flex;align-items:center;justify-content:center;gap:.4rem}.simulate-btn.primary:hover:not(:disabled){background:#219a52}.reset-btn{background:#e67e22;color:#fff}.reset-btn:hover:not(:disabled){background:#d35400}.real-login-btn{background:#3498db;color:#fff}.real-login-btn:hover{background:#2980b9}.simulation-buttons button:disabled{background:#bdc3c7;cursor:not-allowed}.spinner{width:14px;height:14px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.button-group{display:flex;gap:.4rem}.button-group button{flex:1;padding:.6rem;border:none;border-radius:5px;cursor:pointer;font-weight:500;font-size:.8rem}.manual-nav{display:flex;gap:.4rem}.manual-nav button{flex:1;padding:.4rem;border:1px solid #ddd;background:#fff;border-radius:5px;cursor:pointer;font-size:.8rem}.tips-panel ul{margin:0;padding-left:1rem}.tips-panel li{margin-bottom:.4rem;font-size:.8rem;line-height:1.3}.log-entries{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:.4rem}.log-entry{display:grid;grid-template-columns:60px 1fr 1fr auto;gap:.6rem;padding:.6rem;border-radius:5px;font-size:.75rem;align-items:center;animation:slide-in .3s ease-out}@keyframes slide-in{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.log-entry.success{background:#d5f4e6;border-left:3px solid #27ae60}.log-entry.failed{background:#fdeaea;border-left:3px solid #e74c3c}.log-time{font-family:monospace;color:#666;font-size:.65rem}.log-status{padding:.2rem .6rem;border-radius:15px;font-weight:600;font-size:.65rem}.log-status.success{background:#27ae60;color:#fff}.log-status.failed{background:#e74c3c;color:#fff}.no-logs{text-align:center;color:#999;font-style:italic;padding:1.5rem;font-size:.85rem}.simulation-visualization{background:#fff;padding:1.2rem;border-radius:10px;box-shadow:0 3px 10px #0000001a;max-height:580px;overflow-y:auto}.steps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}.steps-header h3{margin:0;color:#2c3e50;font-size:1.1rem;display:flex;align-items:center;gap:.4rem}.step-progress{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;font-size:.8rem;color:#666}.progress-bar{width:100px;height:5px;background:#ecf0f1;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:#3498db;transition:width .3s ease}.steps-list{display:flex;flex-direction:column;gap:.8rem}.step{border:2px solid #e1e8ed;border-radius:8px;padding:1rem;transition:all .3s}.step.active{border-color:#3498db;background:#f8fafc;box-shadow:0 3px 6px #3498db33;transform:translate(4px)}.step.completed{border-color:#27ae60;background:#f0f9f4}.step.failed{border-color:#e74c3c;background:#fdeaea;animation:pulse-error 2s infinite}.step.pending{opacity:.7}.step-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.6rem;flex-wrap:wrap}.step-icon{font-size:1.1rem}.step-number{width:40px;height:40px;background:#3498db;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem}.step.active .step-number{background:#2980b9}.step.completed .step-number{background:#27ae60}.step.failed .step-number{background:#e74c3c}.step-title{font-weight:600;font-size:1rem;flex:1;color:#2c3e50}.step.failed .step-title{color:#e74c3c}.step-status{font-size:1.1rem;font-weight:600;width:18px;text-align:center}.step-description{color:#666;margin-bottom:.6rem;line-height:1.3;font-size:.8rem}.step-explanation{background:#f8f9fa;padding:.6rem;border-radius:5px;margin-bottom:.6rem;font-size:.8rem;line-height:1.3;border-left:3px solid #3498db}.step-error{background:#e74c3c;color:#fff;padding:.6rem;border-radius:5px;margin-bottom:.6rem;font-size:.8rem;border-left:3px solid #c0392b}.step-code{background:#2c3e50;color:#ecf0f1;padding:.8rem;border-radius:6px;font-family:Courier New,monospace;font-size:.75rem;overflow-x:auto}.code-header{font-weight:600;margin-bottom:.4rem;color:#bdc3c7;font-size:.75rem}.step-code pre{margin:0;white-space:pre-wrap;line-height:1.2}.database-schema{background:#fff;padding:1.2rem;border-radius:10px;box-shadow:0 3px 10px #0000001a;height:fit-content;max-height:580px;overflow-y:auto}.schema-tables{display:grid;grid-template-columns:1fr;gap:.8rem}.schema-table{border:2px solid #e1e8ed;border-radius:8px;overflow:hidden}.schema-table h4{background:#34495e;color:#fff;padding:.8rem;margin:0;font-size:.9rem;display:flex;align-items:center;gap:.4rem}.schema-fields{padding:.8rem}.field{display:flex;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid #ecf0f1}.field:last-child{border-bottom:none}.field span:first-child{font-weight:600;color:#2c3e50;font-size:.8rem}.field span:last-child{color:#7f8c8d;font-size:.8rem;text-align:right}.database-operations-panel{background:#fff;padding:1.2rem;border-radius:10px;box-shadow:0 3px 10px #0000001a;max-height:320px;display:flex;flex-direction:column}.database-operations-panel h3{margin-top:0;color:#2c3e50;font-size:1.1rem;display:flex;align-items:center;gap:.4rem}.current-query{background:#2c3e50;color:#fff;padding:.6rem;border-radius:5px;margin-bottom:.8rem;animation:pulse 2s infinite}.query-header{font-size:.75rem;opacity:.8;margin-bottom:.2rem}.query-text{font-family:monospace;font-weight:600;font-size:.8rem}.operations-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.6rem}.database-entry{border:1px solid #e1e8ed;border-left:3px solid #3498db;border-radius:5px;padding:.6rem;background:#f8f9fa;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;font-size:.75rem}.operation{font-weight:600;font-size:.7rem;padding:.15rem .4rem;border-radius:3px;background:#3498db1a}.table{color:#666;font-style:italic}.timestamp{color:#999;font-size:.65rem}.entry-data{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.4rem}.data-field{display:flex;justify-content:space-between;font-size:.7rem}.field-name{font-weight:600;color:#2c3e50}.field-value{color:#7f8c8d;font-family:monospace;max-width:55%;text-align:right;word-break:break-all}.entry-result{font-size:.65rem;color:#27ae60;font-weight:600;text-align:right}.no-operations{text-align:center;color:#999;font-style:italic;padding:1.5rem;font-size:.85rem}.db-operation-badge{color:#fff;padding:.15rem .4rem;border-radius:10px;font-size:.65rem;font-weight:600}.login-container{display:flex;justify-content:center;align-items:center;min-height:50vh}.login-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 15px 30px #0000001a;width:100%;max-width:350px}.login-card h2{text-align:center;margin-bottom:1.5rem;color:#2c3e50;font-size:1.3rem}.login-form{display:flex;flex-direction:column;gap:1.2rem}.login-btn{background:#27ae60;color:#fff;border:none;padding:.8rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.login-btn:hover{background:#219a52}.error-message{background:#fdeaea;color:#e74c3c;padding:.6rem;border-radius:6px;text-align:center;font-weight:500;font-size:.85rem}.login-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e1e8ed}.switch-btn{background:none;border:none;color:#3498db;cursor:pointer;text-decoration:underline;font-size:.9rem}.switch-btn:hover{color:#2980b9}.registration-container{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:1.5rem}.registration-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 15px 30px #0000001a;width:100%;max-width:450px}.registration-card h2{text-align:center;margin-bottom:.8rem;color:#2c3e50;font-size:1.3rem}.registration-subtitle{text-align:center;color:#666;margin-bottom:1.5rem;font-size:.9rem;line-height:1.4}.registration-form{display:flex;flex-direction:column;gap:1.2rem}.register-btn{background:#27ae60;color:#fff;border:none;padding:.8rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s;margin-top:.8rem}.register-btn:hover{background:#219a52}.registration-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e1e8ed}.password-strength{margin-top:.4rem}.strength-meter{height:6px;background:#ecf0f1;border-radius:3px;overflow:hidden;margin-bottom:.4rem}.strength-bar{height:100%;transition:width .3s,background-color .3s}.strength-bar.very-weak{background:#e74c3c;width:25%!important}.strength-bar.weak{background:#e67e22;width:25%!important}.strength-bar.fair{background:#f1c40f;width:50%!important}.strength-bar.good{background:#2ecc71;width:75%!important}.strength-bar.strong{background:#27ae60;width:100%!important}.strength-label{font-size:.8rem;font-weight:600}.password-requirements{background:#f8f9fa;padding:.8rem;border-radius:6px;border-left:3px solid #3498db}.password-requirements h4{margin-bottom:.4rem;color:#2c3e50;font-size:.8rem}.password-requirements li{padding:.2rem 0;font-size:.75rem;display:flex;align-items:center}.password-requirements li:before{content:"•";margin-right:.4rem;font-weight:700}.password-requirements li.met{color:#27ae60}.password-requirements li.unmet{color:#e74c3c}.password-requirements li.optional{color:#7f8c8d}.success-message{background:#d5f4e6;color:#27ae60;padding:.8rem;border-radius:6px;text-align:center;font-weight:500;font-size:.85rem}.success-message small{display:block;margin-top:.4rem;font-size:.75rem;opacity:.8}.registration-form .form-group{display:flex;flex-direction:column;gap:.4rem}.registration-form label{font-weight:600;color:#555;font-size:.85rem}.registration-form input,.registration-form select{padding:.6rem;border:2px solid #e1e8ed;border-radius:6px;font-size:.85rem;transition:border-color .3s}.registration-form input:focus,.registration-form select:focus{outline:none;border-color:#3498db}.registration-form input.error,.registration-form select.error{border-color:#e74c3c}.error-message{color:#e74c3c;font-size:.8rem;font-weight:500}.failure-banner{background:#fdeaea;border:2px solid #e74c3c;border-radius:8px;padding:.8rem;margin-top:.8rem;display:flex;align-items:flex-start;gap:.8rem;animation:shake .5s ease-in-out}.failure-icon{font-size:1.3rem;flex-shrink:0}.failure-details{flex:1}.failure-details strong{color:#e74c3c;display:block;margin-bottom:.4rem;font-size:.85rem}.failure-details p{color:#c0392b;margin:0;font-size:.8rem}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@keyframes pulse-error{0%{box-shadow:0 0 #e74c3c66}70%{box-shadow:0 0 0 8px #e74c3c00}to{box-shadow:0 0 #e74c3c00}}.user-management{width:100%}.user-management h2{color:#2c3e50;margin-bottom:1.5rem;text-align:center;font-size:1.3rem}.policies-display{background:#fff;padding:1.2rem;border-radius:8px;box-shadow:0 3px 8px #0000001a;margin-bottom:1.5rem}.policies-display h3{color:#2c3e50;margin-bottom:.8rem;font-size:1.1rem}.policies-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem}.policy-item{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;border-bottom:1px solid #ecf0f1}.policy-item:last-child{border-bottom:none}.policy-label{font-weight:600;color:#555;font-size:.8rem}.policy-value{color:#2c3e50;font-weight:500;font-size:.8rem}.create-user-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 3px 8px #0000001a;margin-bottom:1.5rem}.create-user-section h3{color:#2c3e50;margin-bottom:1.2rem;font-size:1.1rem}.user-form{display:flex;flex-direction:column;gap:1.2rem}.create-btn{background:#27ae60;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.create-btn:hover:not(:disabled){background:#219a52}.create-btn:disabled{background:#bdc3c7;cursor:not-allowed}.users-list-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 3px 8px #0000001a}.users-list-section h3{color:#2c3e50;margin-bottom:1.2rem;font-size:1.1rem}.no-users{text-align:center;color:#7f8c8d;padding:1.5rem;font-style:italic;font-size:.85rem}.users-table{display:flex;flex-direction:column;border:1px solid #e1e8ed;border-radius:6px;overflow:hidden}.table-header{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:.8rem;background:#34495e;color:#fff;padding:.8rem;font-weight:600;font-size:.8rem}.table-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:.8rem;padding:.8rem;border-bottom:1px solid #e1e8ed;align-items:center;font-size:.8rem}.table-row:last-child{border-bottom:none}.username{font-weight:600;color:#2c3e50}.created-date,.last-login,.role{color:#666}.actions{display:flex;justify-content:center}.delete-btn{background:#e74c3c;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background .3s}.delete-btn:hover:not(:disabled){background:#c0392b}.delete-btn:disabled{background:#bdc3c7;cursor:not-allowed}.password-policy{width:100%;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 8px 25px #0000001a}.password-policy h2{color:#2c3e50;margin-bottom:1.5rem;text-align:center;font-size:1.3rem}.policy-form{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:1.5rem}.policy-item.checkbox{flex-direction:row;align-items:center;gap:.8rem}.policy-item label{font-weight:600;color:#555;font-size:.85rem}.policy-item input[type=number]{padding:.6rem;border:2px solid #e1e8ed;border-radius:6px;font-size:.85rem;width:80px}.policy-item input[type=checkbox]{width:18px;height:18px}.policy-summary{background:#f8f9fa;padding:1.2rem;border-radius:8px;border-left:3px solid #3498db}.policy-summary h3{color:#2c3e50;margin-bottom:.8rem;font-size:1rem}.policy-summary ul{list-style:none;padding:0}.policy-summary li{padding:.4rem 0;border-bottom:1px solid #e1e8ed;font-size:.8rem}.policy-summary li:last-child{border-bottom:none}@media(max-width:1024px){.simulation-layout{grid-template-columns:1fr 1fr}.database-schema{grid-column:1 / -1}}@media(max-width:768px){.simulation-layout{grid-template-columns:1fr}.authentication-simulation{padding:.4rem;gap:1rem}.simulation-header,.control-panel,.tips-panel,.auth-log-panel,.simulation-visualization,.database-schema{padding:.8rem}.steps-header{flex-direction:column;align-items:flex-start;gap:.8rem}.step-progress{align-items:flex-start}.log-entry{grid-template-columns:1fr;gap:.2rem}.button-group,.manual-nav{flex-direction:column}.entry-header{flex-direction:column;align-items:flex-start;gap:.2rem}.step-header{gap:.4rem}.db-operation-badge{font-size:.55rem;padding:.1rem .3rem}.schema-tables{grid-template-columns:1fr}.navigation{flex-wrap:wrap}.app-header{flex-direction:column;gap:.8rem;text-align:center}.table-header,.table-row{grid-template-columns:1fr;gap:.4rem}.table-header span,.table-row span{text-align:center}.policies-list{grid-template-columns:1fr}}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 15px #0000001a}.header-info{display:flex;align-items:center;gap:1.5rem}.session-info{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e1e8ed}.session-timer{display:flex;flex-direction:column;align-items:center;gap:.2rem}.timer-label{font-size:.75rem;color:#666;font-weight:500}.timer-value{font-size:1.1rem;font-weight:700;font-family:Courier New,monospace;color:#27ae60;padding:.2rem .6rem;background:#fff;border-radius:4px;border:2px solid #e1e8ed;min-width:70px;text-align:center}.timer-value.warning{color:#e74c3c;background:#fdeaea;border-color:#e74c3c;animation:pulse-warning 1s infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.7}}.user-welcome{font-size:.9rem;color:#2c3e50;padding:.4rem .8rem;background:#fff;border-radius:4px;border:1px solid #e1e8ed}.logout-btn{background:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:600;transition:background .3s}.logout-btn:hover{background:#c0392b}.system-status{display:flex;align-items:center;gap:.5rem;color:#7f8c8d;font-size:.9rem}.status-indicator{width:8px;height:8px;background:#bdc3c7;border-radius:50%}@media(max-width:768px){.app-header{flex-direction:column;gap:1rem;text-align:center}.session-info{flex-direction:column;gap:.5rem}.session-timer{order:-1}}.user-management-layout{display:flex;flex-direction:row;gap:20px;align-items:flex-start;justify-content:space-between;width:100%}.create-user-section,.users-list-section{flex:1}.create-user-card,.users-list-card{height:100%}@media(max-width:400px){.user-management-layout{flex-direction:column}}.registration-panel{padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #e9ecef;padding-bottom:10px}.tab-btn{padding:12px 24px;border:none;background:none;cursor:pointer;font-size:1rem;font-weight:500;color:#6c757d;border-radius:8px;transition:all .3s;display:flex;align-items:center;gap:8px}.tab-btn:hover{background:#f8f9fa;color:#495057}.tab-btn.active{background:#e7f5ff;color:#1976d2}.success-banner,.error-banner{padding:16px 24px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:12px;font-weight:500}.success-banner{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.error-banner{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.success-icon,.error-icon{font-size:1.2rem}.registration-container{display:grid;grid-template-columns:1fr 320px;gap:24px}.registration-form-wrapper{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #0000001a}.form-header{margin-bottom:32px}.form-header h2{margin:0;color:#2c3e50;font-size:1.8rem}.form-subtitle{color:#6c757d;margin:8px 0 0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-field{display:flex;flex-direction:column;gap:8px}.form-field.full-width{grid-column:1 / -1}.form-field label{font-weight:500;color:#495057;font-size:.9rem}.required{color:#dc3545}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:12px;color:#6c757d}.input-wrapper input,.input-wrapper select{width:100%;padding:12px 12px 12px 40px;border:1px solid #ced4da;border-radius:6px;font-size:.95rem;transition:all .3s}.input-wrapper input:focus,.input-wrapper select:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.input-wrapper input.error{border-color:#dc3545}.error-message{color:#dc3545;font-size:.8rem;margin-top:4px}.password-strength{margin-top:8px}.strength-header{display:flex;justify-content:space-between;margin-bottom:4px;font-size:.85rem}.strength-meter{height:6px;background:#e9ecef;border-radius:3px;overflow:hidden}.strength-bar{height:100%;transition:all .3s}.password-requirements{margin-top:24px;padding:16px;background:#f8f9fa;border-radius:8px}.password-requirements h4{margin:0 0 12px;color:#495057;font-size:.95rem}.password-requirements ul{list-style:none;padding:0;margin:0}.password-requirements li{padding:4px 0;color:#6c757d;font-size:.85rem}.password-requirements li.met{color:#28a745}.form-actions{display:flex;gap:16px;margin-top:32px}.register-button,.view-policies-button,.apply-policies-button{padding:14px 28px;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s}.register-button{background:#1976d2;color:#fff;flex:2}.register-button:hover{background:#1565c0}.view-policies-button{background:#6c757d;color:#fff;flex:1}.view-policies-button:hover{background:#5a6268}.button-icon{font-size:1.1rem}.policy-summary-sidebar{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;height:fit-content}.policy-summary-sidebar h3{margin:0 0 16px;color:#2c3e50}.policy-badge{display:inline-block;padding:6px 12px;background:#e3f2fd;color:#1976d2;border-radius:20px;font-size:.85rem;font-weight:500;margin-bottom:20px}.policy-details{display:flex;flex-direction:column;gap:12px}.policy-detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e9ecef}.detail-label{color:#6c757d;font-size:.9rem}.detail-value{font-weight:500;color:#2c3e50}.detail-value.required{color:#1976d2}.detail-value.optional{color:#6c757d}.policies-container{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #0000001a}.policy-configuration-card{max-width:1000px;margin:0 auto}.policy-configuration-card h2{margin:0;color:#2c3e50}.section-subtitle{color:#6c757d;margin:8px 0 32px}.policy-presets-section{margin-bottom:40px}.policy-presets-section h3{margin-bottom:16px;color:#495057}.preset-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.preset-card{padding:20px;border:1px solid #dee2e6;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s;text-align:left}.preset-card:hover{border-color:#1976d2;box-shadow:0 4px 12px #1976d21a}.preset-card.active{border-color:#1976d2;background:#e7f5ff}.preset-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.preset-icon{font-size:1.5rem}.preset-header h4{margin:0;color:#2c3e50}.preset-description{color:#6c757d;font-size:.85rem;margin:0 0 12px}.preset-stats{display:flex;gap:16px;font-size:.8rem;color:#495057}.policy-sections-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}.policy-section{padding:20px;background:#f8f9fa;border-radius:8px}.policy-section h4{margin:0 0 20px;color:#495057}.policy-field{margin-bottom:20px}.policy-field label{display:block;margin-bottom:8px;color:#6c757d;font-size:.9rem}.number-input{display:flex;align-items:center;gap:12px}.number-input input[type=range]{flex:1}.number-input input[type=number]{width:80px;padding:8px;border:1px solid #ced4da;border-radius:4px}.checkbox-group{display:flex;flex-direction:column;gap:12px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;color:#495057}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.policy-form-actions{display:flex;gap:16px;margin-top:32px}.apply-policies-button{background:#28a745;color:#fff;flex:2}.apply-policies-button:hover{background:#218838}.back-button{padding:14px 28px;background:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .3s}.back-button:hover{background:#5a6268}.database-table-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header-title{display:flex;align-items:center;gap:12px}.table-icon{font-size:1.5rem}.header-title h3{margin:0;color:#2c3e50}.table-actions{display:flex;gap:16px;align-items:center}.record-count{padding:6px 12px;background:#e7f5ff;color:#1976d2;border-radius:20px;font-size:.85rem}.hide-table-btn{padding:8px 16px;border:1px solid #dee2e6;background:#fff;border-radius:4px;cursor:pointer;transition:all .3s}.hide-table-btn:hover{background:#f8f9fa}.table-responsive{overflow-x:auto}.database-table{width:100%;border-collapse:collapse;font-size:.9rem}.database-table th{padding:12px;background:#f8f9fa;color:#495057;font-weight:600;text-align:left;border-bottom:2px solid #dee2e6}.database-table td{padding:12px;border-bottom:1px solid #e9ecef;vertical-align:middle}.database-table tr:hover{background:#f8f9fa}.id-cell{font-weight:600;color:#6c757d}.email-link{color:#1976d2;text-decoration:none}.email-link:hover{text-decoration:underline}.password-hash-cell{position:relative}.hash-preview{font-family:Courier New,monospace;background:#f8f9fa;padding:4px 8px;border-radius:4px;cursor:help}.hash-tooltip{visibility:hidden;position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#2c3e50;color:#fff;padding:12px;border-radius:6px;font-size:.8rem;white-space:nowrap;z-index:1000;margin-bottom:8px}.password-hash-cell:hover .hash-tooltip{visibility:visible}.hash-tooltip code{display:block;background:#34495e;padding:8px;border-radius:4px;margin-top:4px;font-size:.75rem}.hash-meta{margin-top:8px;color:#95a5a6;font-size:.75rem}.role-badge{padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:500}.policy-badge{padding:4px 12px;background:#f3e5f5;color:#7b1fa2;border-radius:20px;font-size:.8rem}.privilege-tag{padding:2px 8px;background:#e8f5e9;color:#2e7d32;border-radius:12px;font-size:.75rem}.privilege-more{padding:2px 8px;background:#e9ecef;color:#495057;border-radius:12px;font-size:.75rem}.date-cell{display:flex;flex-direction:column;gap:4px}.date-time{font-size:.75rem;color:#6c757d}.expiry-badge{display:inline-block;padding:2px 6px;border-radius:10px;font-size:.7rem;margin-left:4px}.expiry-badge.active{background:#e8f5e9;color:#2e7d32}.expiry-badge.expired{background:#ffebee;color:#c62828}.status-indicator{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.8rem}.status-indicator.active{background:#e8f5e9;color:#2e7d32}.status-indicator.locked{background:#ffebee;color:#c62828}.empty-table-message{text-align:center;padding:48px!important}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px}.empty-icon{font-size:3rem}.empty-state p{margin:0;color:#6c757d;font-size:1.1rem}.empty-state small{color:#adb5bd}.table-footer{margin-top:20px;padding-top:20px;border-top:1px solid #e9ecef}.table-stats{display:flex;gap:24px;color:#6c757d;font-size:.85rem}@media(max-width:768px){.registration-container,.form-grid,.preset-cards,.policy-sections-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.table-stats{flex-direction:column;gap:8px}.tabs{flex-direction:column}.tab-btn{width:100%;justify-content:center}}@media(max-width:480px){.registration-panel{padding:10px}.registration-form-wrapper,.policies-container,.database-table-container{padding:16px}.form-header h2{font-size:1.5rem}.database-table{font-size:.8rem}.hash-tooltip{white-space:normal;width:200px}}.user-details-table{background:#fff;padding:1.2rem;border-radius:10px;box-shadow:0 3px 10px #0000001a;height:fit-content;max-height:580px;overflow-y:auto}.user-details-table h3{margin-top:0;margin-bottom:1rem;color:#2c3e50;font-size:1.1rem;display:flex;align-items:center;gap:.5rem}.table-description{color:#27ae60;font-size:.85rem;margin-bottom:1rem;padding:.5rem;background:#d5f4e6;border-radius:4px;text-align:center}.user-table-container{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-info-table{width:100%;border-collapse:collapse;font-size:.9rem}.user-info-table th{text-align:left;padding:.75rem;background:#34495e;color:#fff;font-weight:600;font-size:.85rem}.user-info-table td{padding:.75rem;border-bottom:1px solid #ecf0f1}.user-info-table tr:last-child td{border-bottom:none}.user-info-table tr:hover td{background:#f8f9fa}.user-info-table td:first-child{font-weight:600;color:#2c3e50;width:40%}.user-info-table td:last-child{color:#555}.role-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;display:inline-block}.role-user{background:#e3f2fd;color:#1976d2}.role-manager{background:#fff3e0;color:#f57c00}.role-administrator{background:#fbe9e7;color:#d32f2f}.status-indicator{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;display:inline-block}.status-indicator.active{background:#d5f4e6;color:#27ae60}.status-indicator.locked{background:#fdeaea;color:#e74c3c}.privileges-container{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.privilege-tag{padding:2px 8px;background:#e8f5e9;color:#2e7d32;border-radius:12px;font-size:.7rem}.privilege-more{padding:2px 8px;background:#e9ecef;color:#495057;border-radius:12px;font-size:.7rem}.table-footer-note{margin-top:1rem;padding-top:.5rem;text-align:right;border-top:1px dashed #e1e8ed}.table-footer-note small{color:#27ae60;font-style:italic}.no-user-selected{text-align:center;color:#999;padding:2rem 1rem;font-style:italic}.no-user-selected p{margin-bottom:.5rem;font-size:1rem}.no-user-selected small{font-size:.8rem;opacity:.7}.database-storage-preview{background:#fdf6e3;border:1px solid #eee8d5;border-radius:8px;padding:1rem;margin:1rem 0;box-shadow:inset 0 1px 3px #0000000d}.preview-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;border-bottom:1px solid #eee8d5;padding-bottom:.5rem}.preview-title{font-weight:600;color:#586e75;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.preview-item{margin-bottom:.75rem}.preview-label{display:block;font-size:.8rem;color:#657b83;margin-bottom:.4rem}.hash-display{background:#073642;color:#268bd2;padding:.75rem;border-radius:6px;min-height:2.5rem;display:flex;align-items:center;overflow-x:auto}.hash-value{font-family:Courier New,Courier,monospace;word-break:break-all;font-size:.85rem;font-weight:600;letter-spacing:.5px}.hash-placeholder{color:#586e75;font-style:italic;font-size:.8rem}.preview-note{font-size:.75rem;color:#93a1a1;margin:0;line-height:1.4}.security-insight-section{margin-top:2rem;padding:0 .8rem 2rem}.insight-card{background:linear-gradient(to bottom right,#fff,#f0f7ff);border:1px solid #d0e3ff;border-left:5px solid #3498db;border-radius:10px;padding:1.5rem;box-shadow:0 4px 15px #0000000d}.insight-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.insight-header h3{margin:0;color:#2c3e50;font-size:1.2rem}.insight-icon{font-size:1.5rem}.insight-question{background:#ebf5ff;padding:.75rem 1rem;border-radius:6px;color:#1a5694;margin-bottom:1rem;font-size:.95rem}.insight-answer{color:#333;font-size:.9rem;line-height:1.6}.insight-answer ul{margin-top:.75rem;padding-left:1.5rem}.insight-answer li{margin-bottom:.5rem}
