body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.App{min-height:100vh;display:flex;flex-direction:column}.App-header{background-color:#fffffff2;padding:1.25rem 1.5rem;text-align:center;box-shadow:0 2px 10px #0000001a}.App-header h1{color:#333;font-size:1.5rem;margin-bottom:.35rem}.App-header p{color:#444;font-size:.9rem;font-weight:500}.App-header .subtitle{color:#888;font-size:.8rem;font-weight:400;display:block;margin-top:.35rem}.App-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:1rem}.progress-bar{width:100%;max-width:550px;margin-bottom:1.25rem;background:#fff;border-radius:8px;padding:1rem;box-shadow:0 4px 20px #0000001a}.progress-steps{display:flex;justify-content:space-between;margin-bottom:1rem;position:relative}.step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.step-number{width:35px;height:35px;border-radius:50%;background:#e0e0e0;color:#999;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;margin-bottom:.4rem;transition:all .3s ease}.step.active .step-number{background:#667eea;color:#fff}.step-label{font-size:.9rem;color:#555}@media(max-width:768px){.step-label{font-size:.9rem}}.progress-fill{height:4px;background:#667eea;border-radius:2px;transition:width .3s ease}.form-container{width:100%;max-width:550px;background:#fff;border-radius:8px;padding:1.25rem;box-shadow:0 4px 20px #0000001a}.step-container h2{color:#333;font-size:1.35rem;margin-bottom:.9rem}.form-group{margin-bottom:1.15rem}.form-group label{display:block;margin-bottom:.4rem;color:#555;font-size:.95rem;font-weight:500}.slider{width:100%;height:5px;border-radius:3px;background:#e0e0e0;outline:none;transition:opacity .2s;-webkit-appearance:none;margin:.75rem 0}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer}.slider-labels{display:flex;justify-content:space-between;font-size:.85rem;color:#999}.select-input{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;background:#fff;cursor:pointer}.checkbox-group{background:#f9f9f9;padding:1rem;border-radius:8px;margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;cursor:pointer}.checkbox-label input[type=checkbox]{width:20px;height:20px;margin-right:.75rem;cursor:pointer}.checkbox-label span{font-weight:500;color:#333}.help-text{margin-top:.5rem;font-size:.85rem;color:#555;margin-left:0}.info-box{background:#f0f4ff;border-left:4px solid #667eea;padding:.65rem;border-radius:4px;margin-bottom:.9rem}.info-box h3{color:#333;font-size:1.05rem;margin-bottom:.4rem}.info-box p{color:#666;font-size:.9rem;margin-bottom:.4rem}.button-group{display:flex;gap:1rem;justify-content:space-between}.btn{padding:.65rem 1.75rem;border:none;border-radius:4px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5a67d8;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover{background:#d0d0d0}.btn-large{padding:.85rem 2.5rem;font-size:1rem}.results-container{text-align:center;width:100%;max-width:550px;background:#fff;border-radius:8px;padding:1.25rem;box-shadow:0 4px 20px #0000001a;margin:0 auto}.results-container h2{color:#333;font-size:1.4rem;margin-bottom:1.5rem}.risk-score-display{margin-bottom:1.5rem}.percentage-circle{width:140px;height:140px;border-radius:50%;border:6px solid #667eea;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto .85rem;background:#fff;box-shadow:0 4px 20px #0000001a}.percentage-number{font-size:2rem;font-weight:700;color:#333;line-height:1}.percentage-label{font-size:.8rem;color:#666}.risk-category{font-size:1.5rem;font-weight:700;margin-bottom:.4rem}.risk-description{font-size:1rem;color:#666;margin-bottom:1.5rem}.risk-meter{margin-bottom:1.5rem}.meter-bar{width:100%;height:24px;background:#e0e0e0;border-radius:12px;overflow:hidden;margin-bottom:.4rem}.meter-fill{height:100%;transition:width 1s ease}.meter-labels{display:flex;justify-content:space-between;font-size:.85rem;color:#666}.high-risk-notice{background:#f8d7da;border:1px solid #f5c6cb;padding:.85rem;border-radius:4px;margin-bottom:1.15rem;text-align:left;color:#721c24;font-size:.85rem}.high-risk-notice strong{color:#491217}.disclaimer{background:#fff3cd;border:1px solid #ffc107;padding:.85rem;border-radius:4px;margin-bottom:1.15rem;text-align:left;color:#856404;font-size:.85rem}.disclaimer strong{color:#664100}.results-container .btn{width:100%;max-width:400px;margin:0 auto;display:block}.toggle-group{background:#f9f9f9;padding:1rem;border-radius:8px}.toggle-question{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.toggle-question>span{font-weight:500;color:#333;flex:1;min-width:150px}.toggle-switch-container{display:flex;background:#e0e0e0;border-radius:6px;padding:3px;gap:3px}.toggle-option{padding:.5rem 1.25rem;border:none;background:transparent;color:#666;font-size:.95rem;font-weight:500;cursor:pointer;border-radius:4px;transition:all .3s ease;min-width:60px;min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.toggle-option.active{background:#667eea;color:#fff;box-shadow:0 2px 4px #667eea4d}.toggle-option:hover:not(.active){background:#667eea1a;color:#667eea}.height-unit-toggle{display:flex;gap:.5rem;margin-bottom:.75rem}.height-inputs{display:flex;gap:.5rem;align-items:center}.height-inputs input{width:80px;padding:.6rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;text-align:center}.height-inputs span{color:#666;font-size:.9rem}input,button,select{touch-action:manipulation;-webkit-tap-highlight-color:transparent}input[type=checkbox],input[type=radio]{min-width:24px;min-height:24px}body{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}@media(max-width:768px){.App-header h1{font-size:1.5rem}.form-container{padding:1.25rem}.button-group{flex-direction:column;gap:.75rem}.btn{width:100%;min-height:48px;padding:.85rem 1.75rem;font-size:1rem}.progress-steps{flex-direction:column;align-items:center}.step{margin-bottom:1rem}.slider::-webkit-slider-thumb{width:24px;height:24px}.slider::-moz-range-thumb{width:24px;height:24px}.form-group{margin-bottom:1.5rem}.select-input{min-height:48px;font-size:1rem}.toggle-question{flex-direction:column;align-items:flex-start;gap:.75rem}.toggle-switch-container{width:100%;justify-content:center}.toggle-option{flex:1;min-height:48px;font-size:1rem;padding:.75rem 1.5rem}.toggle-question span{font-size:1rem}}.splash-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.splash-content{text-align:center;max-width:550px;background:#fff;border-radius:16px;padding:30px;box-shadow:0 20px 60px #0000004d}.splash-image{width:100%;max-width:350px;height:auto;border-radius:12px;margin-bottom:22px;box-shadow:0 10px 30px #0000001a}.splash-title{font-size:2rem;color:#000;margin-bottom:8px;font-weight:700}.splash-subtitle{font-size:1.05rem;color:#000;margin-bottom:16px;font-weight:500}.splash-description{font-size:.95rem;color:#000;margin-bottom:24px;line-height:1.6}.splash-start-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 35px;font-size:1rem;font-weight:600;border-radius:50px;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-bottom:16px}.splash-start-button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.splash-note{font-size:.85rem;color:#000;margin:0 0 12px}.splash-credits-button{background:transparent;color:#4c5fd5;border:2px solid #4c5fd5;padding:8px 26px;font-size:.95rem;font-weight:600;border-radius:50px;cursor:pointer;transition:background .2s,color .2s}.splash-credits-button:hover{background:#4c5fd5;color:#fff}.splash-footer{margin-top:24px;padding-top:16px;border-top:1px solid #e0e0e0}.splash-footer p{font-size:.85rem;color:#000;margin:0}.splash-footer a{color:#4c5fd5;text-decoration:none;transition:color .2s}.splash-footer a:hover{color:#5a3a7a;text-decoration:underline}.splash-copyright{margin-top:8px;font-size:.75rem;color:#000}@media(max-width:600px){.splash-content{padding:30px 20px}.splash-title{font-size:2rem}.splash-subtitle{font-size:1rem}.splash-description{font-size:.9rem}}.height-input-container{margin-top:.5rem}.height-input-container label{display:block;margin-bottom:.25rem;font-size:.9rem;color:#555}.credits-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.credits-content{max-width:600px;background:#fff;border-radius:16px;padding:30px;box-shadow:0 20px 60px #0000004d}.credits-content h1{font-size:2rem;color:#333;margin-bottom:24px;text-align:center}.credits-section{margin-bottom:24px}.credits-section h2{font-size:1.2rem;color:#667eea;margin-bottom:12px;border-bottom:2px solid #f0f0f0;padding-bottom:8px}.credits-section p{color:#555;line-height:1.6;margin-bottom:12px}.credits-section ul{list-style:none;padding:0}.credits-section li{padding:8px 0;color:#555;line-height:1.5;border-bottom:1px solid #f5f5f5}.credits-section li:last-child{border-bottom:none}.credits-section a{color:#667eea;text-decoration:none}.credits-section a:hover{text-decoration:underline}.credits-content .btn{display:block;width:100%;max-width:300px;margin:24px auto 0}@media(max-width:600px){.credits-content{padding:24px 16px}.credits-content h1{font-size:1.75rem}.credits-section h2{font-size:1.1rem}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.error-content{text-align:center;max-width:400px;background:#fff;border-radius:16px;padding:40px 30px;box-shadow:0 20px 60px #0000004d}.error-content h1{font-size:1.5rem;color:#333;margin-bottom:16px}.error-content p{color:#666;margin-bottom:24px;line-height:1.6}.pwa-install-prompt{position:fixed;bottom:20px;left:20px;right:20px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:16px;z-index:1000;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-prompt-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.pwa-prompt-text{font-size:.95rem;color:#333;font-weight:500}.pwa-prompt-buttons{display:flex;gap:8px}.pwa-install-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:8px 20px;border-radius:20px;font-size:.9rem;font-weight:500;cursor:pointer}.pwa-dismiss-btn{background:transparent;color:#666;border:none;padding:8px 12px;font-size:.9rem;cursor:pointer}@media(max-width:480px){.pwa-prompt-content{flex-direction:column;align-items:stretch}.pwa-prompt-buttons{justify-content:center}}.pwa-update-prompt{position:fixed;top:0;left:0;right:0;background:#667eea;color:#fff;padding:12px 20px;z-index:1001;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.pwa-update-content{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.pwa-update-content span{font-size:.95rem}.pwa-update-btn{background:#fff;color:#667eea;border:none;padding:6px 16px;border-radius:20px;font-size:.9rem;font-weight:500;cursor:pointer}.pwa-update-btn:hover{background:#f0f0f0}.offline-indicator{position:fixed;bottom:0;left:0;right:0;background:#ff9800;color:#fff;text-align:center;padding:8px;font-size:.85rem;z-index:999}.cookie-consent{position:fixed;bottom:0;left:0;right:0;background-color:#000000f2;color:#fff;padding:16px;box-shadow:0 -4px 12px #0000004d;z-index:10000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cookie-consent-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.cookie-consent-content p{margin:0;flex:1;font-size:14px;line-height:1.5;min-width:250px}.cookie-consent-actions{display:flex;gap:12px}.cookie-consent-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.cookie-consent-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.cookie-consent-button:active{transform:translateY(0)}@media(max-width:768px){.cookie-consent{padding:12px}.cookie-consent-content{flex-direction:column;align-items:flex-start}.cookie-consent-content p{font-size:13px}.cookie-consent-actions{width:100%}.cookie-consent-button{width:100%;padding:14px}}@media(prefers-reduced-motion:reduce){.cookie-consent{animation:none}}.beta-banner{background:#fff3cd;color:#856404;padding:8px 40px 8px 16px;font-size:.85rem;text-align:center;position:relative}.beta-banner a{color:#664d03;font-weight:500}.beta-dismiss{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.25rem;color:#856404;cursor:pointer;padding:4px 8px}.beta-dismiss:hover{color:#664d03}
