:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color:#1e293b;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}button,.btn,[class*=btn-],[class*=-button]{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:12px 24px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:16px;font-weight:600;line-height:1.25;text-align:center;text-decoration:none;white-space:nowrap;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;appearance:none;background:none;margin:0}button:focus-visible,.btn:focus-visible,[class*=btn-]:focus-visible,[class*=-button]:focus-visible{outline:3px solid #3b82f6;outline-offset:2px}.btn-primary,.primary-button,.submit-button,.save-button,.start-button,.subscribe-button,.approve-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:#3b82f6;box-shadow:0 2px 4px #3b82f633}.btn-primary:hover:not(:disabled),.primary-button:hover:not(:disabled),.submit-button:hover:not(:disabled),.save-button:hover:not(:disabled),.start-button:hover:not(:disabled),.subscribe-button:hover:not(:disabled),.approve-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#2563eb;box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.btn-primary:active:not(:disabled),.primary-button:active:not(:disabled),.submit-button:active:not(:disabled),.save-button:active:not(:disabled),.start-button:active:not(:disabled),.subscribe-button:active:not(:disabled),.approve-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #3b82f633}.btn-secondary,.secondary-button,.cancel-button,.back-button,.close-button,.modal-close-button,.toggle-button{background:#fff;color:#1e293b;border-color:#e2e8f0;box-shadow:0 1px 3px #0000001a}.btn-secondary:hover:not(:disabled),.secondary-button:hover:not(:disabled),.cancel-button:hover:not(:disabled),.back-button:hover:not(:disabled),.close-button:hover:not(:disabled),.modal-close-button:hover:not(:disabled),.toggle-button:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.btn-secondary:active:not(:disabled),.secondary-button:active:not(:disabled),.cancel-button:active:not(:disabled),.back-button:active:not(:disabled),.close-button:active:not(:disabled),.modal-close-button:active:not(:disabled),.toggle-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000000d;background:#f1f5f9}.btn-tertiary,.tertiary-button,.view-button,.show-all-button{background:transparent;color:#3b82f6;border-color:transparent;box-shadow:none;padding:12px 20px}.btn-tertiary:hover:not(:disabled),.tertiary-button:hover:not(:disabled),.view-button:hover:not(:disabled),.show-all-button:hover:not(:disabled){background:#eff6ff;color:#2563eb;border-color:transparent}.btn-tertiary:active:not(:disabled),.tertiary-button:active:not(:disabled),.view-button:active:not(:disabled),.show-all-button:active:not(:disabled){background:#dbeafe}.btn-danger,.danger-button,.reject-button,.cancel-request-button{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444;box-shadow:0 2px 4px #ef444433}.btn-danger:hover:not(:disabled),.danger-button:hover:not(:disabled),.reject-button:hover:not(:disabled),.cancel-request-button:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626;box-shadow:0 4px 8px #ef44444d;transform:translateY(-1px)}.btn-success,.success-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981;box-shadow:0 2px 4px #10b98133}.btn-success:hover:not(:disabled),.success-button:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);border-color:#059669;box-shadow:0 4px 8px #10b9814d;transform:translateY(-1px)}.nav-button,.nav-section-button{background:#fff;color:#64748b;border-color:#e2e8f0;min-height:44px;padding:12px 20px;font-weight:500}.nav-button:hover:not(:disabled),.nav-section-button:hover:not(:disabled){background:#f8fafc;color:#1e293b;border-color:#cbd5e1}.nav-button.active,.nav-section-button.active{background:#eff6ff;color:#3b82f6;border-color:#3b82f6;font-weight:600}.btn-icon,.icon-button{min-width:44px;min-height:44px;padding:10px;justify-content:center}.btn-icon svg,.icon-button svg,button svg{width:20px;height:20px;flex-shrink:0}.btn-lg,.btn-large,.master-challenge-button,.full-exam-button{min-height:52px;padding:16px 32px;font-size:18px;font-weight:700;border-radius:10px}.btn-sm,.btn-small,.flag-button,.copy-code-button{min-height:36px;padding:8px 16px;font-size:14px;font-weight:600;border-radius:6px}.btn-xs,.btn-compact{min-height:32px;padding:6px 12px;font-size:13px;font-weight:600;border-radius:6px}button:disabled,.btn:disabled,[class*=btn-]:disabled,[class*=-button]:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;pointer-events:none}.btn-loading,.button-loading{position:relative;color:transparent;pointer-events:none}.btn-loading:after,.button-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid currentColor;border-radius:50%;border-top-color:transparent;animation:button-spin .6s linear infinite;opacity:1;color:inherit}@keyframes button-spin{to{transform:rotate(360deg)}}.btn-group{display:inline-flex;gap:0}.btn-group>button,.btn-group>.btn,.btn-group>[class*=btn-]{border-radius:0;margin-left:-2px}.btn-group>button:first-child,.btn-group>.btn:first-child,.btn-group>[class*=btn-]:first-child{border-top-left-radius:8px;border-bottom-left-radius:8px;margin-left:0}.btn-group>button:last-child,.btn-group>.btn:last-child,.btn-group>[class*=btn-]:last-child{border-top-right-radius:8px;border-bottom-right-radius:8px}.btn-block,.btn-full-width{width:100%;display:flex}@media(max-width:768px){button,.btn,[class*=btn-],[class*=-button]{min-height:48px;padding:14px 20px;font-size:15px}.btn-lg,.btn-large,.master-challenge-button,.full-exam-button{min-height:56px;padding:18px 28px;font-size:17px}.btn-sm,.btn-small{min-height:40px;padding:10px 16px;font-size:14px}}@media(max-width:480px){button,.btn,[class*=btn-],[class*=-button]{padding:14px 16px}.btn-group{flex-direction:column;width:100%}.btn-group>button,.btn-group>.btn,.btn-group>[class*=btn-]{width:100%;border-radius:8px;margin-left:0;margin-top:-2px}.btn-group>button:first-child,.btn-group>.btn:first-child,.btn-group>[class*=btn-]:first-child{margin-top:0}}.profile-button,.analytics-button,.achievements-button,.manager-button{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-color:#8b5cf6;min-height:44px;padding:12px 24px;font-size:16px;font-weight:600;box-shadow:0 2px 4px #8b5cf633}.profile-button:hover:not(:disabled),.analytics-button:hover:not(:disabled),.achievements-button:hover:not(:disabled),.manager-button:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#6d28d9);border-color:#7c3aed;box-shadow:0 4px 8px #8b5cf64d;transform:translateY(-1px)}.study-button,.chapter-button,.section-button{background:#fff;color:#1e293b;border-color:#e2e8f0;min-height:44px;padding:12px 20px;justify-content:flex-start;text-align:left;box-shadow:0 1px 3px #0000001a}.study-button:hover:not(:disabled),.chapter-button:hover:not(:disabled),.section-button:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;box-shadow:0 2px 4px #0000001a}.master-challenge-button{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-color:#f59e0b;box-shadow:0 4px 12px #f59e0b66;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.master-challenge-button:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309);border-color:#d97706;box-shadow:0 6px 16px #f59e0b80;transform:translateY(-2px)}.btn-unstyled{all:unset;cursor:pointer}.btn-shadow-sm{box-shadow:0 1px 2px #0000000d}.btn-shadow{box-shadow:0 2px 4px #0000001a}.btn-shadow-lg{box-shadow:0 4px 12px #00000026}.btn-rounded{border-radius:50px}.btn-square{border-radius:4px}@media(prefers-contrast:high){button,.btn,[class*=btn-],[class*=-button]{border-width:3px}}@media(prefers-reduced-motion:reduce){button,.btn,[class*=btn-],[class*=-button]{transition:none;animation:none}button:hover,.btn:hover,[class*=btn-]:hover,[class*=-button]:hover{transform:none}}@media print{button,.btn,[class*=btn-],[class*=-button]{border:1px solid #000;box-shadow:none}}.homepage{min-height:100vh;background:#fff}.homepage-nav{position:fixed;top:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e5e7eb;z-index:1000;transition:box-shadow .3s ease}.nav-container{max-width:1280px;margin:0 auto;padding:16px 32px;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:#0f172a}.logo-icon{font-size:28px}.nav-actions{display:flex;align-items:center;gap:12px}.btn-nav-secondary{padding:10px 20px;font-size:14px;font-weight:600;color:#64748b;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-nav-secondary:hover{color:#0f172a;background:#f1f5f9}.btn-nav-primary{padding:10px 20px;font-size:14px;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-nav-primary:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.hero-section{padding:120px 32px 80px;background:linear-gradient(180deg,#f8fafc,#fff)}.hero-container{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}.hero-content{display:flex;flex-direction:column;gap:24px}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#dcfce7;border:1px solid #86efac;border-radius:24px;font-size:14px;font-weight:600;color:#166534;width:fit-content}.badge-icon{font-size:16px}.hero-title{font-size:56px;font-weight:800;line-height:1.1;color:#0f172a;margin:0}.hero-title-accent{background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:20px;line-height:1.6;color:#64748b;margin:0}.hero-cta{display:flex;gap:16px;margin-top:16px}.btn-hero-primary{display:flex;align-items:center;gap:8px;padding:16px 32px;font-size:16px;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #10b9814d}.btn-hero-primary:hover{background:#059669;transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.btn-hero-secondary{padding:16px 32px;font-size:16px;font-weight:600;color:#64748b;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .3s ease}.btn-hero-secondary:hover{color:#0f172a;border-color:#cbd5e1;background:#f8fafc}.hero-stats{display:flex;align-items:center;gap:32px;margin-top:32px;padding-top:32px;border-top:1px solid #e5e7eb}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-value{font-size:32px;font-weight:700;color:#10b981}.stat-label{font-size:14px;color:#64748b}.stat-divider{width:1px;height:40px;background:#e5e7eb}.hero-visual{display:flex;justify-content:center;align-items:center}.visual-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px #0000001a;width:100%;max-width:500px}.visual-card-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:#f8fafc;border-bottom:2px solid #e5e7eb}.visual-card-title{font-size:16px;font-weight:600;color:#0f172a}.visual-card-badge{padding:4px 12px;background:#dbeafe;border-radius:12px;font-size:12px;font-weight:600;color:#1e40af}.visual-card-content{padding:24px}.visual-question{font-size:15px;line-height:1.6;color:#334155;margin:0 0 20px}.visual-options{display:flex;flex-direction:column;gap:12px}.visual-option{padding:12px 16px;background:#f8fafc;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;color:#475569;transition:all .2s ease}.visual-option-selected{background:#dcfce7;border-color:#10b981;color:#166534;font-weight:600}.visual-card-footer{padding:20px 24px;background:#f0fdf4;border-top:2px solid #86efac}.visual-result{display:flex;align-items:flex-start;gap:12px}.result-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#10b981;border-radius:50%;font-size:14px;color:#fff;font-weight:700}.result-text{font-size:14px;line-height:1.5;color:#166534}.features-section{padding:80px 32px;background:#fff}.features-container{max-width:1280px;margin:0 auto}.section-header{text-align:center;margin-bottom:64px}.section-title{font-size:48px;font-weight:800;color:#0f172a;margin:0 0 16px}.section-description{font-size:20px;color:#64748b;margin:0}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}.feature-card{padding:32px;background:#fff;border:2px solid #e5e7eb;border-radius:16px;transition:all .3s ease}.feature-card:hover{border-color:#10b981;box-shadow:0 12px 32px #10b98126;transform:translateY(-4px)}.feature-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:12px;margin-bottom:20px}.feature-icon svg{width:28px;height:28px}.feature-icon-blue{background:#dbeafe;color:#1e40af}.feature-icon-green{background:#dcfce7;color:#166534}.feature-icon-purple{background:#e9d5ff;color:#7c3aed}.feature-icon-orange{background:#fed7aa;color:#c2410c}.feature-icon-red{background:#fecaca;color:#991b1b}.feature-icon-teal{background:#ccfbf1;color:#115e59}.feature-title{font-size:20px;font-weight:700;color:#0f172a;margin:0 0 12px}.feature-description{font-size:16px;line-height:1.6;color:#64748b;margin:0}.how-it-works-section{padding:80px 32px;background:#f8fafc}.how-it-works-container{max-width:1280px;margin:0 auto}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}.step-card{text-align:center}.step-number{width:64px;height:64px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fff;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%}.step-title{font-size:24px;font-weight:700;color:#0f172a;margin:0 0 12px}.step-description{font-size:16px;line-height:1.6;color:#64748b;margin:0}.testimonials-section{padding:80px 32px;background:#fff}.testimonials-container{max-width:1280px;margin:0 auto}.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}.testimonial-card{padding:32px;background:#f8fafc;border:2px solid #e5e7eb;border-radius:16px;display:flex;flex-direction:column;gap:20px}.testimonial-rating{display:flex;gap:4px}.star{font-size:20px;color:#fbbf24}.testimonial-text{font-size:16px;line-height:1.6;color:#334155;margin:0;flex-grow:1}.testimonial-author{display:flex;align-items:center;gap:12px}.author-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#10b981;border-radius:50%;font-size:16px;font-weight:700;color:#fff}.author-info{display:flex;flex-direction:column;gap:2px}.author-name{font-size:14px;font-weight:600;color:#0f172a}.author-title{font-size:13px;color:#64748b}.cta-section{padding:80px 32px;background:linear-gradient(135deg,#10b981,#059669)}.cta-container{max-width:1280px;margin:0 auto}.cta-content{text-align:center}.cta-title{font-size:48px;font-weight:800;color:#fff;margin:0 0 16px}.cta-description{font-size:20px;color:#ffffffe6;margin:0 0 40px}.cta-buttons{display:flex;justify-content:center;gap:16px;margin-bottom:24px}.btn-cta-primary{display:flex;align-items:center;gap:8px;padding:16px 32px;font-size:16px;font-weight:600;color:#10b981;background:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 24px #00000026}.btn-cta-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #0003}.btn-cta-secondary{padding:16px 32px;font-size:16px;font-weight:600;color:#fff;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:12px;cursor:pointer;transition:all .3s ease}.btn-cta-secondary:hover{background:#ffffff4d;border-color:#ffffff80}.cta-note{font-size:14px;color:#fffc;margin:0}.homepage-footer{padding:64px 32px 32px;background:#0f172a}.footer-container{max-width:1280px;margin:0 auto}.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:64px;margin-bottom:48px}.footer-brand{display:flex;flex-direction:column;gap:16px}.footer-logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:#fff}.footer-tagline{font-size:14px;color:#94a3b8;margin:0}.footer-links{display:contents}.footer-column{display:flex;flex-direction:column;gap:16px}.footer-heading{font-size:14px;font-weight:600;color:#fff;margin:0}.footer-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.footer-list li{font-size:14px;color:#94a3b8}.footer-bottom{padding-top:32px;border-top:1px solid #334155;text-align:center}.footer-copyright{font-size:14px;color:#94a3b8;margin:0}@media(max-width:1024px){.hero-container{grid-template-columns:1fr;gap:48px}.hero-visual{order:-1}.hero-title{font-size:48px}.features-grid{grid-template-columns:repeat(2,1fr)}.steps-grid{grid-template-columns:1fr;gap:40px}.testimonials-grid{grid-template-columns:1fr}.footer-content{grid-template-columns:1fr 1fr;gap:48px}.footer-brand{grid-column:1 / -1}}@media(max-width:768px){.nav-container{padding:16px 20px}.logo-text{display:none}.nav-actions{display:flex;gap:8px;flex:1;justify-content:flex-end}.btn-nav-secondary,.btn-nav-primary{padding:8px 16px;font-size:13px;white-space:nowrap}.hero-section{padding:100px 20px 60px}.hero-title{font-size:36px}.hero-description{font-size:18px}.hero-cta{flex-direction:column}.btn-hero-primary,.btn-hero-secondary{width:100%;justify-content:center}.hero-stats{flex-direction:column;gap:24px;align-items:flex-start}.stat-divider{display:none}.features-section,.how-it-works-section,.testimonials-section,.cta-section{padding:60px 20px}.section-title{font-size:36px}.section-description{font-size:18px}.features-grid{grid-template-columns:1fr}.cta-title{font-size:36px}.cta-buttons{flex-direction:column}.btn-cta-primary,.btn-cta-secondary{width:100%;justify-content:center}.footer-content{grid-template-columns:1fr}}.free-test-container{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#fff);padding:20px}.test-header{max-width:900px;margin:0 auto 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}.btn-back{display:flex;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;color:#64748b;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-back:hover{color:#0f172a;border-color:#cbd5e1}.test-progress{flex:1;display:flex;flex-direction:column;gap:8px}.progress-text{font-size:14px;font-weight:600;color:#64748b;text-align:center}.progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);transition:width .3s ease}.test-badge{padding:8px 16px;background:#dbeafe;border-radius:8px;font-size:14px;font-weight:600;color:#1e40af;white-space:nowrap}.question-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:48px;margin-bottom:24px;box-shadow:0 4px 16px #0000000d}.question-text{font-size:24px;font-weight:600;line-height:1.5;color:#0f172a;margin:0 0 32px}.options-list{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}.option-button{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;font-size:16px;text-align:left;color:#334155;background:#f8fafc;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease}.option-button:hover:not(:disabled){border-color:#10b981;background:#f0fdf4}.option-button:disabled{cursor:not-allowed}.option-selected,.option-correct{border-color:#10b981;background:#dcfce7;color:#166534;font-weight:600}.option-incorrect{border-color:#ef4444;background:#fee2e2;color:#991b1b;font-weight:600}.option-text{flex:1}.option-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.explanation-box{padding:24px;border-radius:12px;margin-top:32px}.explanation-correct{background:#f0fdf4;border:2px solid #86efac}.explanation-incorrect{background:#fef2f2;border:2px solid #fecaca}.explanation-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.explanation-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:16px;font-weight:700}.explanation-correct .explanation-icon{background:#10b981;color:#fff}.explanation-incorrect .explanation-icon{background:#ef4444;color:#fff}.explanation-title{font-size:18px;font-weight:700}.explanation-correct .explanation-title{color:#166534}.explanation-incorrect .explanation-title{color:#991b1b}.explanation-text{font-size:16px;line-height:1.6;margin:0}.explanation-correct .explanation-text{color:#166534}.explanation-incorrect .explanation-text{color:#991b1b}.test-navigation{display:flex;justify-content:space-between;gap:16px}.btn-nav-test{display:flex;align-items:center;gap:8px;padding:14px 28px;font-size:16px;font-weight:600;border-radius:10px;cursor:pointer;transition:all .2s ease}.btn-previous{color:#64748b;background:#fff;border:2px solid #e5e7eb}.btn-previous:hover:not(:disabled){color:#0f172a;border-color:#cbd5e1}.btn-previous:disabled{opacity:.5;cursor:not-allowed}.btn-next{color:#fff;background:#10b981;border:2px solid #10b981;margin-left:auto}.btn-next:hover:not(:disabled){background:#059669;border-color:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-next:disabled{opacity:.5;cursor:not-allowed}.selection-hint{text-align:center;font-size:14px;color:#94a3b8;margin:16px 0 0}.test-complete-card{max-width:700px;margin:80px auto;background:#fff;border:2px solid #e5e7eb;border-radius:20px;padding:64px 48px;text-align:center;box-shadow:0 20px 60px #0000001a}.complete-icon{font-size:80px;margin-bottom:24px}.complete-title{font-size:40px;font-weight:800;color:#0f172a;margin:0 0 32px}.score-display{display:flex;justify-content:center;margin-bottom:32px}.score-circle{width:200px;height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;box-shadow:0 12px 32px #10b9814d}.score-number{font-size:56px;font-weight:800;color:#fff}.score-label{font-size:14px;font-weight:600;color:#ffffffe6}.complete-message{font-size:18px;line-height:1.6;color:#64748b;margin:0 0 48px}.complete-features{text-align:left;padding:32px;background:#f8fafc;border:2px solid #e5e7eb;border-radius:16px;margin-bottom:32px}.complete-features-title{font-size:20px;font-weight:700;color:#0f172a;margin:0 0 20px;text-align:center}.complete-features-list{display:flex;flex-direction:column;gap:16px}.complete-feature-item{display:flex;align-items:flex-start;gap:12px;font-size:16px;line-height:1.5;color:#334155}.feature-check{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#10b981;border-radius:50%;font-size:14px;font-weight:700;color:#fff}.complete-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.btn-complete-primary{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 32px;font-size:16px;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #10b9814d}.btn-complete-primary:hover{background:#059669;transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.btn-complete-secondary{padding:16px 32px;font-size:16px;font-weight:600;color:#64748b;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease}.btn-complete-secondary:hover{color:#0f172a;border-color:#cbd5e1;background:#f8fafc}.complete-note{font-size:14px;color:#94a3b8;margin:0}@media(max-width:768px){.test-header{flex-wrap:wrap}.test-badge{order:-1;width:100%;text-align:center}.btn-back{font-size:13px;padding:8px 16px}.question-card{padding:32px 24px}.question-text{font-size:20px}.option-button{padding:16px 20px;font-size:15px}.test-navigation{flex-direction:column-reverse}.btn-nav-test{width:100%;justify-content:center}.btn-next{margin-left:0}.test-complete-card{padding:48px 32px;margin:40px auto}.complete-title{font-size:32px}.score-circle{width:160px;height:160px}.score-number{font-size:48px}.complete-features{padding:24px}.complete-feature-item{font-size:15px}}.subscription-paywall{max-width:1400px;margin:0 auto;padding:48px 24px}.subscription-loading{text-align:center;padding:80px 24px;font-size:18px;color:#64748b}.paywall-hero{text-align:center;margin-bottom:64px}.paywall-title{font-size:48px;font-weight:700;color:#0f172a;margin:0 0 16px;line-height:1.2}.paywall-subtitle{font-size:20px;color:#64748b;margin:0 0 24px;line-height:1.5}.billing-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#f1f5f9;border-radius:24px;font-size:14px;font-weight:500;color:#475569}.billing-badge svg{color:#10b981}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px;margin-bottom:64px;max-width:1200px;margin-left:auto;margin-right:auto}.plan-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:32px;position:relative;transition:all .3s ease;display:flex;flex-direction:column}.plan-card:hover{border-color:#cbd5e1;box-shadow:0 12px 24px #00000014;transform:translateY(-4px)}.popular-plan{border-color:#10b981;box-shadow:0 8px 16px #10b98126;position:relative}@media(max-width:768px){.popular-plan{border-width:3px;box-shadow:0 6px 20px #10b98133}}.popular-plan:hover{border-color:#059669;box-shadow:0 16px 32px #10b98133}.current-plan{border-color:#3b82f6;background:linear-gradient(to bottom,#fff,#f0f9ff)}.plan-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:6px 16px;border-radius:20px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 12px #10b9814d}.plan-header{text-align:center;margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid #e2e8f0}.plan-name{font-size:24px;font-weight:700;color:#0f172a;margin:0 0 8px}.plan-tech-count{font-size:14px;font-weight:500;color:#64748b;margin:0 0 24px}.plan-pricing{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:8px}.price-currency{font-size:24px;font-weight:600;color:#475569}.price-amount{font-size:56px;font-weight:700;color:#0f172a;line-height:1}.price-period{font-size:18px;font-weight:500;color:#64748b}.billing-info{font-size:13px;color:#94a3b8;margin:0}.plan-features{flex:1;margin-bottom:32px}.plan-features ul{list-style:none;padding:0;margin:0}.plan-features li{display:flex;align-items:flex-start;gap:12px;padding:12px 0;font-size:15px;color:#334155;line-height:1.5}.check-icon{flex-shrink:0;margin-top:2px}.plan-actions{margin-top:auto}.btn-subscribe,.btn-current,.btn-cancel,.btn-contact{width:100%;padding:14px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.btn-subscribe{background:#0f172a;color:#fff}.btn-subscribe:hover{background:#1e293b;transform:translateY(-2px);box-shadow:0 8px 16px #00000026}.btn-subscribe-popular{background:linear-gradient(135deg,#10b981,#059669)}.btn-subscribe-popular:hover{background:linear-gradient(135deg,#059669,#047857)}.btn-current{background:#e0f2fe;color:#0369a1;cursor:not-allowed}.btn-cancel{background:#fee2e2;color:#dc2626;margin-top:16px}.btn-cancel:hover{background:#fecaca}.trust-signals{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;max-width:1000px;margin:0 auto 64px;padding:32px;background:linear-gradient(to bottom,#f8fafc,#fff);border-radius:16px;border:1px solid #e2e8f0}.trust-item{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:500;color:#334155}.trust-item svg{flex-shrink:0}.faq-section{max-width:800px;margin:0 auto 64px}.faq-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;font-size:18px;font-weight:600;color:#0f172a;cursor:pointer;transition:all .2s ease}.faq-toggle:hover{border-color:#cbd5e1;background:#f8fafc}.faq-content{margin-top:24px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:32px}.faq-item{padding:24px 0;border-bottom:1px solid #e2e8f0}.faq-item:last-child{border-bottom:none;padding-bottom:0}.faq-item h4{font-size:16px;font-weight:600;color:#0f172a;margin:0 0 12px}.faq-item p{font-size:15px;color:#64748b;margin:0;line-height:1.6}.faq-item a{color:#10b981;text-decoration:none;font-weight:600}.faq-item a:hover{text-decoration:underline}.current-subscription-info{max-width:600px;margin:0 auto 64px}.subscription-card{background:#fff;border:2px solid #3b82f6;border-radius:16px;padding:32px}.subscription-card h3{font-size:20px;font-weight:700;color:#0f172a;margin:0 0 24px}.subscription-details{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8fafc;border-radius:8px}.detail-label{font-size:14px;font-weight:600;color:#64748b}.detail-value{font-size:14px;font-weight:500;color:#0f172a}.status-badge{padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600;text-transform:capitalize}.status-active{background:#d1fae5;color:#065f46}.status-trial{background:#dbeafe;color:#1e40af}.status-cancelled{background:#fee2e2;color:#991b1b}.status-expired{background:#f3f4f6;color:#374151}.trial-info{background:linear-gradient(135deg,#dbeafe,#e0f2fe);border:1px solid #3b82f6}.contact-enterprise{max-width:800px;margin:0 auto;padding:48px 32px;background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:16px;text-align:center;color:#fff}.enterprise-content h3{font-size:28px;font-weight:700;margin:0 0 16px;color:#fff}.enterprise-content p{font-size:16px;color:#cbd5e1;margin:0 0 32px;line-height:1.6}.btn-contact{display:inline-flex;background:#10b981;color:#fff;text-decoration:none;width:auto;padding:14px 32px}.btn-contact:hover{background:#059669;transform:translateY(-2px);box-shadow:0 8px 16px #10b9814d}.mobile-plan-nav{display:none}@media(max-width:768px){.mobile-plan-nav{display:flex;justify-content:center;gap:8px;margin-bottom:20px;padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.mobile-plan-nav::-webkit-scrollbar{display:none}.plan-nav-button{flex-shrink:0;padding:10px 16px;background:#f1f5f9;border:2px solid transparent;border-radius:8px;font-size:14px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s ease;min-height:44px}.plan-nav-button.active{background:#fff;border-color:#10b981;color:#10b981;box-shadow:0 2px 8px #10b98126}.plan-nav-button:hover{background:#e2e8f0}.plan-nav-button.active:hover{background:#fff}}.mobile-sticky-footer{display:none}@media(max-width:768px){.mobile-sticky-footer{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(to top,#ffffff 0%,#ffffff 90%,transparent 100%);padding:12px 16px 20px;box-shadow:0 -4px 12px #00000014;z-index:100;display:block;border-top:1px solid #e2e8f0}.mobile-sticky-footer.hidden{transform:translateY(100%);transition:transform .3s ease}.mobile-sticky-footer.visible{transform:translateY(0);transition:transform .3s ease}.sticky-footer-content{display:flex;align-items:center;gap:12px;max-width:600px;margin:0 auto}.sticky-plan-info{flex:1;min-width:0}.sticky-plan-name{font-size:14px;font-weight:700;color:#0f172a;margin:0 0 2px}.sticky-plan-price{font-size:12px;color:#64748b;margin:0}.sticky-plan-price strong{font-size:16px;font-weight:700;color:#0f172a}.sticky-cta-button{flex-shrink:0;padding:12px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;min-height:48px;box-shadow:0 4px 12px #10b98140;transition:all .2s ease}.sticky-cta-button:active{transform:scale(.98)}.subscription-paywall{padding-bottom:100px}}@media(max-width:768px){.plan-card{will-change:transform}.plan-card:hover{transform:none}.plan-card:active{transform:scale(.99);transition:transform .1s ease}svg{will-change:transform}}@media(max-width:768px){.subscription-paywall{padding:24px 16px}.paywall-hero{margin-bottom:32px}.paywall-title{font-size:28px;margin-bottom:12px;line-height:1.2}.paywall-subtitle{font-size:15px;margin-bottom:16px;line-height:1.5}.billing-badge{font-size:13px;padding:6px 12px}.plans-grid{display:block;position:relative;margin-bottom:32px}.plan-card{padding:20px;margin-bottom:20px;border-width:2px}.plan-card:last-child{margin-bottom:0}.plan-badge{font-size:11px;padding:5px 12px;top:-10px}.plan-header{margin-bottom:20px;padding-bottom:20px}.plan-name{font-size:22px;margin-bottom:6px}.plan-tech-count{font-size:13px;margin-bottom:16px}.plan-pricing{margin-bottom:6px}.price-currency{font-size:20px}.price-amount{font-size:44px}.price-period{font-size:16px}.billing-info{font-size:12px}.plan-features{margin-bottom:20px}.plan-features li{padding:8px 0;font-size:14px}.check-icon{width:18px;height:18px}.btn-subscribe,.btn-current,.btn-cancel,.btn-contact{min-height:48px;padding:14px 20px;font-size:15px;font-weight:700;border-radius:10px}.trust-signals{grid-template-columns:1fr;gap:12px;padding:20px 16px;margin-bottom:32px}.trust-item{font-size:14px;gap:10px}.trust-item svg{width:20px;height:20px}.faq-section{margin-bottom:32px}.faq-toggle{padding:16px;font-size:16px;min-height:52px}.faq-content{padding:20px 16px;margin-top:16px}.faq-item{padding:16px 0}.faq-item h4{font-size:15px;margin-bottom:8px}.faq-item p{font-size:14px;line-height:1.6}.subscription-card{padding:20px}.subscription-card h3{font-size:18px;margin-bottom:16px}.detail-row{flex-direction:column;align-items:flex-start;gap:6px;padding:12px}.detail-label,.detail-value{font-size:13px}.contact-enterprise{padding:28px 20px}.enterprise-content h3{font-size:22px;margin-bottom:12px}.enterprise-content p{font-size:14px;margin-bottom:24px;line-height:1.5}.btn-contact{width:100%}}@media(max-width:480px){.subscription-paywall{padding:20px 12px}.paywall-title{font-size:24px}.paywall-subtitle{font-size:14px}.plan-card{padding:16px;border-radius:12px}.price-amount{font-size:40px}.plan-features li{font-size:13px;padding:7px 0}.trust-signals{padding:16px 12px}.faq-toggle{padding:14px;font-size:15px}.contact-enterprise{padding:24px 16px;border-radius:12px}}@media(min-width:769px)and (max-width:1024px){.plans-grid{grid-template-columns:repeat(2,1fr);gap:24px}.plan-card{padding:28px}.trust-signals{grid-template-columns:repeat(2,1fr)}.price-amount{font-size:52px}}@media(min-width:481px)and (max-width:768px){.plans-grid{gap:20px}.trust-signals{grid-template-columns:repeat(2,1fr)}}.payment-collection-container{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:2rem 1rem}.btn-back{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#475569;cursor:pointer;transition:all .2s;margin-bottom:2rem;max-width:140px}.btn-back:hover{background:#f8fafc;border-color:#cbd5e1}.payment-content{max-width:1200px;margin:0 auto}.payment-header{text-align:center;margin-bottom:3rem}.header-icon{font-size:3rem;margin-bottom:1rem}.payment-header h1{font-size:2rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.payment-header p{font-size:1.125rem;color:#64748b}.payment-layout{display:grid;grid-template-columns:1fr 400px;gap:2rem;align-items:start}.payment-form-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.payment-form{display:flex;flex-direction:column;gap:2rem}.form-section h3{font-size:1.125rem;font-weight:600;color:#0f172a;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #f1f5f9}.form-group label{font-size:.875rem;font-weight:500;color:#475569;display:flex;align-items:center;gap:.25rem}.cvv-info{cursor:help;color:#94a3b8;font-size:.875rem}.form-group input,.form-group select{padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;color:#0f172a;transition:all .2s;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.form-group input:disabled,.form-group select:disabled{background:#f8fafc;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.expiry-inputs{display:flex;align-items:center;gap:.5rem}.expiry-inputs select{flex:1}.expiry-separator{color:#94a3b8;font-weight:600}.terms-section{padding:1.5rem;background:#f8fafc;border-radius:8px;margin-top:1rem}.terms-checkbox{display:flex;align-items:start;gap:.75rem;cursor:pointer;font-size:.875rem;color:#475569}.terms-checkbox input[type=checkbox]{margin-top:.25rem;width:18px;height:18px;cursor:pointer}.terms-checkbox a{color:#0ea5e9;text-decoration:underline}.terms-note{margin-top:.75rem;font-size:.8125rem;color:#64748b;line-height:1.5}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem}.error-message svg{flex-shrink:0;stroke:#dc2626}.btn-submit{width:100%;padding:1rem;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e94d}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.security-badges{display:flex;align-items:center;justify-content:center;gap:.5rem;padding-top:1rem;font-size:.8125rem;color:#64748b}.payment-summary-section{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:2rem}.summary-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.summary-card h3{font-size:1.125rem;font-weight:600;color:#0f172a;margin-bottom:1.5rem}.summary-item{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.summary-item .label{font-size:.875rem;color:#64748b;display:flex;flex-direction:column;gap:.25rem}.summary-item .label small{font-size:.75rem;color:#94a3b8}.summary-item .value{font-size:.875rem;color:#0f172a;font-weight:500}.summary-item.highlight{padding:.75rem;background:#f0f9ff;border-radius:6px;margin:1rem 0}.summary-item.highlight .value{color:#0ea5e9;font-weight:600;font-size:1rem}.summary-item.total{padding-top:1rem;margin-top:.5rem}.summary-item.total .label{font-size:.9375rem;font-weight:600;color:#0f172a}.summary-item.total .value{font-size:1.25rem;font-weight:700;color:#0f172a}.summary-item.recurring{margin-top:.5rem}.summary-divider{height:1px;background:#e2e8f0;margin:1rem 0}.features-included{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.features-included h4{font-size:1rem;font-weight:600;color:#0f172a;margin-bottom:1rem}.features-included ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.features-included li{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:#475569}.refund-policy{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;padding:1.5rem}.refund-policy h4{font-size:.9375rem;font-weight:600;color:#15803d;margin-bottom:.5rem}.refund-policy p{font-size:.8125rem;color:#166534;line-height:1.5}@media(max-width:1024px){.payment-layout{grid-template-columns:1fr}.payment-summary-section{position:static;order:-1}}@media(max-width:640px){.payment-collection-container{padding:1rem .5rem}.payment-form-section{padding:1.5rem 1rem}.payment-header h1{font-size:1.5rem}.form-row{grid-template-columns:1fr}.form-group input,.form-group select{font-size:16px}}.onboarding-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8eef3);padding:40px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.btn-logout{position:absolute;top:24px;right:24px;display:flex;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;color:#64748b;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;z-index:10}.btn-logout:hover{color:#0f172a;border-color:#cbd5e1;background:#f8fafc}.btn-logout svg{flex-shrink:0}.onboarding-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#64748b}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#10b981;border-radius:50%;animation:spin 1s linear infinite}.onboarding-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000001a;padding:48px;width:100%;max-width:560px}.onboarding-header{text-align:center;margin-bottom:40px}.onboarding-icon{font-size:64px;margin-bottom:24px}.onboarding-header h1{font-size:32px;font-weight:700;color:#0f172a;margin:0 0 12px}.onboarding-header p{font-size:16px;color:#64748b;margin:0}.onboarding-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#334155}.form-group input,.form-group select{padding:12px 16px;font-size:16px;border:2px solid #e2e8f0;border-radius:8px;outline:none;transition:border-color .2s ease;background:#fff}.form-group input:focus,.form-group select:focus{border-color:#10b981}.form-group select{cursor:pointer}.error-message{padding:12px 16px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:14px}.btn-primary{padding:14px 24px;font-size:16px;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:#059669;transform:translateY(-2px);box-shadow:0 8px 16px #10b9814d}.btn-primary:disabled{background:#94a3b8;cursor:not-allowed}.onboarding-subscription-header{text-align:center;margin-bottom:48px}.onboarding-subscription-header h1{font-size:40px;font-weight:700;color:#0f172a;margin:0 0 12px}.onboarding-subscription-header p{font-size:18px;color:#64748b;margin:0}@media(max-width:768px){.btn-logout{top:16px;right:16px;padding:8px 16px;font-size:13px}.btn-logout svg{width:16px;height:16px}.onboarding-card{padding:32px 24px}.onboarding-header h1{font-size:28px}.onboarding-icon{font-size:48px}.onboarding-subscription-header h1{font-size:32px}.onboarding-subscription-header p{font-size:16px}}.form-note{font-size:13px;color:#64748b;margin:16px 0 0;padding:12px;background:#f8fafc;border-left:3px solid #3b82f6;border-radius:6px;line-height:1.6}.tech-certifications{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.certifications-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.certifications-header h3{margin:0;color:#1e293b;font-size:1.25rem}.add-cert-button{background:#0ea5e9;color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.add-cert-button:hover{background:#0284c7;transform:translateY(-1px)}.add-certification-form{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#475569;font-weight:600}.form-group select,.form-group input{width:100%;padding:.625rem;border:1px solid #cbd5e1;border-radius:6px;font-size:1rem}.form-group select:focus,.form-group input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.error-message{background:#fee2e2;color:#991b1b;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.submit-cert-button{background:#10b981;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.submit-cert-button:hover{background:#059669}.no-certifications{text-align:center;padding:2rem;color:#64748b}.certifications-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.certification-card{border:2px solid #e2e8f0;border-radius:8px;padding:1.25rem;transition:all .2s;background:#fff}.certification-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.certification-card.inactive{opacity:.6;background:#f8fafc}.certification-card.good{border-color:#10b981}.certification-card.warning{border-color:#f59e0b}.certification-card.critical{border-color:#ef4444}.certification-card.expired{border-color:#991b1b;background:#fef2f2}.cert-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.cert-title{display:flex;flex-direction:column;gap:.25rem}.cert-title strong{font-size:1.25rem;color:#1e293b}.cert-name{font-size:.875rem;color:#64748b}.inactive-badge{background:#e2e8f0;color:#475569;padding:.25rem .625rem;border-radius:4px;font-size:.75rem;font-weight:600}.cert-dates{background:#f8fafc;border-radius:6px;padding:.75rem;margin-bottom:1rem}.date-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0}.date-item:not(:last-child){border-bottom:1px solid #e2e8f0;margin-bottom:.375rem}.date-label{font-size:.875rem;color:#64748b;font-weight:500}.date-value{font-size:.875rem;color:#1e293b;font-weight:600}.cert-status{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-weight:600}.cert-status.good{background:#dcfce7;color:#166534}.cert-status.warning{background:#fef3c7;color:#92400e}.cert-status.critical{background:#fee2e2;color:#991b1b}.cert-status.expired{background:#fecaca;color:#7f1d1d}.status-icon{font-size:1.25rem}.status-text{font-size:.875rem}.cert-actions{display:flex;gap:.5rem}.toggle-active-button,.delete-cert-button{flex:1;padding:.5rem;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.toggle-active-button{background:#e2e8f0;color:#475569}.toggle-active-button:hover{background:#cbd5e1}.delete-cert-button{background:#fee2e2;color:#991b1b}.delete-cert-button:hover{background:#fecaca}.expiring-certifications-widget{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem}.expiring-certifications-widget h3{margin:0 0 1rem;color:#1e293b;font-size:1.125rem}.expiring-cert-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:.75rem;transition:all .2s}.expiring-cert-item:hover{background:#f8fafc;border-color:#cbd5e1}.expiring-cert-item:last-child{margin-bottom:0}.expiring-cert-info{flex:1}.expiring-cert-tech{font-size:.875rem;color:#64748b;margin-bottom:.25rem}.expiring-cert-category{font-weight:600;color:#1e293b}.expiring-cert-expires{display:flex;align-items:center;gap:.5rem;font-size:.875rem;padding:.375rem .75rem;border-radius:4px;font-weight:600}.expiring-cert-expires.critical{background:#fee2e2;color:#991b1b}.expiring-cert-expires.warning{background:#fef3c7;color:#92400e}.no-expiring-certs{text-align:center;padding:1.5rem;color:#64748b;font-size:.9375rem}.certifications-manager{padding:1.5rem}.manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.manager-header h2{margin:0 0 .5rem;color:#1e293b}.subtitle{color:#64748b;margin:0}.export-button{background:#10b981;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.export-button:hover{background:#059669;transform:translateY(-1px)}.cert-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.cert-stat-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;text-align:center;transition:all .2s}.cert-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.cert-stat-card.valid{border-color:#10b981;background:linear-gradient(to bottom,#fff,#f0fdf4)}.cert-stat-card.warning{border-color:#f59e0b;background:linear-gradient(to bottom,#fff,#fffbeb)}.cert-stat-card.critical{border-color:#dc2626;background:linear-gradient(to bottom,#fff,#fef2f2)}.cert-stat-value{font-size:2.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.cert-stat-label{font-size:.875rem;color:#64748b;font-weight:500}.filters-section{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.search-input{flex:2;min-width:300px;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem}.search-input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.filter-select{flex:1;min-width:200px;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.certifications-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014}.certifications-table{width:100%;border-collapse:collapse}.certifications-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.certifications-table th{padding:1rem;text-align:left;font-weight:600;color:#475569;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.certifications-table td{padding:1rem;border-bottom:1px solid #e2e8f0}.certifications-table tbody tr:hover{background:#f8fafc}.certifications-table tbody tr.status-expired,.certifications-table tbody tr.status-critical{background:#fef2f2}.certifications-table tbody tr.status-warning{background:#fffbeb}.tech-info,.cert-info{display:flex;flex-direction:column;gap:.25rem}.tech-info strong,.cert-info strong{color:#1e293b;font-size:.9375rem}.tech-info small,.cert-info small{color:#64748b;font-size:.8125rem}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600}.active-badge{color:#166534;background:#dcfce7;padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600}.inactive-badge{color:#475569;background:#e2e8f0;padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600}.na-text{color:#94a3b8;font-style:italic}.doc-link{color:#0ea5e9;text-decoration:none;font-weight:500}.doc-link:hover{text-decoration:underline}.action-buttons{display:flex;gap:.5rem}.edit-btn,.details-btn,.save-btn,.cancel-btn{padding:.5rem .75rem;border:none;border-radius:6px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s}.edit-btn{background:#dbeafe;color:#1e40af}.edit-btn:hover{background:#bfdbfe}.details-btn{background:#e2e8f0;color:#475569}.details-btn:hover{background:#cbd5e1}.save-btn{background:#10b981;color:#fff}.save-btn:hover{background:#059669}.cancel-btn{background:#fee2e2;color:#991b1b}.cancel-btn:hover{background:#fecaca}.inline-edit-input{width:100%;padding:.375rem .5rem;border:1px solid #cbd5e1;border-radius:4px;font-size:.875rem}.inline-edit-input:focus{outline:none;border-color:#0ea5e9}.no-results{text-align:center;padding:3rem;color:#64748b}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-width:800px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #e2e8f0}.modal-header h3{margin:0;color:#1e293b}.close-modal{background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:.5rem;line-height:1}.close-modal:hover{color:#1e293b}.modal-body{padding:1.5rem}.cert-details-section{margin-bottom:2rem}.cert-details-section h4{margin:0 0 1rem;color:#1e293b}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.875rem;color:#64748b;font-weight:500}.detail-value{font-size:1rem;color:#1e293b;font-weight:600}.audit-log-section h4{margin:0 0 1rem;color:#1e293b}.no-logs{text-align:center;padding:2rem;color:#64748b}.audit-log-list{display:flex;flex-direction:column;gap:1rem}.audit-log-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.audit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.audit-action{font-weight:600;color:#0ea5e9;font-size:.875rem}.audit-date{font-size:.8125rem;color:#64748b}.audit-user{font-size:.875rem;color:#475569;margin-bottom:.25rem}.audit-notes{font-size:.875rem;color:#64748b;font-style:italic;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #e2e8f0}.message-banner{padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500}.message-banner.success{background:#dcfce7;color:#166534;border:1px solid #10b981}.message-banner.error{background:#fee2e2;color:#991b1b;border:1px solid #dc2626}.master-challenge-container.no-select,.master-challenge-container.no-select *{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}.master-challenge-container.no-select *::selection{background:transparent}.master-challenge-container.no-select *::-moz-selection{background:transparent}.master-challenge-container{max-width:1000px;margin:0 auto;padding:20px;min-height:100vh}.challenge-intro{text-align:center;padding:40px 20px}.challenge-badge{display:inline-block;background:linear-gradient(135deg,gold,#ffed4e);color:#1a1a1a;padding:8px 24px;border-radius:20px;font-weight:700;font-size:14px;letter-spacing:1px;margin-bottom:20px;box-shadow:0 4px 15px #ffd7004d}.challenge-intro h1{font-size:42px;margin-bottom:10px;background:linear-gradient(135deg,gold,#ff6b6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.challenge-subtitle{font-size:18px;color:#888;margin-bottom:40px}.challenge-specs{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin:40px 0}.spec-item{background:#f5f5f5;padding:20px;border-radius:12px;display:flex;flex-direction:column;gap:8px}.spec-label{font-size:12px;color:#666;text-transform:uppercase;letter-spacing:1px}.spec-value{font-size:24px;font-weight:700;color:#2c3e50}.challenge-rules{text-align:left;max-width:600px;margin:40px auto;background:#fff3cd;padding:25px;border-radius:12px;border:2px solid #ffc107}.challenge-rules h3{margin-top:0;color:#856404}.challenge-rules ul{list-style:none;padding:0;margin:15px 0 0}.challenge-rules li{padding:10px 0;color:#856404;font-size:15px}.start-challenge-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:18px 48px;font-size:18px;font-weight:700;border-radius:30px;cursor:pointer;margin:30px 0;transition:transform .2s,box-shadow .2s;box-shadow:0 8px 25px #667eea66}.start-challenge-btn:hover{transform:translateY(-2px);box-shadow:0 12px 35px #667eea80}.fair-warning{color:#ff6b6b;font-style:italic;margin-top:20px;font-size:14px}.challenge-header{margin-bottom:30px}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:10px;overflow:hidden;margin-bottom:15px}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.challenge-stats{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8f9fa;border-radius:10px;font-weight:600;font-size:14px}.timer{background:#4caf50;color:#fff;padding:8px 16px;border-radius:20px;font-size:16px;font-weight:700;min-width:70px;text-align:center}.timer.urgent{background:#f44;animation:pulse .5s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.question-container{background:#fff;padding:40px;border-radius:16px;box-shadow:0 4px 20px #0000001a}.question-text{font-size:20px;line-height:1.6;color:#2c3e50;margin-bottom:30px;min-height:80px}.options-grid{display:grid;gap:15px}.option-btn{display:flex;align-items:center;gap:15px;padding:20px;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .2s;text-align:left;font-size:16px}.option-btn:hover{background:#e3f2fd;border-color:#667eea;transform:translate(5px)}.option-letter{background:#667eea;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0}.option-text{flex:1;line-height:1.5}.cheat-warning{position:fixed;bottom:20px;right:20px;background:#f44;color:#fff;padding:15px 25px;border-radius:10px;font-weight:700;box-shadow:0 4px 15px #f446;animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.challenge-results{background:#fff;padding:40px;border-radius:16px;box-shadow:0 4px 20px #0000001a}.challenge-results h2{text-align:center;font-size:32px;margin-bottom:30px}.score-display{text-align:center;padding:30px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;margin-bottom:40px}.final-score{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.score-label{font-size:16px;opacity:.9}.score-value{font-size:64px;font-weight:700;text-shadow:0 2px 10px rgba(0,0,0,.2)}.completion-stats{display:flex;justify-content:center;gap:40px;font-size:18px}.warning-flag{margin-top:20px;padding:12px;background:#fff3;border-radius:8px;font-size:14px}.results-list{display:flex;flex-direction:column;gap:20px}.result-item{padding:25px;border-radius:12px;border-left:4px solid}.result-item.correct{background:#f1f8f4;border-left-color:#4caf50}.result-item.incorrect{background:#fff5f5;border-left-color:#f44}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.question-num{font-weight:700;color:#666}.result-badge{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}.result-badge.correct{background:#4caf50;color:#fff}.result-badge.incorrect{background:#f44;color:#fff}.question-text{font-size:16px;margin-bottom:15px;line-height:1.6}.answer-comparison{display:flex;flex-direction:column;gap:8px;margin-bottom:15px;font-size:14px;color:#555}.explanation{padding:15px;background:#00000008;border-radius:8px;font-size:14px;line-height:1.6;color:#444;font-style:italic}.challenge-locked{text-align:center;padding:60px 20px;background:#fff3cd;border-radius:16px;border:2px solid #ffc107}.challenge-locked h2{color:#856404;margin-bottom:20px}.challenge-locked p{font-size:16px;color:#856404;margin:10px 0}.cooldown-reason{margin-top:30px;font-style:italic;font-size:14px}.share-section{text-align:center;padding:40px 20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:16px;margin-bottom:40px;border:2px solid #dee2e6}.share-section h3{font-size:28px;color:#2c3e50;margin-bottom:10px;font-weight:700}.share-subtitle{font-size:16px;color:#6c757d;margin-bottom:30px}.share-buttons{display:flex;justify-content:center;gap:15px;flex-wrap:wrap;margin-bottom:25px}.share-btn{display:flex;align-items:center;gap:10px;padding:14px 28px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #00000026;min-width:140px;justify-content:center}.share-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000040}.share-btn:active{transform:translateY(-1px)}.share-btn svg{flex-shrink:0}.share-btn.twitter{background:linear-gradient(135deg,#1da1f2,#0d8bd9);color:#fff}.share-btn.twitter:hover{background:linear-gradient(135deg,#0d8bd9,#0a6fb0)}.share-btn.facebook{background:linear-gradient(135deg,#1877f2,#0e5fc2);color:#fff}.share-btn.facebook:hover{background:linear-gradient(135deg,#0e5fc2,#0a4d99)}.share-btn.linkedin{background:linear-gradient(135deg,#0077b5,#005885);color:#fff}.share-btn.linkedin:hover{background:linear-gradient(135deg,#005885,#004066)}.share-btn.instagram{background:linear-gradient(135deg,#e1306c,#c13584,#833ab4);color:#fff}.share-btn.instagram:hover{background:linear-gradient(135deg,#c13584,#833ab4,#5851db)}.share-cta{font-size:18px;color:#495057;font-weight:600;margin:0;padding:20px;background:#ffffffb3;border-radius:10px;border:1px solid #dee2e6}@media(max-width:768px){.challenge-intro h1{font-size:32px}.challenge-specs{grid-template-columns:1fr}.question-container{padding:25px}.question-text{font-size:18px}.option-btn{padding:15px}.score-value{font-size:48px}.share-section h3{font-size:24px}.share-buttons{flex-direction:column;align-items:stretch}.share-btn{min-width:100%}.share-cta{font-size:16px}}.master-leaderboard-container{max-width:1200px;margin:0 auto;padding:20px}.leaderboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px}.header-title h1{font-size:36px;margin:0 0 5px;background:linear-gradient(135deg,gold,#ff6b6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.leaderboard-subtitle{color:#666;font-size:16px;margin:0}.refresh-btn{background:#667eea;color:#fff;border:none;padding:12px 24px;border-radius:25px;cursor:pointer;font-weight:600;transition:all .3s;font-size:14px}.refresh-btn:hover:not(:disabled){background:#764ba2;transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.refresh-btn:disabled{opacity:.7;cursor:not-allowed}.refresh-btn.refreshing{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.user-stats-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;border-radius:16px;margin-bottom:30px;box-shadow:0 8px 30px #667eea4d}.user-stats-card h3{margin:0 0 20px;font-size:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;margin-bottom:15px}.stat-item{display:flex;flex-direction:column;gap:8px}.stat-label{font-size:12px;opacity:.9;text-transform:uppercase;letter-spacing:1px}.stat-value{font-size:28px;font-weight:700}.competitor-count{margin:15px 0 0;font-size:14px;opacity:.9;text-align:center}.leaderboard-table{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.table-header{display:grid;grid-template-columns:80px 1fr 120px 100px 150px;padding:20px 25px;background:#f8f9fa;font-weight:700;font-size:13px;color:#666;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e0e0e0}.table-body{display:flex;flex-direction:column}.leaderboard-row{display:grid;grid-template-columns:80px 1fr 120px 100px 150px;padding:20px 25px;border-bottom:1px solid #f0f0f0;transition:all .2s;align-items:center}.leaderboard-row:hover{background:#f8f9fa;transform:translate(5px)}.leaderboard-row:last-child{border-bottom:none}.rank-number{font-weight:700;font-size:18px}.rank-gold{background:linear-gradient(135deg,gold,#ffed4e 50%)}.rank-silver{background:linear-gradient(135deg,silver,#e8e8e8 50%)}.rank-bronze{background:linear-gradient(135deg,#cd7f32,#e0a370 50%)}.rank-top10{background:linear-gradient(135deg,#e3f2fd,#fff 50%)}.current-user{background:#e8f5e9!important;border-left:4px solid #4caf50;font-weight:600}.current-user:hover{background:#c8e6c9!important}.col-rank{text-align:center}.col-name{font-weight:600;font-size:15px;color:#2c3e50}.technician-name{display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-score{text-align:center}.score-badge{background:#667eea;color:#fff;padding:6px 14px;border-radius:20px;font-weight:700;font-size:14px;display:inline-block}.rank-gold .score-badge{background:linear-gradient(135deg,gold,#ff6b6b);color:#1a1a1a}.rank-silver .score-badge{background:linear-gradient(135deg,#9e9e9e,#757575)}.rank-bronze .score-badge{background:linear-gradient(135deg,#cd7f32,sienna)}.col-time{text-align:center;font-family:Courier New,monospace;font-weight:600;color:#555}.col-date{text-align:center;color:#888;font-size:13px}.empty-leaderboard{background:#fff;padding:80px 20px;border-radius:16px;text-align:center;color:#999}.empty-leaderboard p{font-size:18px;margin:10px 0}.leaderboard-footer{margin-top:30px;padding:20px;background:#f8f9fa;border-radius:12px;text-align:center}.leaderboard-footer p{margin:8px 0;font-size:13px;color:#666}@media(max-width:968px){.table-header,.leaderboard-row{grid-template-columns:60px 1fr 100px 90px 110px;padding:15px;font-size:13px}.header-title h1{font-size:28px}.score-badge{padding:4px 10px;font-size:12px}.time-display,.date-display{font-size:12px}}@media(max-width:768px){.table-header{display:none}.leaderboard-row{grid-template-columns:1fr;grid-template-areas:"rank name score" "time date date";gap:10px;padding:20px}.col-rank{grid-area:rank;text-align:left}.col-name{grid-area:name}.col-score{grid-area:score;text-align:right}.col-time{grid-area:time;text-align:left}.col-date{grid-area:date;text-align:right}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:24px}}.mastery-dashboard-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.mastery-dashboard-content{background:#fff;border-radius:16px;max-width:1000px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.mastery-dashboard-inner{padding:2rem}.mastery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}.mastery-header h2{margin:0;font-size:2rem;font-weight:700;color:#0f172a}.mastery-close-btn{background:#64748b;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s;white-space:nowrap}.mastery-close-btn:hover{background:#475569}.mastery-overall-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:2rem;color:#fff;margin-bottom:2rem;text-align:center}.mastery-overall-label{font-size:1rem;opacity:.9;margin-bottom:.5rem}.mastery-overall-score{font-size:4rem;font-weight:700;margin-bottom:.5rem;line-height:1}.mastery-overall-badge{display:inline-block;background:#fff3;padding:.5rem 1.5rem;border-radius:20px;font-size:1.25rem;font-weight:600}.mastery-overall-description{margin-top:1rem;opacity:.9}.mastery-info-card{background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;padding:2rem;color:#fff;margin-bottom:2rem;border:2px solid #34d399}.mastery-info-title{margin:0 0 1rem;font-size:1.5rem;font-weight:700;text-align:center}.mastery-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.mastery-info-item{background:#ffffff26;padding:1rem;border-radius:8px}.mastery-info-icon{font-size:2rem;margin-bottom:.5rem}.mastery-info-item-title{font-weight:600;margin-bottom:.5rem}.mastery-info-item-desc{font-size:.9rem;opacity:.95;line-height:1.4}.mastery-info-result{background:#fff3;padding:1rem;border-radius:8px;text-align:center;font-size:.95rem;line-height:1.5}.mastery-section{margin-bottom:2rem}.mastery-section-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem}.mastery-section-title.weak{color:#ef4444}.mastery-section-title.strong{color:#10b981}.mastery-cards-grid{display:grid;gap:1rem}.mastery-card{border-radius:12px;padding:1.5rem;background:#fff}.mastery-card.weak{border:2px solid #fecaca;background:#fef2f2}.mastery-card.strong{border:2px solid #86efac;background:#f0fdf4}.mastery-card.neutral{border:1px solid #e5e7eb}.mastery-card-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.mastery-card-info{flex:1;min-width:0}.mastery-card-title{font-size:1.25rem;font-weight:700;margin-bottom:.25rem;color:#0f172a}.mastery-card-stats{color:#64748b;font-size:.9rem}.mastery-card-score{text-align:right;flex-shrink:0}.mastery-card-percentage{font-size:2rem;font-weight:700;line-height:1}.mastery-card-level{font-size:.9rem;font-weight:600;margin-top:.25rem}.mastery-progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:1rem}.mastery-progress-fill{height:100%;transition:width .3s}.mastery-recommendation{padding:.75rem;background:#f9fafb;border-radius:8px;font-size:.9rem;color:#374151;line-height:1.5}.mastery-empty-state{text-align:center;padding:3rem 1rem;background:#f9fafb;border-radius:12px;color:#64748b}.mastery-empty-icon{font-size:3rem;margin-bottom:1rem}.mastery-empty-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:#475569}.mastery-loading{text-align:center;padding:3rem}@media(max-width:768px){.mastery-dashboard-overlay{padding:0;align-items:stretch}.mastery-dashboard-content{max-height:100vh;border-radius:0}.mastery-dashboard-inner{padding:1.5rem 1rem}.mastery-header{flex-direction:column;align-items:stretch;margin-bottom:1.5rem}.mastery-header h2{font-size:1.5rem;text-align:center}.mastery-close-btn{width:100%;padding:.875rem}.mastery-overall-card{padding:1.5rem 1rem}.mastery-overall-score{font-size:3rem}.mastery-overall-badge{font-size:1rem;padding:.5rem 1rem}.mastery-info-card{padding:1.5rem 1rem}.mastery-info-title{font-size:1.25rem}.mastery-info-grid{grid-template-columns:1fr;gap:1rem;margin-bottom:1rem}.mastery-info-item{padding:1rem}.mastery-info-icon{font-size:1.75rem}.mastery-info-item-desc{font-size:.85rem}.mastery-info-result{font-size:.875rem}.mastery-section-title{font-size:1.25rem}.mastery-card{padding:1rem}.mastery-card-header{flex-direction:column;align-items:stretch}.mastery-card-score{text-align:left;display:flex;align-items:center;justify-content:space-between;padding-top:.5rem;border-top:1px solid #e5e7eb}.mastery-card-title{font-size:1.125rem}.mastery-card-stats{font-size:.8125rem}.mastery-card-percentage{font-size:1.75rem}.mastery-card-level{font-size:.8125rem}.mastery-recommendation{font-size:.8125rem;padding:.625rem}.mastery-empty-state{padding:2rem 1rem}.mastery-empty-icon{font-size:2.5rem}.mastery-empty-title{font-size:1.125rem}}@media(max-width:480px){.mastery-overall-score{font-size:2.5rem}.mastery-card-title{font-size:1rem;word-break:break-word}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#f5f7fa}#root{min-height:100vh}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.loading-spinner{width:50px;height:50px;border:4px solid #e0e0e0;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.achievement-popup{position:fixed;top:20px;right:20px;z-index:9999;animation:slideInRight .5s ease-out}.achievement-popup-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 10px 40px #0000004d;min-width:320px;max-width:400px;position:relative}.achievement-popup-close{position:absolute;top:.5rem;right:.5rem;background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:background .2s}.achievement-popup-close:hover{background:#ffffff4d}.achievement-popup-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.achievement-popup-icon{font-size:3rem;animation:bounce .6s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.achievement-popup-header h3{margin:0;font-size:1.25rem;font-weight:600}.achievement-popup-body h4{margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.achievement-popup-body p{margin:0 0 1rem;opacity:.9;font-size:.95rem}.achievement-popup-points{display:inline-block;background:#fff3;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:1rem}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.25rem;color:#64748b}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:#fff;border-radius:12px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d}.auth-title{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:#1e293b;text-align:center}.auth-subtitle{margin:0 0 2rem;color:#64748b;text-align:center;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group label{font-weight:500;color:#334155;font-size:.9rem}.form-group input,.form-group select{padding:.75rem;border:1.5px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem;border-radius:8px;font-size:.9rem}.success-message{background:#f0fdf4;border:1px solid #86efac;color:#16a34a;padding:.75rem;border-radius:8px;font-size:.9rem;font-weight:600;animation:slideInSuccess .3s ease-out}@keyframes slideInSuccess{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.toggle-button{background:none;border:none;color:#2563eb;padding:.75rem;margin-top:.5rem;cursor:pointer;font-size:.9rem;transition:color .2s}.toggle-button:hover{color:#1e40af;text-decoration:underline}.dashboard{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e2e8f0}.dashboard-header h1{margin:0 0 .5rem;font-size:2rem;color:#1e293b}.role-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.35rem .85rem;border-radius:20px;font-size:.85rem;font-weight:600}.sign-out-button,.signout-button{background:linear-gradient(135deg,#64748b,#475569);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #0000001a}.sign-out-button:hover,.signout-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4755694d;background:linear-gradient(135deg,#475569,#334155)}.performance-insights{background:linear-gradient(135deg,#f0f4ff,#e0e7ff);border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #667eea26;border:1px solid #c7d2fe}.performance-insights h2{color:#000;margin:0 0 1.5rem;font-size:1.5rem;font-weight:600}.stats-grid .stat-card{background:#fff;padding:1.75rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.stats-grid .stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.stats-grid .stat-card.clickable{cursor:pointer;position:relative}.stat-card.clickable:hover{background:#fff}.stat-badge{margin-top:.5rem;padding:.25rem .75rem;background:#f59e0b;color:#fff;font-size:.75rem;font-weight:600;border-radius:12px;display:inline-block}.stat-icon{font-size:2rem;margin-bottom:.5rem}.stats-grid .stat-value{font-size:2.5rem;font-weight:700;color:#1e293b!important;margin-bottom:.5rem;line-height:1.2;display:block}.stats-grid .stat-label{color:#64748b;font-size:.95rem;font-weight:500}.section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.section h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1e293b}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.category-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;transition:transform .2s,box-shadow .2s}.category-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px #0000001a}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.category-code{background:#667eea;color:#fff;padding:.4rem .75rem;border-radius:6px;font-weight:700;font-size:.9rem}.category-score{background:#10b981;color:#fff;padding:.35rem .7rem;border-radius:6px;font-weight:600;font-size:.85rem}.category-card h3{margin:0 0 .75rem;font-size:1.2rem;color:#1e293b}.category-card p{margin:0 0 1.25rem;color:#64748b;font-size:.9rem;line-height:1.5}.category-footer{display:flex;justify-content:space-between;align-items:center}.tests-taken{color:#64748b;font-size:.85rem}.start-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.start-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #667eea66}.test-history{overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table th{background:#f8fafc;padding:1rem;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0}.history-table td{padding:1rem;border-bottom:1px solid #e2e8f0}.score{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-weight:600;font-size:.9rem}.score.pass{background:#d1fae5;color:#065f46}.score.fail{background:#fee2e2;color:#991b1b}.status{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600}.status.completed{background:#dbeafe;color:#1e40af}.status.in-progress{background:#fef3c7;color:#92400e}.empty-state{text-align:center;color:#64748b;padding:2rem}.test-interface{min-height:100vh;background:#f8fafc;padding:2rem}.test-header{background:#fff;padding:1.5rem 2rem;border-radius:12px;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000001a}.test-header h1{margin:0 0 .25rem;font-size:1.75rem;color:#1e293b}.test-header p{margin:0;color:#64748b;font-size:.95rem}.test-progress{color:#667eea;font-weight:600}.test-content{max-width:900px;margin:0 auto}.question-card{background:#fff;padding:2.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.question-text{font-size:1.35rem;color:#1e293b;margin:0 0 2rem;line-height:1.6}.answer-options{display:flex;flex-direction:column;gap:1rem}.option-button,.answer-option{display:flex;align-items:center;gap:1rem;padding:1.25rem;border:2px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s;text-align:left;font-size:1rem}.option-button:hover,.answer-option:hover{border-color:#667eea;background:#f8fafc;transform:translate(4px)}.option-button.selected,.answer-option.selected{border-color:#10b981;background:#d1fae5;box-shadow:0 0 0 3px #10b9811a}.option-letter{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#667eea;color:#fff;border-radius:50%;font-weight:700;font-size:1.1rem;flex-shrink:0;transition:all .2s}.option-button.selected .option-letter,.answer-option.selected .option-letter{background:#10b981;transform:scale(1.1)}.option-text{flex:1;color:#334155;line-height:1.5}.answer-option.selected .option-text{color:#065f46;font-weight:600}.test-navigation{background:#fff;padding:1.5rem 2rem;border-radius:12px;display:flex;gap:1rem;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0000001a}.nav-button{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.nav-button:hover:not(:disabled){background:#5568d3}.nav-button:disabled{background:#cbd5e1;cursor:not-allowed}.question-indicators{display:flex;gap:.5rem;flex-wrap:wrap;flex:1;justify-content:center}.indicator{width:40px;height:40px;border:2px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s}.indicator:hover{border-color:#667eea}.indicator.active{background:#667eea;color:#fff;border-color:#667eea}.indicator.answered{background:#d1fae5;border-color:#10b981}.indicator.answered.active{background:#10b981;color:#fff}.test-results{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;display:flex;align-items:center;justify-content:center}.results-card{background:#fff;border-radius:16px;padding:3rem;max-width:1000px;width:100%;box-shadow:0 20px 60px #0000004d}.results-card h1{text-align:center;margin:0 0 2rem;font-size:2.5rem;color:#1e293b}.score-display{text-align:center;margin-bottom:2rem;padding:2rem;border-radius:12px}.score-display.pass{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.score-display.fail{background:linear-gradient(135deg,#fee2e2,#fecaca)}.score-value{font-size:4rem;font-weight:800;margin-bottom:.5rem}.score-display.pass .score-value{color:#065f46}.score-display.fail .score-value{color:#991b1b}.score-label{font-size:1.5rem;font-weight:700}.score-display.pass .score-label{color:#047857}.score-display.fail .score-label{color:#b91c1c}.score-details{text-align:center;color:#64748b;font-size:1.1rem;margin-bottom:3rem}.results-breakdown{margin-bottom:2rem}.results-breakdown h2{font-size:1.75rem;margin:0 0 1.5rem;color:#1e293b}.question-review{border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.question-review.correct{border-color:#10b981;background:#f0fdf4}.question-review.incorrect{border-color:#ef4444;background:#fef2f2}.question-number{font-weight:700;color:#667eea;margin-bottom:.75rem;font-size:.9rem}.question-review .question-text{font-size:1.1rem;margin-bottom:1rem;color:#1e293b}.question-review .answer-options{gap:.75rem;margin-bottom:1rem}.question-review .option{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.95rem}.question-review .option.selected{border-width:2px;border-color:#3b82f6;background:#eff6ff;font-weight:600}.question-review .option.correct{border-width:2px;border-color:#10b981;background:#d1fae5;font-weight:600}.explanation{padding:1rem;background:#f8fafc;border-left:4px solid #667eea;border-radius:6px;font-size:.95rem;color:#475569;line-height:1.5}.study-reference{background:#fef3c7;padding:1rem;margin-top:1rem;border-left:4px solid #f59e0b;border-radius:6px;font-size:.95rem;color:#92400e;line-height:1.5}.study-reference strong{color:#f59e0b}.return-button{display:block;width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem;border-radius:10px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s}.return-button:hover{transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.empty-state-card{background:#fff;border-radius:12px;padding:3rem;text-align:center;box-shadow:0 2px 8px #0000001a}.empty-state-card h2{margin:0 0 1rem;font-size:2rem;color:#1e293b}.empty-state-card p{margin:0 0 2rem;color:#64748b;font-size:1.1rem}.primary-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.primary-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.form-card{background:#fff;border-radius:12px;padding:2.5rem;box-shadow:0 2px 8px #0000001a;max-width:500px;margin:0 auto}.form-card h2{margin:0 0 1.5rem;font-size:1.75rem;color:#1e293b}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.secondary-button{background:#f1f5f9;color:#475569;border:none;padding:.875rem 2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.secondary-button:hover{background:#e2e8f0}.tech-list,.test-history{overflow-x:auto}.tech-table{width:100%;border-collapse:collapse}.tech-table th{background:#f8fafc;padding:1rem;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0}.tech-table td{padding:1rem;border-bottom:1px solid #e2e8f0}.tech-name-link{background:none;border:none;color:#0ea5e9;font-weight:600;cursor:pointer;padding:0;font-size:inherit;text-decoration:underline;text-decoration-color:transparent;transition:all .2s}.tech-name-link:hover{color:#0284c7;text-decoration-color:#0284c7}.show-all-button{background:#f1f5f9;color:#475569;border:2px solid #cbd5e1;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.show-all-button:hover{background:#e2e8f0;border-color:#94a3b8;transform:translateY(-1px)}.view-button{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.view-button:hover{background:#5568d3}.manager-button{background:linear-gradient(135deg,#059669,#047857);color:#fff;border:none;padding:.65rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;font-size:1rem}.manager-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #05966966}.achievements-button{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;padding:.65rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;font-size:1rem}.achievements-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #f59e0b66}.back-button{background:#64748b;color:#fff;border:none;padding:.65rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.back-button:hover{background:#475569}.achievements-panel{padding:1rem 0}.achievement-notification{position:fixed;top:2rem;right:2rem;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 10px 40px #0003;z-index:1000;animation:slideIn .5s ease-out;max-width:400px;border:3px solid #f59e0b}@keyframes slideIn{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.achievement-notification h3{margin:0 0 1rem;color:#1e293b;font-size:1.25rem}.new-achievement{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.achievement-icon-large{font-size:3rem}.new-achievement strong{display:block;color:#1e293b;font-size:1.1rem;margin-bottom:.25rem}.new-achievement p{margin:0;color:#64748b;font-size:.9rem}.achievements-header{margin-bottom:2rem}.achievements-stats{display:flex;gap:2rem;margin-bottom:2rem;justify-content:center}.achievements-stats .stat{text-align:center}.achievements-stats .stat-value{font-size:2.5rem;font-weight:700;color:#f59e0b;display:block}.achievements-stats .stat-label{color:#64748b;font-size:.95rem}.achievements-filters{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap}.filter-group{display:flex;gap:.5rem;background:#f1f5f9;padding:.35rem;border-radius:8px}.filter-btn{background:transparent;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:600;color:#64748b;transition:all .2s}.filter-btn.active{background:#fff;color:#667eea;box-shadow:0 2px 4px #0000001a}.category-filter{padding:.5rem 1rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;font-weight:600;color:#475569;cursor:pointer}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.achievement-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;display:flex;gap:1rem;transition:transform .2s,box-shadow .2s}.achievement-card.earned{border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.achievement-card.locked{opacity:.6}.achievement-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a}.achievement-icon{font-size:3rem;flex-shrink:0}.achievement-card.locked .achievement-icon{filter:grayscale(100%);opacity:.5}.achievement-info{flex:1}.achievement-info h4{margin:0 0 .5rem;font-size:1.1rem;color:#1e293b}.achievement-info p{margin:0 0 .75rem;color:#64748b;font-size:.9rem;line-height:1.5}.achievement-meta{display:flex;gap:.75rem;margin-bottom:.5rem}.achievement-category{background:#e0e7ff;color:#4338ca;padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:capitalize}.achievement-points{background:#dcfce7;color:#166534;padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600}.achievement-earned{color:#059669;font-size:.85rem;font-weight:600}.category-actions{display:flex;gap:.5rem}.study-button{background:#10b981;color:#fff;border:none;padding:.6rem 1rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;font-size:.9rem}.study-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #10b98166}.study-book{min-height:100vh;background:#f8fafc}.study-header{background:#fff;padding:2rem;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000d}.study-header h1{margin:0 0 .5rem;font-size:2rem;color:#1e293b}.study-subtitle{margin:0;color:#64748b;font-size:1rem}.close-study-button{background:#ef4444;color:#fff;border:none;padding:.65rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.close-study-button:hover{background:#dc2626}.study-container{display:grid;grid-template-columns:320px 1fr;max-width:1600px;margin:0 auto;min-height:calc(100vh - 120px)}.study-sidebar{background:#fff;border-right:2px solid #e2e8f0;padding:2rem 1.5rem;overflow-y:auto;position:sticky;top:0;height:calc(100vh - 120px)}.study-sidebar h3{margin:0 0 1.5rem;color:#1e293b;font-size:1.25rem}.no-content{color:#64748b;font-size:.9rem;line-height:1.6}.chapter-nav{display:flex;flex-direction:column;gap:.5rem}.chapter-item{display:flex;flex-direction:column}.chapter-button{background:#f8fafc;border:none;padding:1rem;border-radius:8px;text-align:left;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.35rem}.chapter-button:hover{background:#e2e8f0}.chapter-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.chapter-number{font-size:.75rem;font-weight:600;text-transform:uppercase;opacity:.8}.chapter-title{font-weight:600;font-size:.95rem}.section-list{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem;margin-left:1rem;padding-left:1rem;border-left:2px solid #e2e8f0}.section-button{background:transparent;border:none;padding:.6rem .75rem;border-radius:6px;text-align:left;cursor:pointer;transition:all .2s;color:#475569;font-size:.9rem}.section-button:hover{background:#f1f5f9;color:#1e293b}.section-button.active{background:#ede9fe;color:#667eea;font-weight:600}.study-content{padding:3rem;overflow-y:auto}.chapter-header{margin-bottom:3rem}.chapter-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.4rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;margin-bottom:1rem}.chapter-header h2{margin:0 0 .75rem;font-size:2.5rem;color:#1e293b}.chapter-description{color:#64748b;font-size:1.1rem;margin:0}.section-content{background:#fff;border-radius:12px;padding:3rem;box-shadow:0 2px 8px #0000000d;max-width:900px}.section-title{margin:0 0 2rem;font-size:2rem;color:#1e293b;border-bottom:3px solid #667eea;padding-bottom:1rem}.section-text{line-height:1.8;font-size:1.05rem;color:#334155}.content-heading{margin:2rem 0 1rem;font-size:1.4rem;color:#1e293b;font-weight:700}.content-paragraph{margin:0 0 1.5rem}.definition-list{margin:1rem 0 2rem;padding-left:1.5rem;list-style:none}.definition-list li{margin-bottom:1rem;padding-left:1.5rem;position:relative;line-height:1.7}.definition-list li:before{content:"▸";position:absolute;left:0;color:#667eea;font-weight:700}.definition-list li strong{color:#667eea;font-weight:700}.section-navigation{display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem;border-top:2px solid #e2e8f0}.nav-section-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.nav-section-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #667eea66}.nav-section-button.next{margin-left:auto}.no-section-selected{background:#fff;border-radius:12px;padding:4rem;text-align:center;color:#64748b;font-size:1.1rem}.header-actions{display:flex;gap:.75rem;align-items:center}.analytics-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.65rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.analytics-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #667eea66}.master-challenge-button{position:relative;background:linear-gradient(135deg,gold,#ffed4e 20%,#ff6b6b);color:#1a1a1a;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #ffd70066,0 0 20px #ffd70033;text-shadow:0 1px 2px rgba(0,0,0,.1);letter-spacing:.5px;overflow:hidden;text-transform:uppercase;font-size:.95rem}.master-challenge-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s}.master-challenge-button:hover:before{left:100%}.master-challenge-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 25px #ffd70080,0 0 30px #ffd7004d,0 0 40px #ff6b6b33;background:linear-gradient(135deg,#ffed4e,gold 20%,#ff6b6b)}.master-challenge-button:active{transform:translateY(-1px) scale(.98);box-shadow:0 4px 15px #ffd70066}@keyframes challengePulse{0%,to{box-shadow:0 4px 15px #ffd70066,0 0 20px #ffd70033}50%{box-shadow:0 4px 20px #ffd70099,0 0 30px #ffd70066}}.master-challenge-button{animation:challengePulse 2s ease-in-out infinite}.master-challenge-button:hover{animation:none}.master-challenge-button-shimmer{position:relative;background:linear-gradient(135deg,#1e3a8a,#3b82f6,#fbbf24);background-size:200% 200%;color:#fff;border:2px solid #fbbf24;padding:.75rem 1.5rem;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #3b82f666,inset 0 0 0 1px #fbbf244d;text-shadow:0 2px 4px rgba(0,0,0,.3);letter-spacing:.5px;animation:gradientShift 3s ease infinite;text-transform:uppercase;font-size:.95rem}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.master-challenge-button-shimmer:hover{transform:translateY(-3px);box-shadow:0 8px 25px #3b82f680,0 0 30px #fbbf2466,inset 0 0 0 2px #fbbf2480;border-color:#fff}.master-challenge-button:after{content:"⚡";margin-left:.5rem;font-size:1.1em;display:inline-block;animation:sparkle 1.5s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:1;transform:scale(1) rotate(0)}50%{opacity:.7;transform:scale(1.2) rotate(15deg)}}.leaderboard-button,.challenge-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.65rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;font-size:1rem}.leaderboard-button:hover,.challenge-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #667eea66}.analytics-panel{padding:2rem}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.analytics-header h2{margin:0;font-size:1.75rem;color:#1e293b}.view-selector{display:flex;gap:.5rem;background:#fff;padding:.25rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.view-selector button{background:transparent;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;color:#64748b}.view-selector button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.view-selector button:hover:not(.active){background:#f1f5f9;color:#1e293b}.overview-section{display:flex;flex-direction:column;gap:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-box{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1rem}.stat-icon{font-size:2.5rem}.stat-info{flex:1}.stat-value{font-size:2rem;font-weight:700;color:#1e293b;line-height:1}.stat-label{font-size:.9rem;color:#000;margin-top:.25rem}.chart-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.chart-section h3{margin:0 0 1.5rem;font-size:1.25rem;color:#1e293b}.bar-chart{display:flex;flex-direction:column;gap:1.25rem}.bar-item{display:flex;flex-direction:column;gap:.5rem}.bar-label{display:flex;justify-content:space-between;align-items:center;font-weight:600}.bar-category{color:#475569}.bar-value{color:#667eea;font-size:1.1rem}.bar-container{background:#f1f5f9;border-radius:8px;height:32px;overflow:hidden}.bar-fill{height:100%;border-radius:8px;transition:width .5s ease;display:flex;align-items:center;padding:0 .75rem;color:#fff;font-weight:600}.bar-fill.pass{background:linear-gradient(135deg,#10b981,#059669)}.bar-fill.fail{background:linear-gradient(135deg,#ef4444,#dc2626)}.trends-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.trends-section h3{margin:0 0 2rem;font-size:1.25rem;color:#1e293b}.line-chart{display:flex;gap:1rem;height:320px}.chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;font-size:.75rem;color:#94a3b8;padding-top:10px;padding-bottom:30px}.chart-canvas{flex:1;position:relative;padding-bottom:30px}.chart-grid{position:absolute;inset:10px 0 30px}.grid-line{position:absolute;left:0;right:0;height:1px;background:#e2e8f0}.chart-svg{width:100%;height:calc(100% - 30px);margin-top:10px}.chart-x-axis{display:flex;justify-content:space-between;font-size:.75rem;color:#94a3b8;padding:0 1rem}.no-data{text-align:center;padding:3rem;color:#94a3b8}.insights{margin-top:2rem;padding:1.5rem;background:#f8fafc;border-radius:8px}.insights h4{margin:0 0 1rem;color:#1e293b}.insights ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.insights li{padding:.75rem 1rem;border-radius:6px;font-weight:500}.insight-positive{background:#d1fae5;color:#065f46;border-left:4px solid #10b981}.insight-warning{background:#fef3c7;color:#92400e;border-left:4px solid #f59e0b}.categories-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.categories-section h3{margin:0 0 1.5rem;font-size:1.25rem;color:#1e293b}.category-details{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.category-detail-card{border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;transition:box-shadow .2s}.category-detail-card:hover{box-shadow:0 4px 12px #0000001a}.category-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.category-detail-header h4{margin:0;font-size:1.1rem;color:#1e293b}.score-badge{padding:.35rem .75rem;border-radius:6px;font-weight:700;font-size:1rem}.score-badge.pass{background:#d1fae5;color:#065f46}.score-badge.fail{background:#fee2e2;color:#991b1b}.category-detail-stats{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.detail-stat{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.85rem;color:#64748b}.detail-value{font-size:1.1rem;font-weight:700;color:#1e293b}.detail-value.positive{color:#10b981}.detail-value.negative{color:#ef4444}.recommendation{margin-top:1rem;padding:.75rem;background:#fef3c7;border-radius:6px;font-size:.9rem;color:#92400e}.action-buttons{display:flex;gap:.5rem;align-items:center}.analytics-link-button{background:#667eea;color:#fff;border:none;padding:.4rem .65rem;border-radius:6px;font-size:1.1rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.analytics-link-button:hover{transform:translateY(-2px);box-shadow:0 4px 10px #667eea66}.full-exam-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:2rem;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:2rem;box-shadow:0 8px 20px #667eea4d}.full-exam-info h3{margin:0 0 .75rem;font-size:1.75rem}.full-exam-info p{margin:.5rem 0;opacity:.95}.exam-features{list-style:none;padding:0;margin:1rem 0 0;display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.exam-features li{font-size:.95rem;opacity:.95}.full-exam-button{background:#fff;color:#667eea;border:none;padding:1rem 2.5rem;border-radius:12px;font-size:1.25rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #00000026}.full-exam-button:hover{transform:translateY(-3px);box-shadow:0 8px 20px #00000040}.full-exam{min-height:100vh;background:linear-gradient(to bottom,#f8fafc,#e2e8f0)}.exam-header{background:linear-gradient(135deg,#1e293b,#334155);padding:2rem;box-shadow:0 4px 12px #00000026;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center}.exam-info h1{margin:0;font-size:1.75rem;color:#fff}.exam-info p{margin:.5rem 0 0;color:#fffc;font-size:1rem}.exam-stats{display:flex;gap:2rem;align-items:center}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1.5rem;background:#ffffff1a;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#ffffffb3;font-weight:600}.stat-value{font-size:1.5rem;font-weight:700;color:#fff}.timer-stat{background:#10b98133;border-color:#10b9814d}.timer-stat.warning{background:#fbbf2433;border-color:#fbbf244d}.timer-stat.warning .stat-label,.timer-stat.warning .stat-value{color:#fbbf24}.timer-stat.critical{background:#ef444433;border-color:#ef44444d;animation:pulse-border 1s infinite}.timer-stat.critical .stat-label,.timer-stat.critical .stat-value{color:#f87171}@keyframes pulse-border{0%,to{border-color:#ef444480;box-shadow:0 0 #ef444466}50%{border-color:#ef4444cc;box-shadow:0 0 20px #ef444466}}.timer-value{font-family:Courier New,monospace;font-size:1.75rem}.exam-content{padding:2rem;display:grid;grid-template-columns:1fr 350px;gap:2rem;max-width:1600px;margin:0 auto}.question-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.question-count{font-weight:600;color:#64748b}.category-tag{background:#ede9fe;color:#667eea;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600}.flag-button{background:transparent;border:2px solid #e2e8f0;color:#64748b;padding:.35rem .75rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.flag-button:hover{border-color:#f59e0b;color:#f59e0b}.flag-button.flagged{border-color:#f59e0b;background:#fef3c7;color:#92400e}.exam-navigation{display:flex;flex-direction:column;gap:1.5rem}.nav-buttons{display:flex;gap:1rem}.nav-button{flex:1;padding:1rem;border:none;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.nav-button.prev,.nav-button.next{background:#fff;color:#667eea;border:2px solid #667eea}.nav-button.prev:hover,.nav-button.next:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.nav-button.submit{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.nav-button.submit:hover{transform:translateY(-2px);box-shadow:0 6px 15px #10b98166}.nav-button:disabled{opacity:.4;cursor:not-allowed}.question-grid{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.question-grid h3{margin:0 0 1rem;font-size:1.1rem;color:#1e293b}.question-numbers{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin-bottom:1rem}.question-number-btn{aspect-ratio:1;border:2px solid #e2e8f0;background:#fff;border-radius:8px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s;color:#64748b}.question-number-btn.current{border-color:#667eea;background:#667eea;color:#fff}.question-number-btn.answered{background:#d1fae5;border-color:#10b981;color:#065f46}.question-number-btn.unanswered{background:#fff;border-color:#e2e8f0}.question-number-btn.flagged{background:#fef3c7;border-color:#f59e0b;color:#92400e;position:relative}.question-number-btn.flagged:after{content:"🚩";position:absolute;top:-8px;right:-8px;font-size:.75rem}.question-number-btn:hover{transform:scale(1.1);box-shadow:0 2px 8px #00000026}.legend{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem;color:#64748b;padding-top:1rem;border-top:1px solid #e2e8f0}.legend span{display:flex;align-items:center;gap:.5rem}.legend-box{width:20px;height:20px;border-radius:4px;border:2px solid #e2e8f0}.legend-box.current{background:#667eea;border-color:#667eea}.legend-box.answered{background:#d1fae5;border-color:#10b981}.legend-box.unanswered{background:#fff;border-color:#e2e8f0}.legend-box.flagged{background:#fef3c7;border-color:#f59e0b}.confirm-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-dialog{background:#fff;border-radius:16px;padding:2.5rem;max-width:500px;box-shadow:0 20px 60px #0000004d}.confirm-dialog h2{margin:0 0 1rem;color:#1e293b}.confirm-dialog p{margin:.75rem 0;color:#475569}.warning-text{color:#f59e0b;font-weight:600}.confirm-buttons{display:flex;gap:1rem;margin-top:2rem}.cancel-button{flex:1;padding:1rem;background:#fff;border:2px solid #64748b;color:#64748b;border-radius:10px;font-weight:700;cursor:pointer;transition:all .2s}.cancel-button:hover{background:#f1f5f9}.submit-button{flex:1;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;border-radius:10px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s}.submit-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #667eea66}.category-breakdown{margin:2rem 0}.category-breakdown h2{margin:0 0 1.5rem;color:#1e293b}.category-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.category-result-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;text-align:center}.category-result-card h3{margin:0;font-size:1.5rem;color:#667eea}.category-name{margin:.5rem 0;font-size:.85rem;color:#64748b}.category-score{margin-top:1rem;display:flex;flex-direction:column;gap:.25rem}.category-score .percentage{font-size:2rem;font-weight:700}.category-score .percentage.pass{color:#10b981}.category-score .percentage.fail{color:#ef4444}.category-score .fraction{font-size:.9rem;color:#64748b}.question-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.question-category-badge{background:#ede9fe;color:#667eea;padding:.25rem .75rem;border-radius:6px;font-size:.85rem;font-weight:700}.exam-selector-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#667eea,#764ba2);overflow-y:auto;z-index:100}.exam-selector-container{max-width:1400px;margin:0 auto;padding:3rem 2rem}.exam-selector-container h1{color:#fff;text-align:center;font-size:2.5rem;margin:0 0 1rem}.selector-subtitle{color:#ffffffe6;text-align:center;font-size:1.25rem;margin:0 0 3rem}.exam-options{display:flex;flex-direction:column;gap:2rem}.exam-option{background:#fff;border:none;border-radius:16px;padding:2rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #0000001a;text-align:left}.exam-option:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0003}.full-exam-option{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.full-exam-option:hover{box-shadow:0 8px 24px #10b98166}.exam-option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.exam-option-header h2{margin:0;font-size:1.75rem}.exam-option-header h3{margin:0;font-size:1.5rem;color:#667eea}.exam-badge{background:#ffffff4d;color:#fff;padding:.5rem 1rem;border-radius:8px;font-weight:700;font-size:.9rem}.exam-badge.all{background:#fff6}.category-exam-option .exam-badge{background:#ede9fe;color:#667eea}.exam-description{margin:0 0 1rem;font-size:1.1rem;opacity:.95}.category-exam-name{margin:0 0 1rem;font-size:1rem;color:#475569;font-weight:500}.exam-details{display:flex;gap:2rem;font-weight:600;opacity:.95}.exam-details-small{display:flex;gap:1.5rem;font-size:.9rem;color:#64748b;font-weight:600}.category-exams-header{margin-top:2rem;text-align:center}.category-exams-header h3{color:#fff;font-size:1.75rem;margin:0 0 .5rem}.category-exams-header p{color:#ffffffe6;margin:0}.category-exam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.cancel-selector-button{display:block;margin:3rem auto 0;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.5);padding:1rem 2.5rem;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s}.cancel-selector-button:hover{background:#ffffff4d;border-color:#fff}@media(max-width:480px){.full-exam-card{flex-direction:column;padding:1.25rem;gap:1.25rem;align-items:stretch}.full-exam-info h3{font-size:1.25rem;line-height:1.3}.full-exam-info p{font-size:.875rem;line-height:1.5}.exam-features{font-size:.8rem;margin:.75rem 0;padding-left:1.25rem}.exam-features li{margin-bottom:.4rem}.full-exam-button{width:100%;padding:1rem 1.5rem;font-size:1.125rem;min-height:48px;border-radius:10px}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1.25rem}.stat-icon{font-size:2rem}.stat-value{font-size:1.75rem}.stat-label{font-size:.875rem}.categories-grid{grid-template-columns:1fr;gap:1rem}.category-card{padding:1.25rem}.section h2{font-size:1.25rem;margin-bottom:1rem}.section{padding:1.25rem;margin-bottom:1rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}body{font-size:16px;line-height:1.5}h1{font-size:1.5rem;line-height:1.2}h2{font-size:1.25rem;line-height:1.3}h3{font-size:1.125rem;line-height:1.3}p{font-size:.9375rem;line-height:1.5}}@media(min-width:481px)and (max-width:768px){.full-exam-card{flex-direction:column;padding:1.5rem;gap:1.5rem}.full-exam-button{width:100%;padding:1rem 2rem;font-size:1.125rem;min-height:48px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.categories-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}@media(max-width:768px){.exam-header{grid-template-columns:1fr;gap:1.5rem;padding:1.5rem}.exam-info h1{font-size:1.25rem}.exam-info p{font-size:.9rem}.exam-stats{flex-direction:row;gap:1rem;width:100%}.stat-item{flex:1;padding:.75rem .5rem}.stat-label{font-size:.65rem}.stat-value{font-size:1.25rem}.timer-value{font-size:1.5rem}.exam-content{grid-template-columns:1fr;padding:1rem}.question-numbers{grid-template-columns:repeat(5,1fr)}.category-exam-grid{grid-template-columns:1fr}.dashboard{padding:1rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.categories-grid{grid-template-columns:1fr}.test-navigation{flex-direction:column}.question-indicators{order:-1}.history-table,.tech-table{font-size:.85rem}.history-table th,.history-table td,.tech-table th,.tech-table td{padding:.75rem .5rem}}.subscription-banner{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #0ea5e9;border-radius:12px;padding:1.5rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.subscription-status{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.status-icon{font-size:2rem;flex-shrink:0}.status-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.status-info strong{font-size:1.125rem;color:#0c4a6e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trial-info{font-size:.875rem;color:#0369a1}.manage-subscription-button{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;white-space:nowrap;flex-shrink:0;min-height:44px;font-size:.9375rem}.manage-subscription-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #0ea5e966}.manage-subscription-button:active{transform:translateY(0)}@media(max-width:768px){.subscription-banner{flex-direction:column;align-items:stretch;padding:1.25rem;gap:1rem}.subscription-status{justify-content:flex-start;gap:.875rem}.status-icon{font-size:1.75rem}.status-info{flex:1}.status-info strong{font-size:1rem;white-space:normal;overflow:visible;text-overflow:clip}.trial-info{font-size:.8125rem}.manage-subscription-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;text-align:center;min-height:48px}}@media(max-width:480px){.subscription-banner{padding:1rem;gap:.875rem;margin-bottom:1.5rem}.subscription-status{gap:.75rem}.status-icon{font-size:1.5rem}.status-info strong{font-size:.9375rem}.trial-info{font-size:.75rem}.manage-subscription-button{padding:.8125rem 1.25rem;font-size:.9375rem}}@media(max-width:768px)and (orientation:landscape){.subscription-banner{flex-direction:row;padding:1rem 1.25rem}.subscription-status{flex:1;min-width:0}.manage-subscription-button{width:auto;min-width:160px}}@media(min-width:481px)and (max-width:640px){.subscription-banner{padding:1.5rem}.status-info strong{font-size:1.0625rem}.manage-subscription-button{font-size:1rem}}.subscription-plans{max-width:1200px;margin:0 auto}.subscription-plans h2{text-align:center;font-size:2rem;margin-bottom:.5rem;color:#1e293b}.plans-description{text-align:center;color:#64748b;margin-bottom:3rem;font-size:1.125rem}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:3rem}.plan-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:2rem;transition:transform .2s,box-shadow .2s,border-color .2s}.plan-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:#0ea5e9}.plan-card.current-plan{border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.plan-header{border-bottom:2px solid #e2e8f0;padding-bottom:1.5rem;margin-bottom:1.5rem}.plan-header h3{font-size:1.5rem;color:#1e293b;margin-bottom:1rem}.plan-price{display:flex;align-items:baseline;gap:.5rem}.price-amount{font-size:2.5rem;font-weight:700;color:#0ea5e9}.price-period{font-size:1rem;color:#64748b}.plan-features ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.plan-features li{display:flex;align-items:flex-start;gap:.75rem;font-size:.95rem;color:#475569}.feature-icon{color:#10b981;font-weight:700;font-size:1.25rem;flex-shrink:0}.plan-actions{margin-top:2rem}.subscribe-button{width:100%;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.subscribe-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #0ea5e966}.current-plan-button{width:100%;background:#10b981;color:#fff;border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:not-allowed;opacity:.8}.subscription-info{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:2rem;margin-top:2rem}.subscription-info h3{margin-bottom:1.5rem;color:#1e293b}.subscription-details{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border-radius:6px}.detail-label{font-weight:600;color:#475569}.status-badge{padding:.25rem .75rem;border-radius:4px;font-size:.875rem;font-weight:600}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.trial{background:#dbeafe;color:#1e40af}.status-badge.cancelled{background:#fee2e2;color:#991b1b}.status-badge.expired{background:#fef3c7;color:#92400e}.cancel-button{background:#dc2626;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.cancel-button:hover{background:#b91c1c}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:2px solid #e2e8f0;padding-bottom:1rem}.modal-header h2{margin:0;color:#1e293b}.modal-close-button{background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.assignment-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#475569;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.form-group select,.form-group input,.form-group textarea{padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#0ea5e9}.form-group textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.submit-button{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s}.submit-button:hover:not(:disabled){transform:translateY(-2px)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.assign-button-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.assign-button-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.assign-button{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s}.assign-button:hover{background:#059669}.assignments-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}.assignments-table th{background:#f8fafc;padding:1rem;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0}.assignments-table td{padding:1rem;border-bottom:1px solid #e2e8f0}.assignments-table tbody tr:hover{background:#f8fafc}.overdue-row{background:#fef2f2!important}.overdue-row:hover{background:#fee2e2!important}.due-date-cell{display:flex;flex-direction:column;gap:.25rem}.due-indicator{font-size:.75rem;padding:.25rem .5rem;border-radius:4px;font-weight:600;display:inline-block;width:fit-content}.due-indicator.overdue{background:#fee2e2;color:#991b1b}.due-indicator.soon{background:#fef3c7;color:#92400e}.assignment-status{padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:600;display:inline-block}.assignment-status.pending{background:#e0e7ff;color:#3730a3}.assignment-status.in_progress{background:#dbeafe;color:#1e40af}.assignment-status.completed{background:#dcfce7;color:#166534}.assignment-status.overdue{background:#fee2e2;color:#991b1b}@media(max-width:768px){.section-header{flex-direction:column;gap:12px;align-items:stretch;margin-bottom:20px}.section-header h2{font-size:20px;margin:0}.assign-button-primary{width:100%;padding:12px;text-align:center}.assignments-grid{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -20px;padding:0 20px}.assignments-table thead{display:none}.assignments-table,.assignments-table tbody,.assignments-table tr{display:block;width:100%}.assignments-table tr{margin-bottom:16px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;border:1px solid #e2e8f0}.assignments-table tr.overdue-row{border-left:4px solid #ef4444;background:#fef2f2!important}.assignments-table td{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border:none;text-align:left;gap:12px}.assignments-table td:first-child{padding-top:0}.assignments-table td:last-child{padding-bottom:0}.assignments-table td:before{content:attr(data-label);font-weight:600;color:#64748b;min-width:100px;flex-shrink:0;font-size:14px}.assignments-table td:nth-child(1):before{content:"Technician"}.assignments-table td:nth-child(2):before{content:"Test Category"}.assignments-table td:nth-child(3):before{content:"Due Date"}.assignments-table td:nth-child(4):before{content:"Status"}.assignments-table td:nth-child(5):before{content:"Assigned"}.assignments-table td{word-break:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.assignments-table td>*{flex:1;text-align:right}.due-date-cell{align-items:flex-end;text-align:right}.due-indicator{font-size:11px;padding:4px 8px}.assignment-status{font-size:12px;padding:6px 12px;white-space:nowrap}}@media(max-width:480px){.assignments-table td:before{min-width:90px;font-size:13px}.assignments-table td{font-size:14px;gap:8px}.section-header h2{font-size:18px}}@media(max-width:768px){.test-history{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -20px;padding:0 20px}.history-table thead{display:none}.history-table,.history-table tbody,.history-table tr{display:block;width:100%}.history-table tr{margin-bottom:16px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;border:1px solid #e2e8f0;position:relative}.history-table tr:has(.status.completed):before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#10b981;border-radius:8px 0 0 8px}.history-table tr:has(.status.in-progress):before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#3b82f6;border-radius:8px 0 0 8px}.history-table td{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border:none;text-align:left;gap:12px}.history-table td:first-child{padding-top:0}.history-table td:last-child{padding-bottom:0}.history-table td:before{content:attr(data-label);font-weight:600;color:#64748b;min-width:100px;flex-shrink:0;font-size:14px}.history-table td:nth-child(1):before{content:"Technician"}.history-table td:nth-child(2):before{content:"Category"}.history-table td:nth-child(3):before{content:"Date"}.history-table td:nth-child(4):before{content:"Score"}.history-table td:nth-child(5):before{content:"Questions"}.history-table td:nth-child(6):before{content:"Status"}.history-table td{word-break:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.history-table td>*{flex:1;text-align:right}.history-table td .score,.history-table td .status{margin-left:auto}.score{font-size:13px;padding:6px 12px;white-space:nowrap}.status{font-size:12px;padding:6px 12px;white-space:nowrap}}@media(max-width:480px){.history-table td:before{min-width:85px;font-size:13px}.history-table td{font-size:14px;gap:8px}.history-table tr{padding:12px}.score{font-size:12px;padding:5px 10px}.status{font-size:11px;padding:5px 10px}}.assignments-section{background:linear-gradient(135deg,#fff7ed,#ffedd5);border:2px solid #fb923c;border-radius:12px;padding:2rem}.assigned-tests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.assigned-test-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:transform .2s,box-shadow .2s}.assigned-test-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.assigned-test-card.overdue{border-color:#ef4444;background:linear-gradient(135deg,#fff,#fef2f2)}.assigned-test-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.assigned-test-category{display:flex;flex-direction:column;gap:.25rem}.assigned-test-category strong{font-size:1.25rem;color:#0ea5e9}.assigned-test-category span{font-size:.875rem;color:#64748b}.due-badge{padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;white-space:nowrap}.due-badge.overdue{background:#fee2e2;color:#991b1b}.due-badge.soon{background:#fef3c7;color:#92400e}.due-badge:not(.overdue):not(.soon){background:#dbeafe;color:#1e40af}.assigned-test-info{display:flex;flex-direction:column;gap:.5rem}.due-date{color:#475569;font-size:.875rem;font-weight:600}.assignment-notes{color:#64748b;font-size:.875rem;font-style:italic;margin:0}.start-assigned-test-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.75rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.start-assigned-test-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.profile-button{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.profile-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.message-banner{padding:1rem 1.5rem;border-radius:8px;margin-bottom:2rem;font-weight:500}.message-banner.success{background:#d1fae5;color:#065f46;border:1px solid #10b981}.message-banner.error{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}.profile-form{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000000d}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;color:#1e293b;margin-bottom:.5rem}.form-group small{display:block;color:#64748b;font-size:.875rem;margin-top:.25rem}.form-input{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:#667eea}.form-input.disabled{background:#f1f5f9;color:#64748b;cursor:not-allowed}.form-textarea{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .2s}.form-textarea:focus{outline:none;border-color:#667eea}.save-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.save-button:disabled{opacity:.5;cursor:not-allowed}.shop-info{margin-bottom:2rem}.current-shop{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000000d}.shop-details h3{margin:0 0 .5rem;color:#1e293b;font-size:1.5rem}.shop-type{color:#64748b;font-size:1rem;margin:0}.no-shop{color:#64748b;font-style:italic;padding:2rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.pending-request-card{background:#fef3c7;border:2px solid #f59e0b;border-radius:12px;padding:2rem;margin-top:1.5rem}.request-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.request-header h3{margin:0;color:#92400e}.status-badge{padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.875rem}.status-badge.pending{background:#fbbf24;color:#78350f}.request-details p{margin:.5rem 0;color:#92400e}.request-date{font-size:.875rem;color:#a16207;margin-top:1rem}.cancel-request-button{background:#ef4444;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s;margin-top:1rem}.cancel-request-button:hover:not(:disabled){transform:translateY(-2px);background:#dc2626}.cancel-request-button:disabled{opacity:.5;cursor:not-allowed}.shop-change-form{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000000d;margin-top:1.5rem}.shop-change-form h3{margin:0 0 .5rem;color:#1e293b}.form-description{color:#64748b;margin-bottom:1.5rem}.request-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.request-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.request-button:disabled{opacity:.5;cursor:not-allowed}.shop-requests-section{background:#fef3c7;border:2px solid #f59e0b;border-radius:12px;padding:2rem}.shop-requests-section h2{color:#92400e;margin-top:0}.shop-requests-list{display:flex;flex-direction:column;gap:1rem}.shop-request-card{background:#fff;border-radius:8px;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:2rem}.request-info{flex:1}.tech-info h3{margin:0 0 .25rem;color:#1e293b}.tech-email{color:#64748b;margin:0 0 1rem}.request-notes{margin:1rem 0;padding:1rem;background:#f1f5f9;border-radius:8px}.request-notes strong{color:#1e293b;display:block;margin-bottom:.5rem}.request-notes p{margin:0;color:#475569}.request-actions{display:flex;gap:.75rem}.approve-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.approve-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.reject-button{background:#ef4444;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s}.reject-button:hover{transform:translateY(-2px);background:#dc2626}.shop-info-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000000d}.shop-details-section{display:flex;flex-direction:column;gap:2rem}.shop-name-section h3{margin:0 0 .5rem;color:#1e293b;font-size:1.75rem}.shop-code-section{background:linear-gradient(135deg,#f0f4ff,#e0e7ff);border:2px solid #667eea;border-radius:12px;padding:1.5rem}.shop-code-section label{display:block;font-weight:600;color:#4338ca;margin-bottom:.75rem;font-size:1rem}.shop-code-display{display:flex;gap:1rem;align-items:center}.shop-code-value{flex:1;background:#fff;border:2px solid #667eea;border-radius:8px;padding:1rem 1.5rem;font-size:1.5rem;font-weight:700;color:#4338ca;letter-spacing:2px;text-align:center;font-family:Courier New,monospace}.copy-code-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;white-space:nowrap}.copy-code-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.shop-code-hint{display:block;color:#4338ca;font-size:.875rem;margin-top:.75rem;font-style:italic}.no-shop-card{background:#fff;border-radius:12px;padding:3rem 2rem;text-align:center;box-shadow:0 2px 8px #0000000d}.no-shop-card p{color:#64748b;font-style:italic;margin:0}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:900px;width:100%;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.approval-history-modal{max-width:1000px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #e2e8f0}.modal-header h2{margin:0;font-size:1.5rem;color:#1e293b;font-weight:700}.modal-close-button{background:none;border:none;font-size:2rem;color:#64748b;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s,color .2s;line-height:1}.modal-close-button:hover{background:#f1f5f9;color:#1e293b}.modal-close-button:focus{outline:2px solid #2563eb;outline-offset:2px}.modal-body{flex:1;overflow-y:auto;padding:1.5rem 2rem}.modal-footer{padding:1rem 2rem;border-top:2px solid #e2e8f0;display:flex;justify-content:flex-end;gap:.75rem}.modal-close-footer-button{background:#64748b;color:#fff;border:none;padding:.625rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.modal-close-footer-button:hover{background:#475569}.modal-close-footer-button:focus{outline:2px solid #2563eb;outline-offset:2px}.history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.loading-spinner-small{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite}.history-loading p{color:#64748b;font-size:1rem}.history-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem}.error-icon{font-size:3rem;margin:0}.error-text{color:#dc2626;margin:0;font-size:1rem}.retry-button{background:#2563eb;color:#fff;border:none;padding:.625rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:.5rem}.retry-button:hover{background:#1e40af}.history-filters{display:flex;gap:.75rem;margin-bottom:1.5rem;border-bottom:2px solid #e2e8f0;padding-bottom:.5rem}.filter-button{background:none;border:none;padding:.625rem 1rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;color:#64748b;font-size:.9rem}.filter-button:hover{background:#f1f5f9;color:#1e293b}.filter-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.filter-button:focus{outline:2px solid #2563eb;outline-offset:2px}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem}.empty-icon{font-size:3rem;margin:0;opacity:.4}.empty-text{color:#64748b;margin:0;font-size:1rem}.history-list{display:flex;flex-direction:column;gap:1rem}.history-item{background:#fff;border:2px solid #e2e8f0;border-radius:10px;padding:1.25rem;transition:all .2s}.history-item:hover{box-shadow:0 4px 12px #00000014;border-color:#cbd5e1}.history-item.approved{border-left:4px solid #10b981}.history-item.rejected{border-left:4px solid #ef4444}.history-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.history-tech-info h3{margin:0 0 .25rem;font-size:1.1rem;color:#1e293b;font-weight:600}.history-tech-email{margin:0;color:#64748b;font-size:.9rem}.history-status-badge{padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.85rem;white-space:nowrap}.history-status-badge.approved{background:#d1fae5;color:#065f46}.history-status-badge.rejected{background:#fee2e2;color:#991b1b}.history-item-details{display:flex;flex-direction:column;gap:.75rem}.history-detail-row{display:flex;gap:.5rem;font-size:.9rem}.history-detail-row.notes{flex-direction:column}.detail-label{font-weight:600;color:#475569;min-width:130px}.detail-value{color:#1e293b}.shop-code{font-family:monospace;background:#f1f5f9;padding:.125rem .5rem;border-radius:4px;font-weight:600}.history-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;font-size:.95rem}.history-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px #667eea66}.history-button:focus{outline:2px solid #2563eb;outline-offset:2px}.subscription-limit-modal .modal-body{padding:1.5rem}.limit-alert{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:12px;padding:1.5rem;display:flex;gap:1rem;margin-bottom:2rem}.alert-icon{font-size:2.5rem;line-height:1}.alert-content h3{margin:0 0 .5rem;color:#92400e;font-size:1.125rem}.limit-stats{color:#78350f;font-size:.95rem;margin:0}.limit-stats strong{color:#92400e;font-size:1.125rem}.upgrade-section{margin-bottom:1.5rem}.upgrade-section h4{margin:0 0 1rem;color:#1e293b;font-size:1.125rem}.upgrade-card{background:linear-gradient(135deg,#f0f4ff,#e0e7ff);border:2px solid #667eea;border-radius:12px;padding:1.5rem}.upgrade-plan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:2px solid #c7d2fe}.upgrade-plan-header h3{margin:0;color:#1e293b;font-size:1.5rem}.upgrade-price{display:flex;align-items:baseline;gap:.25rem}.price-amount{font-size:2rem;font-weight:700;color:#667eea}.price-period{font-size:.95rem;color:#64748b}.upgrade-benefits,.contact-benefits{display:flex;flex-direction:column;gap:.75rem}.benefit-item{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:#334155}.benefit-icon{width:24px;height:24px;background:#667eea;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.upgrade-actions{display:flex;gap:1rem;margin-top:1.5rem}.upgrade-button{flex:1;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:10px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #667eea4d}.upgrade-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.cancel-button{padding:1rem 2rem;background:#e2e8f0;color:#475569;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.cancel-button:hover{background:#cbd5e1}.enterprise-contact-section{padding:1.5rem;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:12px;margin-bottom:1.5rem}.enterprise-contact-section h4{margin:0 0 .75rem;color:#1e293b;font-size:1.25rem}.enterprise-contact-section p{color:#475569;line-height:1.6;margin-bottom:1.25rem}@media(max-width:480px){.limit-alert{flex-direction:column;text-align:center;padding:1.25rem}.alert-icon{font-size:3rem}.upgrade-plan-header{flex-direction:column;gap:1rem;text-align:center}.upgrade-actions{flex-direction:column}.cancel-button{order:2}}@media(max-width:768px){.modal-content{max-height:90vh;border-radius:12px 12px 0 0;margin-top:auto}.approval-history-modal{max-width:100%}.modal-header{padding:1.25rem 1.5rem}.modal-body{padding:1rem 1.5rem}.header-actions{flex-wrap:wrap;gap:.5rem;width:100%;justify-content:center}.profile-button,.analytics-button,.achievements-button,.signout-button{padding:.5rem .875rem;font-size:.875rem;flex:1 1 auto;min-width:90px;white-space:nowrap}.master-challenge-button{padding:.6rem 1rem;font-size:.8rem;flex:1 1 100%;width:100%;margin-top:.25rem}.master-challenge-button:after{margin-left:.25rem;font-size:.95em}.dashboard-header{padding:1rem}.dashboard-header>div:first-child h1{font-size:1.25rem}.dashboard-header .role-badge{font-size:.75rem}.assigned-tests-grid{grid-template-columns:1fr;gap:1rem}.assigned-test-card{padding:1.25rem}.start-assigned-test-button{width:100%;padding:.875rem 1.5rem;min-height:44px;font-size:1rem}.category-card .start-button,.category-card .study-button{padding:.75rem 1.25rem;min-height:44px;font-size:.95rem}.performance-insights{padding:1.25rem;margin-bottom:1rem}.performance-insights h2{font-size:1.25rem}.modal-footer{padding:1rem 1.5rem}button:not(.icon-button):not(.close-button),.button{min-height:44px}}.history-filters{flex-wrap:wrap;gap:.5rem}.filter-button{flex:1;min-width:max-content;font-size:.85rem;padding:.5rem .75rem}.history-item-header{flex-direction:column}.history-detail-row{flex-direction:column;gap:.25rem}.detail-label{min-width:auto}.master-challenge-button{padding:.7rem 1.2rem;font-size:.85rem;white-space:nowrap}.master-challenge-button:after{margin-left:.3rem;font-size:1em}} .master-challenge-button:focus-visible{outline:3px solid #ffd700;outline-offset:2px}.master-challenge-button:focus:not(:focus-visible){outline:none}@media(prefers-contrast:high){.master-challenge-button{border:2px solid currentColor;text-shadow:none}}@media(prefers-reduced-motion:reduce){.master-challenge-button{animation:none!important;transition:transform .1s ease,box-shadow .1s ease}.master-challenge-button:before{transition:none}.master-challenge-button:after{animation:none!important}.master-challenge-button-shimmer{animation:none!important}}@media(prefers-color-scheme:dark){.master-challenge-button{background:linear-gradient(135deg,#fbbf24,#f59e0b 20%,#dc2626);box-shadow:0 4px 15px #fbbf2480,0 0 20px #fbbf244d}.master-challenge-button:hover{box-shadow:0 8px 25px #fbbf2499,0 0 30px #fbbf2466,0 0 40px #dc26264d}}
