:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.subscription-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10001;padding:1rem}.subscription-modal{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d;position:relative}.subscription-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem 0;margin-bottom:.5rem}.subscription-modal-header h2{margin:0;color:#1a1a1a;font-size:1.5rem;font-weight:600}.close-button{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:.25rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-button:hover{background-color:#f5f5f5}.subscription-modal-content{padding:0 1.5rem 1rem}.subscription-message{color:#4a4a4a;font-size:.95rem;line-height:1.4;margin-bottom:1rem;text-align:center}.pricing-card{border:2px solid #e0e0e0;border-radius:8px;padding:1rem;margin-bottom:.75rem}.pricing-header{text-align:center;margin-bottom:1rem}.pricing-header h3{margin:0 0 .5rem;color:#1a1a1a;font-size:1.25rem;font-weight:600}.pricing-display{display:flex;flex-direction:column;align-items:center;gap:.25rem}.regular-price{color:#888;text-decoration:line-through;font-size:.9rem}.beta-pricing{display:flex;align-items:center;gap:.5rem}.beta-price{font-size:1.5rem;font-weight:700;color:#2563eb}.beta-label{background:linear-gradient(45deg,#f59e0b,#ef4444);color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.features-list{margin-bottom:1rem}.features-list h4{margin:0 0 .5rem;color:#1a1a1a;font-size:.95rem;font-weight:600}.features-list li{display:flex;align-items:flex-start;gap:.5rem;padding:.15rem 0;color:#4a4a4a;font-size:.85rem;line-height:1.3}.checkmark{color:#22c55e;font-weight:700;flex-shrink:0;margin-top:.1rem}.trial-info{background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;padding:.75rem;margin-bottom:1rem}.trial-notice{margin:0;color:#0369a1;font-size:.85rem;line-height:1.3}.modal-actions{display:flex;flex-direction:column;gap:.75rem}.upgrade-button{background:#22c55e;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;display:block;margin:0 auto;max-width:300px}.upgrade-button:hover:not(:disabled){background:#16a34a;transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.continue-trial-button{background:transparent;color:#6b7280;border:1px solid #d1d5db;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s;width:100%;box-sizing:border-box}.continue-trial-button:hover{background:#f9fafb;border-color:#9ca3af}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem;border-radius:6px;font-size:.9rem;margin-top:1rem;text-align:center}.subscription-details{text-align:center;margin-top:1rem}.fine-print{color:#6b7280;font-size:.8rem;line-height:1.4;margin:.25rem 0}@media (max-width: 640px){.subscription-modal-overlay{padding:.5rem}.subscription-modal{margin:0;max-height:calc(100vh - 1rem)}.subscription-modal-header{padding:.75rem 1rem 0;margin-bottom:.25rem}.subscription-modal-header h2{font-size:1.25rem}.subscription-modal-content{padding:0 1rem .75rem}.subscription-message{font-size:.9rem;margin-bottom:.75rem}.pricing-card{padding:.75rem;margin-bottom:.5rem}.pricing-header{margin-bottom:.75rem}.beta-price{font-size:1.1rem}.features-list{margin-bottom:.75rem}.features-list h4{font-size:.9rem;margin-bottom:.25rem}.features-list li{font-size:.8rem;padding:.1rem 0}.trial-info{padding:.5rem;margin-bottom:.75rem}.trial-notice{font-size:.8rem}.modal-actions{gap:.5rem}.upgrade-button{padding:.875rem 1rem;font-size:.95rem;width:100%}}.trial-banner{position:relative;padding:.75rem 1rem;margin:0 0 1rem;border-radius:8px;border:1px solid;animation:slideIn .3s ease-out}.trial-banner.normal{background:linear-gradient(90deg,#dbeafe,#e0f2fe);border-color:#93c5fd;color:#1e40af}.trial-banner.warning{background:linear-gradient(90deg,#fef3c7,#fef7cd);border-color:#fbbf24;color:#92400e}.trial-banner.urgent{background:linear-gradient(90deg,#fee2e2,#fef2f2);border-color:#f87171;color:#dc2626}.trial-banner.expired{background:linear-gradient(90deg,#fecaca,#fee2e2);border-color:#ef4444;color:#dc2626}.trial-banner-content{display:flex;align-items:center;justify-content:space-between;gap:1rem}.trial-banner-message{display:flex;align-items:center;gap:.5rem;flex:1}.trial-icon{font-size:1.1rem;flex-shrink:0}.trial-text-container{display:flex;flex-direction:column;gap:4px}.trial-text{font-size:.9rem;font-weight:500;line-height:1.4}.trial-bonus-text{font-size:.8rem;color:#059669;font-weight:600}.trial-referral-cta{font-size:.8rem;color:#2563eb;font-weight:500;cursor:pointer;text-decoration:underline;transition:color .2s}.trial-referral-cta:hover{color:#1d4ed8;text-decoration:underline}.trial-banner-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.trial-upgrade-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.trial-upgrade-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0003}.trial-dismiss-button{background:#fffc;color:currentColor;border:1px solid currentColor;border-radius:50%;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;font-weight:700;transition:all .2s;padding:0;line-height:1}.trial-dismiss-button:hover{background:#fff;transform:scale(1.1)}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.trial-banner{padding:.625rem .75rem;margin:0 0 .75rem}.trial-banner-content{flex-direction:column;align-items:stretch;gap:.75rem}.trial-banner-message{text-align:center}.trial-banner-actions{justify-content:center}.trial-text{font-size:.85rem}.trial-upgrade-button{padding:.625rem 1.25rem;font-size:.9rem}}@media (max-width: 480px){.trial-banner-content{gap:.5rem}.trial-upgrade-button{padding:.5rem 1rem;font-size:.8rem}.trial-text{font-size:.8rem}}.expired-trial-overlay{position:fixed;inset:0;background:#000c;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem}.expired-trial-modal{background:#fff;border-radius:16px;max-width:400px;width:100%;padding:1.25rem;position:relative;box-shadow:0 20px 60px #0000004d}.expired-header{text-align:center;margin-bottom:1rem}.expired-icon{font-size:3rem;margin-bottom:.5rem}.expired-header h2{color:#dc3545;font-size:1.5rem;margin-bottom:.5rem;font-weight:700}.expired-header p{color:#6c757d;line-height:1.4;font-size:.95rem;margin:0}.expired-pricing{text-align:center;margin-bottom:1rem}.simple-pricing{display:flex;flex-direction:column;align-items:center;gap:.25rem}.price-text{font-size:1.5rem;color:#10b981;font-weight:700}.beta-note{font-size:.8rem;color:#6c757d;font-weight:500}.expired-actions{display:flex;gap:1rem;margin-bottom:1rem}.expired-actions button{border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;flex:1;padding:.75rem 1rem;text-decoration:none;border:2px solid;line-height:1.2;height:52px;display:flex;align-items:center;justify-content:center}.upgrade-button{background:#10b981;color:#fff;border-color:#10b981}.upgrade-button:hover{background:#059669;border-color:#059669}.expired-actions .logout-link{background:transparent;color:#dc3545;border-color:#dc3545}.expired-actions .logout-link:hover{background:#dc3545;color:#fff;border-color:#dc3545}.expired-footer{text-align:center;padding-top:.75rem;border-top:1px solid #e9ecef}.expired-footer p{color:#6c757d;font-size:.8rem;margin:.25rem 0}.help-link{color:#667eea;text-decoration:none}.help-link:hover{color:#5a67d8;text-decoration:underline}@media (max-width: 768px){.expired-trial-modal{padding:1.5rem;margin:.5rem}.expired-header h2{font-size:1.75rem}.expired-header p{font-size:1rem}.features-grid{grid-template-columns:1fr;gap:.75rem}.feature-item{padding:.5rem}.beta-price{font-size:2rem}.price-row{flex-direction:column;gap:.5rem}}@media (max-width: 480px){.expired-trial-overlay{padding:.5rem}.expired-trial-modal{padding:1rem}.expired-icon{font-size:3rem}.expired-header h2{font-size:1.5rem}.beta-price{font-size:1.75rem}.upgrade-button,.browse-button{padding:.875rem 1.5rem;font-size:1rem}}.cancelled-banner{background:linear-gradient(45deg,#ffeaa7,#fdcb6e);border:2px solid #e17055;border-radius:8px;margin:1rem 0;padding:1rem;box-shadow:0 2px 10px #e1705533}.cancelled-content{display:flex;align-items:center;gap:1rem}.cancelled-icon{font-size:2rem;flex-shrink:0}.cancelled-message{flex:1}.cancelled-message h3{color:#d63031;margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.cancelled-message p{color:#2d3436;margin:0;line-height:1.4}.cancelled-message strong{color:#d63031}.cancelled-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.reactivate-button{background:linear-gradient(45deg,#00b894,#00a085);color:#fff;border:none;padding:.75rem 1.25rem;border-radius:6px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.reactivate-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00b8944d}.dismiss-button{background:transparent;border:none;color:#636e72;font-size:1.5rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s;line-height:1;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.dismiss-button:hover{background:#636e721a;color:#2d3436}@media (max-width: 768px){.cancelled-content{flex-direction:column;align-items:flex-start;gap:1rem}.cancelled-actions{align-self:stretch;justify-content:space-between}.reactivate-button{flex:1}}@media (max-width: 480px){.cancelled-banner{margin:.5rem 0;padding:.75rem}.cancelled-message h3{font-size:1rem}.cancelled-message p{font-size:.9rem}.reactivate-button{padding:.625rem 1rem;font-size:.85rem}}.minimal-welcome{margin-bottom:1rem}.trial-expired-banner,.trial-ending-banner{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:6px;font-size:.9rem}.trial-expired-banner{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.trial-ending-banner{background:#fef3c7;border:1px solid #fbbf24;color:#92400e}.trial-message{font-weight:500}.upgrade-button-small{background:#2563eb;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.upgrade-button-small:hover{background:#1d4ed8}@media (max-width: 640px){.trial-expired-banner,.trial-ending-banner{flex-direction:column;gap:.75rem;text-align:center}.upgrade-button-small{width:100%}}.framework-drill{max-width:800px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.drill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:15px;border-bottom:2px solid #e9ecef}.drill-header h3{margin:0;color:#2c3e50;font-size:24px;font-weight:600}.progress-indicator{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500}.problem-container{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #0000000d;border:1px solid #e9ecef;margin-bottom:20px}.question-text{font-size:18px;line-height:1.6;color:#2c3e50;margin-bottom:20px;font-weight:500}.instruction-text{font-size:14px;color:#6c757d;margin-bottom:20px;font-style:italic;padding:10px;background:#f8f9fa;border-radius:6px;border-left:3px solid #007bff}.options-container{margin-bottom:25px}.options-container.single-select{display:grid;gap:12px}.options-container.multi-select{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}.option-button{display:flex;align-items:center;gap:12px;padding:15px 20px;border:2px solid #e9ecef;border-radius:8px;background:#fff;color:#495057;font-size:16px;text-align:left;cursor:pointer;transition:all .2s ease;min-height:60px}.option-button:hover:not(.disabled){border-color:#007bff;background:#f8f9ff;transform:translateY(-1px)}.option-button.selected{border-color:#007bff;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.option-button.disabled{cursor:not-allowed;opacity:.7}.checkbox{font-size:18px;font-weight:700;min-width:20px}.selection-counter{text-align:center;font-size:14px;color:#6c757d;margin-bottom:20px;font-weight:500}.submit-button{width:100%;padding:15px;border:none;border-radius:8px;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.feedback{padding:20px;border-radius:8px;margin-top:20px}.feedback.correct{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #c3e6cb;color:#155724}.feedback.incorrect{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:1px solid #f5c6cb;color:#721c24}.feedback-explanation{font-size:16px;line-height:1.5}.session-stats{display:flex;justify-content:space-around;background:#f8f9fa;padding:15px;border-radius:8px;border:1px solid #e9ecef}.session-stats span{font-size:14px;font-weight:500;color:#495057}.framework-drill.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:18px;color:#6c757d}@media (max-width: 768px){.framework-drill{padding:15px}.drill-header{flex-direction:column;gap:15px;text-align:center}.problem-container{padding:20px}.options-container.multi-select{grid-template-columns:1fr}.option-button{min-height:50px;padding:12px 16px}.session-stats{flex-direction:column;gap:8px;text-align:center}}.issue-tree-builder{max-width:1000px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.builder-header{text-align:center;margin-bottom:30px}.builder-header h3{color:#2c3e50;font-size:28px;margin-bottom:10px}.builder-header p{color:#6c757d;font-size:16px;margin:0}.main-question{display:flex;justify-content:center;margin-bottom:40px}.question-box{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 30px;border-radius:12px;font-size:18px;font-weight:600;text-align:center;max-width:600px;box-shadow:0 6px 20px #667eea4d}.tree-container{min-height:300px;background:#f8f9fa;border:2px dashed #dee2e6;border-radius:12px;padding:30px;margin-bottom:30px;position:relative}.tree-visualization{display:flex;flex-direction:column;gap:20px;align-items:center}.tree-branch{background:#fff;border:2px solid #e9ecef;border-radius:8px;padding:15px;min-width:200px;max-width:400px;cursor:pointer;transition:all .2s ease;position:relative}.tree-branch:hover{border-color:#007bff;transform:translateY(-2px);box-shadow:0 4px 12px #007bff26}.tree-branch.selected{border-color:#007bff;background:linear-gradient(135deg,#e3f2fd,#bbdefb);box-shadow:0 4px 12px #007bff33}.tree-branch.level-1{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-color:#ff9800}.tree-branch.level-2{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border-color:#4caf50}.branch-content{display:flex;justify-content:space-between;align-items:center}.branch-text{font-weight:500;color:#2c3e50;flex-grow:1}.remove-branch{background:#dc3545;color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-left:10px}.remove-branch:hover{background:#c82333}.sub-branches{margin-top:15px;padding-top:15px;border-top:1px solid #dee2e6;display:flex;flex-wrap:wrap;gap:8px}.sub-branch{background:#e9ecef;padding:6px 12px;border-radius:15px;font-size:14px;color:#495057}.input-section{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:25px}.add-branch-form{display:flex;gap:15px;margin-bottom:15px}.branch-input{flex-grow:1;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;outline:none;transition:border-color .2s ease}.branch-input:focus{border-color:#007bff}.add-button{padding:12px 24px;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.selected-info{display:flex;align-items:center;gap:15px;color:#495057;font-size:14px}.clear-selection{background:#6c757d;color:#fff;border:none;padding:6px 12px;border-radius:5px;font-size:12px;cursor:pointer}.feedback{padding:15px 20px;border-radius:8px;margin-bottom:20px;font-weight:500}.feedback.success{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #c3e6cb;color:#155724}.feedback.warning{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #ffeaa7;color:#856404}.feedback.info{background:linear-gradient(135deg,#d1ecf1,#bee5eb);border:1px solid #bee5eb;color:#0c5460}.builder-actions{display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;padding:20px;border-radius:8px;border:1px solid #e9ecef}.tree-stats{font-size:14px;color:#6c757d;font-weight:500}.action-buttons{display:flex;gap:12px}.reset-button,.check-button,.complete-button{padding:10px 20px;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.reset-button{background:#6c757d;color:#fff}.check-button{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.complete-button{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.complete-button:disabled{background:#6c757d;cursor:not-allowed}.reset-button:hover,.check-button:hover,.complete-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0003}.completion-modal{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:40px;border-radius:12px;text-align:center;max-width:500px;box-shadow:0 20px 40px #0000004d}.modal-content h4{color:#28a745;font-size:24px;margin-bottom:15px}.completion-actions{display:flex;gap:15px;justify-content:center;margin-top:25px}.continue-button,.exit-button{padding:12px 24px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.continue-button{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.issue-tree-builder.loading{display:flex;justify-content:center;align-items:center;height:300px;font-size:18px;color:#6c757d}@media (max-width: 768px){.issue-tree-builder{padding:15px}.question-box{padding:15px 20px;font-size:16px}.tree-container{padding:20px}.add-branch-form{flex-direction:column}.builder-actions{flex-direction:column;gap:15px;text-align:center}.action-buttons{justify-content:center}.tree-branch{min-width:150px;max-width:300px}}.case-flow-trainer{max-width:900px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.trainer-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:25px;border-radius:12px;margin-bottom:30px;text-align:center}.trainer-header h3{margin:0 0 15px;font-size:28px;font-weight:600}.case-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.case-title{font-size:18px;font-weight:500}.timer{font-size:16px;font-weight:600;padding:8px 16px;border-radius:20px;background:#fff3}.timer.time-warning{background:#ffc107;color:#000}.timer.time-critical{background:#dc3545;color:#fff;animation:pulse 1s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.phase-progress{display:flex;justify-content:center;gap:20px;align-items:center}.phase-dot{width:40px;height:40px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;position:relative}.phase-dot.active{background:#28a745;box-shadow:0 0 0 3px #28a7454d}.phase-dot.completed{background:#20c997}.phase-dot:not(:last-child):after{content:"";position:absolute;left:100%;top:50%;width:20px;height:2px;background:#ffffff80;transform:translateY(-50%)}.phase-content{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #0000000d;border:1px solid #e9ecef;margin-bottom:25px;min-height:400px}.phase-content h4{color:#2c3e50;font-size:24px;margin-bottom:20px;border-bottom:2px solid #e9ecef;padding-bottom:10px}.case-brief{background:#f8f9fa;padding:20px;border-radius:8px;border-left:4px solid #007bff;font-size:16px;line-height:1.6;margin-bottom:20px}.case-context{background:#fff3e0;padding:20px;border-radius:8px;border-left:4px solid #ff9800;margin-bottom:25px}.case-context h5{margin-top:0;color:#2c3e50;font-size:16px}.case-context ul{margin:10px 0;padding-left:20px}.case-context li{margin-bottom:8px;line-height:1.4}.guidance{background:#e8f5e8;padding:15px;border-radius:8px;border-left:4px solid #28a745;margin-bottom:20px;font-style:italic}.response-textarea{width:100%;padding:15px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;line-height:1.5;resize:vertical;min-height:150px;outline:none;transition:border-color .2s ease}.response-textarea:focus{border-color:#007bff}.word-count{text-align:right;font-size:14px;color:#6c757d;margin:10px 0}.math-problem{background:#f8f9fa;padding:25px;border-radius:8px;border:1px solid #e9ecef;margin-bottom:20px}.problem-text{font-size:18px;margin-bottom:20px;color:#2c3e50;font-weight:500}.math-input{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;outline:none;transition:border-color .2s ease}.math-input:focus{border-color:#007bff}.expected-areas{background:#fff3e0;padding:20px;border-radius:8px;border-left:4px solid #ff9800;margin-bottom:20px}.expected-areas ul{margin:10px 0;padding-left:20px}.expected-areas li{margin-bottom:8px}.phase-button{width:100%;padding:15px;border:none;border-radius:8px;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:20px}.phase-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #007bff4d}.phase-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.phase-feedback{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #c3e6cb;border-radius:8px;padding:20px;margin-bottom:25px;color:#155724}.phase-feedback h5{margin-top:0;font-size:18px;font-weight:600}.score-display{font-size:24px;font-weight:700;margin:10px 0;color:#28a745}.feedback-message{font-size:16px;line-height:1.5;margin-bottom:10px}.correct-answer{background:#dc35451a;padding:10px;border-radius:5px;color:#721c24;font-weight:500}.session-stats{background:#f8f9fa;padding:20px;border-radius:8px;border:1px solid #e9ecef}.scores{display:flex;justify-content:space-around;flex-wrap:wrap;gap:15px}.phase-score{background:#fff;padding:10px 15px;border-radius:20px;border:1px solid #dee2e6;font-weight:500;color:#495057;text-transform:capitalize}.case-flow-trainer.loading{display:flex;justify-content:center;align-items:center;height:300px;font-size:18px;color:#6c757d}.framework-buckets{background:#f8f9fa;border-radius:12px;padding:25px;margin-bottom:30px;border:1px solid #e9ecef}.framework-buckets h5{color:#2c3e50;font-size:20px;margin-bottom:10px;font-weight:600}.bucket-instruction{color:#6c757d;font-size:16px;margin-bottom:20px;line-height:1.5}.buckets-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:25px}.framework-bucket{background:#fff;border-radius:8px;padding:15px;border:2px solid #e9ecef;transition:border-color .2s ease}.framework-bucket:hover{border-color:#007bff}.bucket-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.bucket-number{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.bucket-title-input{flex:1;padding:8px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:15px;font-weight:500;outline:none;transition:border-color .2s ease}.bucket-title-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.bucket-title-input::placeholder{color:#adb5bd;font-weight:400}.bucket-content-textarea{width:100%;padding:10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:14px;line-height:1.4;resize:vertical;outline:none;transition:border-color .2s ease;min-height:70px}.bucket-content-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.bucket-content-textarea::placeholder{color:#adb5bd;font-style:italic}.bucket-tips{background:linear-gradient(135deg,#e8f5e8,#d4edda);border-radius:8px;padding:15px;border-left:4px solid #28a745}.bucket-tips strong{color:#155724;font-size:16px}.bucket-tips ul{margin:10px 0 5px;padding-left:20px}.bucket-tips li{color:#155724;font-size:14px;margin-bottom:5px;line-height:1.4}.traditional-approach{margin-top:25px;padding-top:25px;border-top:2px solid #e9ecef}.traditional-approach h5{color:#6c757d;font-size:16px;margin-bottom:15px;font-weight:500}@media (max-width: 768px){.case-flow-trainer{padding:15px}.trainer-header{padding:20px}.trainer-header h3{font-size:24px}.case-info{flex-direction:column;text-align:center}.phase-progress{gap:15px}.phase-dot{width:35px;height:35px;font-size:14px}.phase-dot:not(:last-child):after{width:15px}.phase-content{padding:20px}.response-textarea{min-height:120px}.scores{flex-direction:column;align-items:center}.phase-score{width:100%;text-align:center}.framework-buckets{padding:20px}.buckets-container{grid-template-columns:1fr;gap:15px}.framework-bucket{padding:12px}.bucket-number{width:24px;height:24px;font-size:12px}.bucket-title-input{font-size:14px;padding:6px 10px}.bucket-content-textarea{font-size:13px;padding:8px 10px;min-height:60px}.bucket-tips{padding:12px}.bucket-tips strong{font-size:15px}.bucket-tips li{font-size:13px}}.case-story-mode{max-width:800px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.story-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:25px;border-radius:12px;margin-bottom:30px;text-align:center}.story-header h3{margin:0 0 10px;font-size:24px;font-weight:600}.scenario-description{font-size:16px;margin-bottom:20px;opacity:.9}.progress-section{margin-top:20px}.progress-bar{width:100%;height:8px;background:#ffffff4d;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);transition:width .3s ease}.progress-text{font-size:14px;font-weight:500;opacity:.9}.question-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #0000000d;border:1px solid #e9ecef;margin-bottom:25px}.step-context{display:flex;align-items:center;gap:15px;margin-bottom:20px}.step-badge{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;padding:6px 12px;border-radius:15px;font-size:14px;font-weight:600}.context-label{background:#f8f9fa;color:#6c757d;padding:6px 12px;border-radius:15px;font-size:12px;font-weight:600;letter-spacing:.5px}.question-text{font-size:18px;line-height:1.6;color:#2c3e50;margin-bottom:25px;font-weight:500;padding:20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #007bff}.previous-answers{margin-bottom:25px;padding:20px;background:#fff3e0;border-radius:8px;border-left:4px solid #ff9800}.previous-answers h5{margin:0 0 15px;color:#2c3e50;font-size:16px}.answer-chain{display:flex;flex-direction:column;gap:8px}.previous-answer{display:flex;align-items:center;gap:12px;font-size:14px}.answer-step{font-weight:600;color:#495057;min-width:60px}.answer-value{font-weight:600;color:#28a745;font-family:Monaco,Consolas,monospace}.answer-context{color:#6c757d;font-style:italic}.input-section{display:flex;gap:15px;margin-bottom:25px}.answer-input{flex-grow:1;padding:15px 20px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;outline:none;transition:border-color .2s ease;font-family:Monaco,Consolas,monospace}.answer-input:focus{border-color:#007bff}.answer-input:disabled{background:#f8f9fa;color:#6c757d}.submit-button{padding:15px 25px;border:none;border-radius:8px;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #28a7454d}.submit-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.step-feedback{padding:20px;border-radius:8px;margin-top:20px}.step-feedback.correct{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #c3e6cb;color:#155724}.step-feedback.incorrect{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:1px solid #f5c6cb;color:#721c24}.feedback-header{font-size:18px;font-weight:600;margin-bottom:10px}.feedback-answer{font-size:16px;font-weight:500;margin-bottom:10px;font-family:Monaco,Consolas,monospace}.feedback-explanation{font-size:15px;line-height:1.5;margin-bottom:12px}.next-step-hint{font-size:14px;font-style:italic;opacity:.8}.session-info{background:#f8f9fa;padding:15px 20px;border-radius:8px;border:1px solid #e9ecef}.current-stats{display:flex;justify-content:space-around;font-size:14px;font-weight:500;color:#495057}.case-story-mode.completion{text-align:center}.completion-header{margin-bottom:30px}.completion-header h3{color:#28a745;font-size:28px;margin-bottom:10px}.case-title{font-size:18px;color:#6c757d;font-weight:500}.completion-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;margin-bottom:40px}.stat-box{background:#fff;padding:25px;border-radius:12px;box-shadow:0 4px 6px #0000000d;border:1px solid #e9ecef}.stat-value{font-size:32px;font-weight:700;color:#28a745;margin-bottom:8px}.stat-label{font-size:14px;color:#6c757d;font-weight:500}.step-review{text-align:left;margin-bottom:30px}.step-review h4{color:#2c3e50;margin-bottom:20px;font-size:20px}.steps-summary{display:flex;flex-direction:column;gap:15px}.step-summary{background:#fff;padding:20px;border-radius:8px;border:1px solid #e9ecef;box-shadow:0 2px 4px #0000000d}.step-summary.correct{border-left:4px solid #28a745}.step-summary.incorrect{border-left:4px solid #dc3545}.step-number{font-weight:600;color:#007bff;margin-bottom:8px}.step-question{font-size:15px;margin-bottom:10px;color:#2c3e50}.step-answers{display:flex;flex-direction:column;gap:5px;font-size:14px}.user-answer{color:#495057}.correct-answer{color:#28a745;font-weight:500}.completion-actions{display:flex;justify-content:center;gap:20px}.restart-button,.exit-button{padding:15px 30px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.restart-button{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.exit-button{background:#6c757d;color:#fff}.restart-button:hover,.exit-button:hover{transform:translateY(-2px);box-shadow:0 6px 12px #0003}.case-story-mode.loading{display:flex;justify-content:center;align-items:center;height:300px;font-size:18px;color:#6c757d}@media (max-width: 768px){.case-story-mode{padding:15px}.story-header,.question-section{padding:20px}.step-context{flex-direction:column;align-items:flex-start;gap:10px}.input-section{flex-direction:column}.current-stats{flex-direction:column;gap:10px}.completion-stats{grid-template-columns:1fr}.completion-actions{flex-direction:column;align-items:center}.restart-button,.exit-button{width:100%;max-width:300px}.answer-chain{gap:12px}.previous-answer{flex-direction:column;align-items:flex-start;gap:4px}}.skills-assessment-intro{max-width:600px;margin:0 auto;padding:2rem;text-align:center}.assessment-header h2{color:#1a1a1a;font-size:2rem;margin-bottom:.5rem}.assessment-subtitle{color:#6b7280;font-size:1.1rem;margin-bottom:2rem;line-height:1.5}.assessment-details{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;text-align:left}.detail-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#f8fafc;border-radius:8px}.detail-icon{font-size:1.5rem;flex-shrink:0;margin-top:.25rem}.detail-item strong{color:#1a1a1a;font-size:1.1rem;display:block;margin-bottom:.25rem}.detail-item p{color:#6b7280;margin:0;font-size:.9rem;line-height:1.4}.assessment-actions{display:flex;gap:1rem;justify-content:center}.start-assessment-button{background:linear-gradient(45deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s}.start-assessment-button:hover{background:linear-gradient(45deg,#1d4ed8,#1e40af);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.cancel-button{background:transparent;color:#6b7280;border:1px solid #d1d5db;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:all .2s}.cancel-button:hover{background:#f9fafb;border-color:#9ca3af}.skills-assessment{max-width:800px;margin:0 auto;padding:1rem}.assessment-progress{margin-bottom:2rem}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-weight:500}.time-remaining{font-family:Courier New,monospace;font-size:1.1rem;padding:.25rem .5rem;border-radius:4px}.time-normal{background:#dcfce7;color:#166534}.time-warning{background:#fef3c7;color:#92400e}.time-critical{background:#fee2e2;color:#dc2626;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);transition:width .3s ease}.question-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem;text-align:center;box-shadow:0 2px 8px #0000001a}.question-text{font-size:1.5rem;color:#1a1a1a;margin-bottom:2rem;line-height:1.4;font-weight:500}.answer-form{display:flex;flex-direction:column;gap:1rem;align-items:center}.answer-input{width:100%;max-width:300px;padding:1rem;font-size:1.2rem;border:2px solid #d1d5db;border-radius:8px;text-align:center;transition:border-color .2s}.answer-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.submit-answer-button{background:#3b82f6;color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.submit-answer-button:hover{background:#2563eb;transform:translateY(-1px)}.assessment-results{max-width:700px;margin:0 auto;padding:2rem}.results-header{text-align:center;margin-bottom:2rem}.results-header h2{color:#1a1a1a;font-size:2rem;margin-bottom:1rem}.results-summary{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem}.result-stat{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#f8fafc;border-radius:8px;min-width:120px}.stat-value{font-size:1.75rem;font-weight:700;color:#1a1a1a;margin-bottom:.25rem}.stat-label{color:#6b7280;font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.skill-breakdown{margin-bottom:2rem}.skill-breakdown h3{color:#1a1a1a;font-size:1.25rem;margin-bottom:1rem;text-align:center}.skill-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.skill-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.skill-name{font-size:.85rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.skill-score{font-size:1.1rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.skill-bar{width:100%;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.skill-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);transition:width .5s ease}.results-actions{text-align:center}.continue-button{background:linear-gradient(45deg,#10b981,#059669);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s}.continue-button:hover{background:linear-gradient(45deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}@media (max-width: 640px){.skills-assessment-intro,.assessment-results,.skills-assessment{padding:1rem}.assessment-details{gap:1rem}.detail-item{padding:.75rem}.assessment-actions{flex-direction:column}.start-assessment-button,.cancel-button{padding:.875rem 1.5rem;font-size:1rem}.results-summary{flex-direction:column;gap:1rem}.result-stat{min-width:auto}.question-text{font-size:1.25rem}.answer-input{font-size:1rem}.skill-grid{grid-template-columns:1fr}}.assessment-page{min-height:calc(100vh - 80px);background:#f8fafc}.assessment-container{max-width:1000px;margin:0 auto;padding:2rem}.assessment-overview{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.assessment-overview h1{color:#1a1a1a;font-size:2.5rem;margin-bottom:.5rem;text-align:center}.overview-subtitle{color:#6b7280;font-size:1.1rem;text-align:center;margin-bottom:2rem;line-height:1.5}.assessment-intro{margin-bottom:3rem}.intro-content h2{color:#1a1a1a;font-size:1.5rem;margin-bottom:1rem}.intro-content>p{color:#4b5563;font-size:1rem;line-height:1.6;margin-bottom:2rem}.assessment-benefits{display:grid;gap:1.5rem;margin-bottom:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.benefit-item{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px}.benefit-icon{font-size:1.75rem;flex-shrink:0;margin-top:.25rem}.benefit-item strong{color:#1a1a1a;font-size:1.1rem;display:block;margin-bottom:.5rem}.benefit-item p{color:#6b7280;margin:0;font-size:.95rem;line-height:1.4}.start-new-assessment-button{background:linear-gradient(45deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;display:block;margin:0 auto}.start-new-assessment-button:hover{background:linear-gradient(45deg,#1d4ed8,#1e40af);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.previous-assessments{margin-top:3rem;padding-top:2rem;border-top:1px solid #e5e7eb}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{color:#1a1a1a;font-size:1.5rem;margin:0}.load-assessments-button{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.load-assessments-button:hover{background:#e5e7eb;border-color:#9ca3af}.loading-assessments{text-align:center;color:#6b7280;padding:2rem;font-style:italic}.no-assessments{text-align:center;color:#6b7280;padding:2rem;background:#f9fafb;border-radius:8px;border:1px dashed #d1d5db}.assessments-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.assessment-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;transition:all .2s}.assessment-card:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000001a}.assessment-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.assessment-date{color:#374151;font-weight:500}.assessment-type{background:#e0f2fe;color:#0369a1;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.assessment-stats{display:flex;justify-content:space-around;margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:6px}.stat{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-value{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin-bottom:.25rem}.stat-label{color:#6b7280;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.skill-preview h4{color:#374151;font-size:.95rem;margin:0 0 .75rem;font-weight:600}.skill-bars{display:flex;flex-direction:column;gap:.5rem}.skill-bar-item{display:flex;align-items:center;gap:.75rem;font-size:.85rem}.skill-name{color:#374151;font-weight:500;min-width:80px;text-transform:capitalize}.skill-bar{flex:1;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.skill-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);transition:width .3s ease}.skill-percentage{color:#6b7280;font-weight:500;min-width:35px;text-align:right;font-size:.8rem}@media (max-width: 768px){.assessment-container{padding:1rem}.assessment-overview{padding:1.5rem}.assessment-overview h1{font-size:2rem}.assessment-benefits{grid-template-columns:1fr;gap:1rem}.benefit-item{padding:1rem}.section-header{flex-direction:column;align-items:stretch;gap:1rem}.assessments-grid{grid-template-columns:1fr}.assessment-stats{flex-direction:column;gap:1rem}.stat{flex-direction:row;justify-content:space-between;text-align:left}.skill-bar-item{gap:.5rem}.skill-name{min-width:60px;font-size:.8rem}}.account-page{min-height:100%;background:#f8f9fa;padding:2rem 0;width:100%;flex:1}.account-container{max-width:800px;margin:0 auto;padding:0 1rem}.account-container h1{font-size:2.5rem;color:#2c3e50;margin-bottom:2rem;text-align:center}.account-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 10px #0000001a}.account-section h2{font-size:1.5rem;color:#2c3e50;margin-bottom:1.5rem;border-bottom:2px solid #e9ecef;padding-bottom:.5rem}.status-card,.profile-card,.billing-card{background:#f8f9fa;border-radius:8px;padding:1.5rem}.status-item{display:flex;flex-direction:column;gap:1rem}.status-badge{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;width:fit-content}.status-badge.darden{background:linear-gradient(45deg,#28a745,#20c997);color:#fff}.status-badge.paid{background:linear-gradient(45deg,#6f42c1,#e83e8c);color:#fff}.status-badge.trial{background:linear-gradient(45deg,#007bff,#6610f2);color:#fff}.status-badge.expired{background:linear-gradient(45deg,#dc3545,#fd7e14);color:#fff;animation:pulse 2s infinite}.status-item p{color:#6c757d;margin:0;line-height:1.5}.upgrade-button,.manage-billing-button{background:linear-gradient(45deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;width:fit-content}.upgrade-button:hover,.manage-billing-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.upgrade-button.urgent{background:linear-gradient(45deg,#dc3545,#b02a37);animation:pulse 2s infinite}.upgrade-button.urgent:hover{box-shadow:0 4px 12px #dc35454d}.profile-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid #e9ecef}.profile-item:last-child{border-bottom:none}.profile-item label{font-weight:600;color:#495057;min-width:150px}.email-display{display:flex;align-items:center;gap:1rem}.email-edit{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.email-input{padding:.5rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;min-width:250px}.email-actions{display:flex;gap:.5rem}.save-button,.cancel-button,.edit-button{padding:.4rem .8rem;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .2s}.save-button{background:#28a745;color:#fff}.save-button:hover{background:#218838}.save-button:disabled{background:#6c757d;cursor:not-allowed}.cancel-button{background:#6c757d;color:#fff}.edit-button{background:#007bff;color:#fff}.edit-button:hover{background:#0056b3}.account-type{font-weight:500;color:#495057}.billing-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid #e9ecef}.billing-item:last-child{border-bottom:none;padding-bottom:0}.billing-item label{font-weight:600;color:#495057;min-width:150px}.plan-info{display:flex;flex-direction:column;align-items:flex-end}.plan-name{font-weight:600;color:#2c3e50}.plan-price{font-size:.9rem;color:#28a745;font-weight:500}.billing-actions{display:flex;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef}.cancel-subscription-button{background:#dc3545;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.cancel-subscription-button:hover{background:#c82333;transform:translateY(-1px)}.danger-zone{border:2px solid #dc3545}.danger-zone h2{color:#dc3545;border-bottom-color:#dc3545}.danger-card{background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;padding:1.5rem}.danger-item{display:flex;justify-content:space-between;align-items:center}.danger-item h3{color:#dc3545;margin:0 0 .5rem;font-size:1.1rem}.danger-item p{color:#6c757d;margin:0;max-width:500px}.danger-button{background:#dc3545;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.danger-button:hover{background:#c82333;transform:translateY(-1px)}.loading{text-align:center;padding:2rem;color:#6c757d;font-size:1.1rem}@media (max-width: 768px){.account-container{padding:0 .5rem}.account-container h1{font-size:2rem}.account-section{padding:1.5rem;margin-bottom:1rem}.profile-item,.billing-item{flex-direction:column;align-items:flex-start;gap:.5rem}.email-edit{align-items:stretch;width:100%}.email-input{min-width:auto;width:100%}.email-actions{justify-content:flex-end}.billing-actions{flex-direction:column}.danger-item{flex-direction:column;align-items:flex-start;gap:1rem}.plan-info{align-items:flex-start}}@media (max-width: 480px){.account-section,.status-card,.profile-card,.billing-card,.danger-card{padding:1rem}}.billing-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem 0}.billing-container{max-width:600px;margin:0 auto;padding:0 1rem}.billing-header{text-align:center;margin-bottom:2rem}.billing-header h1{font-size:2.5rem;color:#fff;margin-bottom:1rem;font-weight:700}.trial-status{background:#fff3;color:#fff;padding:.75rem 1.5rem;border-radius:25px;font-weight:600;display:inline-block;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.trial-status.expired{background:#dc3545e6;animation:pulse 2s infinite}.trial-status.ending{background:#ffc107e6}.upgrade-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 10px 30px #0003;margin-bottom:2rem}.plan-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e9ecef}.plan-header h2{font-size:2rem;color:#2c3e50;margin-bottom:1rem}.pricing{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.original-price{font-size:1.2rem;color:#6c757d;text-decoration:line-through}.beta-price{font-size:2.5rem;color:#28a745;font-weight:700}.beta-label{background:linear-gradient(45deg,#28a745,#20c997);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.features-list{margin-bottom:2rem}.features-list h3{color:#2c3e50;margin-bottom:1rem;font-size:1.2rem}.features-list ul{list-style:none;padding:0;margin:0}.features-list li{padding:.5rem 0;color:#495057;font-size:1rem;line-height:1.4}.billing-info{background:#f8f9fa;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.billing-info h3{color:#2c3e50;margin-bottom:1rem;font-size:1.2rem}.billing-info p{color:#6c757d;line-height:1.5;margin-bottom:1rem}.billing-highlights{display:flex;flex-direction:column;gap:.75rem}.highlight-item{display:flex;align-items:center;gap:.75rem;color:#495057;font-size:.95rem}.highlight-icon{font-size:1.2rem}.upgrade-actions{text-align:center}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #f5c6cb}.upgrade-button{background:linear-gradient(45deg,#28a745,#20c997);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s;width:100%;max-width:300px;margin-bottom:1rem}.upgrade-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #28a7454d}.upgrade-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.upgrade-footer{margin-top:1rem}.upgrade-footer p{font-size:.85rem;color:#6c757d;line-height:1.4;margin:0}.trial-reminder{background:#fffffff2;border-radius:12px;padding:1.5rem;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.reminder-content h3{color:#2c3e50;margin-bottom:.75rem;font-size:1.1rem}.reminder-content p{color:#495057;margin:0;line-height:1.5;font-size:.95rem}.support-section{background:#ffffff1a;border-radius:12px;padding:1.5rem;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.support-section h3{color:#fff;margin-bottom:.75rem;font-size:1.2rem}.support-section p{color:#ffffffe6;margin:0;line-height:1.5}.support-section a{color:#ffc107;text-decoration:none;font-weight:600}.support-section a:hover{text-decoration:underline}@media (max-width: 768px){.billing-container{padding:0 .5rem}.billing-header h1{font-size:2rem}.upgrade-card{padding:1.5rem}.plan-header h2{font-size:1.75rem}.beta-price{font-size:2rem}.pricing{flex-direction:column;gap:.5rem}.billing-highlights{gap:.5rem}.highlight-item{font-size:.9rem}}@media (max-width: 480px){.billing-header h1{font-size:1.75rem}.upgrade-card,.trial-reminder,.support-section{padding:1rem}.upgrade-button{padding:.875rem 1.5rem;font-size:1rem}}.auth-confirm-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-confirm-container{background:#fff;border-radius:16px;padding:40px;text-align:center;box-shadow:0 20px 60px #0000001a;max-width:500px;width:100%}.auth-confirm-container h1{margin:20px 0 16px;color:#1a1a1a;font-size:28px;font-weight:600}.auth-confirm-container p{color:#666;font-size:16px;line-height:1.5;margin-bottom:16px}.password-reset-form{text-align:left;margin-top:24px}.password-reset-form .form-group{margin-bottom:20px}.password-reset-form label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:14px}.password-reset-form input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .2s;box-sizing:border-box}.password-reset-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.password-reset-form .submit-button{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.password-reset-form .submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 25px #667eea4d}.password-reset-form .submit-button:disabled{opacity:.6;cursor:not-allowed}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-icon,.error-icon{font-size:48px;margin-bottom:16px}.auth-confirm-container.success{border-left:4px solid #10b981}.auth-confirm-container.error{border-left:4px solid #ef4444}.redirect-message{font-style:italic;color:#10b981;font-weight:500}.error-actions{margin-top:24px}.retry-button{background:#667eea;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.retry-button:hover{background:#5a67d8}@media (max-width: 768px){.auth-confirm-container{padding:30px 20px;margin:10px}.auth-confirm-container h1{font-size:24px}}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:#333;background-color:#f8f9fa;margin:0;padding:0;width:100%;height:100%}body{display:block!important;place-items:unset!important;min-width:unset!important;min-height:unset!important}#root{width:100%;min-height:100vh;margin:0;padding:0;display:block}.app{min-height:100vh;display:flex;flex-direction:column;background-color:#f8f9fa}.main-content{flex:1;display:flex;flex-direction:column;padding:20px;box-sizing:border-box;min-height:0}.practice-page{display:flex;align-items:center;justify-content:center;width:100%}.history-page{display:flex;align-items:flex-start;justify-content:center;width:100%;padding-top:2rem}.app-container{width:100%;max-width:900px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:40px;text-align:center;margin:0 auto;min-height:600px;display:flex;flex-direction:column;justify-content:center}.session-start{text-align:center;max-width:600px;margin:0 auto;padding:2rem 1rem}.session-start h1{font-size:3rem;font-weight:700;color:#2c3e50;margin-bottom:.5rem}.session-start p{font-size:1.2rem;color:#6c757d;margin-bottom:2rem}.start-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;font-size:1.2rem;font-weight:600;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.start-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.session-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem;background:#f8f9fa;border-radius:8px}.session-info{display:flex;gap:2rem;font-weight:500}.session-info span{color:#495057}.session-buttons{display:flex;gap:.75rem;align-items:center}.solution-button{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;transition:background-color .2s;font-size:.9rem}.solution-button:hover{background:#5a6268}.end-button{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;transition:background-color .2s}.end-button:hover{background:#c82333}.session-paused{text-align:center;padding:2rem;background:#e3f2fd;border-radius:12px;border:2px solid #2196f3;margin-bottom:2rem}.pause-info h2{color:#1976d2;margin-bottom:.5rem;font-size:1.5rem}.pause-info p{color:#555;margin-bottom:1.5rem;font-size:1rem}.session-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;font-weight:500}.session-stats span{color:#1976d2;font-size:1rem}.pause-actions{display:flex;justify-content:center;gap:1rem}.resume-button{background:#4caf50;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:600;font-size:1rem}.resume-button:hover{background:#45a049;transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d}.problem-display{margin:2rem 0}.problem-container{min-height:300px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2rem}.problem-question{font-size:2rem;font-weight:600;color:#2c3e50;line-height:1.4;max-width:600px}.answer-form{display:flex;flex-direction:column;align-items:center;gap:1rem}.answer-input{font-size:1.5rem;padding:12px 20px;border:2px solid #e9ecef;border-radius:8px;text-align:center;width:300px;transition:border-color .2s}.answer-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.submit-button{background:#28a745;color:#fff;border:none;padding:12px 24px;font-size:1.1rem;font-weight:600;border-radius:6px;cursor:pointer;transition:background-color .2s;min-width:120px}.submit-button:hover:not(:disabled){background:#218838}.submit-button:disabled{background:#6c757d;cursor:not-allowed}.feedback{font-size:1.3rem;font-weight:600;padding:12px 24px;border-radius:8px;animation:fadeIn .3s ease-in-out}.feedback.correct{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.feedback.incorrect{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.results-dashboard{text-align:center}.results-container h2{font-size:2.5rem;font-weight:700;color:#2c3e50;margin-bottom:2rem}.overall-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:3rem}.stat-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:1.5rem;border-radius:12px;border:1px solid #dee2e6}.stat-value{font-size:2.5rem;font-weight:700;color:#495057;display:block}.stat-label{font-size:.9rem;color:#6c757d;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.category-breakdown{margin-bottom:3rem;text-align:left}.category-breakdown h3{font-size:1.5rem;color:#2c3e50;margin-bottom:1rem;text-align:center}.category-stats{display:flex;flex-direction:column;gap:.5rem}.category-stat{display:flex;justify-content:space-between;align-items:center;padding:.8rem;background:#f8f9fa;border-radius:6px}.category-name{font-weight:600;color:#495057}.category-accuracy{font-weight:600;color:#28a745}.category-count{color:#6c757d;font-size:.9rem}.performance-feedback{margin-bottom:2rem}.feedback.excellent{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:#155724;border:1px solid #c3e6cb}.feedback.good{background:linear-gradient(135deg,#d1ecf1,#bee5eb);color:#0c5460;border:1px solid #bee5eb}.feedback.needs-work{background:linear-gradient(135deg,#fff3cd,#ffeaa7);color:#856404;border:1px solid #ffeaa7}.new-session-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;font-size:1.2rem;font-weight:600;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.new-session-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}@media (max-width: 768px){.app{align-items:flex-start}.app-container{padding:24px;margin:0;min-height:auto;max-width:100%;border-radius:8px}.session-start h1{font-size:2.5rem}.problem-question{font-size:1.4rem;line-height:1.3}.answer-input{width:100%;max-width:280px;font-size:1.2rem}.session-info{flex-direction:column;gap:.5rem;text-align:center}.session-controls{flex-direction:column;gap:1rem;text-align:center}.overall-stats{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:1rem}.stat-value{font-size:2rem}}@media (max-width: 480px){.app-container{padding:16px}.session-start h1{font-size:2rem}.session-start p{font-size:1rem}.problem-question{font-size:1.2rem}.answer-input{width:100%;font-size:1.1rem}.overall-stats{grid-template-columns:1fr;gap:.5rem}.start-button,.new-session-button{padding:14px 28px;font-size:1.1rem}}.difficulty-selector{margin:1.5rem auto 0;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef;text-align:left;max-width:600px}.difficulty-selector h3{margin-bottom:1rem;color:#2c3e50;text-align:center;font-size:1.2rem}.difficulty-options{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.difficulty-button{padding:1rem;border:2px solid #dee2e6;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:center;color:#495057}.difficulty-button:hover:not(:disabled){border-color:#adb5bd;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.difficulty-button.selected{border-color:#6c757d;background:#6c757d;color:#fff}.difficulty-label{font-weight:600;font-size:1rem;margin-bottom:.5rem;color:inherit}.difficulty-description{font-size:.85rem;line-height:1.3;color:inherit}.question-type-filter{margin:1.5rem auto 0;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef;text-align:left;max-width:600px}.question-type-filter h3{margin-bottom:1.5rem;color:#2c3e50;text-align:center;font-size:1.3rem}.filter-categories{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center}.filter-category{min-width:160px;text-align:center}.category-button{width:100%;padding:.75rem 1rem;font-size:1rem;font-weight:600;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:.75rem}.category-button.all-selected{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border-color:#28a745}.category-button.some-selected{background:linear-gradient(135deg,#ffc107,#fd7e14);color:#fff;border-color:#ffc107}.category-button.none-selected{background:#fff;color:#6c757d;border-color:#dee2e6}.category-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.category-items{display:flex;flex-direction:column;gap:.5rem}.type-button{padding:.5rem .75rem;font-size:.9rem;font-weight:500;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#fff;color:#6c757d}.type-button.selected{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.type-button:hover{border-color:#667eea;color:#495057;transform:translateY(-1px)}.type-button.selected:hover{color:#fff;box-shadow:0 2px 8px #667eea4d}@media (max-width: 768px){.filter-categories{flex-direction:column;align-items:center;gap:1.5rem}.filter-category{width:100%;max-width:250px}.difficulty-selector{margin-top:1.5rem;padding:1rem}.difficulty-options{grid-template-columns:1fr;gap:.75rem}.difficulty-button{padding:.75rem}.question-type-filter{margin-top:1.5rem;padding:1rem}.category-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.5rem}}@media (max-width: 480px){.filter-categories{gap:1rem}.filter-category{max-width:100%}.category-items{grid-template-columns:1fr}}.navbar{background:#fff;border-bottom:1px solid #e9ecef;padding:.75rem 0;box-shadow:0 2px 4px #0000000d;width:100%;position:relative}.navbar-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between}.navbar-logo{display:flex;align-items:center;text-decoration:none;color:#2c3e50;font-weight:700;font-size:1.5rem}.logo-image{height:50px;width:auto;margin-right:.5rem}.logo-text{color:#2c3e50;font-weight:700;font-size:1.5rem}.navbar-links{display:flex;gap:2rem}.nav-link{text-decoration:none;color:#6c757d;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s}.nav-link:hover,.nav-link.active{color:#2c3e50;background:#f8f9fa}.practice-dropdown{position:relative}.practice-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit}.practice-dropdown-menu{position:absolute;top:100%;left:0;margin-top:.5rem;background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 8px 25px #00000026;min-width:320px;z-index:1000;overflow:hidden}.practice-menu-header{padding:1rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #e9ecef}.practice-overview-link{text-decoration:none;color:#2c3e50;font-weight:600;font-size:1rem;display:flex;align-items:center;gap:.5rem}.practice-overview-link:hover{color:#667eea}.practice-menu-divider{height:1px;background:#e9ecef}.practice-menu-items{padding:.5rem 0}.practice-menu-item{width:100%;padding:.75rem 1rem;border:none;background:none;text-align:left;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:.75rem}.practice-menu-item:hover{background:#f8f9fa}.practice-item-icon{font-size:1.25rem;flex-shrink:0}.practice-item-content{flex:1}.practice-item-title{font-weight:600;color:#2c3e50;margin-bottom:.25rem;font-size:.95rem;display:flex;align-items:center;gap:.5rem}.dropdown-beta-badge{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;font-size:.6rem;font-weight:700;padding:.15rem .3rem;border-radius:6px;text-transform:uppercase;letter-spacing:.3px;box-shadow:0 1px 3px #ff6b354d}.mobile-beta-badge{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;font-size:.55rem;font-weight:700;padding:.1rem .25rem;border-radius:4px;text-transform:uppercase;letter-spacing:.2px;margin-left:.4rem;box-shadow:0 1px 2px #ff6b354d}.practice-item-description{color:#6c757d;font-size:.8rem;line-height:1.3}.mobile-practice-section{padding:.5rem 0;border-top:1px solid #f8f9fa;margin-top:.5rem}.mobile-practice-header{padding:.5rem 1.5rem;font-size:.85rem;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.mobile-practice-item{width:100%;padding:.75rem 1.5rem;border:none;background:none;text-align:left;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:.75rem;color:#6c757d;font-weight:500}.mobile-practice-item:hover{background:#f8f9fa;color:#2c3e50}.mobile-practice-icon{font-size:1.1rem;flex-shrink:0}.mobile-practice-title{font-size:.9rem}.navbar-user{display:flex;align-items:center}.auth-buttons{display:flex;gap:.75rem;align-items:center}.sign-in-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.sign-in-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.sign-up-button{background:#ff7f00;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.sign-up-button:hover{background:#d66600;transform:translateY(-1px);box-shadow:0 2px 8px #e572004d}.user-menu{position:relative}.user-button{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid #e9ecef;padding:.5rem .75rem;border-radius:6px;cursor:pointer;transition:all .2s}.user-button:hover{border-color:#ced4da;background:#f8f9fa}.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600}.user-email{font-size:.9rem;color:#495057;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-icon{transition:transform .2s;color:#6c757d}.dropdown-icon.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 12px #0000001a;min-width:200px;z-index:1000}.dropdown-header{padding:.75rem}.dropdown-divider{height:1px;background:#e9ecef;margin:.5rem 0}.dropdown-item{width:100%;padding:.5rem .75rem;border:none;background:none;text-align:left;cursor:pointer;transition:background .2s;font-size:.9rem}.dropdown-item:hover{background:#f8f9fa}.dropdown-item.sign-out{color:#dc3545}.dropdown-item.sign-out:hover{background:#f8f9fa}.desktop-only{display:flex}.mobile-only{display:none}.mobile-menu-button{background:none;border:none;cursor:pointer;padding:.5rem;color:#2c3e50;border-radius:4px;transition:background .2s}.mobile-menu-button:hover{background:#f8f9fa}.mobile-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 4px 12px #0000001a;z-index:1000;display:block;width:100%}.mobile-menu-links{border-bottom:1px solid #e9ecef}.mobile-nav-link{display:block;padding:1rem 1.5rem;text-decoration:none;color:#6c757d;font-weight:500;border-bottom:1px solid #f8f9fa;transition:all .2s}.mobile-nav-link:hover,.mobile-nav-link.active{color:#2c3e50;background:#f8f9fa}.mobile-menu-user{padding:1rem 1.5rem}.mobile-user-info{display:flex;flex-direction:column;gap:1rem}.mobile-user-details{display:flex;align-items:center;gap:.75rem}.mobile-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.1rem}.mobile-user-email{color:#2c3e50;font-weight:500;flex:1}.mobile-sign-out{background:#dc3545;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;width:100%}.mobile-sign-out:hover{background:#c82333;transform:translateY(-1px)}.mobile-auth-buttons{display:flex;flex-direction:column;gap:.75rem}.mobile-sign-in-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.mobile-sign-in-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.mobile-sign-up-button{background:#ff7f00;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.mobile-sign-up-button:hover{background:#d66600;transform:translateY(-1px);box-shadow:0 2px 8px #e572004d}@media (max-width: 950px){.desktop-only{display:none!important}.mobile-only,.mobile-menu-button{display:block!important}.navbar-container{padding:0 1rem;width:100%}.logo-image{height:45px}}@media (max-width: 480px){.navbar-container{padding:0 .75rem}.logo-image{height:40px}.mobile-menu-links,.mobile-menu-user,.mobile-nav-link{padding:.75rem 1rem}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:#fff;border-radius:12px;padding:2rem;width:100%;max-width:400px;margin:1rem}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;color:#2c3e50}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#495057}.sign-in-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#495057}.form-group input{padding:.75rem;border:1px solid #ced4da;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.error-message{color:#dc3545;font-size:.9rem;padding:.5rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px}.success-message{color:#155724;font-size:.9rem;padding:.5rem;background:#d4edda;border:1px solid #c3e6cb;border-radius:4px}.referral-info{margin-bottom:1rem}.referral-badge{padding:.75rem;border-radius:6px;font-size:.9rem;text-align:center}.referral-badge.valid{background:#dcfce7;border:1px solid #059669;color:#166534}.referral-badge.invalid{background:#fee2e2;border:1px solid #dc2626;color:#991b1b}.referral-badge small{font-size:.8rem;opacity:.8}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-footer{text-align:center;margin-top:1rem}.switch-mode{background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;text-decoration:underline}.switch-mode:hover{color:#5a67d8}.forgot-password{background:none;border:none;color:#6c757d;cursor:pointer;font-size:.8rem;text-decoration:underline;margin-top:.5rem;display:block}.forgot-password:hover{color:#495057}.history-container{width:100%;max-width:900px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem}.history-container h2{color:#2c3e50;margin-bottom:2rem;text-align:center;font-size:2.5rem}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.performance-trend{margin-bottom:2rem;padding:1rem;background:#f8f9fa;border-radius:8px}.performance-trend h3{color:#2c3e50;margin-bottom:1rem}.trend-indicator{display:flex;align-items:center;gap:.5rem;font-weight:500}.trend-indicator.improving{color:#28a745}.trend-indicator.declining{color:#dc3545}.trend-indicator.stable{color:#6c757d}.trend-arrow{font-size:1.2rem}.no-sessions{text-align:center;padding:3rem 1rem;color:#6c757d}.no-sessions h3{margin-bottom:1rem;color:#495057}.sessions-list h3{color:#2c3e50;margin-bottom:1rem}.session-item{border:1px solid #e9ecef;border-radius:8px;padding:1rem;margin-bottom:.75rem;transition:all .2s}.session-item:hover{border-color:#ced4da;box-shadow:0 2px 4px #0000000d}.session-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.session-date{font-weight:500;color:#495057}.session-accuracy{font-weight:600;font-size:1.1rem}.session-accuracy.good{color:#28a745}.session-accuracy.okay{color:#ffc107}.session-accuracy.needs-work{color:#dc3545}.session-details{display:flex;gap:1rem;color:#6c757d;font-size:.9rem}.loading,.error{text-align:center;padding:2rem;color:#6c757d}.error{color:#dc3545}@media (max-width: 768px){.navbar-container{padding:0 .5rem}.navbar-links{gap:1rem}.user-email{display:none}.modal-content{margin:.5rem;padding:1.5rem}.history-container{padding:1rem;margin:.5rem}.stats-overview{grid-template-columns:repeat(2,1fr);gap:.75rem}.session-details{flex-wrap:wrap;gap:.75rem}.main-content{padding:10px}.history-page{padding-top:1rem}}@media (max-width: 480px){.navbar-container{flex-wrap:wrap;gap:.5rem}.stats-overview{grid-template-columns:1fr}.session-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.domain-warning-modal{max-width:500px}.domain-warning-content{display:flex;flex-direction:column;gap:1.5rem}.warning-message{text-align:left}.warning-message p{margin-bottom:1rem}.access-info{display:flex;flex-direction:column;gap:.75rem;background:#f8f9fa;padding:1rem;border-radius:8px;margin:1rem 0}.darden-access,.other-access{display:flex;align-items:center;gap:.5rem}.access-icon{font-size:1.2rem}.highlight{color:#667eea;font-weight:600}.waitlist-explanation{background:#fff3cd;padding:1rem;border-radius:8px;border-left:4px solid #ffc107}.waitlist-explanation h3{margin-bottom:.75rem;color:#856404}.waitlist-explanation ul{margin:0;padding-left:1.25rem}.waitlist-explanation li{margin-bottom:.5rem;color:#856404}.warning-actions{display:flex;gap:1rem;justify-content:flex-end}.cancel-button{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;transition:all .2s}.cancel-button:hover{background:#5a6268}.confirm-button{background:linear-gradient(135deg,#ffc107,#fd7e14);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500}.confirm-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #ffc1074d}.waitlist-notification{display:flex;align-items:center;justify-content:center;min-height:80vh;width:100%}.waitlist-container{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:3rem;text-align:center;max-width:600px;width:100%}.waitlist-icon{font-size:4rem;margin-bottom:1rem}.waitlist-container h2{color:#2c3e50;margin-bottom:1.5rem;font-size:2.5rem}.user-info{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:2rem}.user-info p{margin:.25rem 0;color:#495057}.waitlist-message{text-align:left;margin-bottom:2rem}.waitlist-message p{color:#6c757d;line-height:1.6;margin-bottom:1.5rem}.status-info{display:flex;flex-direction:column;gap:.75rem;background:#e7f3ff;padding:1.5rem;border-radius:8px;margin:1.5rem 0}.status-item{display:flex;align-items:center;gap:.75rem}.status-icon{font-size:1.1rem;width:20px;text-align:center}.darden-info{background:#d1edff;padding:1.5rem;border-radius:8px;border-left:4px solid #0066cc;text-align:left;margin-bottom:2rem}.darden-info h3{color:#06c;margin-bottom:.75rem}.darden-info p{color:#049;margin:0}.waitlist-actions{margin-bottom:2rem}.sign-out-button{background:#dc3545;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.sign-out-button:hover{background:#c82333;transform:translateY(-1px)}.contact-info{border-top:1px solid #e9ecef;padding-top:1.5rem}.help-text{color:#6c757d;font-size:.9rem;margin:0}.landing-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.referral-banner{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:12px 0;position:relative;z-index:10}.referral-banner-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:16px;padding:0 20px;flex-wrap:wrap}.referral-icon{font-size:20px;flex-shrink:0}.referral-text{flex:1;text-align:center;min-width:200px}.referral-signup-button{background:#fff;color:#059669;border:none;padding:8px 20px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.referral-signup-button:hover{background:#f0fdf4;transform:translateY(-1px)}.referral-dismiss{background:#fff3;color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.referral-dismiss:hover{background:#ffffff4d}@media (max-width: 768px){.referral-banner-content{flex-direction:column;gap:12px;text-align:center}.referral-text{order:1}.referral-signup-button{order:2}.referral-dismiss{position:absolute;top:8px;right:8px;order:3}}.top-cta-bar{background:#232d4b;color:#fff;padding:.75rem 0;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000001a}.top-cta-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.top-cta-text{font-weight:500;font-size:1rem}.top-cta-buttons{display:flex;gap:.75rem;align-items:center}.top-cta-button{border:none;padding:.5rem 1.5rem;border-radius:6px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease}.top-cta-button.signin{background:transparent;color:#fff;border:2px solid white}.top-cta-button.signin:hover{background:#fff;color:#232d4b;transform:translateY(-1px)}.top-cta-button.signup{background:#ff7f00;color:#fff}.top-cta-button.signup:hover{background:#e67300;transform:translateY(-1px);box-shadow:0 2px 8px #ff7f004d}.main-content-full{flex:1;display:flex;flex-direction:column;width:100%}.hero-section{padding:2rem 0 8rem;min-height:80vh;background:linear-gradient(135deg,#002580,#ff7f00);color:#fff;position:relative;overflow:hidden;display:flex;align-items:center}.hero-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;justify-content:center}.hero-content{text-align:left}.logo-section{margin-bottom:1rem;display:flex;align-items:center}.logo-fallback{font-size:2rem;font-weight:700;color:#ff7f00}.hero-title{font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem;text-align:center}.logo-line{display:flex;justify-content:flex-start;align-items:center;margin-bottom:1.5rem}.hero-logo{height:4rem;width:auto}.brand-highlight{color:#ff7f00}.hero-subtitle{font-size:1.3rem;line-height:1.6;margin-bottom:2.5rem;opacity:.9;text-align:left;max-width:600px}.hero-actions{margin-bottom:2rem;display:flex;align-items:center;justify-content:center}.cta-button{background:#ff7f00;color:#fff;border:none;padding:1rem 2rem;font-size:1.2rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ff7f004d}.cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff7f0066;background:#e67300}.hero-visual{display:flex;justify-content:center;align-items:center}.math-preview{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:2rem;border:1px solid rgba(255,255,255,.2)}.sample-problem{background:#ffffffe6;color:#2c3e50;padding:1.5rem;border-radius:12px;margin-bottom:1rem;box-shadow:0 4px 20px #0000001a}.sample-problem:last-child{margin-bottom:0}.problem-text{font-size:1.1rem;margin-bottom:.5rem;color:#495057}.problem-answer{font-size:1.3rem;font-weight:600;color:#28a745}.features-section{padding:6rem 0;background:#fff}.features-container{max-width:1200px;margin:0 auto;padding:0 2rem;text-align:center}.features-container h2{font-size:2.5rem;color:#2c3e50;margin-bottom:3rem;font-weight:700}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-top:3rem}.feature-card{background:#f8f9fa;padding:2.5rem;border-radius:16px;text-align:left;transition:all .3s ease;border:1px solid #e9ecef}.feature-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a;border-color:#ff7f00}.feature-icon{font-size:3rem;margin-bottom:1.5rem;display:block}.feature-card h3{font-size:1.4rem;color:#2c3e50;margin-bottom:1rem;font-weight:600}.feature-card p{color:#6c757d;line-height:1.6;margin:0}.problem-types-section{padding:6rem 0;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.types-container{max-width:1000px;margin:0 auto;padding:0 2rem;text-align:center}.types-container h2{font-size:2.5rem;color:#2c3e50;margin-bottom:3rem;font-weight:700}.types-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:3rem}.type-category{background:#fff;padding:2.5rem;border-radius:16px;text-align:left;box-shadow:0 4px 20px #00000014;border:1px solid #e9ecef}.type-category h3{font-size:1.4rem;color:#2c3e50;margin-bottom:1.5rem;font-weight:600}.type-category ul{list-style:none;padding:0;margin:0}.type-category li{color:#6c757d;border-bottom:1px solid #f8f9fa;position:relative;padding:.5rem 0 .5rem 1.5rem}.type-category li:before{content:"✓";color:#28a745;font-weight:700;position:absolute;left:0}.type-category li:last-child{border-bottom:none}.access-section{padding:6rem 0;background:#fff}.access-container{max-width:1000px;margin:0 auto;padding:0 2rem;text-align:center}.access-container h2{font-size:2.5rem;color:#2c3e50;margin-bottom:3rem;font-weight:700}.access-info{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem}.darden-access-card,.other-access-card,.premium-access-card,.signin-card{background:#f8f9fa;padding:2.5rem;border-radius:16px;text-align:left;position:relative;border:2px solid transparent}.darden-access-card{border-color:#28a745;background:linear-gradient(135deg,#d4edda,#c3e6cb)}.other-access-card{border-color:#ffc107;background:linear-gradient(135deg,#fff3cd,#ffeaa7)}.premium-access-card{border-color:#2563eb;background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.signin-card{border-color:#6b7280;background:linear-gradient(135deg,#f9fafb,#f3f4f6)}.access-badge{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;margin-bottom:1rem}.access-badge.darden{background:#28a745;color:#fff}.access-badge.waitlist{background:#ffc107;color:#856404}.access-badge.premium{background:#2563eb;color:#fff}.access-badge.signin{background:#6b7280;color:#fff}.darden-access-card h3,.other-access-card h3,.premium-access-card h3,.signin-card h3{font-size:1.4rem;margin-bottom:1rem;font-weight:600}.darden-access-card h3{color:#155724}.other-access-card h3{color:#856404}.premium-access-card h3{color:#1d4ed8}.signin-card h3{color:#374151}.darden-access-card p,.other-access-card p,.premium-access-card p,.signin-card p{line-height:1.6;margin-bottom:2rem}.darden-access-card p{color:#155724}.other-access-card p{color:#856404}.premium-access-card p{color:#1e40af}.signin-card p{color:#4b5563}.access-button{background:#232d4b;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.access-button.darden{background:#ff7f00}.access-button.waitlist{background:#232d4b;color:#fff}.access-button.premium{background:#2563eb;color:#fff}.access-button.signin{background:#6b7280;color:#fff}.access-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.pricing-note{font-size:.9rem;color:#6b7280;margin-top:1rem;margin-bottom:0;font-style:italic}.pricing-highlight{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #10b981;border-radius:12px;padding:1.5rem;margin-top:1.5rem;text-align:center}.pricing-main{font-size:1.1rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.beta-badge{background:linear-gradient(45deg,#10b981,#059669);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;display:inline-block;margin-bottom:.75rem;animation:pulse 2s infinite}.pricing-terms{font-size:.85rem;color:#6b7280;margin:0}.signin-benefits{margin:1rem 0}.signin-benefits p{font-size:.9rem;color:#4b5563;margin:.5rem 0;line-height:1.4}.landing-footer{background:#232d4b;color:#fff;padding:3rem 0 2rem}.footer-container{max-width:1200px;margin:0 auto;padding:0 2rem}.footer-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:2rem}.footer-brand h3{color:#ff7f00;font-size:1.5rem;margin-bottom:.5rem}.footer-brand p,.footer-links p{color:#adb5bd;line-height:1.6}.footer-links h4{color:#fff;margin-bottom:1rem}.footer-bottom{border-top:1px solid #495057;padding-top:2rem;text-align:center}.footer-bottom p{color:#adb5bd;margin:0}.auth-required{display:flex;align-items:center;justify-content:center;min-height:80vh;width:100%}.auth-message{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:3rem;text-align:center;max-width:500px;width:100%}.auth-message h2{color:#2c3e50;margin-bottom:1rem;font-size:2rem}.auth-message p{color:#6c757d;font-size:1.1rem;margin:0}@media (max-width: 768px){.domain-warning-modal{margin:.5rem;max-width:calc(100% - 1rem);max-height:calc(100vh - 2rem);overflow-y:auto}.domain-warning-content{gap:1rem}.access-info{padding:.75rem;margin:.75rem 0}.waitlist-explanation{padding:.75rem}.waitlist-explanation h3{font-size:1rem;margin-bottom:.5rem}.waitlist-explanation ul{padding-left:1rem}.waitlist-explanation li{font-size:.9rem;margin-bottom:.25rem}.warning-actions{flex-direction:column;gap:.75rem}.cancel-button,.confirm-button{width:100%;padding:.75rem}.waitlist-container{padding:2rem 1rem;margin:1rem}.waitlist-container h2{font-size:2rem}.waitlist-icon{font-size:3rem}.access-info{padding:.75rem}.status-info,.darden-info{padding:1rem}.hero-container{grid-template-columns:1fr;gap:2rem;text-align:center}.hero-title{font-size:2.5rem}.hero-logo{height:3rem}.hero-section{min-height:70vh;padding:1.5rem 0 6rem}.hero-subtitle{font-size:1.1rem}}@media (max-width: 480px){.hero-title{font-size:2rem}.hero-logo{height:2.5rem}.hero-section{min-height:60vh;padding:1rem 0 4rem}.logo-line{justify-content:center}.hero-subtitle{text-align:center;margin-left:auto;margin-right:auto}.logo-fallback{font-size:1.5rem}.features-grid{grid-template-columns:1fr}.feature-card{padding:2rem}.types-grid,.access-info{grid-template-columns:1fr}.footer-content{grid-template-columns:1fr;gap:2rem}.top-cta-container{flex-direction:column;gap:.75rem;text-align:center;padding:0 1rem}.top-cta-text{font-size:.9rem}.top-cta-buttons{width:100%;justify-content:center}.top-cta-button{flex:1;max-width:140px;padding:.5rem 1rem;font-size:.9rem}}@media (max-width: 480px){.domain-warning-modal{margin:.25rem;max-width:calc(100% - .5rem)}.domain-warning-content{gap:.75rem}.access-info{padding:.5rem;margin:.5rem 0;font-size:.9rem}.access-icon{font-size:1rem}.waitlist-explanation{padding:.5rem}.waitlist-explanation h3{font-size:.95rem}.waitlist-explanation li{font-size:.85rem}.warning-actions{gap:.5rem}.cancel-button,.confirm-button{padding:.6rem;font-size:.9rem}.top-cta-container{padding:0 .75rem}.top-cta-text{font-size:.85rem;line-height:1.3}.top-cta-buttons{gap:.5rem}.top-cta-button{flex:1;max-width:120px;padding:.4rem .75rem;font-size:.85rem}.waitlist-container{padding:1.5rem .75rem}.waitlist-container h2{font-size:1.75rem}.status-item{align-items:flex-start}.logo-image{height:80px;max-width:85vw;object-fit:contain}}.mobile-keyboard{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:2px solid #e9ecef;box-shadow:0 -4px 12px #0000001a;z-index:1000;padding:.75rem;padding-bottom:max(.75rem,env(safe-area-inset-bottom));min-height:200px}.keyboard-container{max-width:400px;margin:0 auto}.keyboard-row{display:flex;gap:.5rem;margin-bottom:.5rem;justify-content:center}.keyboard-row:last-child{margin-bottom:0}.keyboard-key{flex:1;padding:.75rem;border:1px solid #dee2e6;border-radius:6px;background:#fff;font-size:1.1rem;font-weight:500;cursor:pointer;transition:all .1s ease;min-height:48px;display:flex;align-items:center;justify-content:center}.keyboard-key:active{transform:scale(.95);background:#f8f9fa}.number-key{color:#2c3e50}.number-key:hover{background:#f8f9fa;border-color:#ced4da}.backspace-key{background:#6c757d;color:#fff;font-size:1.2rem}.backspace-key:hover{background:#5a6268}.clear-key{background:#dc3545;color:#fff;font-size:.9rem}.clear-key:hover{background:#c82333}.submit-key{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;font-weight:600;font-size:.95rem}.submit-key:hover{background:linear-gradient(135deg,#218838,#1e7e34)}@media (max-width: 768px){.practice-page.keyboard-visible{padding-bottom:280px}.problem-container.keyboard-visible{min-height:auto;padding-bottom:1rem}}.solution-modal{max-width:600px;max-height:80vh;overflow-y:auto}.solution-content{display:flex;flex-direction:column;gap:1.5rem}.problem-recap{background:#f8f9fa;padding:1.5rem;border-radius:8px;border-left:4px solid #6c757d}.problem-recap h3{margin:0 0 .75rem;color:#2c3e50;font-size:1.1rem}.problem-recap p{margin:0 0 1rem;color:#495057;line-height:1.4}.correct-answer{background:#d4edda;color:#155724;padding:.75rem;border-radius:6px;text-align:center;font-size:1.1rem}.shortcut-explanation{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem}.shortcut-explanation h3{margin:0 0 1rem;color:#ff7f00;font-size:1.2rem;display:flex;align-items:center;gap:.5rem}.shortcut-explanation h3:before{content:"⚡";font-size:1.3rem}.solution-steps{margin:0;padding-left:1.25rem;color:#495057}.solution-steps li{margin-bottom:.5rem;line-height:1.4}.solution-steps li:last-child{margin-bottom:0;font-weight:600;color:#2c3e50}.solution-tip{background:linear-gradient(135deg,#e7f3ff,#cce7ff);padding:1rem;border-radius:8px;border-left:4px solid #0066cc;display:flex;align-items:flex-start;gap:.75rem}.tip-icon{font-size:1.2rem;margin-top:.1rem}.solution-tip p{margin:0;color:#049;line-height:1.4;font-size:.95rem}.solution-actions{margin-top:1rem;display:flex;justify-content:center}.close-solution-button{background:linear-gradient(135deg,#ff7f00,#e67300);color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.close-solution-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #e572004d}.view-solution-button{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;transition:background-color .2s;font-size:.9rem}.view-solution-button:hover{background:#5a6268}.session-controls .view-solution-button{margin-left:1rem}@media (max-width: 768px){.solution-modal{margin:.5rem;max-width:100%;max-height:90vh}.solution-content{gap:1rem}.problem-recap,.shortcut-explanation{padding:1rem}.solution-tip{flex-direction:column;gap:.5rem}.session-controls{flex-direction:column;gap:.75rem;align-items:center}.session-controls .view-solution-button{margin-left:0;width:100%;max-width:200px}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#2c3e50;color:#fff;padding:16px 20px;z-index:10000;box-shadow:0 -2px 10px #0003}.cookie-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.cookie-content p{margin:0;flex:1;min-width:300px}.privacy-link{background:none;border:none;color:#3498db;text-decoration:underline;cursor:pointer;font-size:inherit;padding:0;margin-left:4px}.privacy-link:hover{color:#2980b9}.cookie-buttons{display:flex;gap:12px}.cookie-btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s}.cookie-btn.decline{background:transparent;color:#fff;border:1px solid #bdc3c7}.cookie-btn.decline:hover{background:#34495e}.cookie-btn.accept{background:#27ae60;color:#fff}.cookie-btn.accept:hover{background:#219a52}.privacy-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10001;padding:20px}.privacy-modal{background:#fff;border-radius:8px;max-width:600px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.privacy-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e9ecef}.privacy-header h2{margin:0;color:#2c3e50}.privacy-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.privacy-close:hover{color:#495057}.privacy-content{padding:20px;overflow-y:auto;flex:1}.privacy-content h3{color:#2c3e50;margin:20px 0 10px}.privacy-content h3:first-child{margin-top:0}.privacy-content p{margin-bottom:10px;line-height:1.6}.privacy-content ul{margin:10px 0 20px 20px}.privacy-content li{margin-bottom:5px}@media (max-width: 768px){.cookie-content{flex-direction:column;text-align:center}.cookie-content p{min-width:unset}.privacy-modal{margin:10px;max-height:90vh}}.trial-details{margin-top:1rem;padding:1rem;background:#ffffffe6;border:1px solid rgba(16,185,129,.3);border-radius:8px;font-size:.9rem;line-height:1.6;color:#1f2937;text-align:left}.crossed-price{text-decoration:line-through;color:#6b7280;margin-right:.5rem}.beta-price{color:#10b981;font-weight:600}@supports (env(keyboard-inset-height)){.app{padding-bottom:env(keyboard-inset-height)}}@media (max-width: 768px){.main-content,.main-content-full{padding-bottom:120px}.problem-display{margin-bottom:60px}.submit-button,.clear-button{margin-bottom:20px}.practice-page{min-height:100vh;padding-bottom:150px}.app{min-height:100vh;min-height:-webkit-fill-available}html{scroll-padding-bottom:120px}input:focus{scroll-margin-bottom:120px}.problem-input[readonly]{opacity:1;background-color:#fff;cursor:text}body.keyboard-open{position:fixed;overflow:hidden;width:100%}body.keyboard-open .app{overflow-y:scroll;height:100vh;padding-bottom:220px}}.practice-dashboard{margin-top:2rem}.dashboard-header{text-align:center;margin-bottom:3rem}.dashboard-header h2{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.dashboard-header p{color:#6c757d;font-size:1.2rem;max-width:600px;margin:0 auto;line-height:1.6}.practice-modules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:3rem}.practice-module-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014;border:2px solid #e9ecef;transition:all .3s ease;text-align:center;position:relative}.practice-module-card:hover{border-color:#667eea;transform:translateY(-3px);box-shadow:0 8px 30px #667eea26}.beta-badge{position:absolute;top:-8px;right:-8px;background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:12px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #ff6b354d;z-index:10}.module-icon{font-size:4rem;margin-bottom:1.5rem;display:block}.module-content{text-align:left}.module-title{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:1rem;text-align:center}.module-description{color:#495057;font-size:1.1rem;font-weight:500;margin-bottom:.75rem;text-align:center}.module-detailed{color:#6c757d;font-size:.95rem;line-height:1.5;margin-bottom:2rem;text-align:center}.module-start-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.module-start-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.active-practice-sessions{margin-top:2rem;display:flex;flex-direction:column;gap:2rem}.session-container{background:#fff;border-radius:16px;box-shadow:0 6px 25px #0000001a;border:2px solid #e9ecef;overflow:hidden}.math-drill-session{border-color:#ff9800}.framework-drill-session{border-color:#667eea}.issue-tree-session{border-color:#28a745}.case-flow-session{border-color:#dc3545}.case-story-session{border-color:#6f42c1}.session-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:1rem 1.5rem;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.session-header h3{margin:0;color:#2c3e50;font-size:1.3rem;font-weight:600}.minimize-session{background:#dc3545;color:#fff;border:none;width:32px;height:32px;min-width:32px;min-height:32px;border-radius:50%;cursor:pointer;font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;line-height:1;flex-shrink:0}.minimize-session:hover{background:#c82333;transform:scale(1.1)}.session-container>div:not(.session-header){padding:1.5rem}.session-controls-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:2rem}@media (max-width: 768px){.dashboard-header h2{font-size:2rem}.dashboard-header p{font-size:1.1rem}.practice-modules-grid{grid-template-columns:1fr;gap:1.5rem}.practice-module-card{padding:1.5rem}.module-icon{font-size:3rem}.module-title{font-size:1.3rem}.session-controls-grid{grid-template-columns:1fr;gap:1rem}}@media (max-width: 480px){.dashboard-header h2{font-size:1.75rem}.dashboard-header p{font-size:1rem}.practice-module-card{padding:1.25rem}.module-icon{font-size:2.5rem}.module-title{font-size:1.2rem}.module-description{font-size:1rem}.module-detailed{font-size:.9rem}.session-header{padding:1rem}.session-header h3{font-size:1.1rem}.session-container>div:not(.session-header){padding:1rem}}
