*{margin:0;padding:0;box-sizing:border-box}body{font-family:Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;color:#2c3e50}#app{min-height:100vh}.app-container{max-width:1400px;margin:0 auto;padding:0}.header{background-color:#fff;box-shadow:0 2px 4px #0000001a;padding:2rem 0;margin-bottom:2rem}.header-content{max-width:1400px;margin:0 auto;padding:0 2rem}.header h1{color:#2c3e50;font-size:2rem;font-weight:500;margin-bottom:.5rem}.header p{color:#7f8c8d;font-size:1rem}.main-content{padding:0 2rem 2rem}.section{background-color:#fff;border-radius:8px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.section h2{font-size:1.5rem;font-weight:500;margin-bottom:1.5rem;color:#2c3e50}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-weight:500;margin-bottom:.5rem;color:#2c3e50}.form-input,.form-textarea,.form-select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-family:Roboto,sans-serif;font-size:1rem;transition:border-color .2s;background-color:#fff}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#3e64ff}.form-select{cursor:pointer}.form-select:disabled{cursor:not-allowed}.image-upload-section{margin-bottom:1rem}.image-upload-label{display:inline-block;cursor:pointer}.image-upload-input{display:none}.image-upload-button{display:inline-block;padding:.5rem 1rem;background-color:#f8f9fa;border:2px dashed #3E64FF;border-radius:4px;color:#3e64ff;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s}.image-upload-button:hover{background-color:#e9ecef;border-color:#2d4fd9}.image-upload-label:has(input:disabled) .image-upload-button{cursor:not-allowed;opacity:.5;background-color:#e9ecef}.image-preview-container{margin-top:1rem;position:relative}.stimulus-img{max-width:100%;height:auto;border-radius:4px;border:1px solid #ddd;display:block}.btn-remove-image{margin-top:.5rem;padding:.4rem .8rem;background-color:#dc3545;color:#fff;border:none;border-radius:4px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-remove-image:hover{background-color:#c82333}.btn-remove-image:disabled{cursor:not-allowed;opacity:.5;opacity:.6;background-color:#f5f5f5}.form-textarea{min-height:150px;resize:vertical}.vignettes-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1.5rem}.vignette-group{display:flex;flex-direction:column}.btn{padding:.875rem 2rem;font-size:1rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .2s;font-family:Roboto,sans-serif}.btn-primary{background-color:#3e64ff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2d4fd9}.btn-primary:disabled{background-color:#b0b0b0;cursor:not-allowed}.btn-secondary{background-color:#e0e0e0;color:#2c3e50}.btn-secondary:hover{background-color:#d0d0d0}.button-group{display:flex;gap:1rem}.loading{text-align:center;padding:2rem;color:#7f8c8d}.loading-spinner{border:3px solid #f3f3f3;border-top:3px solid #3E64FF;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:1rem auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{background-color:#fee;border:1px solid #fcc;border-radius:4px;padding:1rem;color:#c33;margin-bottom:1rem}.results-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.result-card{background-color:#f8f9fa;border-radius:4px;padding:1.5rem}.result-card h3{font-size:1.25rem;font-weight:500;margin-bottom:1rem;color:#2c3e50}.stat-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #e0e0e0}.stat-row:last-child{border-bottom:none}.stat-label{color:#7f8c8d;font-weight:400}.stat-value{color:#2c3e50;font-weight:500}.chart-container{margin:2rem 0;background-color:#fff;padding:1rem;border-radius:4px;height:400px}.chart-container canvas{width:100%!important;height:100%!important;display:block}.t-test-results{background-color:#f0f4ff;border-left:4px solid #3E64FF;padding:1.5rem;border-radius:4px;margin-top:2rem}.t-test-results h3{font-size:1.25rem;font-weight:500;margin-bottom:1rem;color:#2c3e50}.significance-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500;margin-left:.5rem}.significance-badge.significant{background-color:#d4edda;color:#155724}.significance-badge.not-significant{background-color:#f8d7da;color:#721c24}.responses-section{margin-top:2rem}.responses-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.responses-list{background-color:#f8f9fa;border-radius:4px;padding:1rem;max-height:300px;overflow-y:auto}.responses-list h4{font-size:1rem;font-weight:500;margin-bottom:.75rem;color:#2c3e50}.response-items{display:flex;flex-wrap:wrap;gap:.5rem}.response-item{background-color:#fff;border:1px solid #ddd;padding:.5rem .75rem;border-radius:4px;font-weight:500;color:#2c3e50}.participant-list{display:flex;flex-direction:column;gap:.5rem}.participant-item{background-color:#fff;border:1px solid #ddd;padding:.75rem;border-radius:4px;display:flex;flex-direction:column;gap:.25rem}.participant-rating{font-size:1.25rem;font-weight:600;color:#3e64ff}.participant-demographics{font-size:.85rem;color:#7f8c8d;font-family:monospace}.radio-group{display:flex;gap:2rem;margin-top:.5rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem}.radio-label input[type=radio]{cursor:pointer;width:1.25rem;height:1.25rem;accent-color:#3E64FF}.radio-label input[type=radio]:disabled{cursor:not-allowed;opacity:.5}.radio-label span{font-weight:500}.mechanism-section{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.mechanism-card{background:#f8f9fa;border-left:4px solid #3E64FF;padding:1.5rem;border-radius:8px;margin-top:1rem}.mechanism-text{font-size:1rem;line-height:1.6;color:#2c3e50;margin:0;white-space:pre-wrap}@media (max-width: 768px){.vignettes-container,.results-grid,.responses-grid{grid-template-columns:1fr}.header-content,.main-content{padding:0 1rem}}.app-footer{flex-shrink:0;background-color:#111;color:#ddd;padding:40px 20px;font-size:14px;line-height:1.6}.footer-container{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:40px}.footer-section h2,.footer-section h3{color:#fff;margin-bottom:10px;font-size:16px}.footer-section p{margin:0;color:#aaa}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section li{margin-bottom:8px;color:#ccc}.footer-section a{color:#ccc;text-decoration:none;transition:color .2s ease}.footer-section a:hover{color:#fff}.footer-copy{border-top:1px solid #333;margin-top:20px;padding-top:10px;font-size:12px;color:#777}@media (min-width: 768px){.footer-container{grid-template-columns:1fr 1fr 1fr}}.progress-bar-container{width:100%;height:24px;background-color:#e0e0e0;border-radius:12px;overflow:hidden;margin-top:1rem;box-shadow:inset 0 1px 3px #0000001a}.progress-bar{height:100%;background:linear-gradient(90deg,#3e64ff,#5a7aff);border-radius:12px;transition:width .3s ease;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:500;font-size:.875rem}.demographic-config-section{background-color:#f8f9fa;border-radius:8px;padding:1.5rem;margin-top:1rem;border:1px solid #e0e0e0}.checkbox-group{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.95rem}.checkbox-label input[type=checkbox]{cursor:pointer;width:1.1rem;height:1.1rem;accent-color:#3E64FF}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.slider-group{display:flex;flex-direction:column;gap:1rem;margin-top:.5rem}.slider-item{display:flex;flex-direction:column;gap:.5rem}.slider-item label{font-size:.95rem;color:#2c3e50;font-weight:500}.slider{width:100%;height:6px;border-radius:3px;background:#e0e0e0;outline:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#3e64ff;cursor:pointer;transition:background .2s}.slider::-webkit-slider-thumb:hover{background:#2d4fd9}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#3e64ff;cursor:pointer;border:none;transition:background .2s}.slider::-moz-range-thumb:hover{background:#2d4fd9}.slider:disabled{cursor:not-allowed;opacity:.5}.demographic-stats-section{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.demographic-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1rem}.demographic-stat-card{background-color:#f8f9fa;border-radius:8px;padding:1.5rem;border:1px solid #e0e0e0}.demographic-stat-card h4{font-size:1.1rem;font-weight:500;margin-bottom:1rem;color:#2c3e50;border-bottom:2px solid #3E64FF;padding-bottom:.5rem}.stat-list{display:flex;flex-direction:column;gap:.5rem}.stat-item{display:flex;justify-content:space-between;padding:.5rem;background-color:#fff;border-radius:4px;font-size:.9rem}@media (max-width: 1024px){.demographic-stats-grid{grid-template-columns:1fr}}@media (max-width: 768px){.checkbox-group{grid-template-columns:repeat(2,1fr)}}
