.course-detail-page{min-height:100vh;background-color:#fff;padding-bottom:60px;padding-top:0!important;margin:0;padding-left:0!important;padding-right:0!important}.course-qrcode-section{background:linear-gradient(135deg,#f0fdf8,#f5fcf9);padding:32px 16px;text-align:center;margin:16px 0}.qrcode-title{font-size:20px;font-weight:600;color:#1a1a1a;margin-bottom:20px}.qrcode-wrapper{display:flex;justify-content:center;align-items:center;margin-bottom:16px}.qrcode-detail-image,.qrcode-loading{width:200px;height:200px;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.1);background:white}.qrcode-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;font-size:14px;color:#999}.loading-spinner{width:32px;height:32px;border:3px solid #f3f3f3;border-top-color:#31c38f;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.qrcode-placeholder{width:200px;height:200px;display:flex;justify-content:center;align-items:center;background:white;border:2px dashed #d9d9d9;border-radius:12px;font-size:14px;color:#999;cursor:pointer;transition:all .3s ease}.qrcode-placeholder:hover{border-color:#31C38F;color:#31C38F}.qrcode-hint{font-size:14px;color:#666;margin-top:8px}.error-container,.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;font-size:15px;color:#999}.error-icon{font-size:48px;margin-bottom:16px}.error-message{margin-bottom:24px}.retry-button{padding:12px 32px;background-color:#31C38F;color:white;border:none;border-radius:24px;font-size:14px;cursor:pointer}.course-detail-page .banner-container{position:relative;width:100%;aspect-ratio:750/562;margin:0!important;padding:0!important;overflow:hidden;max-width:none!important}.course-detail-page .banner-swiper{width:100%;height:100%}.course-detail-page .banner-image{width:100%!important;height:100%!important;max-width:none!important;object-fit:cover;display:block}.course-detail-page .custom-navbar{position:absolute;top:0;left:0;right:0;z-index:1000;padding-top:0}.course-detail-page .navbar-back{position:absolute;left:23px;top:20px;width:9px;height:17px;display:flex;align-items:center;justify-content:center;background-color:transparent;border-radius:0;cursor:pointer;z-index:1001}.course-detail-page .back-icon{width:9px;height:17px;display:block;filter:drop-shadow(0 0 2px rgba(0,0,0,.3))}.course-detail-page .course-info{background-color:#fff;margin-bottom:10px;margin-top:-10px;width:100%;height:152px;box-sizing:border-box;border-radius:10px 10px 0 0;position:relative;z-index:10;padding:0;left:0!important;right:auto!important;top:auto!important}.course-detail-page .course-title{position:absolute;left:17.5px;top:25px;font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:18px;font-weight:600;line-height:18px;color:#222222;width:calc(100% - 150px);overflow:hidden;text-overflow:ellipsis;white-space:normal;word-break:break-word}.course-detail-page .price-section{position:relative;height:100px}.course-detail-page .price-symbol{left:17.5px;top:64.5px;font-size:21px;line-height:18px}.course-detail-page .price-amount,.course-detail-page .price-symbol{position:absolute;font-family:DIN Condensed,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:700;color:#FF4D4F}.course-detail-page .price-amount{left:28.75px;top:58px;font-size:31.5px;line-height:31.5px}.course-detail-page .course-tags{position:absolute;right:17.5px;top:24px;font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:12px;color:#fff}.course-detail-page .course-tag{background-color:#31C38F;border-radius:2px;padding:4px 5px;display:inline-flex;align-items:center;min-height:16px;box-sizing:border-box}.course-detail-page .tag-number{font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;font-weight:700;color:#fff}.course-detail-page .tag-separator,.course-detail-page .tag-text{font-size:12px;color:#fff}.course-detail-page .divider-line{position:absolute;left:17.5px;right:17.5px;top:108px;height:.5px;background-color:#E8E8E8}.course-detail-page .address-section{position:absolute;left:17.5px;right:17.5px;top:120px;display:flex;align-items:center;font-size:12px;color:#666;cursor:pointer}.course-detail-page .location-icon{width:10px;height:13px;margin-right:4px}.course-detail-page .address-text{font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:12px;color:#666;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-detail-page .gray-spacer{position:absolute;left:0;right:0;bottom:0;height:10px;background-color:#F5F5F5}.course-detail-page .time-selector{background-color:#fff;padding:0;margin-bottom:30px;position:relative;width:100%;box-sizing:border-box;overflow:hidden}.course-detail-page .time-icon{position:absolute;left:17.5px;top:31.5px;width:18px;height:18px}.course-detail-page .time-title{position:absolute;left:40.5px;top:31.5px;font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;font-weight:700;line-height:18px;color:#222222}.course-detail-page .time-notice-text{position:absolute;left:109.5px;top:38px;font-size:11px;font-weight:400;line-height:11px;color:#999}.course-detail-page .time-options{margin-top:69.5px;width:100%;display:flex;flex-wrap:wrap;gap:8px;padding:0 17.5px;margin-bottom:0}.course-detail-page .time-option{width:calc(50% - 4px);max-width:166px;height:38px;background-color:#F4F6F8;border-radius:4px;border:none;display:flex;align-items:center;justify-content:center;font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:12px;font-weight:400;line-height:12px;color:#222222;cursor:pointer;transition:all .3s;margin:0}.course-detail-page .time-option.active{background-color:#31C38F;color:#FFFFFF;font-weight:500;border:none}@supports not (gap:8px){.course-detail-page .time-options{margin-left:-4px;margin-right:-4px}.course-detail-page .time-option{margin:0 4px 8px}}.course-detail-page .group-section{background-color:#fff;margin-bottom:30px;width:100%;box-sizing:border-box;position:relative;padding:0;overflow:hidden}.course-detail-page .group-icon{position:absolute;left:17.5px;top:15px;width:18px;height:18px}.course-detail-page .group-title{position:absolute;left:40.5px;top:15px;font-family:PingFang SC,sans-serif;font-size:16px;line-height:18px;color:#222222;font-weight:700}.course-detail-page .group-refund-notice{position:absolute;left:93.5px;top:21.5px;font-family:PingFang SC,sans-serif;font-size:11px;line-height:11px;color:#999999}.course-detail-page .group-list{margin-top:56.5px;margin-bottom:10px;width:100%;padding:0}.course-detail-page .group-item{position:relative;height:27px;margin-bottom:0;border:none}.course-detail-page .group-item:first-child{margin-top:0}.course-detail-page .group-item:not(:first-child){margin-top:22px}.course-detail-page .member-avatars{position:absolute;left:17.5px;top:0;height:20px;display:flex}.course-detail-page .user-avatar{width:20px!important;height:20px!important;min-width:20px!important;max-width:20px!important;min-height:20px!important;max-height:20px!important;border-radius:50%;border:.5px solid #fff;box-sizing:border-box;object-fit:cover}.course-detail-page .user-avatar:first-child{position:absolute;left:0;top:3.5px}.course-detail-page .user-avatar:nth-child(2){position:absolute;left:15px;top:3.5px}.course-detail-page .user-avatar:nth-child(n+3){display:none}.course-detail-page .member-nickname{position:absolute;left:55px;top:7.5px;font-family:PingFang SC,sans-serif;font-size:11px;line-height:12px;color:#666666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:40px}.course-detail-page .group-time{left:100px;color:#222222}.course-detail-page .group-time,.course-detail-page .remain-count{position:absolute;top:7.5px;font-family:PingFang SC,sans-serif;font-size:12px;line-height:12px;white-space:nowrap}.course-detail-page .remain-count{left:241.5px;color:#31C38F}.course-detail-page .join-btn{position:absolute!important;left:292.5px;top:0;width:65px!important;height:27px!important;background-color:#31C38F!important;background-image:none!important;color:#FFFFFF!important;font-family:PingFang SC,sans-serif!important;font-size:12px!important;line-height:12px!important;border-radius:13.5px!important;padding:0!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important;text-align:center!important;border:none!important;box-sizing:border-box!important;cursor:pointer!important}.course-detail-page .course-notice{width:calc(100% - 35px);height:auto;background:linear-gradient(135deg,#FFEBEB,#FFFCFC);margin:0 17.5px 30px;position:relative;border-radius:4px;box-sizing:border-box;padding-top:38px;padding-bottom:15px}.course-detail-page .notice-icon{position:absolute;width:24px;height:24px;left:15px;top:7px}.course-detail-page .notice-title{position:absolute;left:47px;top:10px;font-family:PingFang SC,sans-serif;font-size:13px;line-height:18px;font-weight:700;color:#333333}.course-detail-page .notice-content{width:calc(100% - 30px);max-width:600px;background-color:#FFFFFF;margin:0 auto;border-radius:4px;position:relative;padding:10px 0}.course-detail-page .notice-section-title{font-family:PingFang SC,sans-serif;font-size:12px;font-weight:700;color:#666666;margin:5px 0 10px 15px;line-height:16px}.course-detail-page .notice-section-after{margin-top:30px}.course-detail-page .notice-line{width:100%;display:flex;align-items:flex-start;margin-bottom:6px;position:relative}.course-detail-page .notice-line:last-child{margin-bottom:0}.course-detail-page .notice-line-icon{width:12px;height:12px;margin-left:15px;margin-top:1px;flex-shrink:0}.course-detail-page .notice-line-text{flex:1;margin-left:7px;margin-right:15px;font-family:PingFang SC,sans-serif;font-size:12px;line-height:16px;color:#666666}.course-detail-page .course-intro{background-color:#fff;padding:0;margin-bottom:30px;position:relative;width:100%;box-sizing:border-box;overflow:hidden}.course-detail-page .intro-icon{position:absolute;left:17.5px;top:0;width:18px;height:18px}.course-detail-page .intro-title{position:absolute;left:40.5px;top:0;font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;line-height:18px;font-weight:700;color:#222222}.course-detail-page .intro-content{margin-top:38px;width:100%;padding:0}.course-detail-page .intro-item{position:relative;min-height:13px;margin-bottom:18px}.course-detail-page .intro-item:last-child{margin-bottom:10px}.course-detail-page .intro-label{left:17.5px;color:#222222}.course-detail-page .intro-label,.course-detail-page .intro-value{position:absolute;top:0;font-family:PingFang SC,sans-serif;font-size:13px;line-height:13px;font-weight:400}.course-detail-page .intro-value{left:119.5px;color:#666666;color:#222;font-weight:500}.course-detail-page .bottom-nav{position:fixed;bottom:0;left:0;right:0;height:60px;background-color:#fff;display:flex;align-items:center;padding:0;box-shadow:0 -2px 8px rgba(0,0,0,.1);z-index:1000;box-sizing:border-box}@media (min-width:1024px){.course-detail-page{background-color:#fff;padding-bottom:0}.course-detail-page .bottom-nav{display:none}.course-detail-page .time-options{padding:0 28px;gap:12px}.course-detail-page .time-option{max-width:none;width:calc((100% - 24px) / 3)}.course-detail-page .group-list{padding:0 28px;width:100%;box-sizing:border-box}.course-detail-page .group-item{height:auto}.course-detail-page .group-row{display:flex;align-items:center;gap:12px;width:100%;min-height:36px}.course-detail-page .group-left{display:flex;align-items:center;gap:20px;min-width:0;flex:1 1 auto}.course-detail-page .member-avatars{position:static;left:auto;top:auto;display:flex;align-items:center;flex-shrink:0}.course-detail-page .user-avatar{border:1px solid #fff;margin-left:-6px}.course-detail-page .user-avatar,.course-detail-page .user-avatar:first-child,.course-detail-page .user-avatar:nth-child(2){position:static;left:auto;top:auto}.course-detail-page .user-avatar:first-child{margin-left:0}.course-detail-page .member-nickname{position:static;left:auto;top:auto;max-width:140px;flex-shrink:0;margin-left:8px;line-height:12px;font-size:11px}.course-detail-page .group-center{display:flex;align-items:center;min-width:0;flex:1 1 auto}.course-detail-page .group-time{position:static;left:auto;top:auto;overflow:hidden;text-overflow:ellipsis}.course-detail-page .action-group{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0}.course-detail-page .remain-count{position:static;left:auto;top:auto}.course-detail-page .join-btn{position:static!important;left:auto!important;top:auto!important}}@media (min-width:768px){.course-detail-page .bottom-nav{left:50%;transform:translateX(-50%);max-width:375px;width:375px}}.course-detail-page .nav-home{position:absolute;left:20px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:transparent;padding:0;border:none;line-height:normal;margin:0;height:auto;z-index:10}.course-detail-page .nav-icon{width:22px;height:22px;margin-bottom:4.5px}.course-detail-page .nav-text{font-size:11px;line-height:12px;color:#666}.course-detail-page .nav-enroll{position:absolute;left:150px;top:50%;transform:translateY(-50%);width:205px;height:40px;background:linear-gradient(135deg,#31C38F,#2AB880);color:white;border:none;border-radius:20px;font-size:14px;line-height:21px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px rgba(49,195,143,.3);transition:all .3s;text-align:center;z-index:1}.course-detail-page .nav-enroll:active{opacity:.8}.course-detail-page .course-outline{background-color:#fff;width:100%;box-sizing:border-box;position:relative;margin-top:0;margin-bottom:30px;padding:0;overflow:hidden}.course-detail-page .outline-icon{position:absolute;width:18px;height:18px;left:17.5px;top:0}.course-detail-page .outline-title{position:absolute;left:40.5px;top:0;font-family:PingFang SC,sans-serif;font-size:16px;line-height:18px;color:#222222;font-weight:700}.course-detail-page .outline-content{margin-top:38px;width:100%;padding:0 17.5px 20px;font-size:14px;line-height:20px;color:#666;box-sizing:border-box;word-break:break-word}.course-detail-page .course-schedule-image{padding:15px;background-color:#fff;margin-bottom:10px;width:100%;box-sizing:border-box;border-radius:6px}.course-detail-page .schedule-image-content{width:100%}.course-detail-page .schedule-full-image{width:100%;display:block;border-radius:4px}.course-detail-page .course-schedule{padding:15px;background-color:#fff;margin-bottom:10px;width:100%;box-sizing:border-box;border-radius:6px}.course-detail-page .schedule-content{font-size:14px;line-height:1.6;color:#666}.course-detail-page .section-title{font-size:16px;font-weight:600;color:#222;margin-bottom:10px}.course-detail-page .course-preparation{background-color:#fff;width:100%;box-sizing:border-box;position:relative;margin-top:30px;margin-bottom:0;padding:0;min-height:75px;overflow:hidden}.course-detail-page .preparation-icon{position:absolute;width:18px;height:18px;left:17.5px;top:0}.course-detail-page .preparation-title{position:absolute;left:40.5px;top:0;font-family:PingFang SC,sans-serif;font-size:16px;line-height:18px;color:#222222;font-weight:700}.course-detail-page .preparation-content{margin-top:38px;width:100%;padding:0 17.5px 20px;font-size:14px;line-height:20px;color:#666}.course-detail-page .course-requirements{background-color:#fff;width:100%;box-sizing:border-box;position:relative;margin-top:30px;margin-bottom:0;padding:0;min-height:75px;overflow:hidden}.course-detail-page .requirements-icon{position:absolute;width:18px;height:18px;left:17.5px;top:0}.course-detail-page .requirements-title{position:absolute;left:40.5px;top:0;font-family:PingFang SC,sans-serif;font-size:16px;line-height:18px;color:#222222;font-weight:700}.course-detail-page .requirements-content{margin-top:38px;width:100%;padding:0 17.5px 20px;font-size:14px;line-height:20px;color:#666}.course-detail-page .course-environment{background-color:#fff;width:100%;box-sizing:border-box;position:relative;margin-top:30px;margin-bottom:0;padding:0;min-height:150px;overflow:hidden}.course-detail-page .environment-icon{position:absolute;width:18px;height:18px;left:17.5px;top:0}.course-detail-page .environment-title{position:absolute;left:40.5px;top:0;font-family:PingFang SC,sans-serif;font-size:16px;line-height:18px;color:#222222;font-weight:700}.course-detail-page .environment-images{margin-top:38px;width:100%;padding:0 17.5px 20px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.course-detail-page .environment-image{width:100%;aspect-ratio:1;border-radius:6px;object-fit:cover}.course-detail-page .course-teachers{background-color:#fff;width:100%;box-sizing:border-box;position:relative;margin-top:30px;margin-bottom:30px;padding:0;overflow:hidden}.course-detail-page .teachers-icon{position:absolute;width:18px;height:18px;left:17.5px;top:0}.course-detail-page .teachers-title{position:absolute;left:40.5px;top:0;font-family:PingFang SC,sans-serif;font-size:16px;line-height:18px;color:#222222;font-weight:700}.course-detail-page .teachers-content{margin-top:38px;width:100%;padding:0 17.5px 20px}.course-detail-page .teacher-item{display:flex;gap:15px;margin-bottom:20px}.course-detail-page .teacher-item:last-child{margin-bottom:0}.course-detail-page .teacher-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0}.course-detail-page .teacher-avatar img{width:100%;height:100%;object-fit:cover}.course-detail-page .teacher-info{flex:1}.course-detail-page .teacher-name{font-size:16px;font-weight:600;color:#222;margin-bottom:5px}.course-detail-page .teacher-title-text{font-size:14px;color:#666;margin-bottom:5px}.course-detail-page .teacher-description{font-size:14px;line-height:20px;color:#666}.course-detail-page .course-faq{background-color:#fff;width:100%;margin-top:30px;margin-bottom:30px;padding:0;position:relative;overflow:hidden}.course-detail-page .faq-icon{position:absolute;width:18px;height:18px;left:17.5px;top:0}.course-detail-page .faq-title{position:absolute;left:40.5px;top:0;font-family:PingFang SC,sans-serif;font-size:16px;line-height:18px;color:#222222;font-weight:700}.course-detail-page .faq-content{margin-top:38px;width:100%;padding:0 17.5px 20px}.course-detail-page .faq-item{margin-bottom:25px}.course-detail-page .faq-item:last-child{margin-bottom:0}.course-detail-page .faq-question-row{display:flex;align-items:flex-start;margin-bottom:12px}.course-detail-page .faq-user-avatar{width:24px;height:24px;border-radius:4px;flex-shrink:0}.course-detail-page .faq-question{background-color:#F5F5F5;padding:10px 15px;border-radius:8px;font-size:14px;line-height:18px;color:#222;max-width:70%}.course-detail-page .faq-answer-row{display:flex;align-items:flex-start;justify-content:flex-end}.course-detail-page .faq-answer{background-color:#E6F7F2;padding:10px 15px;border-radius:8px;max-width:70%;margin-right:8px}.course-detail-page .faq-answer-text{font-size:14px;line-height:18px;color:#222}.course-detail-page .faq-answer-text div{margin-bottom:5px}.course-detail-page .faq-answer-text div:last-child{margin-bottom:0}.course-detail-page .faq-teacher-avatar{width:24px;height:24px;border-radius:4px;flex-shrink:0}.course-detail-custom-sidebar{display:none}@media (min-width:769px){.course-detail-custom-sidebar{display:block;position:fixed;right:calc((100vw - 1200px) / 2);top:20px;width:340px;max-height:calc(100vh - 40px);overflow-y:auto;background:transparent;padding:16px;z-index:100;scrollbar-width:none;-ms-overflow-style:none}.course-detail-custom-sidebar::-webkit-scrollbar{display:none}.course-detail-page~.pc-right-sidebar,body:has(.course-detail-page) .pc-right-sidebar{display:none!important}}.course-footer-image{position:relative;width:100%;max-width:750px;margin:20px auto 0;--qrcode-left-percent:82%;--qrcode-bottom-percent:60%;--qrcode-size-percent:26%;--wechat-left-percent:31%;--wechat-bottom-percent:16%}@media (min-width:1024px){.course-footer-image{--wechat-left-percent:31%;--wechat-bottom-percent:18%;--qrcode-size-percent:40%}}.course-footer-bg{width:100%;display:block}.course-footer-qrcode{position:absolute;left:var(--qrcode-left-percent);bottom:var(--qrcode-bottom-percent);width:var(--qrcode-size-percent);max-width:150px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:transparent;transform:translate(-50%,50%)}.course-qrcode-image{width:100%;height:100%;display:block}.course-qrcode-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.9)}.course-qrcode-loading .loading-spinner{width:30%;height:30%;min-width:20px;min-height:20px;max-width:24px;max-height:24px;border:2px solid #f3f3f3;border-top-color:#31c38f;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.course-footer-wechat{position:absolute;left:var(--wechat-left-percent);bottom:var(--wechat-bottom-percent);font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:4.27vw;font-weight:600;color:#31C38F;text-align:left;cursor:pointer;padding:4px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:8px;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;white-space:nowrap;transform:translateX(-50%)}.course-footer-wechat:active{transform:translateX(-50%);opacity:1}.course-footer-wechat:focus{outline:none}@media (min-width:750px){.course-footer-wechat{font-size:16px}}@media (max-width:320px){.course-footer-wechat{font-size:14px}}.wechat-text{user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.wechat-copy-success{position:absolute;right:-30px;top:50%;transform:translateY(-50%);font-size:18px;color:#52C41A;font-weight:700}.copy-success-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:rgba(0,0,0,.8);color:#fff;padding:12px 24px;border-radius:8px;display:flex;align-items:center;gap:8px;z-index:100000;box-shadow:0 4px 12px rgba(0,0,0,.3);animation:fadeInOut 2s ease}.copy-success-toast .toast-icon{width:20px;height:20px;flex-shrink:0}.copy-success-toast .toast-text{font-family:PingFang SC,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;font-weight:500;white-space:nowrap}@keyframes fadeInOut{0%{opacity:0}15%{opacity:1}85%{opacity:1}to{opacity:0}}