:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app{flex-direction:column;min-height:100vh;display:flex}.header{color:#fff;background:linear-gradient(135deg,#1a365d 0%,#2c5282 100%);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 32px;display:flex;box-shadow:0 2px 10px #0000001a}.header h1{margin:0;font-size:1.5rem;font-weight:600}.user-info{align-items:center;gap:12px;display:flex}.user-avatar{border:2px solid #ffffff4d;border-radius:50%;width:36px;height:36px}.user-name{opacity:.95;font-size:.95rem}.logout-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;padding:8px 16px;font-size:.9rem;transition:all .2s}.logout-btn:hover{background:#ffffff40;border-color:#ffffff80}@keyframes spin{to{transform:rotate(360deg)}}.main-content{box-sizing:border-box;flex:1;width:100%;max-width:1200px;margin:0 auto;padding:32px 24px}.section{margin-bottom:40px}.section h2{color:#1a365d;border-bottom:2px solid #3182ce;margin-bottom:20px;padding-bottom:8px}.table-container{overflow-x:auto}.test-history-table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;overflow:hidden;box-shadow:0 1px 3px #0000001a}.test-history-table th,.test-history-table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:14px 16px}.test-history-table th{color:#2d3748;background:#edf2f7;font-weight:600}.test-history-table tr:hover{background:#f7fafc}.status-passed{color:#22543d;background:#c6f6d5;border-radius:4px;padding:4px 8px;font-weight:500}.status-failed{color:#742a2a;background:#fed7d7;border-radius:4px;padding:4px 8px;font-weight:500}.info-box{background:#ebf8ff;border-left:4px solid #3182ce;border-radius:0 8px 8px 0;padding:20px}.info-box p{margin:0 0 12px;line-height:1.6}.info-box p:last-child{margin-bottom:0}.info-box .highlight{color:#2c5282;font-size:1.1rem;font-weight:600}.required-section p{margin-bottom:16px}.required-tests-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin:0 0 24px;padding:0;list-style:none;display:grid}.required-tests-list li{color:#22543d;background:#f0fff4;border:1px solid #9ae6b4;border-radius:6px;padding:12px 16px;font-weight:500}.notice-box{background:#fffaf0;border:1px solid #fbd38d;border-radius:8px;margin-bottom:16px;padding:16px 20px}.notice-box p{margin:0 0 8px}.notice-box p:last-child{margin-bottom:0}.notice-box .important{color:#c05621}.privacy-link a{color:#3182ce;text-decoration:underline}.privacy-link a:hover{color:#2c5282}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;display:grid}.category-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.category-card h3{color:#fff;background:linear-gradient(135deg,#2c5282 0%,#3182ce 100%);margin:0;padding:16px 20px;font-size:1.2rem}.test-list{margin:0;padding:0;list-style:none}.test-item{border-bottom:1px solid #e2e8f0;flex-direction:column;gap:8px;padding:16px 20px;display:flex}.test-item:last-child{border-bottom:none}.test-link{color:#3182ce;text-decoration:none;transition:color .2s}.test-link:hover{color:#2c5282;text-decoration:underline}.test-details{color:#718096;font-size:.9rem}.start-test-btn{color:#fff;cursor:pointer;background:#3182ce;border:none;border-radius:6px;align-self:flex-start;padding:8px 16px;font-size:.9rem;transition:background .2s}.start-test-btn:hover{background:#2c5282}.start-test-btn.active{background:#c53030}.start-test-btn.active:hover{background:#9b2c2c}.test-iframe-container{border:1px solid #e2e8f0;border-radius:8px;width:100%;margin-top:16px;overflow:hidden}.test-iframe{border:none;width:100%;height:768px;display:block}.footer{color:#a0aec0;text-align:center;background:#1a365d;margin-top:auto;padding:20px}.footer p{margin:0}@media (width<=768px){.header{text-align:center;flex-direction:column;padding:16px}.header h1{font-size:1.25rem}.user-info{flex-wrap:wrap;justify-content:center}.user-name{display:none}.main-content{padding:20px 16px}.categories-grid,.required-tests-list{grid-template-columns:1fr}}.login-container{background:linear-gradient(135deg,#1a365d 0%,#2c5282 50%,#3182ce 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.login-header{color:#fff;text-align:center;background:linear-gradient(135deg,#1a365d 0%,#2c5282 100%);padding:32px}.login-header h1{margin:0 0 8px;font-size:1.5rem;font-weight:600}.login-header p{opacity:.9;margin:0;font-size:.95rem}.login-content{text-align:center;padding:40px 32px}.login-content h2{color:#1a365d;margin:0 0 16px;font-size:1.75rem}.login-content>p{color:#4a5568;margin-bottom:32px;line-height:1.6}.google-signin-btn{color:#2d3748;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;gap:12px;width:100%;padding:14px 24px;font-size:1rem;font-weight:500;transition:all .2s;display:inline-flex}.google-signin-btn:hover{background:#f7fafc;border-color:#cbd5e0;box-shadow:0 4px 12px #0000001a}.google-signin-btn:active{transform:scale(.98)}.google-icon{flex-shrink:0}.login-info{background:#ebf8ff;border-left:4px solid #3182ce;border-radius:8px;margin-top:24px;padding:16px}.login-info p{color:#2c5282;margin:0;font-size:.9rem}.login-footer{text-align:center;background:#f7fafc;border-top:1px solid #e2e8f0;padding:20px 32px}.login-footer p{color:#718096;margin:0 0 8px;font-size:.85rem}.login-footer a{color:#3182ce;font-size:.85rem;text-decoration:none}.login-footer a:hover{text-decoration:underline}.loading-container{background:linear-gradient(135deg,#1a365d 0%,#2c5282 50%,#3182ce 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-spinner{border:4px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@media (width<=480px){.login-card{border-radius:0}.login-header{padding:24px}.login-content{padding:32px 24px}}.profile-form-container{background:linear-gradient(135deg,#1a365d 0%,#2c5282 50%,#3182ce 100%);justify-content:center;align-items:flex-start;min-height:100vh;padding:40px 20px;display:flex}.profile-form-card{background:#fff;border-radius:16px;width:100%;max-width:700px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.profile-form-header{color:#fff;text-align:center;background:linear-gradient(135deg,#1a365d 0%,#2c5282 100%);padding:32px}.profile-form-header h1{margin:0 0 8px;font-size:1.75rem;font-weight:600}.profile-form-header p{opacity:.9;margin:0}.profile-form{padding:32px}.error-message{color:#c53030;background:#fed7d7;border:1px solid #fc8181;border-radius:8px;margin-bottom:24px;padding:12px 16px;font-size:.95rem}.form-section{border-bottom:1px solid #e2e8f0;margin-bottom:32px;padding-bottom:24px}.form-section:last-of-type{border-bottom:none;margin-bottom:24px}.form-section h2{color:#1a365d;border-bottom:2px solid #3182ce;margin:0 0 20px;padding-bottom:8px;font-size:1.25rem}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{margin-bottom:16px}.form-group label{color:#2d3748;margin-bottom:6px;font-size:.95rem;font-weight:500;display:block}.form-group input[type=text],.form-group input[type=tel],.form-group input[type=email],.form-group select,.form-group textarea{box-sizing:border-box;border:2px solid #e2e8f0;border-radius:8px;width:100%;padding:12px 14px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3182ce;outline:none;box-shadow:0 0 0 3px #3182ce26}.form-group textarea{resize:vertical;min-height:80px}.file-input{cursor:pointer;background:#f7fafc;padding:10px!important}.file-name{color:#4a5568;margin-top:8px;font-size:.9rem}.checkbox-group label{cursor:pointer;align-items:center;gap:10px;font-weight:400;display:flex}.checkbox-group input[type=checkbox]{cursor:pointer;width:20px;height:20px}.education-entry{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:16px;padding:20px}.education-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.education-header h3{color:#2c5282;margin:0;font-size:1.1rem}.remove-btn{color:#c53030;cursor:pointer;background:#fed7d7;border:none;border-radius:6px;padding:6px 12px;font-size:.85rem;transition:background .2s}.remove-btn:hover{color:#fff;background:#fc8181}.add-education-btn{color:#3182ce;cursor:pointer;background:#ebf8ff;border:2px dashed #3182ce;border-radius:8px;width:100%;padding:12px;font-size:.95rem;font-weight:500;transition:all .2s}.add-education-btn:hover{background:#bee3f8}.form-actions{gap:16px;margin-top:24px;display:flex}.submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2c5282 0%,#3182ce 100%);border:none;border-radius:8px;flex:1;padding:14px 24px;font-size:1rem;font-weight:600;transition:opacity .2s,transform .2s}.submit-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.form-actions .logout-btn{color:#718096;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:14px 24px;font-size:1rem;transition:all .2s}.form-actions .logout-btn:hover{color:#c53030;border-color:#c53030}@media (width<=600px){.profile-form-container{padding:20px 16px}.profile-form-card{border-radius:12px}.profile-form-header,.profile-form{padding:24px}.form-row{grid-template-columns:1fr;gap:0}.form-actions{flex-direction:column}}.dashboard{background:#f7fafc;min-height:100vh;padding:20px}.dashboard-header{text-align:center;margin-bottom:30px}.dashboard-header-top{justify-content:center;align-items:center;gap:20px;display:flex}.dashboard-header h1{color:#1a365d;margin-bottom:8px;font-size:2.5rem}.dashboard-header p{color:#718096;font-size:1.1rem}.dashboard-logout-btn{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:6px;padding:8px 20px;font-size:.95rem;font-weight:500;transition:background .2s}.dashboard-logout-btn:hover{background:#c53030}.dashboard-controls{background:#fff;border-radius:8px;margin-bottom:20px;padding:20px;box-shadow:0 1px 3px #0000001a}.filter-section{align-items:center;gap:15px;display:flex}.filter-input{border:1px solid #e2e8f0;border-radius:6px;flex:1;max-width:400px;padding:10px 15px;font-size:1rem}.filter-input:focus{border-color:#3182ce;outline:none;box-shadow:0 0 0 3px #3182ce1a}.classification-groups{flex-direction:column;gap:15px;display:flex}.classification-group{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.group-header{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2c5282 0%,#3182ce 100%);justify-content:space-between;align-items:center;padding:20px;transition:background .2s;display:flex}.group-header:hover{background:linear-gradient(135deg,#2a4365 0%,#2c5282 100%)}.group-info h3{margin:0;font-size:1.3rem;font-weight:600}.user-count{opacity:.9;font-size:.9rem;font-weight:400}.expand-icon{font-size:1.2rem;transition:transform .2s}.users-table-container{overflow-x:auto}.users-table{border-collapse:collapse;width:100%;font-size:.9rem}.users-table th,.users-table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:12px 15px}.users-table th{color:#2d3748;z-index:10;background:#f7fafc;font-weight:600;position:sticky;top:0}.users-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.users-table th.sortable:hover{background:#edf2f7}.users-table tr:hover{background:#f7fafc}.users-table tr:last-child td{border-bottom:none}.no-results{text-align:center;color:#718096;font-style:italic;padding:40px!important}.dashboard-loading{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:50vh;display:flex}.dashboard-loading p{color:#718096;font-size:1.1rem}.dashboard-error{color:#e53e3e;flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:50vh;display:flex}.dashboard-error h2{color:#e53e3e;margin:0}.user-row.clickable{cursor:pointer;transition:background .2s}.user-row.clickable:hover{background:#f1f5f9}.expand-icon{color:#4a5568;margin-right:8px;font-size:.8rem;transition:transform .2s;display:inline-block}.test-results-row{background:#f8fafc}.test-results-row td{border-bottom:none;padding:0}.test-results-container{background:#fff;border-radius:6px;margin:10px;padding:20px;box-shadow:0 1px 3px #0000001a}.test-results-container h4{color:#2d3748;margin:0 0 15px;font-size:1.1rem}.test-results-table{border-collapse:collapse;width:100%;margin-top:10px;font-size:.9rem}.test-results-table th,.test-results-table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:8px 12px}.test-results-table th{color:#2d3748;background:#f7fafc;font-size:.85rem;font-weight:600}.test-results-table tr:hover{background:#f7fafc}.status-passed{color:#22543d;background:#c6f6d5;border-radius:3px;padding:2px 6px;font-size:.8rem;font-weight:500}.status-failed{color:#742a2a;background:#fed7d7;border-radius:3px;padding:2px 6px;font-size:.8rem;font-weight:500}
