:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light dark;color:#ffffffde;background-color:#242424}body{margin:0;min-height:100vh;background:#0f172a;color:#f1f5f9;display:flex;place-items:center;min-width:320px}#root{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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--primary: #84cc16;--primary-dark: #65a30d;--secondary: #64748b;--background: #0f172a;--surface: #1e293b;--surface-light: #334155;--text: #f1f5f9;--text-secondary: #cbd5e1;--border: #475569;--error: #ef4444;--success: #22c55e;--warning: #f59e0b;--grade-3: #22c55e;--grade-2: #84cc16;--grade-1: #f59e0b;--grade-0: #ef4444}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--background);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column}#root{width:100%}.main-content{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.app-header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%}.header-content{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.header-left,.header-right{display:flex;align-items:center;gap:1rem}.header-logo{background:none;border:none;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:600;transition:color .2s}.header-logo:hover{color:var(--primary)}.header-logo h1{font-size:1.25rem;margin:0}.user-info{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--surface-light);border-radius:.5rem;color:var(--text-secondary)}button{cursor:pointer;border:none;font-family:inherit;font-size:.95rem;transition:all .2s}.btn-primary{background:var(--primary);color:#000;padding:.75rem 2rem;border-radius:.5rem;font-weight:600;width:100%}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary-small{background:var(--primary);color:#000;padding:.5rem 1rem;border-radius:.375rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.btn-primary-small:hover{background:var(--primary-dark)}.btn-secondary{background:var(--surface-light);color:var(--text);padding:.75rem 2rem;border-radius:.5rem;font-weight:600;width:100%}.btn-secondary:hover{background:var(--border)}.btn-secondary-small{background:var(--surface-light);color:var(--text);padding:.5rem 1rem;border-radius:.375rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.btn-secondary-small:hover{background:var(--border)}.btn-link{background:none;color:var(--primary);padding:.5rem;text-decoration:underline}.btn-link:hover{color:var(--primary-dark)}.btn-icon{background:var(--surface-light);color:var(--text);padding:.5rem;border-radius:.375rem;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--border);color:var(--primary)}.btn-danger{background:var(--error);color:#fff;padding:.75rem 2rem;border-radius:.5rem;font-weight:600}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.btn-icon.btn-danger{background:#ef44441a;color:var(--error);padding:.5rem}.btn-icon.btn-danger:hover{background:var(--error);color:#fff}.login-container,.onboarding-container,.profile-container{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:2rem}.login-card,.onboarding-card,.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:3rem;max-width:550px;width:100%;position:relative}.back-button{position:absolute;top:1.5rem;left:1.5rem;background:var(--surface-light);color:var(--text);padding:.5rem 1rem;border-radius:.375rem;font-weight:500;display:flex;align-items:center;gap:.5rem;font-size:.875rem}.back-button:hover{background:var(--border);color:var(--primary)}.login-header,.onboarding-header,.profile-header{text-align:center;margin-bottom:2rem}.login-icon,.onboarding-icon,.profile-icon{width:64px;height:64px;margin:0 auto 1rem;color:var(--primary)}.login-header h1,.onboarding-header h1,.profile-header h1{font-size:1.75rem;margin-bottom:.5rem}.login-header p,.onboarding-header p,.profile-header p{color:var(--text-secondary)}.login-form,.onboarding-form,.profile-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:var(--text-secondary)}.form-group input,.form-group textarea{background:var(--surface-light);border:1px solid var(--border);color:var(--text);padding:.75rem 1rem;border-radius:.5rem;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:2px solid var(--primary);outline-offset:0}.form-actions{display:flex;flex-direction:column;gap:1rem}.login-footer{margin-top:1.5rem;text-align:center}.error-message{background:#ef44441a;border:1px solid var(--error);color:var(--error);padding:.75rem 1rem;border-radius:.5rem;text-align:center}.success-message{background:#22c55e1a;border:1px solid var(--success);color:var(--success);padding:.75rem 1rem;border-radius:.5rem;text-align:center}.loading-container,.error-container{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.spinner{width:48px;height:48px;border:4px solid var(--surface-light);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.progress-overview{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:2rem;margin-bottom:2rem}.overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.overview-header h2{font-size:1.5rem}.overview-actions{display:flex;gap:.5rem}.overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}@media(min-width:1024px){.overview-grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:768px)and (max-width:1023px){.overview-grid{grid-template-columns:repeat(2,1fr)}}.overview-card{background:var(--surface-light);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem}.overview-card.primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#000;border:none}.card-label{font-size:.875rem;font-weight:500;opacity:.8;margin-bottom:.5rem}.card-value{font-size:2rem;font-weight:700;margin-bottom:.25rem}.card-value.large{font-size:3rem}.card-detail{font-size:.875rem;opacity:.8;margin-bottom:.75rem}.progress-bar,.progress-bar-small{background:#ffffff1a;border-radius:9999px;overflow:hidden;height:8px}.progress-bar-small{height:6px;flex:1;min-width:80px}.progress-fill{background:var(--primary);height:100%;transition:width .3s ease}.overview-card.primary .progress-fill{background:#0000004d}.categories-container{display:flex;flex-direction:column;gap:1.5rem}.category-section{background:var(--surface);border:1px solid var(--border);border-radius:1rem;overflow:hidden}.category-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;cursor:pointer;background:var(--surface);transition:background .2s}.category-header:hover{background:var(--surface-light)}.category-info h2{font-size:1.25rem;margin-bottom:.25rem}.category-weight{font-size:.875rem;color:var(--text-secondary)}.category-meta{display:flex;align-items:center;gap:1rem}.progress-text{font-weight:600;color:var(--primary);min-width:45px;text-align:right}.category-content{padding:0 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.criteria-item{background:var(--surface-light);border:1px solid var(--border);border-radius:.75rem;overflow:hidden}.criteria-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;cursor:pointer;transition:background .2s}.criteria-header:hover{background:#ffffff08}.criteria-info{display:flex;align-items:start;gap:1rem;flex:1}.criteria-id{background:var(--primary);color:#000;padding:.25rem .75rem;border-radius:.375rem;font-weight:700;font-size:.875rem;flex-shrink:0}.criteria-titles{flex:1}.criteria-titles h3{font-size:1rem;margin-bottom:.25rem}.criteria-titles p{font-size:.875rem;color:var(--text-secondary)}.criteria-meta{display:flex;align-items:center;gap:1rem}.grade-badge{padding:.375rem .875rem;border-radius:.375rem;font-weight:600;font-size:.875rem}.grade-badge.grade-3{background:var(--grade-3);color:#000}.grade-badge.grade-2{background:var(--grade-2);color:#000}.grade-badge.grade-1{background:var(--grade-1);color:#000}.grade-badge.grade-0{background:var(--grade-0);color:#fff}.criteria-progress{font-weight:600;color:var(--text-secondary);min-width:40px;text-align:right}.criteria-content{padding:0 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1.5rem}.requirements-list{display:flex;flex-direction:column;gap:.75rem}.requirement-item label{display:flex;align-items:start;gap:.75rem;cursor:pointer;padding:.75rem;border-radius:.5rem;transition:background .2s}.requirement-item label:hover{background:#ffffff08}.requirement-item input[type=checkbox],.requirement-item input[type=radio]{margin-top:.25rem;width:18px;height:18px;flex-shrink:0;cursor:pointer;accent-color:var(--primary)}.requirement-text{flex:1;line-height:1.5}.note-section{display:flex;flex-direction:column;gap:.5rem}.note-section label{font-weight:500;color:var(--text-secondary)}.note-section textarea{background:var(--background);border:1px solid var(--border);color:var(--text);padding:.75rem;border-radius:.5rem;font-size:.95rem;font-family:inherit;resize:vertical}.note-section textarea:focus{outline:2px solid var(--primary);outline-offset:0}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:2rem;max-width:450px;width:90%;box-shadow:0 20px 25px -5px #0000004d}.modal-header{display:flex;flex-direction:column;align-items:center;margin-bottom:1.5rem;text-align:center}.modal-icon{width:56px;height:56px;margin-bottom:1rem}.modal-icon.warning{color:var(--error)}.modal-header h2{font-size:1.5rem;margin:0}.modal-body{margin-bottom:2rem}.modal-body p{color:var(--text-secondary);line-height:1.6;text-align:center}.modal-footer{display:flex;gap:1rem;justify-content:flex-end}.modal-footer button{flex:1}.header-logo h1{display:flex;align-items:center;gap:.5rem}.version-badge{font-size:.625rem;font-weight:400;color:var(--text-secondary);background:var(--surface-light);padding:.125rem .375rem;border-radius:.25rem;font-family:Courier New,monospace;letter-spacing:.5px}@media(max-width:768px){.main-content{padding:1rem}.header-content{padding:1rem;flex-direction:column;gap:1rem}.overview-grid{grid-template-columns:1fr}.criteria-info{flex-direction:column;gap:.5rem}.criteria-meta{flex-direction:column;align-items:end;gap:.5rem}.login-card,.onboarding-card,.profile-card{padding:2rem;width:95%}.login-container,.onboarding-container,.profile-container{padding:1rem}}
