*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#0d0d0f;color:#f5f5f5;min-height:100dvh;min-width:390px;line-height:1.5;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{min-height:100dvh;display:flex;flex-direction:column}a{color:#f97316;text-decoration:none}a:hover{text-decoration:underline}img,svg{display:block;max-width:100%}ul,ol{list-style:none}input,button,textarea,select{font:inherit;color:inherit}h1{font-size:1.75rem;font-weight:700}h2{font-size:1.375rem;font-weight:600}h3{font-size:1.125rem;font-weight:600}.text-secondary{color:#a0a0a8}.text-muted{color:#6b6b73}.text-primary{color:#f97316}.text-accent{color:#3b82f6}.text-warning{color:#f59e0b}.text-danger{color:#ef4444}.text-center{text-align:center}.text-success{color:#10b981}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px;padding:.75rem 1.25rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;-webkit-user-select:none;user-select:none;touch-action:manipulation;white-space:nowrap}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background-color:#f97316;color:#fff}.btn-primary:hover:not(:disabled){background-color:#ea580c}.btn-secondary{background-color:#1a1a1e;color:#f5f5f5;border:1px solid #2A2A2E}.btn-secondary:hover:not(:disabled){background-color:#2a2a2e}.btn-danger{background-color:#ef4444;color:#fff}.btn-accent{background-color:#3b82f6;color:#fff}.btn-ghost{background:transparent;color:#a0a0a8;min-height:44px;padding:.5rem .75rem}.btn-ghost:hover:not(:disabled){color:#f5f5f5}.btn-block{width:100%}.card{background-color:#1a1a1e;border:1px solid #2A2A2E;border-radius:12px;padding:1.25rem}.input,.select,.textarea{display:block;width:100%;min-height:48px;padding:.75rem 1rem;background-color:#1a1a1e;border:1px solid #2A2A2E;border-radius:10px;color:#f5f5f5;font-size:1rem;transition:border-color .15s;outline:none}.input:focus,.select:focus,.textarea:focus{border-color:#f97316}.input::placeholder,.textarea::placeholder{color:#6b6b73}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23A0A0A8' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}.textarea{min-height:96px;resize:vertical}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;font-weight:500;color:#a0a0a8}.form-error{color:#ef4444;font-size:.875rem}.badge{display:inline-flex;align-items:center;padding:.35rem .75rem;border-radius:9999px;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.badge-lg{padding:.55rem 1.25rem;font-size:1rem;border-radius:12px}.badge-green{background-color:#10b9812e;color:#10b981}.badge-amber{background-color:#f59e0b2e;color:#f59e0b}.badge-red{background-color:#ef44442e;color:#ef4444}.badge-blue{background-color:#3b82f62e;color:#3b82f6}.badge-orange{background-color:#f973162e;color:#f97316}.badge-gray{background-color:#6b6b732e;color:#a0a0a8}.assessment-accept{background-color:#10b981;color:#fff}.assessment-repair{background-color:#f59e0b;color:#fff}.assessment-reject{background-color:#ef4444;color:#fff}.assessment-ndt{background-color:#3b82f6;color:#fff}.toggle-group{display:flex;background-color:#1a1a1e;border:1px solid #2A2A2E;border-radius:8px;padding:4px;gap:4px}.toggle-option{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:6px;color:#a0a0a8;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.toggle-option:hover{color:#fff}.toggle-option.active{background-color:#f97316;color:#0d0d0f}.expandable-header{display:flex;justify-content:space-between;align-items:flex-start;cursor:pointer;gap:.75rem}.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;background-color:#1a1a1e;border-top:1px solid #2A2A2E;padding-bottom:env(safe-area-inset-bottom,0px);z-index:100}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;min-height:56px;padding:.5rem 0;color:#6b6b73;font-size:.625rem;font-weight:500;text-decoration:none;transition:color .15s;cursor:pointer;touch-action:manipulation}.tab-item:hover{color:#a0a0a8;text-decoration:none}.tab-item.active{color:#f97316}.tab-item svg{width:24px;height:24px}.tab-content{flex:1;padding-bottom:calc(56px + env(safe-area-inset-bottom,0px));overflow-y:auto}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1rem}.spinner{width:40px;height:40px;border:3px solid #2A2A2E;border-top-color:#f97316;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-message{color:#a0a0a8;font-size:.9375rem;text-align:center}.page{padding:1.25rem;max-width:600px;margin:0 auto;width:100%}.page-header{margin-bottom:1.25rem}.stack{display:flex;flex-direction:column;gap:1rem}.stack-sm{display:flex;flex-direction:column;gap:.5rem}.row{display:flex;align-items:center;gap:.75rem}.row-between{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.divider{height:1px;background-color:#2a2a2e;margin:.75rem 0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.warning-box{background-color:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:.875rem 1rem;color:#f59e0b;font-size:.9375rem}.info-box{background-color:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:10px;padding:.875rem 1rem;color:#3b82f6;font-size:.9375rem}.scope-disclaimer{background-color:#3b82f614;border:1px solid rgba(59,130,246,.25);border-left:3px solid #3B82F6;border-radius:8px;padding:.75rem .875rem;color:#93c5fd;font-size:.8125rem;line-height:1.45}.error-banner{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;padding:.875rem 1rem;color:#ef4444;font-size:.9375rem}.checkbox-row{display:flex;align-items:center;gap:.625rem;min-height:44px;cursor:pointer}.checkbox-row input[type=checkbox]{width:20px;height:20px;accent-color:#F97316;cursor:pointer}.auth-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem}.auth-card{width:100%;max-width:420px}.auth-logo{text-align:center;font-size:2rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.25rem}.auth-logo span{color:#f97316}.auth-tagline{text-align:center;color:#a0a0a8;margin-bottom:2rem;font-size:.9375rem}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:200px;background-color:#1a1a1e;border:2px dashed #2A2A2E;border-radius:16px;cursor:pointer;transition:border-color .15s,background-color .15s;padding:2rem 1rem;gap:.875rem;color:#a0a0a8}.upload-zone:hover{border-color:#f97316;color:#f97316}.upload-zone svg{width:48px;height:48px}.upload-zone .upload-text{font-weight:600;font-size:1.0625rem}.upload-zone .upload-hint{font-size:.8125rem;color:#6b6b73}.image-preview{width:100%;border-radius:12px;border:1px solid #2A2A2E;max-height:320px;object-fit:contain;background:#000}.question-card{padding:1.5rem 1.25rem}.question-text{font-size:1.0625rem;font-weight:500;line-height:1.45;margin-bottom:1rem}.option-btn{display:block;width:100%;text-align:left;background:#0d0d0f;border:1px solid #2A2A2E;color:#f5f5f5;padding:.875rem 1rem;border-radius:10px;cursor:pointer;margin-bottom:.5rem;font-size:.9375rem;line-height:1.4;transition:border-color .15s,background .15s;min-height:48px}.option-btn:hover{border-color:#f97316}.option-btn.correct{border-color:#10b981;background:#10b9811a}.option-btn.incorrect{border-color:#ef4444;background:#ef44441a}.option-btn:disabled{cursor:default}.option-letter{display:inline-block;font-weight:700;color:#f97316;margin-right:.5rem}.chip{display:inline-flex;align-items:center;padding:.4rem .75rem;background:#1a1a1e;border:1px solid #2A2A2E;border-radius:9999px;font-size:.8125rem;color:#a0a0a8;cursor:pointer;-webkit-user-select:none;user-select:none}.chip.active{background:#f9731626;border-color:#f97316;color:#f97316}.chip-row{display:flex;flex-wrap:wrap;gap:.5rem}
