: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}}*{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;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}.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 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-top:1.5rem;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef;text-align:left}.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-top:1.5rem;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef;text-align:left}.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:120px;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}.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:#e57200;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:#e57200;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: 768px){.desktop-only{display:none!important}.mobile-only,.mobile-menu-button{display:block!important}.navbar-container{padding:0 1rem;width:100%}.logo-image{height:80px}}@media (max-width: 480px){.navbar-container{padding:0 .75rem}.logo-image{height:60px}.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}.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}.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)}.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:#e57200;color:#fff}.top-cta-button.signup:hover{background:#c60;transform:translateY(-1px);box-shadow:0 2px 8px #e572004d}.main-content-full{flex:1;display:flex;flex-direction:column;width:100%}.hero-section{padding:2rem 0 6rem;background:linear-gradient(135deg,#232d4b,#e57200);color:#fff;position:relative;overflow:hidden}.hero-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.hero-content{text-align:left}.logo-section{margin-bottom:1rem;display:flex;align-items:center}.landing-logo{height:120px;width:auto;margin-right:1rem}.logo-fallback{font-size:2rem;font-weight:700;color:#e57200}.hero-title{font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1rem}.brand-highlight{color:#e57200}.hero-subtitle{font-size:1.3rem;line-height:1.6;margin-bottom:2.5rem;opacity:.9}.hero-actions{margin-bottom:2rem}.cta-button{background:#e57200;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 #e572004d}.cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #e5720066;background:#c60}.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:#e57200}.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{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)}.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}.darden-access-card h3,.other-access-card h3{font-size:1.4rem;margin-bottom:1rem;font-weight:600}.darden-access-card h3{color:#155724}.other-access-card h3{color:#856404}.darden-access-card p,.other-access-card p{line-height:1.6;margin-bottom:2rem}.darden-access-card p{color:#155724}.other-access-card p{color:#856404}.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:#e57200}.access-button.waitlist{background:#232d4b;color:#fff}.access-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.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:#e57200;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-subtitle{font-size:1.1rem}.landing-logo{height:80px;max-width:90vw;object-fit:contain}.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}.landing-logo{height:60px;max-width:85vw}.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}.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:#e57200;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,#e57200,#c60);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}}
