: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;border-top:1px solid #e5e7eb;background:#dbeafe;padding:32px;border-radius:12px}.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:#2986cc}.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}.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-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}.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);position:relative;overflow:hidden;padding:32px;border-radius:20px;margin-bottom:32px;box-shadow:0 12px 40px #667eea59}.user-stats-card:before{content:"";position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%;pointer-events:none}.user-stats-card:after{content:"";position:absolute;bottom:-30%;left:-10%;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}.user-stats-card h3{margin:0 0 24px;font-size:22px;font-weight:700;color:#fff;position:relative;z-index:1;display:flex;align-items:center;gap:10px}.user-stats-card h3:before{content:"🏆";font-size:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:20px;position:relative;z-index:1}.stat-item{display:flex;flex-direction:column;gap:10px;padding:20px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;position:relative}.stat-item:hover{background:#ffffff38;transform:translateY(-4px);box-shadow:0 8px 20px #0003}.stat-item:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#fff6,#ffffff1a);border-radius:12px 12px 0 0}.stat-label{font-size:11px;font-weight:600;color:#ffffffd9;text-transform:uppercase;letter-spacing:1.2px;display:flex;align-items:center;gap:6px}.stat-item:nth-child(1) .stat-label:before{content:"🥇";font-size:14px}.stat-item:nth-child(2) .stat-label:before{content:"📊";font-size:14px}.stat-item:nth-child(3) .stat-label:before{content:"⚡";font-size:14px}.stat-item:nth-child(4) .stat-label:before{content:"🎯";font-size:14px}.stat-value{font-size:32px;font-weight:800;color:#fff;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.2);display:flex;flex-direction:column;gap:6px}.stat-context{font-size:11px;font-weight:500;color:#fffc;text-shadow:none;letter-spacing:.5px}.stat-badge{font-size:10px;font-weight:700;color:gold;background:#ffd70033;padding:4px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.8px;border:1px solid rgba(255,215,0,.3);align-self:flex-start;text-shadow:none;animation:badgePulse 2s infinite}@keyframes badgePulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.competitor-count{margin:20px 0 0;padding:12px 20px;font-size:13px;font-weight:600;color:#fffffff2;text-align:center;background:#ffffff1f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;border:1px solid rgba(255,255,255,.2);position:relative;z-index:1}.competitor-count:before{content:"👥";margin-right:8px;font-size:14px}.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}.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}.user-stats-card{padding:24px 20px}.user-stats-card h3{font-size:20px;margin-bottom:20px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-item{padding:16px 12px}.stat-value{font-size:26px}.stat-label,.stat-context{font-size:10px}.stat-badge{font-size:9px;padding:3px 8px}.competitor-count{font-size:12px;padding:10px 16px}}@media(max-width:480px){.user-stats-card{padding:20px 16px;margin-bottom:24px}.user-stats-card h3{font-size:18px;margin-bottom:16px}.stats-grid{grid-template-columns:1fr;gap:10px}.stat-item{padding:16px;flex-direction:row;justify-content:space-between;align-items:center}.stat-label{font-size:11px;flex:1}.stat-value{font-size:22px;text-align:right}.stat-context{font-size:9px}.stat-badge{font-size:8px;padding:3px 6px}.competitor-count{font-size:11px;padding:10px 14px;margin-top:16px}}.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:1200px;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(4,1fr);gap:1.5rem;margin-bottom:1.5rem}.mastery-info-item{background:#ffffff26;padding:1.25rem;border-radius:8px;display:flex;flex-direction:column;align-items:center;text-align:center}.mastery-info-icon{font-size:2.5rem;margin-bottom:.75rem}.mastery-info-item-title{font-weight:600;margin-bottom:.75rem;font-size:1.05rem}.mastery-info-item-desc{font-size:.9rem;opacity:.95;line-height:1.5}.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;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));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:1200px){.mastery-info-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}@media(max-width:1024px){.mastery-cards-grid{grid-template-columns:1fr}}@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;align-items:flex-start;text-align:left}.mastery-info-icon{font-size:1.75rem;align-self:center}.mastery-info-item-title{font-size:1rem}.mastery-info-item-desc{font-size:.85rem}.mastery-info-result{font-size:.875rem}.mastery-section-title{font-size:1.25rem}.mastery-cards-grid{grid-template-columns:1fr}.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}}.micro-learning-container{display:flex;flex-direction:column;gap:1.5rem;max-width:600px;margin:0 auto;padding:1rem;min-height:80vh}.card-progress{display:flex;flex-direction:column;gap:.5rem}.progress-header{display:flex;justify-content:space-between;align-items:center;position:relative}.progress-text{font-size:.875rem;font-weight:600;color:#64748b}.progress-percentage{font-size:.875rem;font-weight:700;color:#0ea5e9}.progress-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;box-shadow:inset 0 1px 3px #0000001a}.progress-fill{height:100%;background:linear-gradient(90deg,#0ea5e9,#06b6d4);transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px #0ea5e980;position:relative}.progress-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;width:20px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3));animation:shimmer 2s infinite}.flip-card{perspective:1000px;flex:1;min-height:500px;cursor:pointer;transition:transform .2s ease}.flip-card:hover:not(.flipped){transform:translateY(-2px)}.flip-card:active:not(.flipped){transform:scale(.98)}.flip-card.flipped{cursor:default}.flip-card-inner{position:relative;width:100%;height:100%;transition:transform .6s;transform-style:preserve-3d}.flip-card.flipped .flip-card-inner{transform:rotateY(180deg)}.flip-card-front,.flip-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;-webkit-backface-visibility:hidden;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;flex-direction:column;padding:2rem;transition:opacity .3s,visibility .3s}.flip-card-back{transform:rotateY(180deg)}.flip-card:not(.flipped) .flip-card-front{opacity:1;visibility:visible;pointer-events:auto}.flip-card:not(.flipped) .flip-card-back{opacity:0;visibility:hidden;pointer-events:none}.flip-card.flipped .flip-card-front{opacity:0;visibility:hidden;pointer-events:none}.flip-card.flipped .flip-card-back{opacity:1;visibility:visible;pointer-events:auto}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem;flex:1}.skill-tag{background:#f0f9ff;color:#0284c7;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600}.difficulty-badge{padding:.375rem .875rem;border-radius:20px;font-size:.6875rem;font-weight:700;white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 4px #0000001a;border:2px solid transparent}.difficulty-1{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-color:#10b981}.difficulty-2{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-color:#f59e0b}.difficulty-3{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;border-color:#ef4444}.card-content{flex:1;display:flex;flex-direction:column;justify-content:center}.card-label{font-size:.75rem;font-weight:700;color:#0284c7;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.1em;display:inline-block;padding:.375rem .75rem;background:linear-gradient(135deg,#e0f2fe,#bae6fd);border-radius:6px;border-left:3px solid #0ea5e9}.card-text{font-size:1.25rem;line-height:1.7;color:#0f172a;font-weight:500;padding:.5rem 0}.question-label{font-size:1rem;font-weight:700;color:#0ea5e9;text-transform:uppercase;letter-spacing:.05em}.question-text{font-size:1.125rem;font-weight:600;color:#0f172a;margin-bottom:1.5rem;line-height:1.5}.answer-options{display:flex;flex-direction:column;gap:.75rem}.answer-option{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;color:#0f172a;cursor:pointer;transition:all .2s;text-align:left;min-height:60px}.answer-option:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1;transform:translate(4px)}.answer-option:disabled{cursor:not-allowed}.answer-option.selected{background:#dbeafe;border-color:#0ea5e9}.answer-option.correct{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981;border-width:3px;color:#065f46;animation:correctPulse .6s ease;box-shadow:0 0 20px #10b98166;font-weight:600}.answer-option.incorrect{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444;border-width:3px;color:#991b1b;animation:shake .6s ease;box-shadow:0 0 20px #ef44444d}@keyframes correctPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.option-text{flex:1;line-height:1.5}.card-footer{margin-top:2rem}.tap-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;color:#64748b;font-size:.875rem;font-weight:500;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.btn-continue,.btn-next{width:100%;padding:1rem;background:linear-gradient(135deg,#0ea5e9,#06b6d4);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-continue:hover,.btn-next:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0ea5e94d}.btn-next{background:linear-gradient(135deg,#10b981,#059669)}.btn-next:hover{box-shadow:0 4px 12px #10b9814d}.confidence-rating{margin-top:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;border:2px solid #e2e8f0;animation:slideIn .4s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confidence-header{text-align:center;margin-bottom:1.25rem}.confidence-icon{font-size:2rem;margin-bottom:.5rem}.confidence-title{font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:.25rem}.confidence-subtitle{font-size:.75rem;color:#64748b;font-weight:500}.confidence-options{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.confidence-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s ease;min-height:100px}.confidence-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.confidence-btn:active{transform:scale(.95)}.confidence-emoji{font-size:2rem}.confidence-label{font-size:.875rem;font-weight:600;color:#334155;text-align:center}.confidence-guessed:hover{border-color:#fbbf24;background:#fef3c7}.confidence-uncertain:hover{border-color:#60a5fa;background:#dbeafe}.confidence-confident:hover{border-color:#34d399;background:#d1fae5}@media(max-width:640px){.micro-learning-container{padding:.5rem;gap:.875rem;min-height:auto}.flip-card{min-height:420px;-webkit-tap-highlight-color:transparent}.flip-card-inner{transition:transform .5s ease-out}.flip-card-front,.flip-card-back{padding:1.25rem}.flip-card.flipped .flip-card-front{display:none!important;opacity:0!important;visibility:hidden!important;z-index:-1!important}.flip-card.flipped .flip-card-back{display:flex!important;opacity:1!important;visibility:visible!important;z-index:1!important}.flip-card.flipped .tap-hint{display:none!important;opacity:0!important;visibility:hidden!important}.card-header{margin-bottom:1.25rem;flex-wrap:wrap}.skill-tag,.difficulty-badge{font-size:.6875rem;padding:.3125rem .625rem}.card-label{font-size:.8125rem;margin-bottom:.875rem}.card-text,.question-text{font-size:1rem;line-height:1.5}.answer-option{padding:1rem;font-size:.9375rem;min-height:56px;-webkit-tap-highlight-color:transparent}.answer-option:active:not(:disabled){transform:scale(.98);background:#e2e8f0}.btn-continue,.btn-next{padding:1rem;font-size:1rem;min-height:48px;-webkit-tap-highlight-color:transparent}.btn-continue:active,.btn-next:active{transform:translateY(0) scale(.98)}.tap-hint{font-size:.9375rem;padding:.75rem;min-height:44px}.card-progress{margin-bottom:.5rem}.progress-text{font-size:.8125rem}.progress-bar{height:4px}.confidence-rating{padding:1rem}.confidence-options{grid-template-columns:1fr;gap:.5rem}.confidence-btn{min-height:70px;padding:.875rem}.confidence-emoji{font-size:1.5rem}.confidence-label{font-size:.8125rem}}@media(max-width:480px){.micro-learning-container{padding:.25rem}.flip-card{min-height:400px}.flip-card-front,.flip-card-back{padding:1rem}.flip-card.flipped .flip-card-front,.flip-card.flipped .tap-hint{display:none!important}.card-header{margin-bottom:1rem;gap:.5rem}.card-text,.question-text{font-size:.9375rem;line-height:1.4}.answer-option{font-size:.875rem;padding:.875rem;min-height:52px}.option-text{line-height:1.4}.skill-tag,.difficulty-badge{font-size:.625rem;padding:.25rem .5rem}.card-label{font-size:.75rem}.tap-hint svg{width:20px;height:20px}.btn-continue,.btn-next{font-size:.9375rem}}@media(max-width:768px)and (orientation:landscape){.flip-card{min-height:320px}.flip-card-front,.flip-card-back{padding:1rem}.flip-card.flipped .flip-card-front,.flip-card.flipped .tap-hint{display:none!important}.card-content,.answer-options{gap:.5rem}.card-footer{margin-top:1rem}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.flip-card-front,.flip-card-back{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media(prefers-reduced-motion:reduce){.flip-card-inner{transition:transform .1s}.answer-option,.btn-continue,.btn-next{transition:background-color .2s,border-color .2s}.answer-option:hover:not(:disabled){transform:none}.tap-hint{animation:none}@keyframes correctPulse{0%,to{transform:none}}@keyframes shake{0%,to{transform:none}}}.daily-session-container{position:fixed;inset:0;background:linear-gradient(135deg,#f8fafc,#e2e8f0);z-index:1000;overflow-y:auto}.session-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;box-shadow:0 1px 3px #0000001a}.btn-close{padding:.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-close:hover{background:#f1f5f9;border-color:#cbd5e1}.btn-close svg{color:#64748b}.session-stats{display:flex;gap:1rem;align-items:center}.stat-item{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:#f8fafc;border-radius:8px}.stat-item.streak{background:#fef3c7}.stat-icon{font-size:1.125rem}.stat-number{font-size:.9375rem;font-weight:700;color:#0f172a}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#0ea5e9;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.loading-state p{color:#64748b;font-size:1rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h2{font-size:1.5rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.empty-state p{color:#64748b;margin-bottom:2rem}.completion-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.completion-icon{margin-bottom:2rem;animation:scaleIn .6s ease}@keyframes scaleIn{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.completion-screen h1{font-size:2rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.completion-subtitle{font-size:1.125rem;color:#64748b;margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:400px;width:100%;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.stat-value{font-size:2rem;font-weight:700;color:#0ea5e9;margin-bottom:.5rem}.stat-label{font-size:.875rem;color:#64748b;font-weight:500}.streak-badge{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;margin-bottom:2rem}.streak-emoji{font-size:2rem}.streak-text{font-size:1.125rem;font-weight:700;color:#92400e}.completion-actions{display:flex;flex-direction:column;gap:1rem;max-width:300px;width:100%}.btn-primary,.btn-secondary{padding:1rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#0ea5e9,#06b6d4);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0ea5e94d}.btn-secondary{background:#fff;color:#0f172a;border:1px solid #e2e8f0}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}@media(max-width:640px){.completion-screen h1{font-size:1.5rem}.completion-subtitle{font-size:1rem}.stats-grid{gap:.75rem}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.stat-label{font-size:.8125rem}.streak-badge{padding:.75rem 1rem}.streak-emoji{font-size:1.5rem}.streak-text{font-size:1rem}.session-stats{gap:.5rem}.stat-item{padding:.375rem .625rem}.stat-icon{font-size:1rem}.stat-number{font-size:.875rem}}.category-selection{max-width:1200px;margin:0 auto;padding:2rem;min-height:100vh;display:flex;flex-direction:column}.category-selection h1{font-size:2rem;font-weight:700;color:#0f172a;text-align:center;margin-bottom:.5rem;margin-top:2rem}.selection-subtitle{text-align:center;color:#64748b;font-size:1.125rem;margin-bottom:3rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;margin-bottom:2rem}.category-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;min-height:200px;overflow:hidden}.category-card:hover{border-color:#0ea5e9;transform:translateY(-4px);box-shadow:0 8px 16px #0ea5e926}.category-card.selected{border-color:#0ea5e9;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);box-shadow:0 4px 12px #0ea5e933}.category-icon{font-size:3rem;margin-bottom:.5rem}.category-name{font-size:1.125rem;font-weight:700;color:#0f172a;line-height:1.3}.category-description{font-size:.8125rem;color:#64748b;line-height:1.4;max-width:100%;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}@media(max-width:768px){.category-selection{padding:1rem}.category-selection h1{font-size:1.5rem;margin-top:1rem}.selection-subtitle{font-size:1rem;margin-bottom:2rem}.category-grid{grid-template-columns:1fr;gap:1rem}.category-card{padding:1.25rem;min-height:180px}.category-icon{font-size:2.5rem}.category-name{font-size:1rem}.category-description{font-size:.8125rem}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr;max-width:300px}.completion-icon svg{width:64px;height:64px}.category-selection{padding:.5rem}.category-selection h1{font-size:1.25rem}.selection-subtitle{font-size:.9375rem}.category-card{min-height:160px}.category-icon{font-size:2rem}.category-name{font-size:.9375rem}.category-description{font-size:.75rem;line-height:1.3}}.test-trends-container{padding:1.5rem;animation:fadeInUp .5s ease-out}.trends-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.trends-header h3{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:-.5px}.time-range-selector{display:flex;gap:.5rem;background:#fff;padding:.375rem;border-radius:12px;box-shadow:0 2px 8px #00000014;border:2px solid #e2e8f0}.test-trends-container .time-range-selector{background:#fff}.test-trends-container .time-range-selector .range-btn{color:#64748b}.test-trends-container .time-range-selector .range-btn:hover{color:#3b82f6}.test-trends-container .time-range-selector .range-btn.active{color:#fff}.range-btn{padding:.625rem 1.25rem;border:none;background:transparent;color:#64748b!important;font-weight:600;font-size:.875rem;border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.range-btn:hover{color:#3b82f6!important;background:#eff6ff}.range-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb)!important;color:#fff!important;box-shadow:0 2px 8px #3b82f64d}.metrics-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.metric-card{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);opacity:0;transition:opacity .3s ease}.metric-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px #0000001f;border-color:#cbd5e1}.metric-card:hover:before{opacity:1}.metric-icon{font-size:2.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:transform .3s ease}.metric-card:hover .metric-icon{transform:scale(1.1) rotate(5deg)}.metric-content{flex:1}.metric-value{font-size:2rem;font-weight:900;background:linear-gradient(135deg,#0f172a,#1e293b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;letter-spacing:-1px;margin-bottom:.25rem}.metric-label{font-size:.875rem;color:#475569;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.chart-section{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;position:relative;overflow:hidden}.chart-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899)}.chart-section h4{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem;display:flex;align-items:center;gap:.5rem}.chart-section h4:before{content:"📈";font-size:1.5rem}.line-chart-container{width:100%;height:300px;position:relative}.line-chart{width:100%;height:100%}.grid-lines line{stroke-dasharray:4 4}.data-point{cursor:pointer;transition:all .2s ease}.data-point:hover{r:7;filter:drop-shadow(0 2px 8px rgba(59,130,246,.5))}.tooltip{pointer-events:none;animation:fadeIn .2s ease}.category-performance-section{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;position:relative;overflow:hidden}.category-performance-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#3b82f6,#f59e0b)}.category-performance-section h4{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem;display:flex;align-items:center;gap:.5rem}.category-performance-section h4:before{content:"🎯";font-size:1.5rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.category-card{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem;transition:all .3s ease;position:relative;overflow:hidden}.category-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#64748b,#94a3b8);transition:background .3s ease}.category-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#cbd5e1}.category-card:hover:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.category-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.category-info{display:flex;flex-direction:column;gap:.25rem}.category-code{font-size:1.125rem;font-weight:800;color:#1e293b;letter-spacing:-.5px}.category-name{font-size:.8125rem;color:#475569;font-weight:500}.trend-indicator{font-size:1.5rem;font-weight:700;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:all .3s ease}.trend-up{color:#10b981;background:#d1fae5}.trend-down{color:#ef4444;background:#fee2e2}.trend-stable{color:#64748b;background:#f1f5f9}.category-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.category-stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.75rem;color:#3b82f6;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.25rem;font-weight:700;color:#1e293b}.stat-value.pass{color:#059669}.stat-value.fail{color:#dc2626}.category-progress-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}.progress-fill.pass{background:linear-gradient(90deg,#10b981,#059669)}.progress-fill.fail{background:linear-gradient(90deg,#f59e0b,#d97706)}.daily-activity-section{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;position:relative;overflow:hidden}.daily-activity-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#8b5cf6,#ec4899)}.daily-activity-section h4{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem;display:flex;align-items:center;gap:.5rem}.daily-activity-section h4:before{content:"📅";font-size:1.5rem}.activity-chart{display:flex;align-items:flex-end;justify-content:space-between;gap:.5rem;height:150px;padding:1rem 0}.activity-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%;justify-content:flex-end;position:relative}.activity-bar{width:100%;max-width:40px;background:linear-gradient(180deg,#8b5cf6,#7c3aed);border-radius:6px 6px 0 0;min-height:8px;transition:all .3s ease;cursor:pointer;position:relative;box-shadow:0 -2px 8px #8b5cf64d}.activity-bar:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:linear-gradient(180deg,rgba(255,255,255,.3) 0%,transparent 50%);border-radius:6px 6px 0 0}.activity-bar:hover{background:linear-gradient(180deg,#a78bfa,#8b5cf6);box-shadow:0 -4px 16px #8b5cf680;transform:scaleY(1.08) scaleX(1.15)}.activity-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fff;border:2px solid #cbd5e1;border-radius:8px;padding:.5rem .75rem;box-shadow:0 4px 16px #00000026;white-space:nowrap;z-index:10;pointer-events:none;animation:fadeIn .2s ease;display:flex;flex-direction:column;gap:.25rem}.activity-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#cbd5e1}.activity-tooltip strong{font-size:.875rem;color:#1e293b;font-weight:700}.activity-tooltip span{font-size:.75rem;color:#64748b}.activity-label{font-size:.75rem;color:#475569;font-weight:600}.trends-loading,.trends-empty{display:flex;align-items:center;justify-content:center;min-height:300px;color:#64748b;font-size:1.125rem;font-weight:600}.trends-loading:before{content:"";width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-right:1rem}.trends-empty{flex-direction:column;gap:1rem}.trends-empty:before{content:"📊";font-size:4rem;opacity:.3}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.metrics-summary{grid-template-columns:repeat(2,1fr)}.category-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media(max-width:768px){.test-trends-container{padding:1rem}.trends-header{flex-direction:column;align-items:stretch}.trends-header h3{font-size:1.25rem}.time-range-selector{justify-content:stretch}.range-btn{flex:1;padding:.625rem .875rem;font-size:.8125rem}.metrics-summary{grid-template-columns:1fr}.metric-icon{font-size:2rem}.metric-value{font-size:1.75rem}.chart-section,.category-performance-section,.daily-activity-section{padding:1.25rem}.line-chart-container{height:250px}.category-grid{grid-template-columns:1fr}.activity-chart{height:120px;gap:.25rem}.activity-bar{max-width:30px}}@media(max-width:480px){.trends-header h3{font-size:1.125rem}.range-btn{padding:.5rem .625rem;font-size:.75rem}.metric-value{font-size:1.5rem}.metric-label{font-size:.75rem}.chart-section h4,.category-performance-section h4,.daily-activity-section h4{font-size:1rem}.line-chart-container{height:200px}.category-metrics{grid-template-columns:1fr;gap:.75rem}.activity-chart{height:100px}}.performance-insights-container{max-width:1400px;margin:0 auto;padding:2rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh}.performance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:#fff;padding:2rem;border-radius:20px;box-shadow:0 4px 20px #00000014;position:relative;overflow:hidden}.performance-header:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899)}.performance-header h1{font-size:2.25rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:-1px}.subtitle{color:#64748b;font-size:1rem;margin:.5rem 0 0}.export-button{background:linear-gradient(135deg,#3b82f6,#2563eb)!important;color:#fff!important;border:none;padding:.875rem 2rem;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #3b82f64d;position:relative;overflow:hidden}.performance-insights-container .export-button,.performance-header .export-button{color:#fff!important;background:linear-gradient(135deg,#3b82f6,#2563eb)!important}.export-button:before{content:"📊 ";margin-right:.5rem}.export-button:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.export-button:hover:after{width:300px;height:300px}.export-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #3b82f666;color:#fff!important}.export-button:active{transform:translateY(-1px) scale(.98);color:#fff!important}.view-selector{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#fff;padding:.75rem;border-radius:16px;box-shadow:0 4px 20px #00000014;position:relative;overflow:hidden}.view-selector:before{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899)}.view-tab{flex:1;padding:1rem 1.5rem;border:none;background:transparent;color:#64748b;font-weight:700;font-size:1rem;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;z-index:1}.view-tab.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 16px #3b82f64d;transform:scale(1.02)}.view-tab.active:before{content:"";position:absolute;inset:0;border-radius:12px;padding:2px;background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.5}.view-tab:hover:not(.active){background:#f1f5f9;color:#1e293b}.time-period-filters{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1.5rem;border:2px solid #e2e8f0;background:#fff;color:#64748b;border-radius:10px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:#3b82f6;color:#3b82f6}.filter-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff;box-shadow:0 4px 12px #3b82f64d}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2.5rem}.kpi-card{background:#fff;padding:2rem;border-radius:20px;box-shadow:0 4px 20px #0000000f;border:2px solid #e2e8f0;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#94a3b8,#64748b);opacity:0;transition:opacity .3s ease}.kpi-card:after{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(59,130,246,.03) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.kpi-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 16px 40px #0000001f;border-color:#cbd5e1}.kpi-card:hover:before{opacity:1}.kpi-card:hover:after{opacity:1}.kpi-card.excellent{border-color:#10b981;background:linear-gradient(135deg,#fff,#f0fdf4)}.kpi-card.excellent:before{background:linear-gradient(90deg,#10b981,#059669)}.kpi-card.good{border-color:#3b82f6;background:linear-gradient(135deg,#fff,#eff6ff)}.kpi-card.good:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.kpi-card.average{border-color:#f59e0b;background:linear-gradient(135deg,#fff,#fffbeb)}.kpi-card.average:before{background:linear-gradient(90deg,#f59e0b,#d97706)}.kpi-card.below{border-color:#ef4444;background:linear-gradient(135deg,#fff,#fef2f2)}.kpi-card.below:before{background:linear-gradient(90deg,#ef4444,#dc2626)}.kpi-card.neutral{border-color:#e2e8f0}.kpi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.kpi-icon{font-size:3rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15));transition:transform .3s ease;display:inline-block}.kpi-card:hover .kpi-icon{transform:scale(1.15) rotate(5deg)}.kpi-trend{font-size:1.5rem;font-weight:700}.kpi-card.excellent .kpi-trend{color:#10b981}.kpi-card.good .kpi-trend{color:#3b82f6}.kpi-card.average .kpi-trend{color:#f59e0b}.kpi-card.below .kpi-trend{color:#ef4444}.kpi-value{font-size:3.5rem;font-weight:900;background:linear-gradient(135deg,#0f172a,#1e293b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem;letter-spacing:-2px;font-feature-settings:"tnum";transition:transform .3s ease}.kpi-card:hover .kpi-value{transform:scale(1.05)}.kpi-card:nth-child(6) .kpi-value{color:#036;background:none;-webkit-text-fill-color:#003366}.kpi-label{color:#64748b;font-size:.95rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.kpi-comparison{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0;font-size:.875rem;color:#64748b;font-weight:500}.kpi-description{font-size:.875rem;color:#94a3b8;font-style:italic}.performance-chart-section{background:#fff;padding:2.5rem;border-radius:24px;box-shadow:0 6px 30px #00000014;margin-bottom:2.5rem;position:relative;overflow:hidden}.performance-chart-section:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899)}.performance-chart-section h2{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 2rem;letter-spacing:-.5px}.chart-container{height:300px;padding:1rem 0}.bar-chart{height:100%;display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;padding:0 1rem}.bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%;justify-content:flex-end}.bar{width:100%;max-width:60px;background:linear-gradient(180deg,#3b82f6,#2563eb);border-radius:12px 12px 0 0;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 16px #3b82f64d;min-height:20px;position:relative;cursor:pointer}.bar:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:linear-gradient(180deg,rgba(255,255,255,.3) 0%,transparent 50%);border-radius:12px 12px 0 0}.bar.success{background:linear-gradient(180deg,#10b981,#059669);box-shadow:0 -4px 16px #10b9814d}.bar.success:hover{box-shadow:0 -6px 24px #10b98180}.bar.warning{background:linear-gradient(180deg,#f59e0b,#d97706);box-shadow:0 -4px 16px #f59e0b4d}.bar.warning:hover{box-shadow:0 -6px 24px #f59e0b80}.bar:hover{transform:scaleY(1.08) scaleX(1.1);box-shadow:0 -6px 24px #3b82f680;filter:brightness(1.1)}.bar-label{font-size:.875rem;font-weight:600;color:#1e293b}.bar-date{font-size:.75rem;color:#64748b;text-align:center;white-space:nowrap}.detailed-metrics{background:#fff;padding:2.5rem;border-radius:24px;box-shadow:0 6px 30px #00000014;position:relative;overflow:hidden}.detailed-metrics:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899)}.detailed-metrics h2{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 2rem;letter-spacing:-.5px}.metrics-list{display:flex;flex-direction:column;gap:1rem}.metric-item{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s ease}.metric-item:hover{border-color:#3b82f6;background:#fff}.metric-item.expanded{border-color:#3b82f6;background:#fff;box-shadow:0 4px 16px #3b82f626}.metric-summary{display:flex;justify-content:space-between;align-items:center}.metric-date{font-weight:600;color:#1e293b;font-size:1rem}.metric-quick-stats{display:flex;gap:1rem}.quick-stat{padding:.375rem .875rem;background:#e2e8f0;color:#64748b;border-radius:8px;font-size:.875rem;font-weight:600}.quick-stat.success{background:#d1fae5;color:#059669}.quick-stat.warning{background:#fef3c7;color:#d97706}.metric-details{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e2e8f0}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.8125rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:1.25rem;font-weight:700;color:#1e293b}.goals-section{background:#fff;padding:2.5rem;border-radius:24px;box-shadow:0 6px 30px #00000014;position:relative;overflow:hidden}.goals-section:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6)}.goals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.goals-header h2{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:-.5px}.add-goal-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.875rem 2rem;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #10b9814d;position:relative;overflow:hidden}.add-goal-button:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.add-goal-button:hover:after{width:300px;height:300px}.add-goal-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #10b98166}.add-goal-button:active{transform:translateY(-1px) scale(.98)}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.goal-card{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.goal-card:hover{box-shadow:0 12px 40px #0000001f;transform:translateY(-6px) scale(1.02);border-color:#cbd5e1}.goal-card.active{border-color:#3b82f6;background:linear-gradient(135deg,#fff,#eff6ff)}.goal-card.completed{border-color:#10b981;background:linear-gradient(135deg,#fff,#f0fdf4)}.goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.goal-type{font-size:1rem;font-weight:700;color:#1e293b;text-transform:capitalize}.goal-status-badge{padding:.375rem .875rem;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.goal-status-badge.active{background:#dbeafe;color:#2563eb}.goal-status-badge.completed{background:#d1fae5;color:#059669}.goal-progress{margin-bottom:1rem}.progress-text{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.75rem}.progress-text .current{font-size:2rem;font-weight:800;color:#1e293b}.progress-text .separator{font-size:1.5rem;color:#94a3b8}.progress-text .target{font-size:1.5rem;font-weight:600;color:#64748b}.progress-bar{height:12px;background:#e2e8f0;border-radius:6px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:6px;transition:width .5s ease}.goal-card.completed .progress-fill{background:linear-gradient(90deg,#10b981,#059669)}.progress-percentage{font-size:.875rem;font-weight:600;color:#64748b;text-align:right}.goal-footer{padding-top:1rem;border-top:1px solid #e2e8f0}.goal-deadline{font-size:.875rem;color:#64748b;font-weight:500}.empty-state{text-align:center;padding:3rem 2rem;color:#64748b}.empty-state p{font-size:1.125rem;margin:0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.goal-modal{padding:2rem}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#1e293b}.close-button{background:none;border:none;font-size:2rem;color:#64748b;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.close-button:hover{background:#f1f5f9;color:#1e293b}.goal-form{display:flex;flex-direction:column;gap:1.25rem}.form-group label{font-weight:600;color:#1e293b;font-size:.95rem}.form-group select,.form-group input{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:all .2s ease}.form-group select:focus,.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;gap:1rem;margin-top:1rem}.cancel-button,.create-button{flex:1;padding:.875rem 1.5rem;border:none;border-radius:10px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease}.cancel-button{background:#f1f5f9;color:#64748b}.cancel-button:hover{background:#e2e8f0;color:#1e293b}.create-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.create-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.loading:before{content:"";width:60px;height:60px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.loading:after{content:"Loading performance data...";font-size:1.125rem;font-weight:600;color:#64748b}.kpi-card{animation:fadeInUp .6s ease-out backwards}.kpi-card:nth-child(1){animation-delay:.1s}.kpi-card:nth-child(2){animation-delay:.2s}.kpi-card:nth-child(3){animation-delay:.3s}.kpi-card:nth-child(4){animation-delay:.4s}.kpi-card:nth-child(5){animation-delay:.5s}.kpi-card:nth-child(6){animation-delay:.6s}.performance-chart-section{animation:fadeInUp .6s ease-out .3s backwards}.bar-wrapper{animation:fadeInUp .4s ease-out backwards}.bar-wrapper:nth-child(1){animation-delay:.5s}.bar-wrapper:nth-child(2){animation-delay:.55s}.bar-wrapper:nth-child(3){animation-delay:.6s}.bar-wrapper:nth-child(4){animation-delay:.65s}.bar-wrapper:nth-child(5){animation-delay:.7s}.bar-wrapper:nth-child(6){animation-delay:.75s}.bar-wrapper:nth-child(7){animation-delay:.8s}.bar-wrapper:nth-child(8){animation-delay:.85s}.bar-wrapper:nth-child(9){animation-delay:.9s}.bar-wrapper:nth-child(10){animation-delay:.95s}@media(max-width:768px){.performance-insights-container{padding:1rem}.performance-header{flex-direction:column;align-items:flex-start;gap:1rem}.performance-header h1{font-size:1.5rem}.view-selector{flex-direction:column}.time-period-filters{gap:.5rem}.filter-btn{flex:1;min-width:calc(50% - .25rem);padding:.65rem 1rem;font-size:.85rem}.kpi-grid{grid-template-columns:1fr;gap:1rem}.kpi-value{font-size:2.5rem}.bar-chart{gap:.5rem;padding:0 .5rem}.bar{max-width:40px}.bar-date{font-size:.65rem}.metric-summary{flex-direction:column;align-items:flex-start;gap:.75rem}.metric-quick-stats{width:100%;justify-content:space-between}.detail-grid{grid-template-columns:repeat(2,1fr)}.goals-grid{grid-template-columns:1fr}.goals-header{flex-direction:column;align-items:flex-start;gap:1rem}.add-goal-button{width:100%}.modal-content{margin:1rem}.modal-actions{flex-direction:column}}.trends-section{animation:fadeInUp .6s ease-out .3s backwards}@media(max-width:480px){.performance-header h1{font-size:1.375rem}.subtitle{font-size:.875rem}.kpi-icon,.kpi-value{font-size:2rem}.kpi-label{font-size:.8125rem}.view-tab{padding:.75rem 1rem;font-size:.875rem}.performance-chart-section,.detailed-metrics,.goals-section,.trends-section{padding:1.25rem}.chart-container{height:250px}}.technician-scheduling{padding:2rem;max-width:1400px;margin:0 auto;animation:fadeInUp .4s ease-out}.scheduling-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.scheduling-header h2{font-size:1.75rem;font-weight:800;color:#1e293b;margin:0;display:flex;align-items:center;gap:.75rem}.scheduling-header h2:before{content:"📅";font-size:2rem}.btn-add-schedule{padding:.875rem 1.75rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #10b9814d}.btn-add-schedule:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166;background:linear-gradient(135deg,#059669,#047857)}.btn-add-schedule:active{transform:translateY(0)}.calendar-view{background:#fff;border-radius:20px;padding:2rem;margin-bottom:2.5rem;box-shadow:0 4px 24px #00000014;border:2px solid #e2e8f0;position:relative;overflow:hidden}.calendar-view:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #f1f5f9}.calendar-header h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.calendar-nav{padding:.625rem 1.25rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;font-weight:600;font-size:.9375rem;color:#475569;cursor:pointer;transition:all .2s}.calendar-nav:hover{background:#3b82f6;border-color:#3b82f6;color:#fff;transform:translate(0)}.calendar-grid{display:flex;flex-direction:column;gap:.75rem}.calendar-day-names{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:.5rem}.day-name{text-align:center;font-weight:700;font-size:.8125rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px;padding:.5rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.calendar-day{aspect-ratio:1;min-height:100px;padding:.75rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:.5rem;transition:all .2s;position:relative;overflow:hidden}.calendar-day.empty{background:transparent;border-color:transparent}.calendar-day.today{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.calendar-day.has-schedule{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#10b981}.calendar-day:hover:not(.empty){transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.day-number{font-weight:700;font-size:1rem;color:#1e293b;align-self:flex-start}.schedule-indicator{padding:.375rem .625rem;border-radius:6px;font-size:.75rem;font-weight:700;text-align:center;cursor:pointer;transition:all .2s;background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 4px #10b9814d}.schedule-indicator:hover{transform:scale(1.05);box-shadow:0 4px 8px #10b98166}.schedule-indicator.recertification{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d}.schedules-list{margin-top:2rem}.schedules-list h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem;display:flex;align-items:center;gap:.5rem}.schedules-list h3:before{content:"📋";font-size:1.75rem}.no-schedules{text-align:center;padding:3rem 2rem;color:#64748b;font-size:1.125rem;background:#f8fafc;border-radius:16px;border:2px dashed #cbd5e1}.schedules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.schedule-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.schedule-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#3b82f6)}.schedule-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#cbd5e1}.schedule-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.schedule-category{display:flex;flex-direction:column;gap:.25rem}.category-code{font-size:1.25rem;font-weight:800;color:#1e293b;letter-spacing:-.5px}.category-name{font-size:.8125rem;color:#64748b;font-weight:500}.schedule-type{padding:.375rem .875rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.schedule-type.certification{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.schedule-type.recertification{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.schedule-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem}.detail-row{display:flex;align-items:center;gap:.75rem;font-size:.9375rem}.detail-icon{font-size:1.125rem;width:24px;text-align:center}.detail-text{color:#475569;flex:1}.schedule-actions{display:flex;gap:.75rem}.btn-edit,.btn-delete{flex:1;padding:.625rem 1rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:none}.btn-edit{background:#eff6ff;color:#2563eb;border:2px solid #bfdbfe}.btn-edit:hover{background:#2563eb;color:#fff;border-color:#2563eb}.btn-delete{background:#fef2f2;color:#dc2626;border:2px solid #fecaca}.btn-delete:hover{background:#dc2626;color:#fff;border-color:#dc2626}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2rem 1.5rem;border-bottom:2px solid #f1f5f9}.modal-header h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.modal-close{width:40px;height:40px;border-radius:10px;border:2px solid #e2e8f0;background:#f8fafc;font-size:1.5rem;color:#64748b;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#dc2626;border-color:#dc2626;color:#fff;transform:rotate(90deg)}.schedule-form{padding:2rem}.form-group label{display:block;font-weight:600;font-size:.9375rem;color:#1e293b;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;color:#1e293b;transition:all .2s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:2px solid #f1f5f9}.btn-cancel,.btn-save{padding:.875rem 2rem;border-radius:10px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none}.btn-cancel{background:#f1f5f9;color:#475569}.btn-save{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.btn-save:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.scheduling-loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.125rem;color:#64748b;font-weight:600}.scheduling-loading:before{content:"";width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-right:1rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.schedules-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.calendar-day{min-height:80px}}@media(max-width:768px){.technician-scheduling{padding:1rem}.scheduling-header{flex-direction:column;align-items:stretch}.calendar-view{padding:1.5rem}.calendar-days{gap:.25rem}.calendar-day{min-height:60px;padding:.5rem}.day-number{font-size:.875rem}.schedule-indicator{font-size:.625rem;padding:.25rem .375rem}.schedules-grid{grid-template-columns:1fr}.modal-content{max-width:100%;border-radius:20px 20px 0 0;max-height:95vh}}@media(max-width:480px){.calendar-header h3{font-size:1.25rem}.calendar-nav{padding:.5rem 1rem;font-size:.875rem}.day-name{font-size:.75rem}.schedule-form{padding:1.5rem}.form-actions{flex-direction:column}.btn-cancel,.btn-save{width:100%}}.a1-focus-areas{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e0e7ff);padding:2rem;animation:fadeIn .3s ease-out;width:100%;box-sizing:border-box;overflow-x:hidden}.focus-areas-header{max-width:1600px;margin:0 auto 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.header-content h1{font-size:2.25rem;font-weight:800;color:#1e293b;margin:0 0 .5rem;display:flex;align-items:center;gap:.75rem}.header-content h1:before{content:"🎯";font-size:2.5rem}.btn-close-focus{padding:.875rem 1.75rem;background:#fff;color:#475569;border:2px solid #e2e8f0;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000000d}.btn-close-focus:hover{background:#3b82f6;border-color:#3b82f6;color:#fff;transform:translate(-2px)}.performance-summary-card{max-width:1600px;margin:0 auto 2.5rem;background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 8px 32px #0000001a;border:3px solid #e2e8f0;position:relative;overflow:visible;width:100%;box-sizing:border-box}.performance-summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6)}.summary-header{display:flex;align-items:center;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.readiness-badge{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 2rem;background:#f8fafc;border-radius:20px;border:3px solid #e2e8f0;transition:all .3s}.readiness-badge:hover{transform:scale(1.02);box-shadow:0 8px 24px #0000001a}.readiness-icon{font-size:3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.readiness-score{font-size:2.5rem;font-weight:900;line-height:1;letter-spacing:-1px}.readiness-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.readiness-message{flex:1;font-size:1.25rem;font-weight:700;line-height:1.4}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,180px),1fr));gap:1.5rem;width:100%}.stat-box{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#fff);border-radius:16px;border:2px solid #e2e8f0;transition:all .3s}.stat-box:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014;border-color:#cbd5e1}.stat-value{font-size:2.5rem;font-weight:900;color:#1e3a8a;line-height:1;margin-bottom:.5rem}.stat-label{font-size:.875rem;font-weight:600;color:#475569;text-align:center;text-transform:uppercase;letter-spacing:.5px}.recommendations-section{max-width:1600px;margin:0 auto 2.5rem}.recommendations-section h2{font-size:1.75rem;font-weight:800;color:#1e293b;margin:0 0 .5rem}.section-subtitle{font-size:1rem;color:#64748b;margin:0 0 1.5rem;font-weight:500}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.recommendation-card{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #00000014;border:3px solid #e2e8f0;transition:all .3s;position:relative;overflow:hidden}.recommendation-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#ef4444,#f59e0b)}.recommendation-card[data-priority="1"]:before{background:linear-gradient(90deg,#dc2626,#ef4444)}.recommendation-card[data-priority="2"]:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.recommendation-card[data-priority="3"]:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.recommendation-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #0000001f;border-color:#cbd5e1}.rec-priority{padding:.375rem .875rem;background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border-radius:20px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.rec-code{padding:.375rem .875rem;background:#f1f5f9;color:#475569;border-radius:8px;font-size:.875rem;font-weight:800}.rec-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1rem;line-height:1.3}.rec-stats{display:flex;gap:1.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.rec-stat-label{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.rec-stat-value{font-size:1.5rem;font-weight:800;color:#1e293b}.rec-reason{font-size:.9375rem;color:#64748b;line-height:1.6;margin:0;font-weight:500}.focus-areas-section{max-width:1600px;margin:0 auto 2.5rem;width:100%;box-sizing:border-box}.focus-areas-section h2{font-size:1.75rem;font-weight:800;color:#1e293b;margin:0 0 .5rem}.focus-areas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,380px),1fr));gap:1.5rem;width:100%}.focus-area-card{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #00000014;border:3px solid #e2e8f0;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden}.focus-area-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#64748b,#94a3b8);transition:all .3s}.focus-area-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #0000001f;border-color:#cbd5e1}.focus-area-card:hover:before{height:6px;background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.focus-area-card.selected{border-color:#3b82f6;box-shadow:0 12px 32px #3b82f633}.focus-area-card.selected:before{height:6px;background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.area-code-badge{padding:.625rem 1.125rem;border-radius:12px;font-size:1rem;font-weight:800;color:#fff;letter-spacing:.5px;box-shadow:0 4px 12px #00000026}.area-weight{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.weight-value{font-size:1.25rem;font-weight:800;color:#1e293b}.weight-label{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.area-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 .75rem;line-height:1.3}.area-description{font-size:.9375rem;color:#64748b;line-height:1.6;margin:0 0 1.5rem}.performance-bar{flex:1;height:16px;background:#f1f5f9;border-radius:8px;overflow:hidden;box-shadow:inset 0 2px 4px #0000000f}.performance-fill{height:100%;border-radius:8px;transition:width .8s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #00000026;position:relative;overflow:hidden}.performance-fill:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}.performance-percentage{font-size:1.125rem;font-weight:800;min-width:60px;text-align:right}.area-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #f1f5f9}.area-stat{display:flex;align-items:center;gap:.75rem}.stat-icon{font-size:1.5rem}.stat-number{font-size:1.25rem;font-weight:800;color:#1e293b;line-height:1}.stat-text{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.performance-level-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:12px;font-weight:700;font-size:.9375rem;transition:all .3s}.level-icon{font-size:1.25rem}.level-text{letter-spacing:.5px}.area-expanded-content{animation:expandDown .3s ease-out}.expanded-divider{height:2px;background:linear-gradient(90deg,transparent 0%,#cbd5e1 50%,transparent 100%);margin:1.5rem 0}.expanded-insights{padding:1rem;background:#f8fafc;border-radius:12px;border:2px solid #e2e8f0}.expanded-insights h4{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.insight-text{font-size:.9375rem;color:#475569;line-height:1.6;margin:0 0 .75rem}.last-practiced{font-size:.8125rem;color:#94a3b8;font-style:italic;margin:0}.performance-guide-section{max-width:1600px;margin:0 auto;background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 4px 20px #00000014;border:3px solid #e2e8f0}.performance-guide-section h2{font-size:1.75rem;font-weight:800;color:#1e293b;margin:0 0 2rem}.guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.guide-item{display:flex;gap:1.25rem;padding:1.5rem;background:#f8fafc;border-radius:16px;border:2px solid #e2e8f0;transition:all .3s}.guide-item:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.guide-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.guide-content h4{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.guide-content p{font-size:.9375rem;color:#64748b;line-height:1.5;margin:0}.focus-areas-loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.125rem;color:#64748b;font-weight:600}.focus-areas-loading:before{content:"";width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-right:1rem}@keyframes expandDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media(max-width:1024px){.focus-areas-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,340px),1fr))}.area-stats{grid-template-columns:repeat(3,1fr);gap:.75rem}}@media(max-width:768px){.a1-focus-areas{padding:1rem}.focus-areas-header{flex-direction:column;align-items:stretch}.header-content h1{font-size:1.75rem}.performance-summary-card{padding:1.5rem}.summary-header{flex-direction:column;align-items:stretch}.readiness-message{font-size:1.125rem}.summary-stats{grid-template-columns:repeat(auto-fit,minmax(min(100%,140px),1fr))}.focus-areas-grid,.recommendations-grid{grid-template-columns:1fr}.area-stats{grid-template-columns:repeat(3,1fr)}.guide-grid{grid-template-columns:1fr}}@media(max-width:480px){.header-content h1{font-size:1.5rem}.readiness-badge{padding:1.25rem 1.5rem}.readiness-score,.stat-value{font-size:2rem}.area-stats,.summary-stats{grid-template-columns:1fr}}.a2-focus-areas{padding:2rem;max-width:1400px;margin:0 auto;background:linear-gradient(to bottom,#f8fafc,#fff);min-height:100vh}.focus-areas-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.header-content h1{font-size:1.875rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.header-subtitle{font-size:1rem;color:#64748b;margin:0}.btn-close-focus{padding:.75rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-close-focus:hover{background:#f8fafc;border-color:#cbd5e1;transform:translate(-2px)}.performance-summary-card{background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px -1px #0000001a}.summary-header{display:flex;align-items:center;gap:2rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #f1f5f9}.readiness-badge{display:flex;align-items:center;gap:1rem;padding:1.5rem;border:3px solid;border-radius:12px;background:#fff}.readiness-icon{font-size:2.5rem}.readiness-content{display:flex;flex-direction:column;gap:.25rem}.readiness-score{font-size:2rem;font-weight:700;line-height:1}.readiness-label{font-size:.875rem;color:#64748b;font-weight:500}.readiness-message{flex:1;font-size:1.125rem;font-weight:600;line-height:1.5}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-box{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#f8fafc;border-radius:8px}.stat-value{font-size:1.875rem;font-weight:700;color:#1e3a8a}.summary-stats .stat-box .stat-value.stat-value--questions{color:#1e3a8a}.stat-label{font-size:.875rem;color:#475569;font-weight:600}.ase-weight-distribution{margin-top:2rem;padding-top:2rem;border-top:2px solid #f1f5f9}.ase-weight-distribution h3{font-size:1.25rem;font-weight:600;color:#0f172a;margin:0 0 1rem}.weight-bars{display:flex;flex-direction:column;gap:1rem}.weight-bar-item{display:flex;flex-direction:column;gap:.5rem}.weight-bar-header{display:flex;justify-content:space-between;align-items:center}.weight-label{font-size:.875rem;font-weight:600;color:#475569}.weight-percentage{font-size:.875rem;font-weight:700;color:#3b82f6}.weight-bar-container{position:relative;height:32px;background:#f1f5f9;border-radius:8px;overflow:hidden}.weight-bar-fill{position:absolute;height:100%;background:#3b82f6;border-radius:8px;transition:width .3s ease}.weight-bar-overlay{position:absolute;height:100%;border-radius:8px;transition:all .3s ease}.weight-note{margin-top:1rem;font-size:.875rem;color:#64748b;font-style:italic}.recommendations-section{margin-bottom:2rem}.recommendations-section h2{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.section-subtitle{font-size:.875rem;color:#64748b;margin:0 0 1.5rem}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.recommendation-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;border-left:4px solid;transition:all .2s}.recommendation-card[data-priority="1"]{border-left-color:#ef4444;background:linear-gradient(to right,#fef2f2,#fff 20%)}.recommendation-card[data-priority="2"]{border-left-color:#f59e0b;background:linear-gradient(to right,#fffbeb,#fff 20%)}.recommendation-card[data-priority="3"]{border-left-color:#3b82f6;background:linear-gradient(to right,#eff6ff,#fff 20%)}.recommendation-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.rec-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.rec-priority{font-size:.75rem;font-weight:700;text-transform:uppercase;color:#64748b;letter-spacing:.05em}.rec-code{font-size:.875rem;font-weight:600;color:#3b82f6;padding:.25rem .75rem;background:#eff6ff;border-radius:4px}.rec-title{font-size:1.125rem;font-weight:600;color:#0f172a;margin:0 0 1rem}.rec-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.rec-stat{display:flex;flex-direction:column;gap:.25rem}.rec-stat-label{font-size:.75rem;color:#64748b;font-weight:500}.rec-stat-value{font-size:1.25rem;font-weight:700;color:#0f172a}.rec-stat-value.impact-score{color:#ef4444}.rec-reason{font-size:.875rem;color:#475569;line-height:1.5;margin:0}.focus-areas-section{margin-bottom:2rem}.focus-areas-section h2{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.focus-areas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem;margin-top:1.5rem}.focus-area-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:all .2s;border:2px solid transparent}.focus-area-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#e2e8f0}.focus-area-card.selected{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633}.area-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.area-code-badge{font-size:.875rem;font-weight:700;color:#fff;padding:.5rem .75rem;border-radius:6px}.area-weight{text-align:right}.weight-value{display:block;font-size:1.5rem;font-weight:700;color:#3b82f6;line-height:1}.weight-label{display:block;font-size:.75rem;color:#64748b;font-weight:500}.area-title{font-size:1.125rem;font-weight:600;color:#0f172a;margin:0 0 .75rem}.area-description{font-size:.875rem;color:#64748b;line-height:1.5;margin:0 0 1.5rem}.performance-bar-container{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.performance-bar{flex:1;height:12px;background:#f1f5f9;border-radius:6px;overflow:hidden}.performance-fill{height:100%;border-radius:6px;transition:width .3s ease}.performance-percentage{font-size:1rem;font-weight:700;min-width:60px;text-align:right}.area-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem}.area-stat{display:flex;align-items:center;gap:.5rem}.stat-icon{font-size:1.25rem}.stat-content{display:flex;flex-direction:column;gap:.125rem}.stat-number{font-size:1.125rem;font-weight:700;color:#0f172a;line-height:1}.stat-text{font-size:.75rem;color:#64748b;line-height:1}.performance-level-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:.875rem}.level-icon{font-size:1.125rem}.area-expanded-content{margin-top:1.5rem}.expanded-divider{height:2px;background:linear-gradient(to right,#e2e8f0 0%,transparent 100%);margin-bottom:1.5rem}.expanded-insights h4{font-size:1rem;font-weight:600;color:#0f172a;margin:0 0 .75rem}.insight-text{font-size:.875rem;color:#475569;line-height:1.6;margin:0 0 .75rem}.last-practiced{font-size:.75rem;color:#94a3b8;font-style:italic;margin:0}.drill-down-section{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #f1f5f9}.drill-down-section h4{font-size:1rem;font-weight:600;color:#0f172a;margin:0 0 1rem}.loading-drill{font-size:.875rem;color:#64748b;font-style:italic}.drill-down-list{display:flex;flex-direction:column;gap:.75rem}.drill-down-item{padding:.75rem;background:#f8fafc;border-radius:6px;border-left:3px solid #cbd5e1}.drill-down-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.drill-down-topic{font-size:.875rem;font-weight:600;color:#0f172a;flex:1}.drill-down-accuracy{font-size:.875rem;font-weight:700}.drill-down-stats{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#64748b}.performance-guide-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.performance-guide-section h2{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.guide-item{display:flex;gap:1rem;align-items:flex-start}.guide-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.guide-content h4{font-size:1rem;font-weight:600;color:#0f172a;margin:0 0 .5rem}.guide-content p{font-size:.875rem;color:#64748b;line-height:1.5;margin:0}.exam-strategy-section{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:12px;padding:2rem;color:#fff;box-shadow:0 4px 6px #0000001a}.exam-strategy-section h2{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 1rem}.strategy-intro{font-size:1rem;line-height:1.6;margin:0 0 1.5rem;opacity:.95}.strategy-list{display:flex;flex-direction:column;gap:1rem}.strategy-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff1a;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.strategy-weight{font-size:1.5rem;font-weight:700;color:#fff;min-width:60px;text-align:center}.strategy-desc{font-size:.875rem;line-height:1.5;opacity:.95}@media(max-width:768px){.a2-focus-areas{padding:1rem}.focus-areas-header,.summary-header{flex-direction:column;gap:1rem}.summary-stats{grid-template-columns:repeat(2,1fr)}.focus-areas-grid{grid-template-columns:1fr}.area-stats,.rec-stats{grid-template-columns:repeat(2,1fr)}}.a3-focus-areas{padding:2rem;max-width:1400px;margin:0 auto;background:linear-gradient(to bottom,#f8fafc,#fff);min-height:100vh}.focus-areas-loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.125rem;color:#64748b}.empty-state{max-width:800px;margin:4rem auto;background:#fff;border-radius:20px;padding:4rem 3rem;text-align:center;box-shadow:0 10px 30px #00000014}.empty-state-icon{font-size:5rem;margin-bottom:1.5rem;opacity:.8}.empty-state h2{font-size:2rem;font-weight:700;color:#1e293b;margin:0 0 1rem}.empty-state p{font-size:1.125rem;color:#64748b;margin:0 0 1rem;line-height:1.6}.empty-state-hint{font-weight:600;color:#475569;margin-top:2rem}.empty-state-features{list-style:none;padding:0;margin:1rem 0 0;text-align:left;max-width:500px;margin:1.5rem auto 0}.empty-state-features li{padding:.75rem 0;font-size:1rem;color:#475569;border-bottom:1px solid #e2e8f0}.empty-state-features li:last-child{border-bottom:none}.a3-focus-areas .focus-areas-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.a3-focus-areas .header-content h1{font-size:1.875rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.a3-focus-areas .header-subtitle{font-size:1rem;color:#64748b;margin:0}.a3-focus-areas .btn-close-focus{padding:.75rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s;white-space:nowrap}.a3-focus-areas .btn-close-focus:hover{background:#f8fafc;border-color:#cbd5e1;transform:translate(-2px)}@media(max-width:768px){.a3-focus-areas{padding:1rem}.a3-focus-areas .focus-areas-header{flex-direction:column;gap:1rem}.a3-focus-areas .summary-stats{grid-template-columns:repeat(2,1fr)}.a3-focus-areas .focus-areas-grid{grid-template-columns:1fr}.a3-focus-areas .area-stats{grid-template-columns:repeat(2,1fr)}}.focus-areas-page{min-height:100vh;background:linear-gradient(to bottom,#f8fafc,#fff)}.focus-areas-page-header{display:flex;justify-content:space-between;align-items:flex-start;padding:2rem 2rem 1.5rem;gap:2rem;background:#fff;border-bottom:2px solid #e2e8f0;box-shadow:0 2px 4px #0000000d}.focus-areas-page-header .header-content h1{font-size:1.875rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.focus-areas-page-header .header-subtitle{font-size:1rem;color:#64748b;margin:0}.btn-close-focus-page{padding:.75rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-close-focus-page:hover{background:#f8fafc;border-color:#cbd5e1;transform:translate(-2px)}.focus-areas-dropdown-container{padding:1.5rem 2rem;background:#fff;border-bottom:2px solid #e2e8f0}.dropdown-wrapper{position:relative;max-width:600px;margin:0 auto}.dropdown-trigger{display:flex;align-items:center;gap:1rem;width:100%;padding:1.125rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border:2px solid #2563eb;border-radius:12px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #3b82f640;position:relative;overflow:hidden}.dropdown-trigger:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff1a,#fff0);opacity:0;transition:opacity .25s ease}.dropdown-trigger:hover:before{opacity:1}.dropdown-trigger:hover{transform:translateY(-2px);box-shadow:0 8px 20px #3b82f659;border-color:#1d4ed8}.dropdown-trigger:active{transform:translateY(0);box-shadow:0 2px 8px #3b82f64d}.dropdown-trigger:focus-visible{outline:3px solid rgba(59,130,246,.5);outline-offset:2px}.trigger-icon{font-size:2.25rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transition:transform .25s cubic-bezier(.4,0,.2,1);flex-shrink:0}.dropdown-trigger:hover .trigger-icon{transform:scale(1.1)}.trigger-content{display:flex;flex-direction:column;gap:.25rem;text-align:left;flex:1;min-width:0}.trigger-title{font-size:1.125rem;font-weight:700;color:#fff;line-height:1.3;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trigger-subtitle{font-size:.875rem;color:#ffffffe6;font-weight:500;letter-spacing:.01em}.dropdown-arrow{color:#fff;transition:transform .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 12px 32px #0000001f,0 2px 8px #00000014;z-index:100;max-height:480px;overflow-y:auto;animation:dropdownSlideIn .25s cubic-bezier(.4,0,.2,1)}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu::-webkit-scrollbar{width:8px}.dropdown-menu::-webkit-scrollbar-track{background:#f1f5f9;border-radius:0 12px 12px 0}.dropdown-menu::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.dropdown-menu::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dropdown-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border-bottom:1px solid #f1f5f9;position:relative}.dropdown-item:last-child{border-bottom:none}.dropdown-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,#3b82f6 0%,transparent 100%);transition:width .25s ease}.dropdown-item:hover:before{width:4px}.dropdown-item:hover{background:linear-gradient(90deg,#3b82f60f,#3b82f605)}.dropdown-item:active{background:#3b82f61a}.dropdown-item:focus-visible{outline:2px solid rgba(59,130,246,.5);outline-offset:-2px;background:#3b82f60d}.dropdown-item.selected{background:linear-gradient(90deg,#3b82f61a,#3b82f60d);border-left:3px solid #3b82f6;padding-left:calc(1.5rem - 3px)}.dropdown-item.selected:before{width:3px}.item-icon{font-size:2rem;line-height:1;transition:transform .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.dropdown-item:hover .item-icon{transform:scale(1.08)}.dropdown-item.selected .item-icon{transform:scale(1.05);filter:drop-shadow(0 1px 3px rgba(59,130,246,.3))}.item-content{display:flex;flex-direction:column;gap:.25rem;text-align:left;flex:1;min-width:0}.item-title{font-size:1rem;font-weight:600;color:#0f172a;line-height:1.3;transition:color .2s ease;letter-spacing:-.01em}.dropdown-item:hover .item-title{color:#1e40af}.dropdown-item.selected .item-title{color:#1e40af;font-weight:700}.item-subtitle{font-size:.8125rem;color:#64748b;font-weight:500;transition:color .2s ease;letter-spacing:.01em}.dropdown-item:hover .item-subtitle{color:#475569}.dropdown-item.selected .item-subtitle{color:#3b82f6;font-weight:600}.check-icon{color:#3b82f6;flex-shrink:0;animation:checkMarkIn .3s cubic-bezier(.4,0,.2,1)}@keyframes checkMarkIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.focus-areas-content{padding:0}.focus-areas-content .a1-focus-areas,.focus-areas-content .a2-focus-areas{padding:2rem;background:transparent;min-height:auto}.focus-areas-content .focus-areas-header{display:none}@media(max-width:768px){.focus-areas-page-header{flex-direction:column;gap:1rem;padding:1.5rem 1rem}.focus-areas-dropdown-container{padding:1rem}.dropdown-wrapper{max-width:100%}.dropdown-trigger{padding:1rem 1.25rem}.trigger-icon{font-size:2rem}.trigger-title{font-size:1rem}.trigger-subtitle{font-size:.8125rem}.dropdown-item{padding:.875rem 1.25rem}.item-icon{font-size:1.75rem}.item-title{font-size:.9375rem}.item-subtitle{font-size:.75rem}.focus-areas-content .a1-focus-areas,.focus-areas-content .a2-focus-areas{padding:1rem}}@media(max-width:1024px)and (min-width:769px){.dropdown-wrapper{max-width:500px}}:root{--color-primary: #3B82F6;--color-primary-dark: #2563EB;--color-primary-light: #60A5FA;--color-primary-subtle: #EFF6FF;--color-success: #10B981;--color-success-dark: #059669;--color-success-light: #34D399;--color-success-subtle: #ECFDF5;--color-warning: #F59E0B;--color-warning-dark: #D97706;--color-warning-subtle: #FEF3C7;--color-error: #EF4444;--color-error-dark: #DC2626;--color-error-subtle: #FEE2E2;--color-info: #8B5CF6;--color-info-dark: #7C3AED;--color-info-light: #A78BFA;--color-info-subtle: #F5F3FF;--color-neutral-900: #111827;--color-neutral-800: #1F2937;--color-neutral-700: #374151;--color-neutral-600: #4B5563;--color-neutral-500: #6B7280;--color-neutral-400: #9CA3AF;--color-neutral-300: #D1D5DB;--color-neutral-200: #E5E7EB;--color-neutral-100: #F3F4F6;--color-neutral-50: #F9FAFB;--color-white: #FFFFFF;--bg-primary: #FFFFFF;--bg-secondary: #F9FAFB;--bg-tertiary: #F3F4F6;--bg-accent: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-xxl: 3rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-xxl: 2rem;--touch-target-min: 44px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12);--shadow-md: 0 4px 8px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .18);--transition-fast: .15s ease;--transition-base: .25s ease}.dashboard-redesign{min-height:100vh;background:#fff;padding-bottom:var(--spacing-xxl)}.dashboard-redesign:before{content:none}.dashboard-header-redesign{background:transparent;color:var(--color-neutral-900);padding:var(--spacing-lg) var(--spacing-xl);margin-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-neutral-200);padding-bottom:var(--spacing-xl)}.header-top-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.brand-section h1{font-size:var(--font-size-xxl);font-weight:800;margin:0;color:var(--color-neutral-900);line-height:1.2;letter-spacing:-.5px}.user-role{display:block;font-size:var(--font-size-sm);color:var(--color-neutral-600);font-weight:500;margin-top:var(--spacing-xs);text-transform:uppercase;letter-spacing:.5px}.header-quick-actions{display:flex;gap:var(--spacing-sm)}.quick-action-btn{min-height:var(--touch-target-min);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-neutral-100);border:2px solid var(--color-neutral-300);color:var(--color-neutral-900);border-radius:var(--radius-md);font-weight:600;font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:var(--spacing-xs);-webkit-backdrop-filter:none;backdrop-filter:none}.quick-action-btn:hover{background:var(--color-neutral-200);border-color:var(--color-neutral-400);transform:translateY(-2px)}.quick-action-btn:active{transform:translateY(0)}.btn-icon{font-size:var(--font-size-lg);line-height:1}.signout-btn:hover{background:var(--color-error);border-color:var(--color-error);color:var(--color-white)}.mobile-menu-toggle{display:none;min-height:var(--touch-target-min);min-width:var(--touch-target-min);padding:var(--spacing-sm);background:var(--color-neutral-100);border:2px solid var(--color-neutral-300);color:var(--color-neutral-900);border-radius:var(--radius-md);font-size:1.5rem;cursor:pointer;transition:all var(--transition-base);align-items:center;justify-content:center}.mobile-menu-toggle:hover{background:var(--color-neutral-200);border-color:var(--color-neutral-400)}.mobile-menu-toggle:active{transform:scale(.95)}.hamburger-icon{display:block;line-height:1}.dashboard-nav{display:flex;gap:var(--spacing-xs);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.dashboard-nav::-webkit-scrollbar{display:none}.nav-btn{min-height:44px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-neutral-100);border:2px solid var(--color-neutral-300);color:var(--color-neutral-900);border-radius:var(--radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:var(--spacing-xs);white-space:nowrap;flex-shrink:0}.nav-btn:hover{background:var(--color-neutral-200);border-color:var(--color-neutral-400);transform:translateY(-2px);box-shadow:var(--shadow-md)}.nav-btn-primary{background:var(--color-success);border-color:var(--color-success-dark);color:var(--color-white)}.nav-btn-primary:hover{background:var(--color-success-dark);border-color:var(--color-success-dark)}.nav-icon{font-size:1.125rem;line-height:1}.nav-text{font-weight:600;letter-spacing:.3px}@media(min-width:1200px){.dashboard-nav{gap:var(--spacing-sm)}}@media(max-width:1199px){.dashboard-header-redesign{padding:var(--spacing-md) var(--spacing-lg)}.brand-section h1{font-size:var(--font-size-xl)}.nav-btn{padding:var(--spacing-sm) var(--spacing-md)}.nav-text{font-size:var(--font-size-sm)}}@media(max-width:767px){.dashboard-redesign{padding-bottom:var(--spacing-lg)}.dashboard-header-redesign{padding:var(--spacing-md);margin-bottom:var(--spacing-lg);position:relative}.header-top-row{flex-direction:row;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.brand-section h1{font-size:1.5rem;letter-spacing:-.3px}.user-role{font-size:var(--font-size-xs);margin-top:.25rem}.mobile-menu-toggle{display:flex}.header-quick-actions{display:none}.dashboard-nav{position:absolute;top:100%;left:0;right:0;background:var(--color-white);border-top:2px solid var(--color-neutral-200);box-shadow:var(--shadow-lg);flex-direction:column;gap:0;padding:0;max-height:0;overflow:hidden;opacity:0;transition:all var(--transition-base);z-index:1000}.dashboard-nav.mobile-open{max-height:80vh;opacity:1;overflow-y:auto;padding:var(--spacing-sm)}.nav-btn{width:100%;padding:var(--spacing-md);font-size:1rem;gap:var(--spacing-md);border-radius:var(--radius-sm);border-width:1px;margin-bottom:var(--spacing-xs)}.nav-btn:last-child{margin-bottom:0}.nav-icon{font-size:1.5rem}.nav-text{font-size:1rem;font-weight:600}.btn-label{display:block}.mobile-menu-divider{height:1px;background:var(--color-neutral-300);margin:var(--spacing-md) 0}.mobile-menu-action{background:var(--color-neutral-50);border-color:var(--color-neutral-200)}.mobile-menu-signout:hover{background:var(--color-error);border-color:var(--color-error);color:var(--color-white)}.mobile-menu-divider,.mobile-menu-action{display:none}.dashboard-nav.mobile-open .mobile-menu-divider,.dashboard-nav.mobile-open .mobile-menu-action{display:flex}.dashboard-nav.mobile-open .mobile-menu-divider{display:block}.section{padding:var(--spacing-md)!important;margin-bottom:var(--spacing-md)!important}.daily-learning-section{padding:0 var(--spacing-md);margin-bottom:var(--spacing-lg)}.daily-learning-card{flex-direction:column;padding:var(--spacing-lg);gap:var(--spacing-lg)}.daily-learning-header{flex-direction:column;text-align:center;gap:var(--spacing-sm)}.daily-learning-header h2{font-size:1.25rem}.daily-learning-header p{font-size:.875rem}.daily-learning-features{flex-wrap:wrap;justify-content:center;gap:var(--spacing-xs)}.feature-badge{font-size:.75rem;padding:.375rem .625rem}.daily-learning-preview{width:100%;max-width:280px;margin:0 auto}.assignments-section h2{font-size:1.25rem;margin-bottom:var(--spacing-md)}.assigned-tests-grid{grid-template-columns:1fr!important;gap:var(--spacing-md)}.assigned-test-card{padding:var(--spacing-md)}.assigned-test-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.full-exam-card{flex-direction:column;padding:var(--spacing-lg);gap:var(--spacing-lg)}.full-exam-info h3{font-size:1.25rem}.full-exam-info p{font-size:.875rem}.exam-features{padding-left:var(--spacing-md)}.exam-features li{font-size:.875rem;margin-bottom:var(--spacing-xs)}.full-exam-button{width:100%;font-size:1rem}.category-grid{grid-template-columns:1fr!important;gap:var(--spacing-md)}.category-card{padding:var(--spacing-md)}.category-card h3{font-size:1rem}.category-card p{font-size:.875rem}.category-stats{gap:var(--spacing-md);margin:var(--spacing-md) 0}.stat-item{min-width:auto}.stat-value{font-size:1.25rem}.stat-label{font-size:.75rem}.start-test-button,.start-assigned-test-button,.start-daily-learning-button{font-size:.9375rem;padding:.875rem 1.5rem}.contest-widget{padding:0 var(--spacing-md);margin-bottom:var(--spacing-lg)}.back-button{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}}.history-table tbody tr{transition:background-color var(--transition-fast)}.history-table tbody tr:hover{background-color:var(--color-neutral-50)}.history-card{transition:all var(--transition-fast)}.history-card:hover{background-color:var(--color-neutral-50);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.executive-summary{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 10px 40px #667eea4d;color:#fff}.executive-summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.executive-summary-title{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;color:#fff}.executive-summary-subtitle{margin:0;font-size:.9375rem;opacity:.9}.time-range-selector{display:flex;gap:.5rem;background:#ffffff1a;padding:.25rem;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.time-range-selector button{padding:.5rem 1rem;border:none;background:transparent;color:#fff;border-radius:6px;cursor:pointer;font-weight:500;font-size:.875rem;transition:all .2s}.time-range-selector button:hover{background:#ffffff26}.time-range-selector button.active{background:#ffffff40;box-shadow:0 2px 8px #0000001a}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem}.kpi-card{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;display:flex;gap:1rem;align-items:flex-start;transition:all .2s;border:1px solid rgba(255,255,255,.2)}.kpi-card:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.kpi-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0;box-shadow:0 4px 12px #00000026}.kpi-content{flex:1;min-width:0}.kpi-label{font-size:.875rem;opacity:.9;margin-bottom:.5rem;font-weight:500}.kpi-value{font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem;font-family:JetBrains Mono,monospace}.kpi-trend{font-size:.8125rem;font-weight:600;display:flex;align-items:center;gap:.25rem}.kpi-subtitle{font-size:.8125rem;opacity:.8}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.25rem}.executive-summary .insight-card{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;border:1px solid rgba(255,255,255,.2)}.insight-title{margin:0 0 1.25rem;font-size:1.125rem;font-weight:600;color:#fff}.insight-empty{color:#ffffffb3;font-size:.9375rem;margin:0;text-align:center;padding:2rem 0}.top-performers-list{display:flex;flex-direction:column;gap:1rem}.top-performer-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff1a;border-radius:8px;transition:all .2s}.top-performer-item:hover{background:#ffffff26;transform:translate(4px)}.performer-rank{font-size:1.5rem;line-height:1}.performer-info{flex:1;min-width:0}.performer-name{font-weight:600;font-size:.9375rem;margin-bottom:.25rem}.performer-stats{font-size:.8125rem;opacity:.8}.performer-score{font-size:1.5rem;font-weight:700;font-family:JetBrains Mono,monospace}.trend-item{display:grid;grid-template-columns:120px 1fr 60px;gap:1rem;align-items:center;margin-bottom:1rem}.trend-item:last-child{margin-bottom:0}.trend-label{font-size:.875rem;font-weight:500}.trend-bar-container{height:12px;background:#fff3;border-radius:6px;overflow:hidden}.trend-bar{height:100%;border-radius:6px;transition:width .6s ease;box-shadow:0 2px 8px #0003}.trend-value{text-align:right;font-weight:700;font-family:JetBrains Mono,monospace;font-size:.875rem}.quick-insights-list{display:flex;flex-direction:column;gap:.75rem}.insight-item{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;font-size:.875rem;font-weight:500;line-height:1.5}.insight-item.positive{background:#10b98133;border:1px solid rgba(16,185,129,.3)}.insight-item.warning{background:#f59e0b33;border:1px solid rgba(245,158,11,.3)}.insight-item.neutral{background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.insight-icon{font-size:1.25rem;line-height:1;flex-shrink:0}@media(max-width:768px){.executive-summary{padding:1.5rem}.executive-summary-header{flex-direction:column}.time-range-selector{width:100%;justify-content:stretch}.time-range-selector button{flex:1;padding:.625rem .5rem}.kpi-grid,.insights-grid{grid-template-columns:1fr}.trend-item{grid-template-columns:100px 1fr 50px;gap:.75rem}.kpi-value{font-size:1.75rem}}@media(max-width:480px){.kpi-icon{width:48px;height:48px;font-size:1.5rem}.kpi-value{font-size:1.5rem}}.manager-schedule-view{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e0e7ff);padding:2rem;animation:fadeIn .3s ease-out}.schedule-view-header{max-width:1600px;margin:0 auto 2rem;background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 24px #00000014;border:2px solid #e2e8f0}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-top h2{font-size:2rem;font-weight:800;color:#1e293b;margin:0;display:flex;align-items:center;gap:.75rem}.header-top h2:before{content:"🗓️";font-size:2.25rem}.btn-close-view{padding:.875rem 1.75rem;background:#f1f5f9;color:#475569;border:2px solid #e2e8f0;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.btn-close-view:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}.header-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.view-toggle{display:flex;gap:.5rem;background:#f8fafc;padding:.375rem;border-radius:12px;border:2px solid #e2e8f0}.toggle-btn{padding:.625rem 1.25rem;border:none;background:transparent;border-radius:8px;font-weight:600;font-size:.9375rem;color:#64748b;cursor:pointer;transition:all .2s}.toggle-btn:hover{color:#3b82f6}.toggle-btn.active{background:#fff;color:#3b82f6;box-shadow:0 2px 8px #3b82f633}.filters{display:flex;gap:.75rem;flex-wrap:wrap;flex:1;justify-content:center}.filter-select{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-weight:600;font-size:.9375rem;color:#475569;background:#fff;cursor:pointer;transition:all .2s;min-width:180px}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select:hover{border-color:#cbd5e1}.btn-add-schedule-manager{padding:.875rem 1.75rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #8b5cf64d;white-space:nowrap}.btn-add-schedule-manager:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.calendar-view-manager{max-width:1600px;margin:0 auto;background:#fff;border-radius:20px;padding:2.5rem;box-shadow:0 4px 24px #00000014;border:2px solid #e2e8f0}.calendar-grid-manager{display:flex;flex-direction:column;gap:.75rem}.calendar-days-manager{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem}.calendar-day-manager{min-height:120px;padding:.875rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:.5rem;transition:all .2s;position:relative;overflow-y:auto}.calendar-day-manager.empty{background:transparent;border-color:transparent}.calendar-day-manager.today{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.calendar-day-manager.has-schedule{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.calendar-day-manager:hover:not(.empty){transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.day-schedules{display:flex;flex-direction:column;gap:.5rem;flex:1}.schedule-chip{padding:.5rem .75rem;border-radius:8px;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center;gap:.5rem;background:#fff;border:2px solid #e2e8f0;box-shadow:0 2px 4px #0000000d}.schedule-chip:hover{transform:scale(1.02);box-shadow:0 4px 8px #0000001f}.schedule-chip.certification{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981;color:#065f46}.schedule-chip.recertification{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6;color:#1e40af}.schedule-chip.completed{opacity:.6;text-decoration:line-through}.schedule-chip.cancelled{opacity:.4;background:#f1f5f9;border-color:#cbd5e1;color:#64748b}.chip-tech{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip-category{font-weight:800;background:#0000001a;padding:.125rem .5rem;border-radius:4px}.list-view-manager{max-width:1600px;margin:0 auto}.schedules-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-item{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:all .3s;position:relative;overflow:hidden}.stat-item:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#8b5cf6,#3b82f6)}.stat-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.stat-value{font-size:2.5rem;font-weight:900;color:#1e293b}.stat-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;text-align:center}.schedules-table{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #00000014;border:2px solid #e2e8f0}.table-header{display:grid;grid-template-columns:1.5fr 1.2fr 1.5fr .8fr 1.2fr .8fr 1.2fr;padding:1.5rem;background:#f8fafc;font-weight:700;font-size:.8125rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e2e8f0;gap:1rem}.table-body{display:flex;flex-direction:column}.table-row{display:grid;grid-template-columns:1.5fr 1.2fr 1.5fr .8fr 1.2fr .8fr 1.2fr;padding:1.5rem;border-bottom:1px solid #f1f5f9;transition:all .2s;align-items:center;gap:1rem}.table-row:hover{background:#f8fafc}.table-row.urgent{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-left:4px solid #dc2626}.table-row.urgent:hover{background:linear-gradient(135deg,#fee2e2,#fecaca)}.col-tech strong{color:#1e293b;font-weight:700}.col-date{display:flex;flex-direction:column;gap:.25rem}.days-until{font-size:.75rem;font-weight:600;color:#f59e0b;background:#fef3c7;padding:.25rem .5rem;border-radius:4px;display:inline-block;align-self:flex-start}.col-category{display:flex;flex-direction:column;gap:.25rem}.category-badge{font-weight:800;font-size:.875rem;color:#1e293b;background:#e0e7ff;padding:.25rem .625rem;border-radius:6px;display:inline-block;align-self:flex-start}.category-name-small{font-size:.75rem;color:#64748b}.type-badge{padding:.375rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;display:inline-block;align-self:flex-start}.type-badge.certification{background:#d1fae5;color:#065f46}.type-badge.recertification{background:#dbeafe;color:#1e40af}.status-badge{padding:.375rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.status-badge.scheduled{background:#dbeafe;color:#1e40af}.status-badge.completed{background:#d1fae5;color:#065f46}.status-badge.cancelled{background:#f1f5f9;color:#64748b}.status-badge.rescheduled{background:#fef3c7;color:#92400e}.col-actions{display:flex;gap:.5rem}.btn-edit-small,.btn-delete-small{padding:.5rem .875rem;border-radius:6px;font-weight:600;font-size:.8125rem;cursor:pointer;transition:all .2s;border:none}.btn-edit-small{background:#eff6ff;color:#2563eb}.btn-edit-small:hover{background:#2563eb;color:#fff}.btn-delete-small{background:#fef2f2;color:#dc2626}.btn-delete-small:hover{background:#dc2626;color:#fff}.modal-content-manager{background:#fff;border-radius:20px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}.schedule-form-manager{padding:2rem}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.manager-schedule-loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.125rem;color:#64748b;font-weight:600}.manager-schedule-loading:before{content:"";width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin-right:1rem}@media(max-width:1200px){.table-header,.table-row{grid-template-columns:1.5fr 1.2fr 1.2fr .8fr 1fr 1fr;font-size:.8125rem}.col-location{display:none}}@media(max-width:1024px){.header-controls{flex-direction:column;align-items:stretch}.filters{justify-content:stretch}.filter-select{flex:1;min-width:auto}.calendar-days-manager{gap:.5rem}.calendar-day-manager{min-height:100px}}@media(max-width:768px){.manager-schedule-view{padding:1rem}.schedule-view-header{padding:1.5rem}.header-top{flex-direction:column;align-items:stretch}.calendar-view-manager{padding:1.5rem}.table-header{display:none}.table-row{grid-template-columns:1fr;padding:1.5rem;gap:.75rem;border-bottom:2px solid #e2e8f0}.col-tech,.col-date,.col-category,.col-type,.col-location,.col-status{display:flex;justify-content:space-between;align-items:center}.col-tech:before,.col-date:before,.col-category:before,.col-type:before,.col-location:before,.col-status:before{content:attr(data-label);font-weight:700;color:#64748b;font-size:.75rem;text-transform:uppercase}.col-actions{width:100%;justify-content:stretch}.btn-edit-small,.btn-delete-small{flex:1}.form-row{grid-template-columns:1fr}}@media(max-width:480px){.header-top h2{font-size:1.5rem}.view-toggle{width:100%}.toggle-btn{flex:1}.calendar-days-manager{gap:.25rem}.calendar-day-manager{min-height:70px;padding:.5rem}.schedule-chip{font-size:.625rem;padding:.375rem .5rem}}.intelligence-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.intelligence-dashboard .dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.intelligence-dashboard .header-content h2{font-size:1.875rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.intelligence-dashboard .header-subtitle{color:#64748b;font-size:1rem;margin:0}.intelligence-dashboard .btn-export{background:#2563eb;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.intelligence-dashboard .btn-export:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.intelligence-dashboard .view-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb;padding-bottom:1rem}.intelligence-dashboard .tab-btn{padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#64748b;font-weight:600;cursor:pointer;transition:all .2s}.intelligence-dashboard .tab-btn:hover{color:#2563eb;background:#eff6ff}.intelligence-dashboard .tab-btn.active{color:#2563eb;border-bottom-color:#2563eb}.intelligence-dashboard .loading-state{text-align:center;padding:3rem;color:#64748b;font-size:1.125rem}.intelligence-dashboard .overview-section{display:flex;flex-direction:column;gap:2rem}.intelligence-dashboard .metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.intelligence-dashboard .metric-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;border-left:4px solid #2563eb}.intelligence-dashboard .metric-label{color:#64748b;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.intelligence-dashboard .metric-value{font-size:2.5rem;font-weight:700;color:#1e293b}.intelligence-dashboard .recent-anomalies h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:1rem}.intelligence-dashboard .anomaly-item{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem;border-left:4px solid #64748b}.intelligence-dashboard .anomaly-item.severity-high{border-left-color:#f59e0b}.intelligence-dashboard .anomaly-item.severity-critical{border-left-color:#ef4444}.intelligence-dashboard .anomaly-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.intelligence-dashboard .anomaly-type{font-weight:700;color:#1e293b}.intelligence-dashboard .anomaly-severity{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;background:#e5e7eb;color:#64748b}.intelligence-dashboard .anomaly-description{color:#475569;margin:.5rem 0}.intelligence-dashboard .anomaly-recommendation{color:#2563eb;font-size:.875rem;margin:.5rem 0 0}.intelligence-dashboard .benchmarks-section h3,.intelligence-dashboard .anomalies-section h3,.intelligence-dashboard .recommendations-section h3,.intelligence-dashboard .trends-section h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:1.5rem}.intelligence-dashboard .metrics-list,.intelligence-dashboard .anomalies-list,.intelligence-dashboard .recommendations-list,.intelligence-dashboard .trends-list{display:flex;flex-direction:column;gap:1rem}.intelligence-dashboard .metric-item{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;align-items:center}.intelligence-dashboard .metric-info{flex:1}.intelligence-dashboard .metric-name{font-weight:700;color:#1e293b;margin-bottom:.5rem}.intelligence-dashboard .metric-stats{display:flex;gap:1rem;align-items:center}.intelligence-dashboard .current-value{font-size:1.5rem;font-weight:700;color:#2563eb}.intelligence-dashboard .trend{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.intelligence-dashboard .trend-up{background:#dcfce7;color:#16a34a}.intelligence-dashboard .trend-down{background:#fee2e2;color:#dc2626}.intelligence-dashboard .trend-stable{background:#e5e7eb;color:#64748b}.intelligence-dashboard .metric-comparison{color:#64748b;font-size:.875rem}.intelligence-dashboard .anomaly-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;border-left:4px solid #64748b}.intelligence-dashboard .anomaly-card.severity-high{border-left-color:#f59e0b}.intelligence-dashboard .anomaly-card.severity-critical{border-left-color:#ef4444}.intelligence-dashboard .anomaly-card .anomaly-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.intelligence-dashboard .anomaly-card h4{margin:0;font-size:1.125rem;color:#1e293b}.intelligence-dashboard .severity-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.intelligence-dashboard .severity-badge.high{background:#fef3c7;color:#f59e0b}.intelligence-dashboard .severity-badge.critical{background:#fee2e2;color:#dc2626}.intelligence-dashboard .anomaly-details{margin:1rem 0;padding:1rem;background:#f8fafc;border-radius:6px}.intelligence-dashboard .anomaly-details p{margin:.5rem 0;color:#475569;font-size:.875rem}.intelligence-dashboard .recommendation-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;border-left:4px solid #2563eb}.intelligence-dashboard .recommendation-card h4{margin:0 0 .75rem;font-size:1.125rem;color:#1e293b}.intelligence-dashboard .recommendation-text{color:#475569;margin-bottom:1rem}.intelligence-dashboard .recommendation-priority{color:#64748b;font-size:.875rem;font-weight:600}.intelligence-dashboard .priority-high{color:#f59e0b}.intelligence-dashboard .priority-critical{color:#dc2626}.intelligence-dashboard .trend-item{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.intelligence-dashboard .trend-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.intelligence-dashboard .trend-period{color:#64748b;font-size:.875rem;font-weight:600}.intelligence-dashboard .trend-metric{font-weight:700;color:#1e293b}.intelligence-dashboard .trend-value{display:flex;justify-content:space-between;align-items:center}.intelligence-dashboard .trend-value .value{font-size:1.5rem;font-weight:700;color:#2563eb}.intelligence-dashboard .trend-value .change{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.intelligence-dashboard .trend-value .change.positive{background:#dcfce7;color:#16a34a}.intelligence-dashboard .trend-value .change.negative{background:#fee2e2;color:#dc2626}.authority-dashboard{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:2rem}.authority-header{background:#fff;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #00000014;display:flex;justify-content:space-between;align-items:center;position:relative;overflow:hidden}.authority-header:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#f59e0b,#ef4444,#ec4899)}.authority-header h1{font-size:2.25rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem;letter-spacing:-1px}.header-subtitle{color:#64748b;font-size:1rem;margin:0 0 .5rem;font-weight:500}.data-freshness{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#64748b;margin-top:.5rem}.freshness-indicator{color:#10b981;font-size:.625rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.metrics-section{margin-bottom:2rem}.metrics-section h2{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;align-items:stretch}.metric-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;border:2px solid #e2e8f0;transition:all .3s ease;display:flex;flex-direction:column;min-height:280px}.metric-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f;border-color:#f59e0b}.metric-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;min-height:44px}.metric-header h3{font-size:1rem;font-weight:700;color:#1e293b;margin:0;flex:1;line-height:1.3;padding-right:.5rem}.trend-indicator{padding:.375rem .75rem;border-radius:8px;font-weight:700;font-size:.875rem;flex-shrink:0;height:fit-content;white-space:nowrap}.trend-indicator.up{background:#d1fae5;color:#059669}.trend-indicator.down{background:#fee2e2;color:#dc2626}.trend-indicator.stable{background:#e0f2fe;color:#0284c7}.metric-value{font-size:2.5rem;font-weight:900;color:#1e293b;margin:0;line-height:1;height:60px;display:flex;align-items:baseline}.metric-details{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0;flex:1}.detail-row{display:flex;justify-content:space-between;font-size:.875rem;color:#64748b;line-height:1.5;min-height:24px;align-items:center}.detail-row span:first-child{flex-shrink:0}.detail-row span:last-child{font-weight:700;color:#1e293b;text-align:right}.btn-export-small{background:#f1f5f9;color:#1e293b;border:none;padding:.5rem 1rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;margin-top:auto;height:40px}.btn-export-small:hover{background:#f59e0b;color:#fff}.quick-insights-section{margin-bottom:2rem}.quick-insights-section h2{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.insight-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;border-left:6px solid #e2e8f0;transition:all .3s ease}.insight-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f}.insight-card.trend{border-left-color:#3b82f6}.insight-card.anomaly{border-left-color:#f59e0b}.insight-card.prediction{border-left-color:#8b5cf6}.insight-card.benchmark{border-left-color:#10b981}.insight-type-badge{display:inline-block;padding:.25rem .75rem;background:#f1f5f9;color:#1e293b;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;margin-bottom:1rem}.insight-card h3{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 .75rem;line-height:1.4}.insight-card p{color:#475569;line-height:1.6;margin-bottom:1rem}.insight-confidence{margin-bottom:1rem;padding:.5rem;background:#f8fafc;border-radius:8px;font-size:.875rem;color:#64748b;font-weight:600}.insight-actions{display:flex;gap:.75rem}.btn-summary,.btn-details{flex:1;padding:.75rem 1rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-summary{background:#f59e0b;color:#fff}.btn-summary:hover{background:#d97706;transform:translateY(-2px)}.btn-details{background:#f1f5f9;color:#1e293b}.btn-details:hover{background:#e2e8f0}.insights-detailed-grid{display:grid;gap:1.5rem}.insight-detailed-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;border-left:6px solid #e2e8f0;cursor:pointer;transition:all .3s ease}.insight-detailed-card:hover{box-shadow:0 8px 30px #0000001f}.insight-detailed-card.selected{border-left-color:#f59e0b;box-shadow:0 8px 30px #f59e0b33}.insight-detailed-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.type-badge{padding:.375rem .875rem;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;margin-bottom:.5rem;display:inline-block}.type-badge.trend{background:#dbeafe;color:#1e40af}.type-badge.anomaly{background:#fef3c7;color:#b45309}.type-badge.prediction{background:#ede9fe;color:#6b21a8}.type-badge.benchmark{background:#d1fae5;color:#065f46}.publication-status{display:flex;gap:.5rem;align-items:center}.ready-badge{padding:.375rem .875rem;background:#d1fae5;color:#065f46;border-radius:8px;font-size:.75rem;font-weight:700}.confidence-badge{padding:.375rem .875rem;background:#f1f5f9;color:#1e293b;border-radius:8px;font-size:.75rem;font-weight:700}.insight-expanded{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e2e8f0}.key-findings{margin-bottom:1.5rem}.key-findings h4{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.key-findings ul{list-style:none;padding:0;margin:0}.key-findings li{padding:.75rem 1rem;background:#f8fafc;border-left:3px solid #f59e0b;border-radius:8px;margin-bottom:.5rem;color:#475569;line-height:1.5}.supporting-data{margin-bottom:1.5rem}.supporting-data h4{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.data-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.data-label{color:#64748b;font-weight:600;text-transform:capitalize}.data-value{color:#1e293b;font-weight:700}.export-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.btn-export,.btn-social{padding:.75rem 1rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-export{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-export:hover{transform:translateY(-2px);box-shadow:0 4px 16px #f59e0b66}.btn-social{background:linear-gradient(135deg,#ec4899,#be185d);color:#fff}.btn-social:hover{transform:translateY(-2px);box-shadow:0 4px 16px #ec489966}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.report-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;border:2px solid #e2e8f0;transition:all .3s ease}.report-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f;border-color:#f59e0b}.report-type-badge{display:inline-block;padding:.375rem .875rem;background:#fef3c7;color:#b45309;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;margin-bottom:1rem}.report-card h3{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1rem;line-height:1.3}.report-summary{color:#475569;line-height:1.6;margin-bottom:1.5rem}.report-stats h4{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 1rem}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem}.stat-item{display:flex;justify-content:space-between;padding:.75rem;background:#f8fafc;border-radius:8px}.stat-label{color:#64748b;font-weight:600;font-size:.875rem}.stat-value{color:#1e293b;font-weight:700;font-size:.875rem}.report-metadata{margin:1.5rem 0;padding:1rem;background:#f8fafc;border-radius:8px}.metadata-item{font-size:.875rem;color:#475569;margin-bottom:.5rem;line-height:1.5}.metadata-item:last-child{margin-bottom:0}.format-options h4{font-size:.875rem;font-weight:700;color:#1e293b;margin:1rem 0 .5rem}.format-badges{display:flex;gap:.5rem;flex-wrap:wrap}.format-badge{padding:.25rem .75rem;background:#e0f2fe;color:#0c4a6e;border-radius:6px;font-size:.75rem;font-weight:600}.report-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:1.5rem}.btn-export-report{padding:.75rem;border:none;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.875rem}.btn-export-report:hover{transform:translateY(-2px);box-shadow:0 4px 16px #3b82f666}.publishing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.publishing-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;border:2px solid #e2e8f0;transition:all .3s ease}.publishing-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f}.card-icon{font-size:3rem;margin-bottom:1rem}.publishing-card h3{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.publishing-card p{color:#64748b;line-height:1.5;margin-bottom:1rem}.asset-options,.webinar-options,.whitepaper-config{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0}.asset-options label,.webinar-options label,.whitepaper-config label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#475569;cursor:pointer}.insight-selector{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;margin-bottom:1rem;cursor:pointer}.template-options{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.template-btn{padding:.75rem;border:2px solid #e2e8f0;background:#fff;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.template-btn:hover{border-color:#f59e0b;background:#fffbeb}.newsletter-preview{padding:1rem;background:#f8fafc;border-radius:8px;margin-bottom:1rem}.newsletter-preview strong{display:block;margin-bottom:.5rem;color:#1e293b}.newsletter-preview ul{list-style:none;padding:0;margin:0}.newsletter-preview li{padding:.5rem 0;color:#475569;font-size:.875rem;border-bottom:1px solid #e2e8f0}.newsletter-preview li:last-child{border-bottom:none}.btn-generate{width:100%;padding:.875rem;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-radius:8px;font-weight:700;cursor:pointer;transition:all .2s ease}.btn-generate:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}.analytics-grid{display:grid;gap:1.5rem}.analytics-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;border:2px solid #e2e8f0}.analytics-card h3{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem}.forecast-chart,.market-share-chart,.positioning-matrix{margin-bottom:1.5rem}.chart-placeholder{background:#f8fafc;border-radius:12px;padding:2rem;text-align:center;color:#94a3b8;min-height:300px;display:flex;flex-direction:column;justify-content:center;align-items:center}.forecast-bars{display:flex;align-items:flex-end;gap:.5rem;height:200px;width:100%;max-width:600px;margin-top:2rem}.forecast-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.forecast-bar{width:100%;background:linear-gradient(180deg,#3b82f6,#2563eb);border-radius:4px 4px 0 0;transition:all .3s ease}.forecast-bar-wrapper:hover .forecast-bar{background:linear-gradient(180deg,#f59e0b,#d97706);transform:scaleY(1.05)}.bar-label{margin-top:.5rem;font-size:.75rem;color:#64748b;font-weight:600}.forecast-details,.market-insights,.positioning-details{background:#f8fafc;padding:1rem;border-radius:8px;margin-bottom:1rem}.forecast-details p,.market-insights p,.positioning-details p{margin:.5rem 0;color:#475569;font-size:.875rem}.share-segments{display:flex;height:60px;border-radius:8px;overflow:hidden;margin-bottom:1rem}.segment{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;transition:all .3s ease}.segment:hover{opacity:.9;transform:scaleY(1.1)}.matrix-quadrants{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:#e2e8f0;margin-top:1rem}.quadrant{background:#f8fafc;padding:2rem;min-height:150px;display:flex;align-items:center;justify-content:center;position:relative;font-weight:700;color:#64748b}.quadrant.leaders{background:#d1fae5;color:#065f46}.marker{position:absolute;width:12px;height:12px;background:#ef4444;border-radius:50%;border:3px solid white;box-shadow:0 2px 8px #0000004d}.marker.your-position{top:30%;right:35%}.authority-footer{background:#fff;border-radius:16px;padding:2rem;margin-top:2rem;box-shadow:0 4px 20px #00000014}.footer-content{display:grid;gap:1rem}.methodology-note,.data-attribution,.freshness-info{color:#64748b;font-size:.875rem;line-height:1.6}.methodology-note strong,.data-attribution strong,.freshness-info strong{color:#1e293b;display:inline-block;margin-right:.5rem}@media(max-width:1024px){.metrics-grid{grid-template-columns:repeat(2,1fr)}.insights-grid,.reports-grid{grid-template-columns:1fr}.publishing-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.authority-dashboard{padding:1rem}.authority-header{flex-direction:column;align-items:flex-start;gap:1rem}.authority-header h1{font-size:1.5rem}.metrics-grid,.stats-grid,.report-actions,.publishing-grid,.template-options,.export-options{grid-template-columns:1fr}}.master-dashboard{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e0f2fe);padding:2rem}.dashboard-header{max-width:1600px;margin:0 auto 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.header-content h1{font-size:2.5rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.header-subtitle{font-size:1.125rem;color:#64748b;margin:0;font-weight:500}.btn-close{padding:.875rem 1.75rem;background:#fff;color:#475569;border:2px solid #e2e8f0;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.btn-close:hover{background:#0ea5e9;border-color:#0ea5e9;color:#fff}.view-tabs{max-width:1600px;margin:0 auto 2rem;display:flex;gap:1rem;background:#fff;padding:.5rem;border-radius:16px;box-shadow:0 4px 20px #00000014}.tab-btn{flex:1;padding:1rem 2rem;background:transparent;border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.tab-btn:hover{background:#f1f5f9;color:#0f172a}.tab-btn.active{background:#0ea5e9;color:#fff}.overview-section{max-width:1600px;margin:0 auto}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;padding:2rem;border-radius:20px;box-shadow:0 4px 20px #00000014;border:3px solid #e2e8f0;text-align:center;transition:all .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0000001f}.stat-icon{font-size:3rem;margin-bottom:1rem}.stat-value{font-size:3rem;font-weight:900;color:#0f172a;margin-bottom:.5rem}.stat-label{font-size:.875rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px}.quick-actions{background:#fff;padding:2.5rem;border-radius:24px;box-shadow:0 4px 20px #00000014;margin-bottom:3rem}.quick-actions h2{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.action-card{display:flex;flex-direction:column;align-items:center;padding:2rem;background:linear-gradient(135deg,#f8fafc,#fff);border:2px solid #e2e8f0;border-radius:16px;cursor:pointer;transition:all .3s;text-align:center}.action-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#0ea5e9}.action-icon{font-size:3rem;margin-bottom:1rem}.action-title{font-size:1.25rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.action-desc{font-size:.9375rem;color:#64748b}.recent-activity{background:#fff;padding:2.5rem;border-radius:24px;box-shadow:0 4px 20px #00000014}.recent-activity h2{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem}.shops-preview{display:grid;gap:1rem}.shop-preview-card{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:#f8fafc;border-radius:12px;border:2px solid #e2e8f0;transition:all .2s}.shop-preview-card:hover{border-color:#cbd5e1;background:#fff}.shop-info h3{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.shop-info p{font-size:.9375rem;color:#64748b;margin:0}.free-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#fef3c7,#fef08a);color:#92400e;border-radius:8px;font-size:.875rem;font-weight:700}.section-header{max-width:1600px;margin:0 auto 2rem}.search-input{width:100%;padding:1rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;color:#0f172a;transition:all .2s}.search-input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 4px #0ea5e91a}.table-container{max-width:1600px;margin:0 auto;background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:linear-gradient(135deg,#0ea5e9,#0284c7)}.data-table th{padding:1.25rem;text-align:left;font-size:.875rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.data-table tbody tr{border-bottom:1px solid #e2e8f0;transition:all .2s}.data-table tbody tr:hover{background:#f8fafc}.data-table td{padding:1.25rem;font-size:.9375rem;color:#0f172a}.data-table td code{padding:.25rem .5rem;background:#f1f5f9;border-radius:4px;font-family:monospace;font-size:.875rem;color:#0ea5e9;font-weight:600}.text-sm{font-size:.8125rem;color:#64748b;margin-top:.25rem}.status-badge{padding:.375rem .875rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge.approved{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.status-badge.pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.status-badge.rejected{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.free-access-badge{padding:.375rem .875rem;background:linear-gradient(135deg,#fef3c7,#fef08a);color:#92400e;border-radius:20px;font-size:.75rem;font-weight:700}.no-access{color:#94a3b8}.action-buttons{display:flex;gap:.5rem}.action-buttons button{padding:.5rem;border:none;border-radius:8px;font-size:1.25rem;cursor:pointer;transition:all .2s}.btn-grant{background:linear-gradient(135deg,#fef3c7,#fef08a)}.btn-grant:hover{transform:scale(1.1);box-shadow:0 4px 12px #fbbf244d}.btn-delete{background:linear-gradient(135deg,#fee2e2,#fecaca)}.btn-delete:hover{transform:scale(1.1);box-shadow:0 4px 12px #ef44444d}.score{padding:.375rem .875rem;border-radius:20px;font-weight:700;font-size:.875rem}.score.good{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.score.needs-work{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:#fff;border-radius:24px;padding:2.5rem;max-width:600px;width:100%;box-shadow:0 20px 60px #0000004d}.modal-content h2{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.modal-subtitle{font-size:1rem;color:#64748b;margin:0 0 2rem}.form-group label{display:block;font-size:.9375rem;font-weight:600;color:#0f172a;margin-bottom:.75rem}.days-selector{display:flex;gap:.75rem;flex-wrap:wrap}.days-btn{flex:1;min-width:100px;padding:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;font-size:.9375rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s}.days-btn:hover{border-color:#cbd5e1;background:#fff}.days-btn.selected{background:#0ea5e9;border-color:#0ea5e9;color:#fff}.reason-input{width:100%;padding:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;font-size:.9375rem;color:#0f172a;font-family:inherit;resize:vertical;transition:all .2s}.reason-input:focus{outline:none;border-color:#0ea5e9;background:#fff}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.btn-cancel{flex:1;padding:1rem 2rem;background:#f1f5f9;border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#e2e8f0}.btn-confirm{flex:1;padding:1rem 2rem;background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s}.btn-confirm:hover{box-shadow:0 8px 24px #0ea5e94d;transform:translateY(-2px)}.loading-state{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.125rem;color:#64748b;font-weight:600}@media(max-width:1024px){.data-table{font-size:.875rem}.data-table th,.data-table td{padding:1rem}}@media(max-width:768px){.master-dashboard{padding:1rem}.dashboard-header{flex-direction:column;align-items:stretch}.header-content h1{font-size:2rem}.view-tabs{flex-direction:column}.stats-grid{grid-template-columns:repeat(2,1fr)}.actions-grid{grid-template-columns:1fr}.table-container{overflow-x:auto}.data-table{min-width:800px}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.tech-detail-modal{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out}.tech-detail-standalone{background:#fff;border-radius:0;width:100%;min-height:100vh;display:flex;flex-direction:column;box-shadow:none;max-width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:24px 32px;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px 16px 0 0}.header-content h2{margin:0 0 8px;font-size:28px;font-weight:700}.tech-email{margin:0;opacity:.9;font-size:14px;color:#fff}.header-actions{display:flex;gap:12px}.export-button{padding:10px 20px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.4);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:14px}.export-button:hover{background:#ffffff4d;border-color:#fff9;transform:translateY(-1px)}.close-button{width:40px;height:40px;background:#fff3;color:#fff;border:none;border-radius:8px;font-size:24px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#ffffff4d;transform:rotate(90deg)}.back-button{padding:10px 20px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.4);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:14px;white-space:nowrap}.back-button:hover{background:#ffffff4d;border-color:#fff9;transform:translate(-2px)}.tab-navigation{display:flex;gap:0;padding:0 32px;background:#f9fafb;border-bottom:2px solid #e5e7eb}.tab-button{padding:16px 24px;background:transparent;border:none;font-size:15px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent;position:relative}.tab-button:hover{color:#667eea;background:#667eea0d}.tab-button.active{color:#667eea;border-bottom-color:#667eea;background:#fff}.modal-content{flex:1;overflow:hidden;padding:32px;background:#f9fafb;display:flex;flex-direction:column;width:100%;box-sizing:border-box}.tech-detail-standalone .modal-content{max-width:1400px;margin:0 auto;padding:32px 48px}.loading-state{padding:60px 20px;text-align:center;font-size:18px;color:#6b7280}.empty-state{padding:60px 20px;text-align:center;color:#9ca3af;font-size:16px}.summary-tab{display:flex;flex-direction:column;gap:28px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:28px}.stat-card{background:#fff;padding:32px 28px;border-radius:20px;box-shadow:0 4px 12px #0000000f;transition:all .35s cubic-bezier(.4,0,.2,1);border:2px solid transparent;position:relative;overflow:hidden;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:160px}.stat-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#667eea08,#764ba208);opacity:0;transition:opacity .35s;z-index:0}.stat-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 12px 24px #667eea26;border-color:#667eea4d}.stat-card:hover:before{opacity:1}.stat-label{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:16px;display:block;position:relative;z-index:1}.stat-value{font-size:56px;font-weight:900;color:#1f2937;line-height:1;position:relative;z-index:1;letter-spacing:-1px}.trend-improving{color:#10b981;display:inline-flex;align-items:center;gap:8px}.trend-declining{color:#ef4444;display:inline-flex;align-items:center;gap:8px}.trend-stable{color:#3b82f6;display:inline-flex;align-items:center;gap:8px}.summary-section{background:#fff;padding:32px;border-radius:16px;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb;transition:box-shadow .3s}.summary-section:hover{box-shadow:0 4px 12px #0000001a}.summary-section h3{margin:0 0 24px;font-size:22px;color:#1f2937;font-weight:800;letter-spacing:-.5px;position:relative;padding-bottom:12px}.summary-section h3:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px}.summary-text p{margin:0 0 20px;line-height:1.8;color:#374151;font-size:16px}.summary-text p:last-child{margin-bottom:0}.text-success{color:#10b981;font-weight:600}.text-warning{color:#f59e0b;font-weight:600}.recommendations-list{list-style:none;padding:0;margin:0}.recommendation-item{padding:18px 20px;margin-bottom:14px;border-radius:12px;border-left:5px solid #3b82f6;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1e40af;line-height:1.7;font-size:15px;box-shadow:0 2px 4px #0000000d;transition:all .2s}.recommendation-item:hover{transform:translate(4px);box-shadow:0 4px 8px #00000014}.recommendation-item:last-child{margin-bottom:0}.recommendation-item strong{font-weight:700;display:inline-block;margin-right:4px}.recommendation-item.critical{border-left-color:#ef4444;background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#991b1b}.recommendation-item.warning{border-left-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7);color:#92400e}.recommendation-item.success{border-left-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#065f46}.history-tab{display:flex;flex-direction:column;gap:20px;height:100%;overflow-y:auto;width:100%}.history-header{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;width:100%;box-sizing:border-box}.history-header h3{margin:0 0 8px;font-size:20px;color:#1f2937}.history-subtitle{margin:0;color:#6b7280;font-size:14px}.history-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow-x:auto;width:100%;box-sizing:border-box}.history-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.history-table th{padding:14px 16px;text-align:left;font-size:13px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.5px}.history-table td{padding:16px;border-bottom:1px solid #f3f4f6;font-size:14px;color:#1f2937}.history-table tbody tr{transition:background-color .15s}.history-table tbody tr:hover{background:#f9fafb}.passed-row{background:#10b98108}.failed-row{background:#ef444408}.category-cell{display:flex;flex-direction:column;gap:4px}.category-name{font-size:12px;color:#6b7280}.score-badge{display:inline-block;padding:4px 12px;border-radius:6px;font-weight:600;font-size:14px}.result-badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 20px;border-radius:24px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.8px;min-width:80px;box-shadow:0 2px 4px #0000001a;transition:all .2s}.result-badge:hover{transform:scale(1.05);box-shadow:0 4px 8px #00000026}.result-badge.pass{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.result-badge.fail{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.mastery-tab{display:flex;flex-direction:column;gap:24px}.mastery-header{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a}.mastery-header h3{margin:0 0 8px;font-size:20px;color:#1f2937}.mastery-subtitle{margin:0;color:#6b7280;font-size:14px}.mastery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.mastery-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;transition:transform .2s,box-shadow .2s}.mastery-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.mastery-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.mastery-card-header h4{margin:0;font-size:18px;color:#1f2937;font-weight:700}.mastery-badge{padding:6px 14px;border-radius:20px;color:#fff;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.mastery-category-name{margin:0 0 20px;color:#6b7280;font-size:13px}.progress-bar-container{margin-bottom:20px}.progress-bar-label{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px;color:#6b7280;font-weight:600}.progress-value{color:#1f2937;font-weight:700}.progress-bar{height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden}.progress-fill{height:100%;transition:width .5s ease-out;border-radius:6px}.mastery-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-top:16px;border-top:1px solid #e5e7eb}.mastery-stat{display:flex;flex-direction:column;gap:4px}.mastery-stat .stat-label{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.mastery-stat .stat-value{font-size:16px;color:#1f2937;font-weight:700}.last-practice{margin:12px 0 0;font-size:12px;color:#9ca3af;font-style:italic}.struggles-tab{display:flex;flex-direction:column;gap:24px}.struggles-header{background:#fff;padding:32px;border-radius:16px;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb;margin-bottom:24px}.struggles-header h3{margin:0 0 12px;font-size:24px;color:#1f2937;font-weight:800;letter-spacing:-.5px}.struggles-subtitle{margin:0;color:#6b7280;font-size:16px;line-height:1.5}.no-struggles{background:linear-gradient(135deg,#f0fdf4,#dcfce7);padding:80px 48px;border-radius:16px;text-align:center;box-shadow:0 2px 8px #00000014;border:2px solid #d1fae5;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center}.success-message{margin:0 0 20px;font-size:32px;color:#10b981;font-weight:800;letter-spacing:-.5px}.success-subtitle{margin:0;color:#059669;font-size:18px;line-height:1.6;font-weight:500;max-width:500px}.struggles-list{display:flex;flex-direction:column;gap:16px}.struggle-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;border-left:4px solid #ef4444}.struggle-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.struggle-header h4{margin:0 0 8px;font-size:16px;color:#1f2937;font-weight:700}.trend-indicator{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;margin-top:4px}.trend-indicator.trend-improving{background:#d1fae5;color:#065f46}.trend-indicator.trend-declining{background:#fee2e2;color:#991b1b}.trend-indicator.trend-stable{background:#dbeafe;color:#1e40af}.severity-badge{padding:8px 16px;border-radius:20px;color:#fff;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.struggle-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:16px}.metric{display:flex;flex-direction:column;gap:6px}.metric-label{font-size:12px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:20px;color:#1f2937;font-weight:700}.metric-value.failure-rate{color:#ef4444}.struggle-visualization{margin-bottom:16px}.heatmap-bar{height:12px;background:#f3f4f6;border-radius:6px;overflow:hidden}.heatmap-fill{height:100%;transition:width .5s ease-out;border-radius:6px}.struggle-recommendation{padding:12px;background:#f9fafb;border-radius:6px;font-size:13px;line-height:1.6;color:#374151}.struggle-recommendation strong{color:#1f2937}.focus-tab{height:100%;max-height:calc(90vh - 280px);overflow:hidden;width:100%;box-sizing:border-box}.focus-tab .focus-areas-page{min-height:auto;height:100%;background:transparent;display:flex;flex-direction:column}.focus-tab .focus-areas-page-header{padding:0 0 1.5rem;background:transparent;border-bottom:2px solid #e2e8f0;box-shadow:none;flex-shrink:0}.focus-tab .focus-areas-page-header .header-content h1{font-size:1.5rem;margin-bottom:.25rem}.focus-tab .focus-areas-page-header .header-subtitle{font-size:.875rem}.focus-tab .btn-close-focus-page{display:none}.focus-tab .focus-areas-tabs{padding:1rem 0;background:transparent;border-bottom:2px solid #e2e8f0;flex-shrink:0;gap:.75rem}.focus-tab .focus-tab{min-width:180px;padding:.75rem 1rem}.focus-tab .tab-icon{font-size:1.25rem}.focus-tab .tab-content{gap:.25rem}.focus-tab .tab-title{font-size:.875rem}.focus-tab .tab-subtitle{font-size:.75rem}.focus-tab .focus-areas-content{flex:1;overflow-y:auto;min-height:0;padding:1.5rem 0 0}.focus-tab .a1-focus-areas,.focus-tab .a2-focus-areas,.focus-tab .a3-focus-areas,.focus-tab .a4-focus-areas,.focus-tab .a5-focus-areas,.focus-tab .a6-focus-areas,.focus-tab .a7-focus-areas,.focus-tab .a8-focus-areas{height:100%;overflow:visible;width:100%;padding:0}.focus-tab .focus-areas-header{display:none}.focus-tab .performance-summary-card,.focus-tab .recommendations-section{margin-bottom:1.5rem}.focus-tab .recommendations-section h2{font-size:1.25rem;margin-bottom:.75rem}.focus-tab .section-subtitle{font-size:.875rem;margin-bottom:1rem}.focus-tab .focus-areas-section h2{font-size:1.25rem;margin-bottom:.75rem}.focus-tab .focus-areas-grid{gap:1rem}.focus-tab .focus-area-card{padding:1.25rem}.focus-tab .performance-guide-section{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e2e8f0}.focus-tab .performance-guide-section h2{font-size:1.125rem;margin-bottom:1rem}.trends-tab{height:100%;overflow-y:auto;width:100%}@media(max-width:768px){.tech-detail-modal{max-height:95vh;border-radius:12px}.modal-header{padding:20px;flex-direction:column;align-items:flex-start;gap:16px}.header-actions{width:100%;justify-content:space-between}.tab-navigation{padding:0 16px;overflow-x:auto}.tab-button{padding:14px 18px;font-size:14px;white-space:nowrap}.modal-content,.tech-detail-standalone .modal-content{padding:20px}.stats-grid{grid-template-columns:1fr;gap:16px}.stat-card{padding:28px 24px;min-height:140px}.stat-value{font-size:48px}.stat-label{font-size:10px;margin-bottom:12px}.mastery-grid{grid-template-columns:1fr}.struggle-metrics{grid-template-columns:1fr;gap:12px}.history-table-container{overflow-x:auto}.history-table{min-width:600px}.no-struggles{padding:60px 32px;min-height:240px}.success-message{font-size:26px}.success-subtitle{font-size:16px}.struggles-header{padding:24px}.struggles-header h3{font-size:20px}.struggles-subtitle{font-size:14px}}@media(min-width:769px)and (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:18px}.stat-card{min-height:150px}.stat-value{font-size:52px}.no-struggles{padding:70px 40px;min-height:280px}.success-message{font-size:28px}.success-subtitle{font-size:17px}}*{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}.forgot-password-link{background:none;border:none;color:#2563eb;padding:.5rem;margin-top:.5rem;cursor:pointer;font-size:.875rem;transition:color .2s;text-align:center;width:100%}.forgot-password-link:hover{color:#1e40af;text-decoration:underline}.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,#f8fafc,#f1f5f9);border-radius:20px;padding:2.5rem;margin-bottom:2rem;box-shadow:0 4px 24px #0000000f;border:1px solid #e2e8f0}.performance-insights h2{color:#1e293b;margin:0 0 2rem;font-size:1.75rem;font-weight:700;letter-spacing:-.5px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:0}.stats-grid .stat-card{background:#fff;padding:2rem 1.75rem;border-radius:16px;box-shadow:0 2px 12px #0000000d;border:1px solid #e2e8f0;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.stats-grid .stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#2563eb);opacity:0;transition:opacity .3s ease}.stats-grid .stat-card:nth-child(1):before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.stats-grid .stat-card:nth-child(2):before{background:linear-gradient(90deg,#10b981,#059669)}.stats-grid .stat-card:nth-child(3):before{background:linear-gradient(90deg,#f59e0b,#d97706)}.stats-grid .stat-card:nth-child(4):before{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.stats-grid .stat-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #0000001f;border-color:#cbd5e1}.stats-grid .stat-card:hover:before{opacity:1}.stats-grid .stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{background:#fafafa}.stat-badge{margin-top:.5rem;padding:.25rem .75rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:.75rem;font-weight:600;border-radius:12px;display:inline-block;box-shadow:0 2px 8px #f59e0b4d}.stat-icon{font-size:2.5rem;margin-bottom:.75rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.stats-grid .stat-value{font-size:3rem;font-weight:800;color:#0f172a!important;margin-bottom:.5rem;line-height:1;display:block;letter-spacing:-1px}.stats-grid .stat-label{color:#64748b;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@media(min-width:1024px){.stats-grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:640px)and (max-width:1023px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}.performance-insights{padding:2rem}.performance-insights h2{font-size:1.5rem}.stats-grid .stat-value{font-size:2.5rem}}@media(max-width:639px){.stats-grid{grid-template-columns:1fr;gap:1rem}.performance-insights{padding:1.5rem;border-radius:16px}.performance-insights h2{font-size:1.375rem;margin-bottom:1.5rem}.stats-grid .stat-card{padding:1.75rem 1.5rem}.stat-icon{font-size:2.25rem}.stats-grid .stat-value{font-size:2.5rem}.stats-grid .stat-label{font-size:.8125rem}}.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}.history-cards-mobile{display:none}.history-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s ease}.history-card:hover{box-shadow:0 4px 8px #0000001f}.history-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.history-card-category{flex:1;display:flex;flex-direction:column;gap:.25rem}.category-code{font-size:.875rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.category-name{font-size:.875rem;color:#4b5563;font-weight:500}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.status-badge.completed{background:#dbeafe;color:#1e40af}.status-badge.in-progress{background:#fef3c7;color:#92400e}.history-card-details{display:flex;flex-direction:column;gap:.75rem}.history-detail-row{display:flex;justify-content:space-between;align-items:center}.detail-label{font-size:.875rem;color:#6b7280;font-weight:500}.detail-value{font-size:.9375rem;color:#111827;font-weight:600}.score-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-weight:700;font-size:.875rem}.score-badge.pass{background:#d1fae5;color:#065f46}.score-badge.fail{background:#fee2e2;color:#991b1b}.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{max-width:1400px;margin:0 auto;padding:3rem 2rem;background:#fff;min-height:100vh}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:2px solid #F3F4F6}.analytics-header h2{margin:0;font-size:2rem;font-weight:700;color:#111827;letter-spacing:-.025em}.view-selector{display:flex;gap:.5rem;background:#f9fafb;padding:.375rem;border-radius:12px;border:1px solid #E5E7EB}.view-selector button{background:transparent;border:none;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s ease;color:#6b7280}.view-selector button.active{background:#3b82f6;color:#fff;box-shadow:0 4px 12px #3b82f64d}.view-selector button:hover:not(.active){background:#fff;color:#111827;box-shadow:0 2px 4px #0000000d}.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:linear-gradient(135deg,#fff,#f9fafb);border:2px solid #E5E7EB;border-radius:16px;padding:2rem;display:flex;align-items:center;gap:1.25rem;transition:all .3s ease;position:relative;overflow:hidden}.stat-box:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#3b82f6,#2563eb)}.stat-box:hover{border-color:#3b82f6;box-shadow:0 8px 24px #3b82f626;transform:translateY(-2px)}.stat-icon{font-size:3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.stat-info{flex:1}.stat-value{font-size:2.5rem;font-weight:800;color:#111827;line-height:1;letter-spacing:-.025em}.stat-label{font-size:.875rem;font-weight:600;color:#6b7280;margin-top:.5rem;text-transform:uppercase;letter-spacing:.05em}.chart-section{background:#fff;border:2px solid #E5E7EB;border-radius:16px;padding:2.5rem;box-shadow:0 1px 3px #0000000d}.chart-section h3{margin:0 0 2rem;font-size:1.375rem;font-weight:700;color:#111827;letter-spacing:-.025em}.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:#3b82f6;font-size:1.125rem;font-weight:700}.bar-container{background:#f3f4f6;border-radius:12px;height:40px;overflow:hidden;border:1px solid #E5E7EB}.bar-fill{height:100%;border-radius:12px;transition:width .6s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;padding:0 1rem;color:#fff;font-weight:700;font-size:.875rem;position:relative;overflow:hidden}.bar-fill:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:200%}}.bar-fill.pass{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d}.bar-fill.fail{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d}.trends-section{background:#fff;border:2px solid #E5E7EB;border-radius:16px;padding:2.5rem;box-shadow:0 1px 3px #0000000d}.trends-section h3{margin:0 0 2.5rem;font-size:1.375rem;font-weight:700;color:#111827;letter-spacing:-.025em}.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:2.5rem;padding:2rem;background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #E5E7EB;border-radius:12px}.insights h4{margin:0 0 1.25rem;font-size:1.125rem;font-weight:700;color:#111827}.insights ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.insights li{padding:1rem 1.25rem;border-radius:10px;font-weight:600;font-size:.9375rem;display:flex;align-items:center;gap:.75rem}.insights li:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.insight-positive{background:#ecfdf5;color:#065f46;border:2px solid #10B981}.insight-positive:before{background:#10b981}.insight-warning{background:#fffbeb;color:#92400e;border:2px solid #F59E0B}.insight-warning:before{background:#f59e0b}.categories-section{background:#fff;border:2px solid #E5E7EB;border-radius:16px;padding:2.5rem;box-shadow:0 1px 3px #0000000d}.categories-section h3{margin:0 0 2rem;font-size:1.375rem;font-weight:700;color:#111827;letter-spacing:-.025em}.category-details{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.category-detail-card{background:linear-gradient(135deg,#fff,#f9fafb);border:2px solid #E5E7EB;border-radius:12px;padding:1.75rem;transition:all .3s ease}.category-detail-card:hover{border-color:#3b82f6;box-shadow:0 8px 24px #3b82f626;transform:translateY(-2px)}.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.125rem;font-weight:700;color:#111827;letter-spacing:-.025em}.score-badge{padding:.5rem 1rem;border-radius:8px;font-weight:700;font-size:1.125rem;box-shadow:0 2px 8px #0000001a}.score-badge.pass{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.score-badge.fail{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.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;animation:fadeIn .4s ease-out}.exam-selector-container{max-width:1400px;margin:0 auto;padding:3rem 2rem;animation:slideInUp .5s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.exam-selector-container h1{color:#fff;text-align:center;font-size:3rem;margin:0 0 1rem;font-weight:900;letter-spacing:-1px;text-shadow:0 4px 12px rgba(0,0,0,.2)}.selector-subtitle{color:#fffffff2;text-align:center;font-size:1.375rem;margin:0 0 3rem;font-weight:500;text-shadow:0 2px 8px rgba(0,0,0,.15);max-width:800px;margin-left:auto;margin-right:auto}.exam-options{display:flex;flex-direction:column;gap:2rem}.exam-option{background:#fff;border:none;border-radius:20px;padding:2.5rem;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #00000026;text-align:left;position:relative;overflow:hidden}.exam-option:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.exam-option:hover:before{left:100%}.exam-option:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 48px #00000040}.exam-option:active{transform:translateY(-4px) scale(1.01)}.full-exam-option{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:3px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #10b9814d}.full-exam-option:after{content:"";position:absolute;inset:0;border-radius:20px;padding:3px;background:linear-gradient(135deg,#fff6,#ffffff1a);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.full-exam-option:hover{box-shadow:0 16px 56px #10b98180;border-color:#fff6}.exam-option-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:1rem}.exam-option-header h2{margin:0;font-size:2rem;flex:1;font-weight:800;letter-spacing:-.5px}.exam-option-header h3{margin:0;font-size:1.5rem;color:#667eea}.category-exam-option .exam-option-header{justify-content:flex-start;margin-bottom:.75rem}.exam-badge{background:#ffffff4d;color:#fff;padding:.625rem 1.25rem;border-radius:12px;font-weight:800;font-size:.95rem;letter-spacing:.5px;box-shadow:0 2px 8px #00000026;transition:all .3s ease}.exam-option:hover .exam-badge{transform:scale(1.05);box-shadow:0 4px 12px #0003}.exam-badge.all{background:#fff6;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.category-exam-option .exam-badge{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#667eea;font-size:1.125rem;font-weight:800;padding:.625rem 1rem;border:2px solid #c4b5fd;box-shadow:0 2px 8px #667eea33}.exam-description{margin:0 0 1.5rem;font-size:1.25rem;opacity:.95;font-weight:500;line-height:1.6}.category-exam-name{margin:0 0 1.25rem;font-size:1.25rem;color:#1e293b;font-weight:700;line-height:1.5;min-height:3rem}.exam-details{display:flex;gap:2rem;font-weight:700;opacity:.95;font-size:1.125rem}.exam-details span{display:flex;align-items:center;gap:.5rem;transition:transform .3s ease}.exam-option:hover .exam-details span{transform:translateY(-2px)}.exam-details-small{display:flex;gap:1.5rem;font-size:.95rem;color:#64748b;font-weight:700}.exam-details-small span{display:flex;align-items:center;gap:.375rem;transition:color .3s ease}.category-exam-option:hover .exam-details-small span{color:#475569}.category-exams-header{margin-top:3rem;text-align:center;padding:2rem;background:#ffffff1a;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);margin-bottom:2rem}.category-exams-header h3{color:#fff;font-size:2rem;margin:0 0 .75rem;font-weight:800;letter-spacing:-.5px;text-shadow:0 2px 8px rgba(0,0,0,.15)}.category-exams-header p{color:#fffffff2;margin:0;font-size:1.125rem;font-weight:500}.category-exam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.category-exam-option{animation:fadeInScale .5s ease-out backwards}.category-exam-option:nth-child(1){animation-delay:.1s}.category-exam-option:nth-child(2){animation-delay:.15s}.category-exam-option:nth-child(3){animation-delay:.2s}.category-exam-option:nth-child(4){animation-delay:.25s}.category-exam-option:nth-child(5){animation-delay:.3s}.category-exam-option:nth-child(6){animation-delay:.35s}.category-exam-option:nth-child(7){animation-delay:.4s}.category-exam-option:nth-child(8){animation-delay:.45s}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.category-exam-option{position:relative;display:flex;flex-direction:column;background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #e2e8f0}.category-exam-option:hover{border-color:#667eea;background:linear-gradient(135deg,#fff,#faf5ff)}.cancel-selector-button{display:block;margin:3rem auto 0;background:#ffffff26;color:#fff;border:3px solid rgba(255,255,255,.4);padding:1.125rem 3rem;border-radius:16px;font-size:1.125rem;font-weight:800;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #0003}.cancel-selector-button:hover{background:#ffffff40;border-color:#fff;transform:translateY(-2px);box-shadow:0 6px 24px #0000004d}.cancel-selector-button:active{transform:translateY(0)}@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!important;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)!important;gap:1.25rem}.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-desktop{display:none}.history-cards-mobile{display:block}.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}}.daily-learning-section{margin-bottom:2rem}.daily-learning-card{display:grid;grid-template-columns:1fr 300px;gap:2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:2rem;color:#fff;box-shadow:0 4px 6px -1px #0000001a}.daily-learning-content{display:flex;flex-direction:column;gap:1.5rem}.daily-learning-header{display:flex;align-items:center;gap:1rem}.daily-learning-icon{font-size:3rem}.daily-learning-header h2{margin:0;font-size:1.75rem;font-weight:700}.daily-learning-header p{margin:.25rem 0 0;opacity:.9;font-size:1rem}.daily-learning-features{display:flex;flex-wrap:wrap;gap:.75rem}.feature-badge{background:#fff3;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600}.start-daily-learning-button{background:#fff;color:#667eea;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:all .2s;max-width:300px}.start-daily-learning-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0003}.daily-learning-preview{display:flex;align-items:center;justify-content:center}.preview-card{background:#fff;border-radius:12px;padding:1.5rem;width:100%;box-shadow:0 4px 6px #0000001a;transform:rotate(-3deg);transition:transform .3s}.preview-card:hover{transform:rotate(0)}.preview-front{color:#0f172a}.preview-label{font-size:.75rem;font-weight:600;color:#0ea5e9;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.preview-text{font-size:1rem;line-height:1.5;font-weight:500}@media(max-width:968px){.daily-learning-card{grid-template-columns:1fr}.daily-learning-preview{display:none}}@media(max-width:640px){.daily-learning-card{padding:1.5rem}.daily-learning-header h2{font-size:1.5rem}.daily-learning-header p{font-size:.9375rem}.daily-learning-icon{font-size:2.5rem}.feature-badge{font-size:.8125rem;padding:.375rem .75rem}.start-daily-learning-button{font-size:1rem;max-width:100%}}@media(max-width:767px){.analytics-panel{padding:1.5rem 1rem}.analytics-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:2rem;padding-bottom:1rem}.analytics-header h2{font-size:1.5rem}.view-selector{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.view-selector::-webkit-scrollbar{display:none}.view-selector button{padding:.5rem 1rem;font-size:.875rem;white-space:nowrap}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-box{padding:1.25rem}.stat-icon,.stat-value{font-size:2rem}.stat-label{font-size:.8125rem}.chart-section,.trends-section,.categories-section{padding:1.5rem}.chart-section h3,.trends-section h3,.categories-section h3{font-size:1.125rem;margin-bottom:1.25rem}.bar-item{gap:.375rem}.bar-category,.bar-value{font-size:.875rem}.bar-container{height:36px}.line-chart{height:280px;flex-direction:column;gap:.5rem}.chart-y-axis{flex-direction:row;justify-content:space-between;padding:0;width:100%;order:-1}.chart-canvas{width:100%;padding-bottom:20px}.chart-x-axis{font-size:.6875rem;padding:0}.insights{padding:1.25rem;margin-top:1.5rem}.insights h4{font-size:1rem}.insights li{padding:.875rem 1rem;font-size:.875rem}.category-details{grid-template-columns:1fr;gap:1rem}.category-detail-card{padding:1.25rem}.category-detail-header{flex-direction:column;align-items:flex-start;gap:.75rem}.category-detail-header h4{font-size:1rem}.score-badge{padding:.375rem .75rem;font-size:1rem}.category-detail-stats{grid-template-columns:1fr 1fr;gap:.625rem}.detail-label{font-size:.75rem}.detail-value{font-size:1rem}}
