.profile-panel-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;animation:profileFadeIn .2s ease}@keyframes profileFadeIn{0%{opacity:0}to{opacity:1}}.profile-panel-container{position:relative;width:90%;max-width:500px;max-height:90vh;background-color:#fffce7;border:3px solid #225400;border-radius:20px;box-shadow:0 8px 32px #0000004d;animation:profileSlideUp .3s cubic-bezier(.4,0,.2,1);overflow-y:auto}@keyframes profileSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.close-profile-button{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:transparent;border:none;font-size:2rem;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;z-index:10}.close-profile-button:hover{background-color:#0000000d;color:#000}.profile-panel-content{padding:2rem}.profile-back-button{background:none;border:none;color:#225400;font-size:.95rem;font-weight:500;cursor:pointer;padding:0;margin-bottom:1rem;display:flex;align-items:center;gap:.25rem;transition:color .2s ease}.profile-back-button:hover{color:#1a4000}.profile-panel-content h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:600;color:#000;text-align:center;letter-spacing:-.02em}.profile-subtitle{margin:0 0 1.5rem;font-size:.95rem;color:#666;text-align:center}.profile-loading{padding:3rem;text-align:center;color:#666;font-size:1rem}.profile-error{padding:1rem;background:#fee2e2;border:2px solid #ef4444;border-radius:8px;color:#b91c1c;font-size:.95rem;margin-bottom:1.5rem;text-align:center;font-weight:500}.profile-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e8e5d5}.profile-section:last-of-type{border-bottom:none;margin-bottom:1rem}.profile-section h3{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#225400}.profile-field{margin-bottom:1rem}.profile-field label{display:block;font-size:.9rem;font-weight:500;color:#000;margin-bottom:.5rem}.profile-input,.profile-textarea,.profile-select{width:100%;padding:.75rem 1rem;background:#fff;border:2px solid #d0d0d0;border-radius:8px;font-size:.95rem;color:#000;transition:all .2s ease;font-family:inherit}.profile-input:focus,.profile-textarea:focus,.profile-select:focus{outline:none;border-color:#225400;box-shadow:0 0 0 3px #2254001a}.profile-input::placeholder,.profile-textarea::placeholder{color:#999}.profile-input-disabled{background:#f5f5f0;color:#666;cursor:not-allowed}.profile-textarea{resize:vertical;min-height:80px}.profile-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.profile-field-hint{display:block;font-size:.8rem;color:#888;margin-top:.35rem}.profile-toggle-field{display:flex;justify-content:space-between;align-items:flex-start;padding:.75rem 0;border-bottom:1px solid #f0f0e8}.profile-toggle-field:last-child{border-bottom:none}.profile-toggle-field label{display:flex;flex-direction:column;gap:.25rem;cursor:pointer}.profile-toggle-field label span:first-child{font-size:.95rem;font-weight:500;color:#000}.profile-toggle-description{font-size:.8rem;color:#888;font-weight:400}.profile-toggle{width:48px;height:26px;appearance:none;background:#d0d0d0;border-radius:13px;cursor:pointer;transition:all .2s ease;position:relative;flex-shrink:0}.profile-toggle:before{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.profile-toggle:checked{background:#225400}.profile-toggle:checked:before{transform:translate(22px)}.profile-stats{display:flex;gap:1.5rem;padding:1rem 0}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.profile-stat-value{font-size:1.5rem;font-weight:700;color:#225400}.profile-stat-label{font-size:.8rem;color:#666;text-transform:uppercase;letter-spacing:.05em}.profile-actions{padding-top:.5rem}.profile-save-button{width:100%;padding:.875rem 1.5rem;background-color:#225400;color:#fffce7;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.profile-save-button:hover:not(:disabled){background-color:#1a4000;transform:translateY(-1px);box-shadow:0 4px 12px #2254004d}.profile-save-button:active:not(:disabled){transform:translateY(0)}.profile-save-button:disabled{opacity:.6;cursor:not-allowed}.profile-admin-badge{display:flex;justify-content:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e8e5d5}.profile-admin-badge span{display:inline-block;padding:.25rem .75rem;background:#225400;color:#fffce7;border-radius:4px;font-size:.75rem;font-weight:600;letter-spacing:.05em}.profile-affiliate-badge{display:flex;justify-content:flex-start;margin-bottom:1rem}.profile-affiliate-badge span{display:inline-block;padding:.25rem .75rem;background:#1e40af;color:#fff;border-radius:4px;font-size:.75rem;font-weight:600;letter-spacing:.05em}.profile-legal-footer{margin-top:1rem;text-align:center;font-size:.75rem;color:#888}.profile-legal-footer a{color:#666;text-decoration:none;transition:color .2s ease}.profile-legal-footer a:hover{color:#225400;text-decoration:underline}.profile-legal-separator{margin:0 .5rem;color:#ccc}.login-button-secondary{background-color:transparent;color:#666;border:2px solid #d0d0d0}.login-button-secondary:hover{background-color:#f5f5f0;color:#333;border-color:#999;box-shadow:none;transform:none}.location-selector-wrapper{position:relative;width:100%}.location-selector-trigger{width:100%;padding:.75rem 1rem;background:#fff;border:2px solid #d0d0d0;border-radius:8px;font-size:.95rem;color:#000;cursor:pointer;display:flex;align-items:center;justify-content:space-between;text-align:left;font-family:inherit;transition:all .2s ease}.location-selector-trigger:hover{border-color:#999}.location-selector-trigger:focus{outline:none;border-color:#225400;box-shadow:0 0 0 3px #2254001a}.location-value{color:#000}.location-placeholder{color:#999}.location-chevron{transition:transform .2s ease;color:#666}.location-chevron.open{transform:rotate(180deg)}.location-selector-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:2px solid #d0d0d0;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100;overflow:hidden}.location-search-container{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid #e8e5d5}.location-search-container svg{color:#999;flex-shrink:0}.location-search-input{flex:1;border:none;font-size:.95rem;font-family:inherit;outline:none;background:transparent;color:#000}.location-current-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:none;border:none;border-bottom:1px solid #e8e5d5;cursor:pointer;font-size:.9rem;font-family:inherit;color:#225400;font-weight:500;transition:background-color .2s ease;text-align:left}.location-current-btn:hover:not(:disabled){background:#f5f5f0}.location-current-btn:disabled{color:#999;cursor:not-allowed}.location-current-btn svg{color:currentColor}.location-search-loading{padding:.75rem 1rem;text-align:center;color:#666;font-size:.9rem}.location-search-result{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;font-size:.9rem;font-family:inherit;color:#000;text-align:left;transition:background-color .2s ease}.location-search-result:hover{background:#f5f5f0}.location-search-result svg{color:#999;flex-shrink:0}@media (max-width: 480px){.profile-panel-container{width:95%;max-height:95vh;margin:.5rem;border-radius:16px}.profile-panel-content{padding:1.5rem 1.25rem}.profile-panel-content h2{font-size:1.5rem}.close-profile-button{width:44px;height:44px;font-size:1.75rem}.profile-input,.profile-textarea,.profile-select,.profile-save-button{min-height:44px}.profile-toggle{width:52px;height:30px}.profile-toggle:before{width:24px;height:24px}.profile-toggle:checked:before{transform:translate(22px)}.profile-stats{justify-content:center}}.landing-page{height:100vh;width:100vw;background-color:#fffce7;display:flex;align-items:center;justify-content:center;padding:2rem;overflow:hidden;box-sizing:border-box;position:fixed;top:0;left:0}.landing-buttons{display:flex;gap:1rem;align-items:center}.landing-login-button{display:inline-flex;align-items:center;background-color:#225400;color:#fffce7;border:1.5px solid #225400;padding:.875rem 1.75rem;border-radius:6px;font-size:.95rem;font-weight:500;letter-spacing:.005em;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.landing-login-button:hover{background-color:#1a4200;border-color:#1a4200;transform:translateY(-1px)}.landing-hero{position:relative;width:100%;height:100%}.landing-carousel{position:relative;width:100%;height:100%;border-radius:24px;overflow:hidden;border:3px solid #225400;box-shadow:0 20px 60px #0003}.carousel-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1s ease-in-out}.carousel-image.active{opacity:1}.landing-overlay{position:absolute;top:50%;left:4rem;transform:translateY(-50%);text-align:left;z-index:10;background:#fffce7f7;padding:2.5rem 3rem;border-radius:20px;border:3px solid #225400;box-shadow:0 12px 40px #00000040;max-width:550px}.landing-info-button{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;background:transparent;border:1.5px solid #d0d0d0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#666}.landing-info-button:hover{border-color:#225400;color:#225400;background-color:#2254000a}.landing-badge{display:inline-block;background-color:#225400;color:#fffce7;padding:.5rem 1.25rem;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:1.5rem}.landing-title{font-size:3.5rem;font-weight:600;color:#000;margin:0 0 1rem;line-height:1.15;letter-spacing:-.02em}.landing-subtitle{font-size:1.1rem;font-weight:400;color:#444;margin:0 0 2.5rem;line-height:1.5;letter-spacing:.01em}.landing-features{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.feature-item{display:flex;gap:1rem;align-items:flex-start}.feature-icon{font-size:1.75rem;flex-shrink:0}.feature-icon-img{width:36px;height:36px;flex-shrink:0;object-fit:contain}.feature-item strong{display:block;font-size:.95rem;font-weight:500;color:#000;margin-bottom:.35rem;letter-spacing:.005em}.feature-item p{font-size:.9rem;font-weight:400;color:#666;line-height:1.6;margin:0}.landing-cta{display:inline-flex;align-items:center;gap:.5rem;background-color:transparent;color:#000;border:1.5px solid #d0d0d0;padding:.875rem 1.75rem;border-radius:6px;font-size:.95rem;font-weight:500;letter-spacing:.005em;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.landing-cta:hover{border-color:#225400;background-color:#2254000a;transform:translateY(-1px)}.landing-cta span{font-size:1.2rem}.landing-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(34,84,0,.15);text-align:center}.landing-footer p{margin:0 0 .5rem;font-size:.85rem;color:#666}.landing-footer-links{display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:.85rem}.landing-footer-links span{color:#999}.landing-footer-link{background:none;border:none;color:#225400;text-decoration:none;cursor:pointer;padding:0;font-size:.85rem;font-weight:400;transition:color .2s ease}.landing-footer-link:hover{color:#1a4000;text-decoration:underline}@media (max-width: 640px){.landing-page{padding:.75rem}.landing-buttons{flex-direction:column;gap:.75rem}.landing-login-button{width:100%;justify-content:center;padding:.875rem 1.5rem;min-height:44px}.landing-carousel{border-radius:16px}.landing-overlay{padding:1.5rem;left:.75rem;right:.75rem;max-width:calc(100% - 1.5rem);border-radius:16px}.landing-info-button{width:36px;height:36px;top:.75rem;right:.75rem}.landing-info-button svg{width:20px;height:20px}.landing-badge{padding:.4rem 1rem;font-size:.7rem;margin-bottom:1rem}.landing-title{font-size:1.75rem;margin-bottom:.75rem}.landing-subtitle{font-size:.9rem;margin-bottom:1.5rem}.landing-features{gap:1rem;margin-bottom:1.5rem}.feature-item{gap:.75rem}.feature-icon{font-size:1.5rem}.feature-icon-img{width:30px;height:30px}.feature-item strong{font-size:.85rem}.feature-item p{font-size:.8rem}.landing-cta{width:100%;justify-content:center;padding:.875rem 1.5rem;min-height:44px}}@media (max-width: 768px){.landing-page{padding:1rem}.landing-overlay{padding:2rem;left:1rem;right:1rem;max-width:calc(100% - 2rem)}.landing-title{font-size:2.25rem}.landing-subtitle{font-size:.95rem}.feature-item strong{font-size:.9rem}.feature-item p{font-size:.85rem}}@media (max-width: 375px){.landing-page{padding:.5rem}.landing-login-button{padding:.75rem 1.25rem;font-size:.9rem}.landing-carousel{border-radius:12px;border-width:2px}.landing-overlay{padding:1.25rem;left:.5rem;right:.5rem;max-width:calc(100% - 1rem);border-radius:12px;border-width:2px}.landing-info-button{width:32px;height:32px;top:.5rem;right:.5rem}.landing-info-button svg{width:18px;height:18px}.landing-badge{padding:.35rem .875rem;font-size:.65rem;margin-bottom:.875rem}.landing-title{font-size:1.5rem;line-height:1.2;margin-bottom:.5rem}.landing-subtitle{font-size:.85rem;margin-bottom:1.25rem;line-height:1.4}.landing-features{gap:.875rem;margin-bottom:1.25rem}.feature-icon{font-size:1.25rem}.feature-icon-img{width:26px;height:26px}.feature-item strong{font-size:.8rem}.feature-item p{font-size:.75rem;line-height:1.4}.landing-cta{padding:.75rem 1.25rem;font-size:.9rem}}.explore-page{position:relative;height:100vh;width:100vw;background-color:#fffce7;overflow:hidden}.email-confirmation-banner{position:absolute;top:110px;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:12px;box-shadow:0 4px 12px #00000026;max-width:90%;width:auto}.email-confirmation-content{display:flex;align-items:center;gap:10px;color:#92400e;font-size:14px;font-weight:500}.email-confirmation-content svg{flex-shrink:0;color:#d97706}.email-confirmation-resend{flex-shrink:0;padding:8px 16px;background:#225400;color:#fffce7;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s ease,transform .1s ease}.email-confirmation-resend:hover:not(:disabled){background:#1a4200;transform:translateY(-1px)}.email-confirmation-resend:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 600px){.email-confirmation-banner{flex-direction:column;text-align:center;top:105px;padding:10px 16px}.email-confirmation-content{flex-direction:column;gap:6px}.email-confirmation-resend{width:100%}}.cluster-marker{border-radius:50%;background-color:#2563eb;border:3px solid white;box-shadow:0 2px 10px #0000004d;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;transform:translateZ(0)}.cluster-marker--sm{width:30px;height:30px;font-size:12px}.cluster-marker--md{width:40px;height:40px;font-size:13px}.cluster-marker--lg{width:50px;height:50px;font-size:14px}.cluster-marker--xl{width:60px;height:60px;font-size:14px}.cluster-marker:hover,.course-marker:hover{will-change:transform}.course-marker{width:32px;height:32px;border-radius:50%;border:3px solid white;box-shadow:0 2px 8px #0000004d;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#000;transform:translateZ(0)}.course-marker--grade-s{background-color:#6d8}.course-marker--grade-a{background-color:#b8e986}.course-marker--grade-b{background-color:#ffeb3b}.course-marker--grade-c{background-color:#ffb74d}.course-marker--grade-d{background-color:#f96}.course-marker--grade-f{background-color:#ff6b6b}.course-marker--grade-unknown{background-color:#999}.course-marker--selected{transform:scale(1.3) translateZ(0);border-color:#225400;box-shadow:0 0 0 3px #22540066,0 4px 12px #0006;z-index:10}.cluster-marker--selected{transform:scale(1.2) translateZ(0);border-color:#225400;box-shadow:0 0 0 3px #22540066,0 4px 12px #0006;z-index:10}.course-list-item.virtual-item{height:100%;margin:0;display:flex;flex-direction:column;justify-content:center}.explore-header{position:absolute;top:2rem;left:2rem;z-index:1000;display:flex;align-items:center;gap:.5rem;background-color:#fffce7f2;padding:.75rem 1.5rem;border-radius:12px;border:2px solid #225400;box-shadow:0 4px 16px #0000001a}.explore-logo{width:36px;height:36px}.explore-title{margin:0;font-size:1.5rem;font-weight:600;color:#000;letter-spacing:-.02em}.explore-topbar{position:absolute;top:2rem;left:50%;transform:translate(-50%);z-index:1000;background-color:#fffce7;border:3px solid #225400;border-radius:35px;display:flex;flex-direction:row;padding:.5rem .75rem;gap:.75rem;align-items:center;box-shadow:0 4px 20px #00000026;transition:left .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1)}.explore-topbar.topbar-shifted{left:calc(50% - 200px);transform:translate(-50%)}.topbar-search-container{position:relative;display:flex;align-items:center}.search-icon-input{position:absolute;left:.75rem;color:#666;stroke-width:2.5;pointer-events:none}.topbar-search-input{width:250px;height:36px;padding:.5rem .75rem .5rem 2.5rem;border:none;background-color:transparent;font-size:.9rem;color:#000;outline:none}.topbar-search-input::placeholder{color:#999}.topbar-icon-button{width:36px;height:36px;background-color:transparent;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative}.topbar-icon-button svg{width:22px;height:22px;color:#000;stroke-width:2.5}.topbar-icon-button:hover{transform:scale(1.1)}.topbar-icon-button:hover svg{color:#225400}.topbar-icon-button:active{transform:scale(.95)}.topbar-icon-button.active svg{color:#225400}.filter-badge-count{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background-color:#225400;color:#fff;border-radius:50%;font-size:.7rem;font-weight:600;display:flex;align-items:center;justify-content:center}.topbar-location-picker{position:relative}.topbar-location-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:transparent;border:none;border-radius:20px;font-size:.85rem;font-weight:500;color:#333;cursor:pointer;transition:all .2s ease;white-space:nowrap}.topbar-location-badge:hover{background-color:#22540014}.topbar-location-badge.active{background-color:#225400;color:#fffce7}.topbar-location-badge .location-name{max-width:150px;overflow:hidden;text-overflow:ellipsis}.topbar-location-badge .chevron-icon{transition:transform .2s ease}.topbar-location-badge.active .chevron-icon{transform:rotate(180deg)}.topbar-location-dropdown{position:absolute;top:calc(100% + 8px);left:0;width:320px;background-color:#fffce7;border:2px solid #225400;border-radius:12px;box-shadow:0 4px 20px #00000026;z-index:1100;overflow:hidden}.location-search-input-container{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid #e8e5d5}.location-search-input-container svg{color:#666;flex-shrink:0}.location-search-input{flex:1;border:none;background-color:transparent;font-size:.9rem;color:#333;outline:none}.location-search-input::placeholder{color:#999}.use-current-location-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background-color:transparent;border:none;border-bottom:1px solid #e8e5d5;font-size:.9rem;color:#225400;cursor:pointer;transition:background-color .2s ease;text-align:left}.use-current-location-btn:hover{background-color:#2254000d}.use-current-location-btn svg{flex-shrink:0}.location-search-loading{padding:.75rem 1rem;font-size:.85rem;color:#666;text-align:center}.location-search-results{max-height:200px;overflow-y:auto}.location-search-result{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background-color:transparent;border:none;font-size:.85rem;color:#333;cursor:pointer;transition:background-color .2s ease;text-align:left}.location-search-result:hover{background-color:#2254000d}.location-search-result svg{color:#888;flex-shrink:0}.location-search-result span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.redo-search-button{position:absolute;top:7rem;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background-color:#225400;color:#fffce7;border:none;border-radius:20px;font-size:.875rem;font-weight:500;cursor:pointer;box-shadow:0 4px 16px #0003;transition:all .2s ease;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.redo-search-button:hover{background-color:#1a4000;transform:translate(-50%) translateY(-2px);box-shadow:0 6px 20px #00000040}.redo-search-button:active{transform:translate(-50%) translateY(0)}.redo-search-button svg{flex-shrink:0}.explore-sidebar{position:absolute;left:1.5rem;top:50%;transform:translateY(-50%);z-index:1002;background-color:#fffce7;border:3px solid #225400;border-radius:35px;display:flex;flex-direction:column;padding:.75rem .5rem;gap:.75rem;align-items:center;box-shadow:0 4px 20px #00000026;transition:left .25s cubic-bezier(.4,0,.2,1)}.explore-sidebar.pushed{left:calc(500px + 3rem)}.sidebar-icon-button{width:36px;height:36px;background-color:transparent;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative}.sidebar-icon-button svg{width:22px;height:22px;color:#000;stroke-width:2.5}.sidebar-icon-button:hover{transform:scale(1.1)}.sidebar-icon-button:hover svg{color:#225400}.sidebar-icon-button:active{transform:scale(.95)}.sidebar-icon-button.active{background-color:#225400;border-radius:8px}.sidebar-icon-button.active svg{color:#fffce7}.sidebar-icon-button.authenticated svg{color:#225400}.auth-checkmark{position:absolute;bottom:0;right:0;width:18px;height:18px;background-color:#225400;border-radius:50%;border:2px solid #fffce7;display:flex;align-items:center;justify-content:center}.auth-checkmark svg{width:12px!important;height:12px!important;stroke:#fffce7!important;stroke-width:3.5!important;fill:none!important}.sidebar{width:280px;background-color:#fffce7;border-right:2px solid #e8e5d5;display:flex;flex-direction:column;padding:1.5rem;gap:1rem;overflow-y:auto}.sidebar-header{padding-bottom:.5rem}.sidebar-title{font-size:1.1rem;font-weight:600;color:#000;margin:0;letter-spacing:-.01em}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem}.nav-button{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:1.5px solid #d0d0d0;border-radius:6px;font-size:.9rem;font-weight:500;color:#000;cursor:pointer;transition:all .2s ease;text-align:left}.nav-button:hover{border-color:#225400;background-color:#2254000a}.nav-button.active{background-color:#225400;border-color:#225400;color:#fffce7}.nav-icon{font-size:1.1rem}.sidebar-section{padding:.5rem 0}.feature-button,.pdf-button{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:beige;border:1.5px solid #d0d0d0;border-radius:6px;font-size:.9rem;font-weight:500;color:#000;cursor:pointer;transition:all .2s ease}.feature-button:hover,.pdf-button:hover{border-color:#225400;background-color:#2254000f}.feature-icon,.pdf-icon{font-size:1.1rem}.feature-badge,.pdf-badge{margin-left:auto;background-color:#225400;color:#fffce7;padding:.2rem .6rem;border-radius:999px;font-size:.7rem;font-weight:600}.sidebar-footer{display:flex;gap:.5rem;padding:.5rem 0 1rem;border-bottom:1px solid #e8e5d5}.footer-button{flex:1;padding:.5rem .75rem;background:transparent;border:none;font-size:.85rem;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;border-radius:4px}.footer-button:hover{color:#000;background-color:#0000000a}.footer-button.active{color:#000;background-color:#22540014}.sidebar-search{position:relative}.search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;background:#fff;border:1.5px solid #d0d0d0;border-radius:6px;font-size:.9rem;color:#000;transition:all .2s ease}.search-input:focus{outline:none;border-color:#225400;box-shadow:0 0 0 3px #2254001a}.search-input::placeholder{color:#999}.search-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:1rem;color:#666;pointer-events:none}.course-count{padding:.5rem 0;font-size:.85rem;color:#666;text-align:center}.sidebar-bottom{margin-top:auto;padding-top:1rem;border-top:1px solid #e8e5d5}.action-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background-color:#225400;color:#fffce7;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.action-button:hover{background-color:#1a4000;transform:translateY(-1px);box-shadow:0 4px 12px #2254004d}.action-icon{font-size:1.1rem}.info-panel-overlay{position:absolute;top:8rem;left:2rem;width:500px;max-height:calc(100vh - 10rem);background-color:#fffce7;border:3px solid #225400;border-radius:20px;z-index:1001;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026;animation:slideInFromLeft .25s cubic-bezier(.4,0,.2,1)}.info-panel-overlay--right{left:auto;right:2rem;animation:slideInFromRight .25s cubic-bezier(.4,0,.2,1)}@keyframes slideInFromRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.info-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:2px solid #e8e5d5}.info-panel-header h2{margin:0;font-size:1.3rem;font-weight:600;color:#000;letter-spacing:-.01em}.close-info-button{width:32px;height:32px;background:transparent;border:none;font-size:2rem;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-info-button:hover{background-color:#0000000d;color:#000}.info-panel-content{flex:1;overflow-y:auto;padding:1.5rem}.info-panel-content h3{margin:0 0 .75rem;font-size:1.1rem;font-weight:600;color:#000;letter-spacing:-.01em}.info-panel-content h4{margin:0 0 .35rem;font-size:.95rem;font-weight:600;color:#000}.info-panel-content p{margin:0;font-size:.85rem;color:#555;line-height:1.5}.about-section{margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:2px solid #e8e5d5}.about-text{font-size:.95rem!important;color:#333!important;line-height:1.7!important;font-style:italic;text-align:left;margin:0}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e8e5d5}.info-card{background:#f5f3e8;border-radius:8px;padding:1rem;text-align:center}.info-card h4{margin:0 0 .5rem;font-size:.9rem;color:#333}.info-card p{margin:0;font-weight:600;color:#225400}.info-subtext{font-size:.75rem;font-weight:400!important;color:#666!important;margin-top:.25rem!important}.quality-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e8e5d5}.quality-section h3{text-align:center;margin-bottom:.5rem}.quality-subtitle{font-size:.875rem;color:#666;margin-bottom:1.5rem;text-align:center}.grade-scale{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.grade-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.grade-badge{width:38px;height:38px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;color:#000;flex-shrink:0}.grade-s .grade-badge{background-color:#6d8}.grade-a .grade-badge{background-color:#b8e986}.grade-b .grade-badge{background-color:#ffeb3b}.grade-c .grade-badge{background-color:#ffb74d}.grade-d .grade-badge{background-color:#f96}.grade-f .grade-badge{background-color:#ff6b6b}.grade-label{font-size:.625rem;font-weight:600;color:#888;letter-spacing:.05em;text-transform:uppercase}.grade-arrow{color:#ccc;font-size:.875rem;margin:0 .25rem}.categories-grid{display:grid;grid-template-columns:1fr;gap:0}.category-item{background:transparent;border:none;border-bottom:1px solid #e8e5d5;border-radius:0;padding:1rem 0;display:flex;align-items:center;gap:1rem}.category-item:last-child{border-bottom:none}.category-icon{font-size:1.75rem;flex-shrink:0;width:2.5rem;text-align:center}.category-item h4{margin:0 0 .25rem;font-size:.9rem;font-weight:600}.category-item p{font-size:.8rem;color:#777;line-height:1.4}.pins-scale{display:flex;flex-direction:column;gap:.75rem}.pins-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#2254000d;border-radius:8px}.pins-badge{font-size:1.25rem;min-width:60px}.pins-badge-svg{width:40px;height:40px;object-fit:contain;min-width:60px}.pins-info{flex:1}.pins-label{font-weight:600;font-size:.9rem;color:#225400;margin-bottom:.25rem}.pins-description{font-size:.8rem;color:#666;line-height:1.4}.review-types-grid{display:flex;flex-direction:column;gap:.75rem}.review-type-item{display:flex;align-items:flex-start;gap:1rem;padding:.75rem;background:#00000005;border-radius:8px}.review-type-icon{font-size:1.5rem;flex-shrink:0}.review-type-item h4{margin:0 0 .25rem;font-size:.9rem;font-weight:600;color:#000}.review-type-item p{margin:0;font-size:.8rem;color:#666;line-height:1.4}.info-legal-footer{margin-top:1.5rem;text-align:center;font-size:.75rem;color:#888}.info-legal-footer a{color:#666;text-decoration:none;transition:color .2s ease}.info-legal-footer a:hover{color:#225400;text-decoration:underline}.info-legal-separator{margin:0 .5rem;color:#ccc}.course-list-overlay{position:absolute;top:2rem;right:2rem;bottom:2rem;width:400px;background-color:#fffce7;border:3px solid #225400;border-radius:20px;z-index:1001;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026;transition:width .25s cubic-bezier(.4,0,.2,1)}.course-list-overlay--expanded{width:800px}.course-list-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:2px solid #e8e5d5}.course-list-header-buttons{display:flex;align-items:center;gap:.5rem}.expand-list-button{width:32px;height:32px;background:transparent;border:none;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.expand-list-button:hover{background-color:#0000000d;color:#225400}.course-list-header h2{margin:0;font-size:1.3rem;font-weight:600;color:#000;letter-spacing:-.01em}.close-list-button{width:32px;height:32px;background:transparent;border:none;font-size:2rem;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-list-button:hover{background-color:#0000000d;color:#000}.course-list-content{flex:1;overflow-y:auto;padding:1rem;min-height:0}.course-list-content.virtual-list{padding:0;overflow:hidden}.course-list-content.course-list-grid{padding:1rem;overflow-y:auto}.course-sidebar-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.course-card-sidebar{background:#fff;border:2px solid #e8e5d5;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s ease}.course-card-sidebar:hover{border-color:#225400;box-shadow:0 4px 16px #22540026;transform:translateY(-2px)}.course-card-sidebar--selected{border-color:#225400;background-color:#2254000d;box-shadow:0 0 0 3px #22540033}.course-card-sidebar--selected:hover{transform:none}.course-card-sidebar-image{position:relative;height:120px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.course-card-sidebar-img{width:100%;height:100%;object-fit:cover}.course-card-sidebar-badge{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#000;box-shadow:0 2px 6px #0003}.course-card-sidebar-ranking{position:absolute;top:8px;left:8px;padding:.2rem .4rem;background-color:gold;border-radius:4px;font-size:.7rem;font-weight:700;color:#000;box-shadow:0 2px 6px #0003}.course-card-sidebar-pin{position:absolute;bottom:8px;right:8px;width:36px;height:36px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.course-card-sidebar-content{padding:.75rem}.course-card-sidebar-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.25rem}.course-card-sidebar-badges{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.course-card-ranking-badge{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .45rem;background:linear-gradient(135deg,gold,#ffc400);border-radius:6px;font-size:.7rem;font-weight:700;color:#000;box-shadow:0 1px 3px #00000026;letter-spacing:-.02em}.course-card-pin-badge{width:28px;height:28px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.15))}.course-card-sidebar-name{margin:0;font-size:.9rem;font-weight:600;color:#000;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.course-card-sidebar-location{margin:0 0 .5rem;font-size:.75rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-card-sidebar-details{display:flex;gap:.5rem;font-size:.7rem;color:#888}.course-list-item{background:#fff;border:2px solid #e8e5d5;border-radius:12px;padding:1rem;margin-bottom:1rem;cursor:pointer;transition:all .2s ease}.course-list-item:hover{border-color:#225400;box-shadow:0 4px 12px #2254001a;transform:translateY(-2px)}.course-list-item--selected{border-color:#225400;background-color:#2254000d}.course-list-item--expanded{height:auto!important;justify-content:flex-start}.course-list-item--expanded .course-details{display:flex;flex-wrap:wrap;gap:1rem;padding-top:.5rem;margin-top:.5rem;border-top:1px solid #e8e5d5}.course-list-item--expanded .detail-item{font-size:.85rem;color:#666}.course-list-item--expanded .detail-item strong{color:#000;font-weight:600}.course-list-item--expanded .view-editorial-button{margin-top:.75rem}.expanded-search-banner{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#2254001a,#2254000d);border-bottom:1px solid #e8e5d5;font-size:.85rem;color:#333}.expanded-search-banner svg{color:#225400;flex-shrink:0}.expanded-search-banner strong{color:#225400}.expanded-search-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1rem;color:#666;font-size:.9rem}.loading-spinner{width:32px;height:32px;border:3px solid #e8e5d5;border-top-color:#225400;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.no-results-message{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 1.5rem;text-align:center}.no-results-message svg{color:#ccc}.no-results-message p{margin:0;font-size:1rem;color:#333}.no-results-message p strong{color:#225400}.no-results-message span{font-size:.85rem;color:#888}.selected-course-card{margin:1rem;padding:1.25rem;background:#fff;border:2px solid #225400;border-radius:12px;box-shadow:0 4px 12px #22540026}.selected-course-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.selected-course-title-container{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.selected-course-title-container h3{margin:0;font-size:1.15rem;font-weight:600;color:#000;letter-spacing:-.01em}.other-courses-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;margin:0 1rem;background:#f5f3e8;border-radius:8px}.other-courses-header h3{margin:0;font-size:.9rem;font-weight:600;color:#333}.other-courses-count{background:#225400;color:#fffce7;padding:.2rem .6rem;border-radius:12px;font-size:.8rem;font-weight:600}.course-list-item-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.course-list-item-header h3{margin:0;font-size:1.05rem;font-weight:600;color:#000;letter-spacing:-.01em;flex:1}.course-list-item h3{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;color:#000;letter-spacing:-.01em}.course-list-location{margin:0 0 .25rem;font-size:.9rem;color:#666;font-weight:500}.course-list-address{margin:0 0 .75rem;font-size:.85rem;color:#888}.course-list-rating{display:flex;gap:.5rem}.rating-badge{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600;color:#000}.ranking-badge{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .55rem;background:linear-gradient(135deg,gold,#ffc400);border-radius:6px;font-size:.8rem;font-weight:700;color:#000;flex-shrink:0;box-shadow:0 1px 3px #0000001f;letter-spacing:-.02em}.course-title-container{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.course-title-container h3{margin:0;font-size:1.05rem;font-weight:600;color:#000;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.popup-title-container{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.popup-title-container h3{margin:0}.popup-title-container .ranking-badge{padding:.3rem .6rem;font-size:.85rem}.popup-title-container .course-pin-badge{width:28px;height:28px}.cluster-panel{position:absolute;bottom:20px;left:20px;right:20px;display:flex;justify-content:center;gap:.75rem;overflow-x:auto;z-index:100;scrollbar-width:none;-ms-overflow-style:none}.cluster-panel::-webkit-scrollbar{display:none}.cluster-course-card{flex-shrink:0;width:280px;background:#fff;border:3px solid #225400;border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #0003}.cluster-course-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.cluster-course-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.cluster-course-header h4{margin:0;font-size:.95rem;font-weight:600;color:#000;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cluster-course-address{margin:0;font-size:.85rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-container{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#e5e3df}.map-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffce7f2;padding:1.5rem 2rem;border-radius:12px;border:2px solid #225400;box-shadow:0 8px 24px #0003;z-index:10}.map-overlay.error{border-color:#e85d75}.map-overlay p{margin:0;font-size:.95rem;font-weight:500;color:#000}.course-popup{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);background:#fffce7fa;padding:1.5rem 2rem;border-radius:12px;border:2px solid #225400;box-shadow:0 8px 24px #00000040;z-index:100;min-width:300px;max-width:400px}.course-popup--hover{animation:fadeInUp .15s ease-out;pointer-events:none}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.close-popup{position:absolute;top:.75rem;right:.75rem;background:transparent;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-popup:hover{background-color:#0000001a;color:#000}.popup-header-content{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.popup-header-content h3{margin:0;font-size:1.2rem;font-weight:600;color:#000;letter-spacing:-.01em;flex:1}.popup-grade-badge{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;font-size:1rem;font-weight:700;color:#000;flex-shrink:0}.course-popup h3{margin:0 0 .5rem;font-size:1.2rem;font-weight:600;color:#000;letter-spacing:-.01em}.course-location{margin:0 0 .5rem;font-size:.9rem;color:#666;font-weight:500}.course-address{margin:0 0 1rem;font-size:.85rem;color:#888}.course-details{display:flex;flex-wrap:wrap;gap:1rem;padding-top:.5rem;border-top:1px solid #e8e5d5}.detail-item{font-size:.85rem;color:#666}.detail-item strong{color:#000;font-weight:600}.course-difficulty{display:flex;gap:.5rem}.difficulty-badge{display:inline-block;padding:.4rem .9rem;border-radius:6px;font-size:.85rem;font-weight:600;color:#fff;text-transform:capitalize}.mapboxgl-ctrl-top-right{top:9rem;right:1rem;transition:right .25s cubic-bezier(.4,0,.2,1)}.map-container.list-open .mapboxgl-ctrl-top-right{right:calc(400px + 3rem)}.map-container.list-open.list-expanded .mapboxgl-ctrl-top-right{right:calc(800px + 3rem)}.mapboxgl-ctrl-group{background-color:#fffce7!important;border:2px solid #225400!important;border-radius:8px!important;box-shadow:0 4px 12px #00000026!important}.mapboxgl-ctrl-group button{width:36px;height:36px}.mapboxgl-ctrl-group button:hover{background-color:#22540014!important}@media (max-width: 640px){.explore-page{position:fixed;inset:0}.explore-header{display:none}.explore-topbar{position:fixed;top:0;left:0;right:0;transform:none;padding:.75rem;gap:.5rem;border-radius:0;border:none;border-bottom:2px solid #225400;z-index:1000}.explore-topbar.topbar-shifted{left:0;transform:none}.topbar-search-container{flex:1}.topbar-search-input{width:100%;min-width:0;flex:1}.topbar-icon-button{width:44px;height:44px;flex-shrink:0}.topbar-icon-button svg{width:24px;height:24px}.topbar-location-picker{flex-shrink:0}.topbar-location-badge{padding:.5rem;gap:.35rem}.topbar-location-badge .location-name{max-width:80px;font-size:.8rem}.topbar-location-badge .chevron-icon{display:none}.topbar-location-dropdown{position:fixed;top:60px;left:0;right:0;width:100%;border-radius:0 0 12px 12px;border-top:none}.map-container{position:fixed;inset:60px 0 0;height:auto}.explore-sidebar{position:fixed;bottom:1rem;left:50%;top:auto;transform:translate(-50%);flex-direction:row;padding:.5rem 1rem;gap:.5rem;border-radius:30px}.explore-sidebar.pushed{left:50%;transform:translate(-50%)}.sidebar-icon-button{width:44px;height:44px}.sidebar-icon-button svg{width:24px;height:24px}.redo-search-button{top:70px;font-size:.8rem;padding:.5rem .875rem}.mapboxgl-ctrl-top-right{top:70px;right:.5rem}.info-panel-overlay{position:fixed;inset:auto 0 0;width:100%;max-width:100%;max-height:70vh;border-radius:20px 20px 0 0;animation:slideUpFromBottom .3s ease}.info-panel-header{padding:1rem 1rem .75rem}.info-panel-header h2{font-size:1.1rem}.close-info-button{width:44px;height:44px;font-size:1.75rem}.info-panel-content{padding:1rem}.grade-scale{gap:.35rem}.grade-badge{width:32px;height:32px;font-size:.85rem}.grade-arrow{font-size:.7rem;margin:0 .15rem}.filter-panel-overlay{position:fixed;inset:65px auto auto 50%;width:calc(100% - 1.5rem);max-width:400px;max-height:calc(100vh - 80px);transform:translate(-50%);border-radius:16px;z-index:1100;animation:fadeIn .2s ease}.filter-panel-overlay.filter-panel-shifted{left:50%}.filter-panel-header{padding:1rem}.filter-panel-header h2{font-size:1.1rem}.close-filter-button{width:44px;height:44px;font-size:1.75rem}.filter-panel-content{padding:1rem}.filter-option{padding:.75rem 1rem;min-height:44px}.filter-option input[type=radio],.filter-option input[type=checkbox]{width:20px;height:20px}.filter-checkbox{padding:.75rem 1rem;min-height:44px}.filter-checkbox input[type=checkbox]{width:24px;height:24px}.pin-option{min-width:70px;padding:.75rem}.pin-option input[type=checkbox]{width:20px;height:20px}.course-list-overlay{position:fixed;inset:auto 0 0;width:100%;max-height:60vh;border-radius:20px 20px 0 0}.course-list-overlay--expanded{width:100%}.expand-list-button{display:none}.course-list-header{padding:1rem}.close-list-button{width:44px;height:44px;font-size:1.75rem}.course-sidebar-grid{grid-template-columns:1fr}.course-popup{left:1rem;right:1rem;transform:none;max-width:none;min-width:auto;bottom:5rem;padding:1.25rem}.course-popup--hover{animation:fadeInUpMobile .15s ease-out}@keyframes fadeInUpMobile{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.close-popup{width:44px;height:44px;top:.5rem;right:.5rem;font-size:1.5rem}.cluster-panel{left:.5rem;right:.5rem;bottom:5rem;gap:.5rem;padding-bottom:.5rem}.cluster-course-card{width:260px;padding:.875rem}.login-panel-container{width:95%;max-width:100%;margin:0 .5rem}.close-login-button{width:44px;height:44px;font-size:1.75rem}.login-panel-content{padding:2rem 1.25rem 1.5rem}.login-panel-content h2{font-size:1.5rem}.form-input{padding:.875rem 1rem;min-height:44px}.login-button,.google-button{min-height:44px}.remember-me input[type=checkbox]{width:20px;height:20px}.review-ratings-grid{grid-template-columns:repeat(3,1fr)}.mapboxgl-ctrl-group button{width:44px;height:44px}.map-container.list-open .mapboxgl-ctrl-top-right{right:1rem}}@keyframes slideUpFromBottom{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.explore-page{flex-direction:column}.sidebar{width:100%;max-height:40vh;border-right:none;border-bottom:2px solid #e8e5d5}.review-ratings-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 375px){.explore-topbar{padding:.5rem;gap:.35rem}.topbar-icon-button{width:40px;height:40px}.map-container{top:54px}.mapboxgl-ctrl-top-right{top:64px}.redo-search-button{top:62px}.cluster-course-card{width:240px}.course-popup{padding:1rem}.popup-header-content h3{font-size:1rem}.popup-grade-badge{width:32px;height:32px;font-size:.9rem}.filter-panel-overlay{top:55px;max-height:calc(100vh - 65px)}}.login-panel-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-panel-container{position:relative;width:90%;max-width:420px;background-color:#fffce7;border:3px solid #225400;border-radius:20px;box-shadow:0 8px 32px #0000004d;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.close-login-button{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:transparent;border:none;font-size:2rem;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;z-index:10}.close-login-button:hover{background-color:#0000000d;color:#000}.login-panel-content{padding:2.5rem 2rem 2rem}.login-panel-content h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:600;color:#000;text-align:center;letter-spacing:-.02em}.login-subtitle{margin:0 0 2rem;font-size:.95rem;color:#666;text-align:center}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:#000}.form-input{width:100%;padding:.875rem 1rem;background:#fff;border:2px solid #d0d0d0;border-radius:8px;font-size:.95rem;color:#000;transition:all .2s ease}.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:-.5rem}.remember-me{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#666;cursor:pointer}.remember-me input[type=checkbox]{width:16px;height:16px;cursor:pointer}.forgot-password{font-size:.875rem;color:#225400;text-decoration:none;transition:color .2s ease}.forgot-password:hover{color:#1a4000;text-decoration:underline}.login-button{width:100%;padding:.875rem 1.5rem;background-color:#225400;color:#fffce7;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.login-button:hover{background-color:#1a4000;transform:translateY(-1px);box-shadow:0 4px 12px #2254004d}.login-button:active{transform:translateY(0)}.divider{position:relative;text-align:center;margin:.5rem 0}.divider span{display:inline-block;padding:0 1rem;background-color:#fffce7;color:#999;font-size:.875rem;font-weight:500;position:relative;z-index:1}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:#d0d0d0;z-index:0}.google-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1.5rem;background-color:#fff;border:2px solid #d0d0d0;border-radius:8px;font-size:.95rem;font-weight:500;color:#000;cursor:pointer;transition:all .2s ease}.google-button:hover{border-color:#225400;background-color:#22540005;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.google-button:active{transform:translateY(0)}.signup-text{margin:1rem 0 0;font-size:.9rem;color:#666;text-align:center}.signup-link{color:#225400;text-decoration:none;font-weight:600;transition:color .2s ease}.signup-link:hover{color:#1a4000;text-decoration:underline}.filter-panel-overlay{position:absolute;top:7rem;left:50%;transform:translate(-50%);width:360px;max-height:calc(100vh - 8rem);background-color:#fffce7;border:3px solid #225400;border-radius:20px;z-index:1100;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.filter-panel-overlay.filter-panel-shifted{left:calc(50% - 200px)}.filter-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem 1rem;border-bottom:2px solid #e8e5d5}.filter-panel-header h2{margin:0;font-size:1.3rem;font-weight:600;color:#000;letter-spacing:-.01em}.close-filter-button{width:32px;height:32px;background:transparent;border:none;font-size:2rem;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-filter-button:hover{background-color:#0000000d;color:#000}.filter-panel-content{flex:1;overflow-y:auto;padding:1rem 1.5rem 1.5rem}.filter-section{margin-bottom:1.5rem}.filter-section h3{margin:0 0 .75rem;font-size:.95rem;font-weight:600;color:#333}.filter-options{display:flex;flex-wrap:wrap;gap:.5rem}.filter-option{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border:2px solid #e8e5d5;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9rem}.filter-option:hover{border-color:#225400}.filter-option input[type=radio]{accent-color:#225400;width:16px;height:16px;cursor:pointer}.filter-option input[type=radio]:checked+span{font-weight:600}.rating-filter-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;font-size:.85rem;font-weight:700;color:#000}.filter-checkboxes{display:flex;flex-direction:column;gap:.5rem}.filter-checkbox{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border:2px solid #e8e5d5;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9rem}.filter-checkbox:hover{border-color:#225400}.filter-checkbox input[type=checkbox]{accent-color:#225400;width:18px;height:18px;cursor:pointer}.filter-checkbox input[type=checkbox]:checked+span{font-weight:600}.filter-checkbox:has(input:checked){background:#2254001a;border-color:#225400}.filter-checkbox:has(input:checked) span{color:#225400;font-weight:600}.clear-filters-button{width:100%;padding:.75rem;margin-top:.5rem;background:transparent;border:2px solid #e8e5d5;border-radius:8px;font-size:.9rem;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease}.clear-filters-button:hover{border-color:#225400;color:#225400;background-color:#2254000d}.pins-filter-options{gap:.75rem}.pin-option{min-width:60px;justify-content:center}.pin-option input[type=checkbox]{accent-color:#225400;width:16px;height:16px;cursor:pointer}.pin-option:has(input:checked){background:#22540026;border-color:#225400}.pin-svg{width:28px;height:28px;object-fit:contain}.architect-filter{position:relative}.architect-dropdown-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1rem;background:#fff;border:2px solid #e8e5d5;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9rem;color:#666}.architect-dropdown-trigger:hover{border-color:#225400}.architect-dropdown-trigger.open{border-color:#225400;border-bottom-left-radius:0;border-bottom-right-radius:0}.architect-dropdown-trigger.has-selection{color:#225400;background:#2254000d;border-color:#225400}.architect-dropdown-text{flex:1;text-align:left}.architect-dropdown-chevron{transition:transform .2s ease}.architect-dropdown-chevron.open{transform:rotate(180deg)}.architect-dropdown-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #225400;border-top:none;border-bottom-left-radius:8px;border-bottom-right-radius:8px;z-index:1200;max-height:300px;display:flex;flex-direction:column;box-shadow:0 4px 12px #00000026}.architect-search-container{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-bottom:1px solid #e8e5d5}.architect-search-container svg{color:#999;flex-shrink:0}.architect-search-input{flex:1;border:none;outline:none;font-size:.85rem;background:transparent}.architect-search-input::placeholder{color:#999}.clear-architects-btn{display:block;width:100%;padding:.5rem .75rem;background:#22540014;border:none;border-bottom:1px solid #e8e5d5;font-size:.8rem;color:#225400;cursor:pointer;text-align:left;transition:background .2s ease}.clear-architects-btn:hover{background:#22540026}.architect-options-list{flex:1;overflow-y:auto;padding:.5rem 0}.architect-option{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;cursor:pointer;transition:background .15s ease}.architect-option:hover{background:#2254000d}.architect-option input[type=checkbox]{accent-color:#225400;width:16px;height:16px;cursor:pointer;flex-shrink:0}.architect-name{flex:1;font-size:.85rem;color:#333}.architect-count{font-size:.75rem;color:#999;background:#f0f0f0;padding:.15rem .4rem;border-radius:4px}.architect-option:has(input:checked) .architect-name{font-weight:600;color:#225400}.architect-loading,.architect-empty{padding:1rem;text-align:center;color:#999;font-size:.85rem}.architect-more-hint{padding:.5rem .75rem;text-align:center;color:#999;font-size:.75rem;font-style:italic;border-top:1px solid #e8e5d5}.selected-architects{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.selected-architect-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#2254001a;border:1px solid #225400;border-radius:4px;font-size:.8rem;color:#225400}.remove-architect-btn{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;background:transparent;border:none;font-size:1rem;color:#225400;cursor:pointer;opacity:.7;transition:opacity .15s ease}.remove-architect-btn:hover{opacity:1}.course-pin-badge{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.15))}.course-pin-badge-sm{width:26px;height:26px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.15))}.view-editorial-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:1rem;padding:.75rem 1rem;background-color:#225400;color:#fffce7;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.view-editorial-button:hover{background-color:#1a4000;transform:translateY(-1px);box-shadow:0 4px 12px #2254004d}.view-editorial-button:active{transform:translateY(0)}.view-editorial-button svg{flex-shrink:0}.view-editorial-button--card{margin-top:.75rem;padding:.5rem .75rem;font-size:.8rem}.view-editorial-button--inline{width:auto;margin-top:.5rem;padding:.4rem .75rem;font-size:.75rem;border-radius:6px}.view-editorial-button--popup{margin-top:.75rem;padding:.5rem .75rem;font-size:.8rem;border-radius:6px}.course-list-item-buttons{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.review-display-loading{padding:.75rem;color:#666;font-size:.85rem;text-align:center}.review-display-compact{margin-top:1rem;padding-top:1rem;border-top:1px solid #e8e5d5}.review-display-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.cm-pins-badge{display:inline-block;padding:.25rem .5rem;background:linear-gradient(135deg,#225400,#3a7a00);color:#fffce7;font-size:.7rem;font-weight:700;border-radius:4px;letter-spacing:.05em}.review-price{font-size:.9rem;font-weight:600;color:#225400}.review-ratings-compact{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.rating-item{font-size:.8rem;color:#666}.rating-item strong{color:#333}.review-excerpt{margin:0;font-size:.85rem;color:#555;line-height:1.5;font-style:italic}.review-display-full{margin-top:1.5rem;padding:1.25rem;background:#fff;border-radius:12px;border:2px solid #e8e5d5}.review-header-left{display:flex;align-items:center;gap:.75rem}.review-date{font-size:.8rem;color:#888}.review-price-badge{font-size:1rem;font-weight:700;color:#225400}.review-difficulty{display:flex;align-items:center;gap:.5rem;margin:1rem 0;padding:.75rem;background:#f9faf5;border-radius:8px}.difficulty-label{font-size:.85rem;color:#666}.difficulty-value{font-size:.9rem;font-weight:600;color:#225400}.review-ratings-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin-bottom:1rem}.rating-cell{display:flex;flex-direction:column;align-items:center;padding:.5rem;background:#f9faf5;border-radius:6px}.rating-label{font-size:.65rem;color:#888;text-align:center;margin-bottom:.25rem}.rating-grade{font-size:.95rem;font-weight:700;color:#225400}.review-text-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #e8e5d5}.review-text{margin:0;font-size:.9rem;line-height:1.7;color:#333;white-space:pre-wrap}@media (max-width: 768px){.review-ratings-grid{grid-template-columns:repeat(3,1fr)}}.pins-learn-more-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:1rem;padding:.625rem 1rem;background-color:transparent;border:2px solid #225400;border-radius:8px;font-size:.85rem;font-weight:600;color:#225400;cursor:pointer;transition:all .2s ease}.pins-learn-more-button:hover{background-color:#225400;color:#fffce7}.pins-learn-more-button svg{flex-shrink:0}.pins-doc-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000b3;backdrop-filter:blur(4px);z-index:3000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease;padding:2rem}.pins-doc-container{position:relative;width:100%;max-width:720px;max-height:calc(100vh - 4rem);background:linear-gradient(180deg,#fffdf0,#fffce7);border:3px solid #225400;border-radius:24px;box-shadow:0 24px 64px #00000059,0 0 0 1px #ffffff1a inset;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.pins-doc-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.75rem;background:linear-gradient(180deg,rgba(34,84,0,.06) 0%,transparent 100%);border-bottom:1px solid rgba(34,84,0,.15);flex-shrink:0}.pins-doc-header-content{display:flex;align-items:center;gap:1rem}.pins-doc-logo{width:44px;height:44px}.pins-doc-logo-img{width:100%;height:100%;object-fit:cover}.pins-doc-header-text h2{margin:0;font-size:1.25rem;font-weight:700;color:#1a3d00;letter-spacing:-.02em}.pins-doc-tagline{margin:.15rem 0 0;font-size:.8rem;color:#5a7a4a;font-weight:500}.close-pins-doc-button{width:36px;height:36px;background:#0000000d;border:none;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-pins-doc-button:hover{background-color:#0000001a;color:#333;transform:scale(1.05)}.pins-doc-content{flex:1;overflow-y:auto;padding:1.5rem 1.75rem 2rem}.pins-doc-intro-section{text-align:center;margin-bottom:1.75rem}.pins-doc-intro-section p{font-size:.95rem;line-height:1.7;color:#555;max-width:560px;margin:0 auto}.pins-doc-cards{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.pins-doc-card{background:#fff;border-radius:16px;padding:1.25rem;border:2px solid transparent;box-shadow:0 2px 8px #0000000f;transition:all .2s ease}.pins-doc-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001a}.pins-doc-card-1{border-color:#22540033;background:linear-gradient(135deg,#fff,#22540008)}.pins-doc-card-2{border-color:#2254004d;background:linear-gradient(135deg,#fff,#2254000d)}.pins-doc-card-3{border-color:#22540080;background:linear-gradient(135deg,#fff,#ffd70014);box-shadow:0 4px 16px #2254001a}.pins-doc-card-header{display:flex;align-items:center;gap:.875rem;margin-bottom:.75rem}.pins-doc-card-badge{width:48px;height:48px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.pins-doc-card-header h3{margin:0;font-size:1.1rem;font-weight:700;color:#1a3d00}.pins-doc-card-subtitle{display:block;font-size:.75rem;font-weight:600;color:#225400;text-transform:uppercase;letter-spacing:.05em;margin-top:.1rem}.pins-doc-card blockquote{margin:0 0 .75rem;padding:.5rem .875rem;background:#2254000f;border-left:3px solid #225400;border-radius:0 6px 6px 0;font-size:.9rem;font-style:italic;color:#333;font-weight:500}.pins-doc-card>p{margin:0 0 .875rem;font-size:.875rem;line-height:1.6;color:#555}.pins-doc-card-traits{display:flex;flex-wrap:wrap;gap:.5rem}.pins-doc-card-traits span{padding:.3rem .625rem;background:#22540014;border-radius:100px;font-size:.75rem;font-weight:600;color:#225400}.pins-doc-divider{display:flex;align-items:center;text-align:center;margin:.5rem 0 1.5rem}.pins-doc-divider:before,.pins-doc-divider:after{content:"";flex:1;border-bottom:1px solid #e8e5d5}.pins-doc-divider span{padding:0 1rem;font-size:.8rem;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.08em}.pins-doc-criteria-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.875rem;margin-bottom:1.5rem}.pins-doc-criteria-item{padding:1rem;background:#fff;border:1px solid #e8e5d5;border-radius:12px;transition:all .2s ease}.pins-doc-criteria-item:hover{border-color:#225400;box-shadow:0 4px 12px #22540014}.pins-doc-criteria-item:last-child{grid-column:1 / -1}.pins-doc-criteria-icon{width:36px;height:36px;background:linear-gradient(135deg,#2254001a,#2254000d);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:.625rem;color:#225400}.pins-doc-criteria-item h4{margin:0 0 .35rem;font-size:.9rem;font-weight:700;color:#1a3d00}.pins-doc-criteria-item p{margin:0;font-size:.8rem;line-height:1.5;color:#666}.pins-doc-footer-note{display:flex;gap:.75rem;padding:1rem 1.125rem;background:linear-gradient(135deg,#2254000d,#22540005);border:1px solid rgba(34,84,0,.15);border-radius:12px}.pins-doc-footer-note svg{flex-shrink:0;color:#225400;margin-top:.1rem}.pins-doc-footer-note p{margin:0;font-size:.8rem;color:#555;line-height:1.55}.pins-doc-footer-note strong{color:#225400}@media (max-width: 640px){.pins-doc-overlay{padding:0;backdrop-filter:none}.pins-doc-container{max-width:100%;max-height:100vh;border-radius:0;border:none}.pins-doc-header{padding:1rem 1.25rem}.pins-doc-logo{width:36px;height:36px}.pins-doc-header-text h2{font-size:1.1rem}.pins-doc-tagline{font-size:.75rem}.close-pins-doc-button{width:40px;height:40px}.pins-doc-content{padding:1.25rem}.pins-doc-card{padding:1rem}.pins-doc-card-badge{width:40px;height:40px}.pins-doc-card-header h3{font-size:1rem}.pins-doc-criteria-grid{grid-template-columns:1fr}.pins-doc-criteria-item:last-child{grid-column:auto}}.oauth-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.oauth-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:.875rem 1.5rem;border:2px solid #d0d0d0;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:#fff}.oauth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.oauth-button:active:not(:disabled){transform:translateY(0)}.oauth-button:disabled{opacity:.6;cursor:not-allowed}.google-button{color:#1f1f1f;border-color:#dadce0}.google-button:hover:not(:disabled){background-color:#f8f9fa;border-color:#dadce0}.apple-button{background:#000;color:#fff;border-color:#000}.apple-button:hover:not(:disabled){background:#1a1a1a}.oauth-divider{display:flex;align-items:center;text-align:center;color:#6b7280;margin:20px 0;font-size:.875rem;font-weight:500}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;border-bottom:1px solid #e5e7eb}.oauth-divider span{padding:0 12px}.signup-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#fffce7;padding:2rem}.signup-form{background:#fff;padding:2.5rem;border-radius:20px;border:3px solid #225400;box-shadow:0 8px 32px #00000026;width:100%;max-width:480px}.signup-header{text-align:center;margin-bottom:2rem}.signup-title{font-size:2rem;font-weight:600;color:#000;margin:0 0 .5rem;letter-spacing:-.02em}.signup-subtitle{font-size:.95rem;color:#666;margin:0;line-height:1.4}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.9rem;font-weight:500;color:#225400;margin-bottom:.5rem}.form-input{width:100%;padding:.875rem 1rem;border:2px solid #d0d0d0;border-radius:8px;font-size:.95rem;color:#000;background:#fff;transition:all .2s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#225400;box-shadow:0 0 0 3px #2254001a}.form-input.error{border-color:#ef4444}.form-input.error:focus{box-shadow:0 0 0 3px #ef44441a}.form-input::placeholder{color:#999}.error-message{color:#ef4444;font-size:.8rem;margin-top:.35rem;font-weight:500}.password-strength{margin-top:.75rem;padding:.75rem;background:#f8f9fa;border-radius:6px}.strength-bar{display:flex;gap:4px;margin-bottom:.5rem}.strength-segment{height:4px;flex:1;border-radius:2px;transition:background-color .3s ease;background-color:#e5e5e5}.requirements-list{list-style:none;padding:0;margin:.5rem 0 0;font-size:.8rem;color:#666}.requirements-list li{margin-bottom:.25rem;display:flex;align-items:center;gap:.35rem}.requirements-list li.met{color:#16a34a;font-weight:500}.password-toggle-button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#666;font-size:.8rem;font-weight:500;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease}.password-toggle-button:hover{color:#225400;background:#2254000d}.signup-button{width:100%;padding:.875rem 1.5rem;background-color:#225400;color:#fffce7;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.signup-button:hover:not(:disabled){background-color:#1a4000;transform:translateY(-1px);box-shadow:0 4px 12px #2254004d}.signup-button:active:not(:disabled){transform:translateY(0)}.signup-button:disabled{opacity:.6;cursor:not-allowed}.login-link{text-align:center;margin-top:1.5rem;font-size:.9rem;color:#666}.login-link a{color:#225400;text-decoration:none;font-weight:600;transition:color .2s ease}.login-link a:hover{color:#1a4000;text-decoration:underline}@media (max-width: 768px){.signup-container{padding:1rem}.signup-form{padding:2rem 1.5rem}.signup-title{font-size:1.75rem}.signup-subtitle{font-size:.875rem}}.welcome-overlay{position:fixed;inset:0;z-index:9999;pointer-events:none}.welcome-overlay-backdrop{position:absolute;inset:0;background:#00000080;pointer-events:none}.welcome-overlay-backdrop:has(.welcome-overlay-spotlight){background:transparent}.welcome-overlay-spotlight{position:absolute;border-radius:12px;box-shadow:0 0 0 4px #fffce780,0 0 0 9999px #0009;pointer-events:none;transition:all .3s ease-out;z-index:10000}.welcome-overlay-spotlight.interactive{box-shadow:0 0 0 4px #22540099,0 0 0 9999px #0009;animation:pulse-spotlight 2s ease-in-out infinite}@keyframes pulse-spotlight{0%,to{box-shadow:0 0 0 4px #22540099,0 0 20px #2254004d,0 0 0 9999px #0009}50%{box-shadow:0 0 0 8px #22540066,0 0 30px #22540080,0 0 0 9999px #0009}}.welcome-flow-card{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--color-background, #fffce7);border-radius:16px;padding:32px 24px 24px;max-width:420px;width:calc(100% - 40px);box-shadow:0 8px 32px #0000004d;z-index:10001;animation:slideUp .3s cubic-bezier(.4,0,.2,1);pointer-events:auto}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.welcome-flow-dismiss{position:absolute;top:12px;right:12px;background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--color-text-secondary, #666);padding:4px 8px;transition:color .2s}.welcome-flow-dismiss:hover{color:var(--color-text, #000)}.welcome-step{text-align:center;margin-bottom:24px}.welcome-step-title{font-size:22px;font-weight:700;color:var(--color-primary, #225400);margin:0 0 12px;line-height:1.3}.welcome-step-description{font-size:15px;line-height:1.6;color:var(--color-text, #333);margin:0}.welcome-step-action{display:flex;align-items:center;justify-content:center;gap:8px;margin:16px 0 0;padding:12px 16px;background:#22540014;border-radius:8px;font-size:14px;font-weight:500;color:var(--color-primary, #225400)}.welcome-step-action-icon{font-size:18px;animation:bounce-hand 1s ease-in-out infinite}@keyframes bounce-hand{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.welcome-icon-states{display:flex;justify-content:space-evenly;margin:16px 0}.welcome-icon-item{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;max-width:100px}.welcome-icon-circle{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fffce7;border:2px solid #e8e5d5;color:#666}.welcome-icon-active .welcome-icon-circle{background:#225400;border-color:#225400;color:#fffce7}.welcome-icon-played .welcome-icon-circle{background:#2e8b5726;border-color:#2e8b57;color:#2e8b57}.welcome-icon-item span{font-size:12px;color:var(--color-text, #333);text-align:center;line-height:1.3}.welcome-icon-single{display:flex;justify-content:center;margin:16px 0}.progress-indicator{display:flex;justify-content:center;gap:8px;margin:24px 0}.progress-dot{width:8px;height:8px;border-radius:50%;background:#d1d5db;transition:all .3s ease}.progress-dot.active{background:var(--color-primary, #225400);transform:scale(1.3)}.progress-dot.completed{background:var(--color-primary, #225400);opacity:.6}.welcome-flow-actions{display:flex;gap:12px;margin-top:20px}.welcome-flow-btn{flex:1;padding:12px 24px;border-radius:8px;font-weight:600;font-size:15px;cursor:pointer;transition:all .2s;border:none;font-family:inherit}.welcome-flow-btn-primary{background:var(--color-primary, #225400);color:#fff}.welcome-flow-btn-primary:hover{background:#1a4000;transform:translateY(-1px);box-shadow:0 2px 8px #2254004d}.welcome-flow-btn-primary:active{transform:translateY(0)}.welcome-flow-btn-secondary{background:transparent;color:var(--color-primary, #225400);border:2px solid var(--color-primary, #225400)}.welcome-flow-btn-secondary:hover{background:#2254000d}.welcome-flow-skip{display:block;width:100%;margin-top:12px;background:none;border:none;color:var(--color-text-secondary, #666);cursor:pointer;font-size:14px;text-decoration:underline;padding:8px;transition:color .2s;font-family:inherit}.welcome-flow-skip:hover{color:var(--color-text, #333)}@media (max-width: 640px){.welcome-flow-card{bottom:16px;width:calc(100% - 32px);padding:28px 20px 20px}.welcome-step-title{font-size:20px}.welcome-step-description{font-size:14px}.welcome-flow-btn{padding:10px 20px;font-size:14px}}@media (prefers-reduced-motion: reduce){.welcome-flow-card{animation:none}.welcome-overlay-spotlight,.progress-dot,.welcome-flow-btn{transition:none}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif;color:#0f172a;background-color:#f8fafc;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{margin:0;padding:0;height:100%;width:100%;background-color:#f1f5f9;overflow:hidden}#root{height:100%;width:100%}main.app-shell{max-width:960px;margin:0 auto;padding:2rem 1.5rem 4rem}header{margin-bottom:2rem}header h1{margin:0}.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.course-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 8px 20px #0f172a14;display:flex;flex-direction:column;gap:.75rem}.course-card header h2{margin:0;font-size:1.1rem}.course-card .instructor{margin:.25rem 0 0;color:#475569}dl{display:flex;justify-content:space-between;margin:0}dl div{display:flex;flex-direction:column;gap:.25rem}.description{margin:0;color:#334155}footer{display:flex;flex-wrap:wrap;gap:.5rem}.tag{background:#e2e8f0;color:#0f172a;padding:.2rem .6rem;border-radius:999px;font-size:.75rem}.status{padding:1.25rem;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0f172a0f}.status.error{border:1px solid #f87171}.status pre{margin:.5rem 0 0;overflow:auto;font-size:.8rem;color:#b91c1c}:root{--touch-target-min: 44px;--mobile-padding: 1rem;--mobile-gap: .75rem}@media (max-width: 768px){button,[role=button],input[type=checkbox],input[type=radio],.clickable{min-height:var(--touch-target-min);min-width:var(--touch-target-min)}}@media (max-width: 480px){.course-grid{grid-template-columns:1fr;gap:1rem}}@media (max-width: 640px){main.app-shell{padding:1rem 1rem 3rem}}
