*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:#f5f7fa;color:#333;line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;padding:2rem;text-align:center}.app-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.app-header .tagline{font-size:1.1rem;opacity:.9}.app-main{flex:1;max-width:1200px;margin:0 auto;padding:2rem;width:100%}.app-footer{background:#1e293b;color:#94a3b8;padding:1.5rem;text-align:center;font-size:.875rem}.app-footer p{margin:.25rem 0}.error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1rem 1.5rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;color:#dc2626}.error-banner button{background:none;border:none;color:#dc2626;cursor:pointer;font-weight:500}.upload-section{display:flex;flex-direction:column;align-items:center;gap:2rem}.file-upload-container{width:100%;max-width:600px}.file-upload-zone{border:2px dashed #cbd5e1;border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s ease;background:#fff}.file-upload-zone:hover,.file-upload-zone.dragging{border-color:#2563eb;background:#eff6ff}.file-upload-zone.disabled{opacity:.6;cursor:not-allowed}.upload-icon{color:#64748b;margin-bottom:1rem}.file-upload-zone:hover .upload-icon,.file-upload-zone.dragging .upload-icon{color:#2563eb}.upload-text{font-size:1.125rem;color:#475569;margin-bottom:.5rem}.upload-subtext{font-size:.875rem;color:#94a3b8}.upload-error{color:#dc2626;margin-top:.5rem;font-size:.875rem}.upload-info{text-align:center;color:#64748b}.upload-info p{font-size:1rem;margin-bottom:1rem}.upload-info ul{list-style:none;display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.upload-info li{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.upload-info li:before{content:"✓";color:#22c55e;font-weight:700}.loading-section{display:flex;justify-content:center;padding:4rem 2rem}.loading-content{text-align:center}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{font-size:1.125rem;color:#475569;margin-bottom:1.5rem}.loading-steps{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.loading-steps span{padding:.5rem 1rem;background:#f1f5f9;border-radius:20px;font-size:.875rem;color:#94a3b8;transition:all .2s ease}.loading-steps span.active{background:#2563eb;color:#fff}.loading-steps span.done{background:#22c55e;color:#fff}.results-view{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;overflow:hidden}.results-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;gap:1rem}.results-title h2{font-size:1.5rem;color:#1e293b}.test-date{display:block;font-size:.875rem;color:#64748b;font-weight:400;margin-top:.25rem}.results-meta{display:flex;align-items:center;gap:1rem}.total-markers{font-size:.875rem;color:#64748b}.reset-button{background:#f1f5f9;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;color:#475569;cursor:pointer;transition:all .2s ease}.reset-button:hover{background:#e2e8f0}.panels-container{padding:1rem}.panel-section{border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem;overflow:hidden}.panel-header{display:flex;align-items:center;padding:1rem;background:#f8fafc;cursor:pointer;-webkit-user-select:none;user-select:none}.panel-header:hover{background:#f1f5f9}.panel-toggle{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#64748b;margin-right:.75rem}.panel-header h3{flex:1;font-size:1rem;font-weight:600;color:#1e293b}.panel-count{font-size:.75rem;color:#64748b;background:#e2e8f0;padding:.25rem .75rem;border-radius:12px}.panel-content{padding:0 1rem 1rem}.marker-header-row,.marker-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 100px;gap:1rem;padding:.75rem 0;align-items:center}.marker-header-row{font-size:.75rem;text-transform:uppercase;color:#64748b;border-bottom:1px solid #e2e8f0;font-weight:600}.marker-row{border-bottom:1px solid #f1f5f9;font-size:.875rem}.marker-row:last-child{border-bottom:none}.marker-name{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#1e293b}.marker-value{font-weight:600;color:#1e293b}.marker-unit,.marker-range{color:#64748b}.marker-flag{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-align:center}.flag-normal{background:#dcfce7;color:#166534}.flag-high{background:#fee2e2;color:#dc2626}.flag-low{background:#fef3c7;color:#d97706}.info-icon{position:relative;display:inline-flex;cursor:help;color:#94a3b8;transition:color .2s ease}.info-icon:hover{color:#2563eb}.tooltip{position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:.5rem;width:300px;background:#1e293b;color:#fff;padding:1rem;border-radius:8px;font-size:.8125rem;font-weight:400;z-index:1000;box-shadow:0 4px 12px #00000026}.tooltip:before{content:"";position:absolute;left:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:#1e293b}.tooltip-description{margin-bottom:.75rem;line-height:1.5}.tooltip-flags p{margin:.5rem 0;line-height:1.4}.tooltip-flags strong{color:#94a3b8}.health-summary{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:1.5rem}.health-summary.loading{display:flex;justify-content:center;padding:2rem;background:linear-gradient(135deg,#eff6ff,#f8fafc);border:1px solid #e2e8f0}.summary-loading{text-align:center;display:flex;align-items:center;gap:1rem}.summary-loading .spinner{width:24px;height:24px;margin:0}.summary-loading p{color:#64748b;margin:0}.health-summary h2{font-size:1.25rem;color:#1e293b;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.summary-content p{color:#374151;line-height:1.7;margin-bottom:1rem}.summary-content p:last-child{margin-bottom:0;color:#64748b;font-size:.875rem;font-style:italic;padding-top:.5rem;border-top:1px solid #f1f5f9}@media (max-width: 768px){.app-header h1{font-size:2rem}.app-main{padding:1rem}.marker-header-row,.marker-row{grid-template-columns:1fr;gap:.25rem}.marker-header-row{display:none}.marker-row{padding:1rem 0}.marker-name{font-size:.9375rem}.marker-value:before{content:"Value: ";color:#94a3b8;font-weight:400}.marker-unit:before{content:"Unit: ";color:#94a3b8}.marker-range:before{content:"Reference: ";color:#94a3b8}.marker-flag{justify-self:start}.tooltip{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);margin-left:0;max-width:90vw}.tooltip:before{display:none}.results-header{flex-direction:column;align-items:flex-start}.upload-info ul{flex-direction:column;align-items:center}}.password-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb,#1d4ed8)}.password-gate-content{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 4px 24px #00000026;text-align:center;width:100%;max-width:400px;margin:1rem}.password-gate-content h1{font-size:2rem;color:#1e293b;margin-bottom:.5rem}.password-gate-content>p{color:#64748b;margin-bottom:1.5rem}.password-gate-content form{display:flex;flex-direction:column;gap:1rem}.password-gate-content input{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem;transition:border-color .2s ease}.password-gate-content input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.password-gate-content button{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .2s ease}.password-gate-content button:hover{opacity:.9}.password-error{color:#dc2626;font-size:.875rem;margin-top:.5rem}
