*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--navy: #1e3a5f;--navy-dark: #152d4a;--blue: #2563eb;--blue-hover: #1d4ed8;--blue-light: #dbeafe;--teal: #0d9488;--green: #16a34a;--green-light: #dcfce7;--red: #dc2626;--red-light: #fee2e2;--yellow: #ca8a04;--yellow-light: #fef9c3;--grey-50: #f8fafc;--grey-100: #f1f5f9;--grey-200: #e2e8f0;--grey-300: #cbd5e1;--grey-400: #94a3b8;--grey-500: #64748b;--grey-600: #475569;--grey-700: #334155;--grey-800: #1e293b;--white: #ffffff;--shadow-sm: 0 1px 3px rgba(0,0,0,.1);--shadow: 0 2px 8px rgba(0,0,0,.1);--shadow-lg: 0 4px 16px rgba(0,0,0,.12);--radius: 8px;--radius-lg: 12px}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--grey-100);color:var(--grey-800);line-height:1.5;font-size:15px}#root{min-height:100vh;display:flex;flex-direction:column}.nav{background:var(--navy);padding:0 1.5rem;display:flex;align-items:center;gap:1rem;height:56px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0003}.nav-brand{color:var(--white);font-weight:700;font-size:1.1rem;text-decoration:none;white-space:nowrap;margin-right:.5rem}.nav-links{display:flex;align-items:center;gap:.25rem;flex:1;flex-wrap:wrap}.nav-link{color:#fffc;text-decoration:none;font-size:.875rem;padding:.375rem .625rem;border-radius:var(--radius);transition:background .15s,color .15s;white-space:nowrap}.nav-link:hover,.nav-link.active{background:#ffffff26;color:var(--white)}.page{flex:1;padding:2rem 1.5rem;max-width:1200px;margin:0 auto;width:100%}.page-narrow{max-width:480px;margin:2rem auto;padding:0 1rem}.page-wide{max-width:1200px}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem}.card-sm{padding:1rem}.card-lg{padding:2rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;cursor:pointer;border:none;transition:background .15s,transform .1s,box-shadow .15s;text-decoration:none;line-height:1.4}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--blue);color:var(--white)}.btn-primary:hover{background:var(--blue-hover);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--grey-200);color:var(--grey-700)}.btn-secondary:hover{background:var(--grey-300)}.btn-navy{background:var(--navy);color:var(--white)}.btn-navy:hover{background:var(--navy-dark)}.btn-outline{background:transparent;color:var(--blue);border:1.5px solid var(--blue)}.btn-outline:hover{background:var(--blue-light)}.btn-danger{background:var(--red);color:var(--white)}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:1.125rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--grey-700);margin-bottom:.375rem}.form-input{width:100%;padding:.625rem .875rem;border:1.5px solid var(--grey-300);border-radius:var(--radius);font-size:.9rem;background:var(--white);color:var(--grey-800);transition:border-color .15s,box-shadow .15s;outline:none}.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1f}.form-input.error{border-color:var(--red)}.form-hint{font-size:.8rem;color:var(--grey-500);margin-top:.25rem}.form-error{font-size:.8rem;color:var(--red);margin-top:.25rem}.alert{padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;margin-bottom:1rem}.alert-error{background:var(--red-light);color:#991b1b;border:1px solid #fca5a5}.alert-success{background:var(--green-light);color:#166534;border:1px solid #86efac}.alert-info{background:var(--blue-light);color:#1e40af;border:1px solid #93c5fd}.alert-warning{background:var(--yellow-light);color:#92400e;border:1px solid #fde047}.progress-bar-wrap{background:var(--grey-200);border-radius:999px;overflow:hidden;height:8px}.progress-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--teal));transition:width .4s ease}.progress-bar-wrap.thick{height:14px}.grid{display:grid;gap:1.25rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-5{grid-template-columns:repeat(5,1fr)}.stat-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.25rem;text-align:center}.stat-value{font-size:2rem;font-weight:700;color:var(--navy);line-height:1.1}.stat-label{font-size:.8rem;color:var(--grey-500);margin-top:.25rem;text-transform:uppercase;letter-spacing:.05em}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-blue{background:var(--blue-light);color:#1e40af}.badge-green{background:var(--green-light);color:#166534}.badge-grey{background:var(--grey-200);color:var(--grey-600)}.keyboard-banner{background:#fffbeb;border-bottom:1px solid #fde68a;padding:.5rem 1.5rem;font-size:.8rem;color:#92400e;text-align:center}.ad-placeholder{background:var(--grey-200);border:2px dashed var(--grey-300);border-radius:var(--radius);height:90px;display:flex;align-items:center;justify-content:center;color:var(--grey-400);font-size:.875rem;margin-top:2rem}.xp-bar-wrap{background:var(--grey-200);border-radius:999px;height:20px;overflow:hidden;position:relative}.xp-bar-fill{height:100%;background:linear-gradient(90deg,#2563eb,#0d9488);border-radius:999px;transition:width .5s ease}.xp-bar-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--white);text-shadow:0 1px 2px rgba(0,0,0,.3)}.section-title{font-size:1.125rem;font-weight:700;color:var(--navy);margin-bottom:1rem}.page-title{font-size:1.75rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}.page-subtitle{color:var(--grey-500);margin-bottom:1.5rem}.landing-hero{min-height:calc(100vh - 56px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;background:linear-gradient(135deg,#1e3a5f,#1e40af,#0d9488);color:var(--white)}.landing-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.15;margin-bottom:1rem}.landing-tagline{font-size:1.25rem;opacity:.85;margin-bottom:.75rem}.landing-notice{font-size:.875rem;opacity:.7;margin-bottom:2rem;display:flex;align-items:center;gap:.5rem}.landing-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.btn-white{background:var(--white);color:var(--navy);font-weight:600}.btn-white:hover{background:var(--grey-100)}.btn-outline-white{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.6)}.btn-outline-white:hover{background:#ffffff1a}.recovery-box{background:var(--grey-800);color:var(--white);border-radius:var(--radius);padding:1.5rem;text-align:center;font-family:monospace;font-size:1.5rem;letter-spacing:.15em;margin:1rem 0}.practice-prompt{background:var(--white);border:2px solid var(--grey-200);border-radius:var(--radius-lg);padding:1.5rem 2rem;font-size:1.25rem;line-height:2;min-height:120px;margin-bottom:1rem;font-family:Courier New,monospace;letter-spacing:.02em}.char-correct{color:var(--green)}.char-wrong{color:var(--red);background:#fee2e2;border-radius:2px}.char-current{background:#dbeafe;border-radius:2px}.char-pending{color:var(--grey-400)}.practice-input{width:100%;padding:.875rem 1rem;font-size:1.1rem;border:2px solid var(--blue);border-radius:var(--radius);font-family:Courier New,monospace;outline:none;background:var(--grey-50)}.practice-input:focus{box-shadow:0 0 0 3px #2563eb26}.timer-display{font-size:3rem;font-weight:700;color:var(--navy);text-align:center;font-variant-numeric:tabular-nums}.timer-display.warning{color:var(--red)}.job-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;transition:transform .15s,box-shadow .15s;border:2px solid transparent}.job-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--blue)}.job-card-title{font-weight:700;color:var(--navy);font-size:1rem}.job-card-skills{font-size:.8rem;color:var(--grey-500)}.job-card-readiness{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.skill-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.25rem;text-align:center;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s;border:2px solid transparent}.skill-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--blue)}.skill-card-icon{font-size:2rem;margin-bottom:.5rem}.skill-card-name{font-weight:600;color:var(--navy);font-size:.9rem;margin-bottom:.75rem}.badge-item{background:var(--white);border-radius:var(--radius-lg);padding:1rem;text-align:center;border:2px solid var(--grey-200);transition:border-color .15s}.badge-item.earned{border-color:#fbbf24;background:#fffbeb}.badge-item-icon{font-size:2rem;margin-bottom:.375rem}.badge-item-name{font-weight:600;font-size:.8rem;color:var(--navy)}.badge-item-desc{font-size:.7rem;color:var(--grey-500);margin-top:.25rem}.badge-item.locked{opacity:.45;filter:grayscale(1)}.steps-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:2rem}.step-dot{width:10px;height:10px;border-radius:50%;background:var(--grey-300)}.step-dot.active{background:var(--blue);transform:scale(1.3)}.step-dot.done{background:var(--teal)}.grade-display{font-size:5rem;font-weight:800;text-align:center;line-height:1}.grade-A-plus{color:#7c3aed}.grade-A{color:var(--green)}.grade-B{color:var(--blue)}.grade-C{color:var(--yellow)}.grade-D{color:var(--red)}.divider{border:none;border-top:1px solid var(--grey-200);margin:1.5rem 0}a.link{color:var(--blue);text-decoration:none}a.link:hover{text-decoration:underline}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--grey-500)}.text-navy{color:var(--navy)}.font-bold{font-weight:700}.font-semibold{font-weight:600}@media (max-width: 768px){.grid-3,.grid-4,.grid-5{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.nav-links{display:none}.page{padding:1rem}.stat-value{font-size:1.5rem}}@media (max-width: 480px){.grid-3,.grid-4,.grid-5{grid-template-columns:1fr}.landing-title{font-size:2rem}}
