@import"https://fonts.googleapis.com/css2?family=Sarabun:wght@400;500;600;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;background:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background:#fff}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.mobile-layout{display:flex;flex-direction:column;min-height:100vh}.mobile-content{flex:1;overflow-y:auto;padding-bottom:70px}.bottom-navbar{position:fixed;bottom:0;left:0;right:0;height:70px;background-color:#fff;display:flex;justify-content:space-around;align-items:center;border-top:1px solid #e8e8e8;box-shadow:0 -2px 8px #0000000f;z-index:1000;padding:8px 0;padding-bottom:env(safe-area-inset-bottom,8px)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:none;border:none;cursor:pointer;padding:8px 16px;min-width:70px;transition:all .2s ease}.nav-item:focus{outline:none}.nav-item:focus-visible{outline:none}.nav-item:active{transform:scale(.95)}.nav-icon{font-size:22px;color:#999;transition:color .2s ease}.nav-label{font-size:11px;color:#999;white-space:nowrap;transition:color .2s ease}.nav-item.active .nav-icon{color:#8cbf18}.nav-item.active .nav-label{color:#8cbf18;font-weight:500}#qr-reader__header_message,#qr-reader__status_span,#qr-reader__dashboard_section_csr span,#qr-reader__camera_permission_button+br{display:none!important}#qr-reader{border:none!important;background:transparent!important}#qr-reader video{border-radius:12px;border:3px solid #5aad1e!important}#qr-reader__scan_region{background:transparent!important}#qr-reader__dashboard_section_csr button{background:#5aad1e!important;color:#fff!important;border:none!important;border-radius:8px!important;padding:10px 24px!important;cursor:pointer!important}.register-container-success{font-family:Sarabun,sans-serif;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:#fff}.success-wrapper{display:flex;flex-direction:column;align-items:center;gap:20px;opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.success-wrapper.visible{opacity:1;transform:translateY(0)}.icon-circle{width:80px;height:80px;border-radius:50%;background-color:#f0fae8;display:flex;align-items:center;justify-content:center}.checkmark{width:36px;height:36px;stroke:#52c41a;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;fill:none;stroke-dasharray:60;stroke-dashoffset:60;animation:draw .5s ease .3s forwards}@keyframes draw{to{stroke-dashoffset:0}}.success-text{color:#52c41a;font-size:18px;font-weight:600;letter-spacing:.01em}.register-container{display:flex;flex-direction:column;min-height:100vh;width:100%;background-color:#fff;font-family:Prompt,Roboto,sans-serif}.register-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 8px;background-color:#fff;border-bottom:1px solid #f0f0f0}.back-button{background:none;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#88c126;font-size:24px;line-height:1}.back-button:hover{opacity:.8}.register-title{font-size:20px;font-weight:700;color:#88c126;margin:0;text-align:center}.header-spacer{width:34px}.register-form-section{flex:1;display:flex;flex-direction:column;padding:8px 14px 100px;overflow-y:auto}.register-form-wrapper{width:100%;max-width:400px;margin:0 auto}.register-alert{margin-bottom:24px;border-radius:8px;border:1px solid transparent;background-color:#fff1f0;color:#e02b1d;font-size:14px;font-weight:400px}.register-alert .ant-alert-message{color:#d48806;font-size:13px}.form-label{font-size:14px;color:#333;font-weight:500}.required{color:#ff4d4f;margin-left:2px}.register-form-wrapper .ant-form-item{margin-bottom:16px}.register-form-wrapper .ant-form-item-label{padding-bottom:4px}.register-form-wrapper .ant-form-item-label>label{height:auto}.register-form-wrapper .ant-input,.register-form-wrapper .ant-input-affix-wrapper{border-radius:8px;border:1px solid #e0e0e0;padding:12px 16px;font-size:14px}.register-form-wrapper .ant-input-affix-wrapper{padding:0 16px}.register-form-wrapper .ant-input-affix-wrapper .ant-input{background-color:transparent;padding:12px 0}.register-form-wrapper .ant-input::placeholder{color:#999}.register-form-wrapper .ant-input:focus,.register-form-wrapper .ant-input-affix-wrapper:focus,.register-form-wrapper .ant-input-affix-wrapper-focused{border-color:#88c126;box-shadow:0 0 0 2px #88c1261a}.register-button-wrapper{position:fixed;bottom:0;left:0;right:0;padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom));background-color:#fff;box-shadow:0 -2px 8px #00000014;z-index:100}.register-button-wrapper .register-button{max-width:400px;margin:0 auto;display:block}.register-button{width:100%;height:48px!important;background-color:#88c126!important;border-color:#88c126!important;border-radius:24px!important;font-size:16px!important;font-weight:600!important;box-shadow:none!important}.register-button:hover,.register-button:focus{background-color:#7ab31e!important;border-color:#7ab31e!important}.register-button:disabled,.register-button.ant-btn-disabled{background-color:#c8e89a!important;border-color:#c8e89a!important;color:#fff!important;cursor:not-allowed!important}.otp-section{flex:1;display:flex;flex-direction:column;align-items:center;padding:40px 24px 100px}.otp-wrapper{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:0}.otp-description{font-size:14px;color:#555;text-align:center;margin:0 0 6px}.otp-email{font-size:14px;font-weight:600;color:#88c126;text-align:center;margin:0 0 32px}.otp-inputs{display:flex;gap:10px;justify-content:center;margin-bottom:12px}.otp-box{width:46px;height:52px;border:1.5px solid #d9d9d9;border-radius:8px;text-align:center;font-size:20px;font-weight:600;color:#333;background-color:#f9f9f9;outline:none;transition:border-color .2s,box-shadow .2s;caret-color:#88c126}.otp-box:focus{border-color:#88c126;box-shadow:0 0 0 2px #88c12626;background-color:#fff}.otp-box.otp-box-filled{border-color:#88c126;background-color:#fff}.otp-box.otp-box-error{border-color:#ff4d4f;box-shadow:0 0 0 2px #ff4d4f1a}.otp-error-text{font-size:12px;color:#ff4d4f;text-align:center;margin:4px 0 8px;width:100%}.otp-resend-row{margin-top:10px;text-align:center}.otp-resend-label,.otp-timer-text,.otp-resend-link{font-size:13px;color:#888}.otp-resend-action{color:#88c126;font-weight:600;cursor:pointer;text-decoration:underline}@media(min-width:768px){.register-container{background-color:#fff}.register-header{background-color:#fff;box-shadow:0 2px 8px #0000000f}.register-form-section{padding:40px 24px}.register-form-wrapper{background-color:#fff;padding:40px;border-radius:16px;box-shadow:0 4px 12px #00000014}.register-button-wrapper{position:static;padding:0;background-color:transparent;box-shadow:none;max-width:400px;margin:32px auto 0}.otp-section{padding-bottom:40px}}.home-container{max-width:430px;margin:0 auto;min-height:100vh;padding:20px 16px 32px;font-family:Sarabun,Noto Sans Thai,sans-serif}.home-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.home-avatar{border:3px solid #8dc44b;flex-shrink:0}.home-greeting{display:flex;flex-direction:column;line-height:1.3}.home-greeting-label{font-size:13px;color:#888}.home-greeting-name{margin:0!important;font-size:17px!important;font-weight:700!important;color:#222}.schedule-card{border-radius:16px!important;background:#fff!important;margin-bottom:24px;box-shadow:0 2px 12px #00000012!important}.schedule-card .ant-card-body{padding:16px!important}.schedule-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.schedule-title-row{display:flex;align-items:center;gap:8px}.schedule-icon{color:#8dc44b;font-size:18px}.schedule-title{font-weight:700;font-size:15px;color:#222}.schedule-date{font-size:12px;color:#888}.schedule-list{display:flex;flex-direction:column;gap:0}.schedule-item{display:flex;gap:12px;position:relative}.schedule-item--active{background:#f4faeb;border-radius:12px;padding:10px 12px;margin:-4px -8px 8px}.schedule-dot-wrapper{display:flex;flex-direction:column;align-items:center;padding-top:4px;min-width:12px}.schedule-dot{width:10px;height:10px;border-radius:50%;background:#ccc;flex-shrink:0}.schedule-dot--active{background:#8dc44b;box-shadow:0 0 0 3px #8dc44b40}.schedule-line{width:2px;flex:1;min-height:20px;background:#e8e8e8;margin:4px 0}.schedule-content{display:flex;flex-direction:column;padding-bottom:8px;flex:1}.schedule-item--active .schedule-content{padding-bottom:0}.schedule-time{font-size:13px;color:#aaa;font-weight:500}.schedule-time--active{font-size:18px!important;font-weight:800!important;color:#333!important;line-height:1.2}.schedule-course-title{font-size:13px;font-weight:600;color:#444;margin-top:4px}.schedule-course-sub{font-size:12px;color:#8dc44b;margin-top:2px}.schedule-footer{display:flex;justify-content:flex-end;margin-top:8px}.schedule-view-all{color:#8dc44b!important;font-size:13px!important;font-weight:600!important;padding:0!important;height:auto!important}.schedule-view-all:hover{color:#6aaa2a!important}.courses-section{display:flex;flex-direction:column;gap:16px}.courses-heading{margin:0 0 4px!important;font-size:17px!important;font-weight:700!important;color:#222}.course-card{border-radius:16px!important;overflow:hidden;box-shadow:0 2px 12px #00000012!important;background:#fff!important}.course-card .ant-card-body{padding:0!important}.course-image-wrapper{width:100%;height:180px;overflow:hidden}.course-image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.course-card:hover .course-image{transform:scale(1.03)}.course-body{padding:14px 16px 16px}.course-title{margin:0 0 10px!important;font-size:15px!important;font-weight:700!important;color:#222;line-height:1.4!important}.course-meta{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}.course-meta-row{display:flex;align-items:center;gap:6px}.meta-icon{color:#8dc44b;font-size:13px;flex-shrink:0}.meta-text{font-size:12px;color:#666}.course-desc{font-size:12px!important;color:#888!important;margin:0 0 12px!important;line-height:1.6!important}.course-stats{display:flex;gap:20px;border-top:1px solid #f0f0f0;padding-top:12px;margin-top:4px}.stat-item{display:flex;align-items:center;gap:6px}.stat-icon{font-size:14px}.stat-icon--clock{color:#888}.stat-icon--star{color:#8dc44b}.stat-text{font-size:13px;color:#555;font-weight:500}.schedule-page{max-width:430px;margin:0 auto;min-height:100vh;padding:0 0 32px;font-family:Sarabun,Noto Sans Thai,sans-serif}.sched-topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px}.sched-back-btn{width:32px;height:32px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#333;padding:0;border-radius:50%;transition:background .2s}.sched-back-btn:hover{background:#0000000f}.sched-page-title{margin:0!important;font-size:20px!important;font-weight:800!important;color:#8dc44b!important;letter-spacing:.2px}.sched-calendar-card{background:#fff;border-radius:16px;margin:0 16px 16px;padding:16px 12px 20px;box-shadow:0 2px 10px #0000000f;display:flex;flex-direction:column;align-items:center;gap:14px}.sched-month-label{font-size:14px;color:#555;font-weight:500;text-align:center}.sched-week-strip{display:flex;justify-content:space-between;width:100%;gap:4px}.sched-day-btn{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;border:none;background:transparent;cursor:pointer;padding:8px 4px;border-radius:8px;transition:background .2s}.sched-day-btn:hover:not(.sched-day-btn--active){background:#f4faeb}.sched-day-btn--active{background:#8dc44b}.sched-day-num{font-size:16px;font-weight:700;color:#333;line-height:1}.sched-day-name{font-size:12px;color:#888;line-height:1}.sched-day-btn--active .sched-day-num,.sched-day-btn--active .sched-day-name{color:#fff}.sched-list-card{background:#fff;border-radius:16px;margin:0 16px;padding:20px 16px 24px;box-shadow:0 2px 10px #0000000f}.sched-date-heading{display:flex;align-items:center;gap:10px;margin-bottom:20px}.sched-date-icon{font-size:20px;color:#8dc44b}.sched-date-title{margin:0!important;font-size:18px!important;font-weight:800!important;color:#222!important}.sched-timeline{display:flex;flex-direction:column}.sched-timeline-row{display:flex;gap:14px;align-items:stretch}.sched-dot-col{display:flex;flex-direction:column;align-items:center;padding-top:14px;flex-shrink:0;width:12px}.sched-dot{width:12px;height:12px;border-radius:50%;background:#ccc;flex-shrink:0}.sched-dot--active{background:#8dc44b;box-shadow:0 0 0 3px #8dc44b40}.sched-connector{width:2px;flex:1;min-height:24px;background:repeating-linear-gradient(to bottom,#c8c8c8 0px,#c8c8c8 5px,transparent 5px,transparent 10px);margin:4px 0}.sched-item-card{flex:1;background:#f7f7f7;border-radius:12px;padding:12px 14px;margin-bottom:12px;display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:box-shadow .2s,transform .15s}.sched-item-card:hover{box-shadow:0 4px 16px #8dc44b33;transform:translateY(-1px)}.sched-item-card:active{transform:scale(.98)}.sched-item-card--active{background:#fff;border:1.5px solid #8dc44b;box-shadow:0 2px 10px #8dc44b26}.sched-item-time{font-size:16px!important;font-weight:700!important;color:#aaa!important;line-height:1.3!important}.sched-item-time--active{color:#8dc44b!important}.sched-item-title{font-size:13px;font-weight:600;color:#333;line-height:1.4}.sched-item-sub{font-size:12px;color:#999}.lesson-modal .ant-modal-content{border-radius:20px!important;padding:0!important;overflow:hidden}.lesson-modal-body{position:relative;padding:0;font-family:Sarabun,Noto Sans Thai,sans-serif}.lesson-modal-title{margin:0!important;padding:0!important;font-size:17px!important;font-weight:800!important;color:#222!important;text-align:center;line-height:1.4!important}.lesson-modal-img-wrap{margin:16px 0 0;width:100%;height:200px;overflow:hidden}.lesson-modal-img{width:100%;height:100%;object-fit:cover;display:block}.lesson-modal-subtitle{margin:16px 20px 12px!important;font-size:16px!important;font-weight:800!important;color:#222!important}.lesson-modal-section{padding:0 20px;margin-bottom:14px;display:flex;flex-direction:column;gap:4px}.lesson-modal-label{font-size:14px;font-weight:700;color:#222;display:block}.lesson-modal-desc{font-size:13px!important;color:#555!important;line-height:1.7!important;margin:0!important}.lesson-modal-value{font-size:13px;color:#555}.lesson-modal-actions{display:flex;gap:12px;padding:16px 20px 0}.lesson-btn{flex:1;height:48px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;border:none;transition:opacity .2s,transform .15s;font-family:Sarabun,Noto Sans Thai,sans-serif}.lesson-btn:active{transform:scale(.97)}.lesson-btn--outline{background:#fff;border:1.5px solid #8dc44b;color:#8dc44b}.lesson-btn--outline:hover{background:#f4faeb}.lesson-btn--primary{background:#8dc44b;color:#fff;box-shadow:0 4px 12px #8dc44b59}.lesson-btn--primary:hover{background:#7ab53a}.sched-month-nav{display:flex;align-items:center;justify-content:space-between;width:100%}.sched-nav-btn{width:32px;height:32px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:#555;border-radius:50%;transition:background .2s}.sched-nav-btn:hover{background:#f4faeb;color:#8dc44b}.mycourse-page{max-width:430px;margin:0 auto;min-height:100vh;padding:20px 16px 40px;font-family:Sarabun,Noto Sans Thai,sans-serif}.mycourse-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}.mycourse-avatar{border:3px solid #8dc44b;flex-shrink:0}.mycourse-greeting{display:flex;flex-direction:column;line-height:1.3}.mycourse-greeting-label{font-size:13px;color:#888}.mycourse-greeting-name{margin:0!important;font-size:17px!important;font-weight:700!important;color:#222}.mycourse-search-wrap{background:#fff;border:1.5px solid #8dc44b;border-radius:8px;padding:4px 8px 4px 16px;display:flex;align-items:center;margin-bottom:22px}.mycourse-search-input{flex:1;font-size:14px!important;color:#555!important;background:transparent!important;box-shadow:none!important}.mycourse-search-input input::placeholder{color:#aaa}.mycourse-search-input .ant-input-suffix{display:flex;align-items:center}.mycourse-filter-btn{border:none;background:transparent;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;color:#8dc44b;font-size:17px;border-radius:50%;transition:background .2s}.mycourse-filter-btn:hover{background:#f4faeb}.mycourse-section-title{margin:0 0 14px!important;font-size:18px!important;font-weight:800!important;color:#222!important}.mycourse-list{display:flex;flex-direction:column;gap:16px}.mycourse-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #00000012;cursor:pointer;transition:box-shadow .25s,transform .2s}.mycourse-card:hover{box-shadow:0 6px 20px #8dc44b33;transform:translateY(-2px)}.mycourse-card:active{transform:scale(.99)}.mycourse-img-wrap{width:100%;height:200px;overflow:hidden}.mycourse-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.mycourse-card:hover .mycourse-img{transform:scale(1.04)}.mycourse-body{padding:14px 16px 16px}.mycourse-title{margin:0 0 10px!important;font-size:16px!important;font-weight:800!important;color:#222!important;line-height:1.4!important}.mycourse-meta{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.mycourse-meta-row{display:flex;align-items:center;gap:7px}.mycourse-meta-icon{color:#8dc44b;font-size:13px;flex-shrink:0}.mycourse-meta-text{font-size:13px;color:#666}.mycourse-desc{font-size:13px!important;color:#888!important;margin:0 0 12px!important;line-height:1.6!important}.mycourse-stats{display:flex;gap:20px;border-top:1px solid #f0f0f0;padding-top:12px}.mycourse-stat{display:flex;align-items:center;gap:6px}.mycourse-stat-icon{font-size:15px}.mycourse-stat-icon--clock{color:#aaa}.mycourse-stat-icon--star{color:#8dc44b}.mycourse-stat-text{font-size:13px;color:#555;font-weight:600}.mycourse-center{display:flex;justify-content:center;padding:24px 0}.mycourse-end-text{display:block;text-align:center;color:#aaa;padding:16px 0;font-size:13px}.cd-page{max-width:430px;margin:0 auto;min-height:100vh;font-family:Sarabun,Noto Sans Thai,sans-serif;display:flex;flex-direction:column}.cd-topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 12px;flex-shrink:0}.cd-back-btn{width:32px;height:32px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#333;padding:0;border-radius:50%;transition:background .2s}.cd-back-btn:hover{background:#0000000f}.cd-page-title{margin:0!important;font-size:20px!important;font-weight:800!important;color:#8dc44b!important}.cd-scroll{flex:1;overflow-y:auto;padding:0 16px 40px}.cd-course-title{margin:4px 0 14px!important;font-size:20px!important;font-weight:800!important;color:#222!important;line-height:1.4!important}.cd-carousel{position:relative;border-radius:14px;overflow:hidden;margin-bottom:16px;height:210px}.cd-carousel-track{display:flex;height:100%;transition:transform .35s ease}.cd-carousel-img{min-width:100%;height:100%;object-fit:cover;display:block}.cd-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:6px}.cd-dot{width:8px;height:8px;border-radius:50%;border:none;background:#fff9;cursor:pointer;padding:0;transition:background .2s,transform .2s}.cd-dot--active{background:#fff;transform:scale(1.2)}.cd-progress-block{background:#fff;border-radius:14px;padding:14px 16px;margin-bottom:16px;display:flex;flex-direction:column;gap:8px;box-shadow:0 1px 8px #0000000f}.cd-progress-row{display:flex;align-items:center;gap:8px}.cd-progress-icon{color:#8dc44b;font-size:14px}.cd-progress-label{font-size:13px;color:#555}.cd-progress-bar{width:100%;height:6px;background:#e8e8e8;border-radius:10px;overflow:hidden}.cd-progress-fill{height:100%;background:#8dc44b;border-radius:10px;transition:width .4s ease}.cd-progress-text{font-size:13px;color:#888}.cd-progress-done{color:#8dc44b;font-weight:700}.cd-tabs{display:flex;background:#f0f0f0;border-radius:8px;padding:4px;margin-bottom:20px;gap:4px}.cd-tab{flex:1;height:40px;border:none;border-radius:8px;background:transparent;font-size:14px;font-weight:600;color:#999;cursor:pointer;transition:background .2s,color .2s;font-family:Sarabun,Noto Sans Thai,sans-serif}.cd-tab--active{background:#8dc44b;color:#fff;box-shadow:0 2px 8px #8dc44b4d}.cd-content{display:flex;flex-direction:column;gap:20px}.cd-section{display:flex;flex-direction:column;gap:8px}.cd-section-title{margin:0!important;font-size:15px!important;font-weight:800!important;color:#222!important}.cd-paragraph{font-size:13px!important;color:#555!important;line-height:1.75!important;margin:0!important}.cd-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}.cd-list li{font-size:13px;color:#555;line-height:1.6}.cd-info-row{display:flex;align-items:center;gap:8px}.cd-info-icon{color:#8dc44b;font-size:14px;flex-shrink:0}.cd-info-text{font-size:13px;color:#555}.cd-instructors{display:flex;flex-direction:row;gap:12px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none;-ms-overflow-style:none}.cd-instructors::-webkit-scrollbar{display:none}.cd-instructor-card{display:flex;align-items:center;gap:10px;background:#fff;border-radius:14px;padding:10px 16px 10px 10px;box-shadow:0 1px 8px #00000012;border:1px solid #ebebeb;flex-shrink:0;min-width:170px}.cd-instructor-avatar{border:2.5px solid #8dc44b;flex-shrink:0}.cd-instructor-info{display:flex;flex-direction:column;gap:3px}.cd-instructor-name{font-size:14px;font-weight:700;color:#222;line-height:1.3;white-space:nowrap}.cd-instructor-role{font-size:12px;color:#aaa;white-space:nowrap}.cd-lesson-block{display:flex;flex-direction:column;gap:10px}.cd-lesson-header{display:flex;align-items:center;justify-content:space-between}.cd-lesson-chapter{margin:0!important;font-size:15px!important;font-weight:800!important;color:#222!important}.cd-lesson-enroll-btn{background:#8dc44b;color:#fff;border:none;border-radius:6px;padding:6px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:Sarabun,Noto Sans Thai,sans-serif;transition:background .2s}.cd-lesson-enroll-btn:hover{background:#7ab53a}.cd-lesson-card{display:flex;gap:12px;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 1px 8px #0000000f;transition:box-shadow .2s}.cd-lesson-card--active{border:1.5px solid #8dc44b;box-shadow:0 2px 12px #8dc44b33;background:#f9fdf2}.cd-lesson-img{width:90px;height:90px;object-fit:cover;flex-shrink:0;display:block}.cd-lesson-info{padding:10px 12px 10px 0;display:flex;flex-direction:column;gap:5px;justify-content:center}.cd-lesson-name{font-size:14px;font-weight:700;color:#222}.cd-lesson-meta{display:flex;align-items:center;gap:6px}.cd-lesson-icon{color:#8dc44b;font-size:12px;flex-shrink:0}.cd-lesson-meta-text{font-size:12px;color:#666}.session-page{max-width:430px;margin:0 auto;min-height:100vh;font-family:Sarabun,Noto Sans Thai,sans-serif;display:flex;flex-direction:column}.session-topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 12px;flex-shrink:0}.session-back-btn{width:32px;height:32px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#333;border-radius:50%;transition:background .2s;padding:0}.session-back-btn:hover{background:#0000000f}.session-page-title{margin:0!important;font-size:20px!important;font-weight:800!important;color:#8dc44b!important}.session-scroll{flex:1;overflow-y:auto;padding-bottom:100px}.session-hero{width:100%;height:220px;overflow:hidden}.session-hero-img{width:100%;height:100%;object-fit:cover;display:block}.session-content{background:#fff;padding:20px 18px 24px;display:flex;flex-direction:column;gap:18px}.session-lesson-title{margin:0!important;font-size:20px!important;font-weight:800!important;color:#222!important}.session-section{display:flex;flex-direction:column;gap:6px}.session-label{font-size:15px;font-weight:800;color:#222;display:block}.session-value{font-size:14px;color:#555}.session-paragraph{font-size:13px!important;color:#555!important;line-height:1.75!important;margin:0!important}.session-meta-row{display:flex;align-items:center;gap:8px}.session-meta-icon{color:#8dc44b;font-size:14px;flex-shrink:0}.session-meta-text{font-size:13px;color:#555}.session-instructors{display:flex;flex-direction:row;gap:10px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:4px}.session-instructors::-webkit-scrollbar{display:none}.session-instructor-card{display:flex;align-items:center;gap:10px;background:#f9f9f9;border-radius:14px;padding:10px 14px 10px 10px;border:1px solid #ebebeb;flex-shrink:0;min-width:165px}.session-instructor-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2.5px solid #8dc44b;flex-shrink:0}.session-instructor-info{display:flex;flex-direction:column;gap:2px}.session-instructor-name{font-size:13px;font-weight:700;color:#222;white-space:nowrap}.session-instructor-role{font-size:11px;color:#aaa;white-space:nowrap}.session-footer{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:80%;max-width:430px;padding:12px 20px 24px}.session-cta-btn{width:100%;height:40px;border-radius:8px;border:none;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-family:Sarabun,Noto Sans Thai,sans-serif;transition:opacity .2s,transform .15s}.session-cta-btn:active:not(:disabled){transform:scale(.98)}.session-cta-btn--primary{background:#8dc44b;color:#fff;box-shadow:0 4px 14px #8dc44b59}.session-cta-btn--primary:hover{background:#7ab53a}.session-cta-btn--secondary{background:#f4a623;color:#fff;box-shadow:0 4px 14px #f4a62359}.session-cta-btn--secondary:hover{background:#e09510}.session-cta-btn--checkout{background:#f26355;color:#fff;box-shadow:0 4px 14px #f2635559}.session-cta-btn--checkout:hover{background:#e0503f}.session-cta-btn--done{background:#fff;color:#8dc44b;border:2px solid #8dc44b;cursor:pointer}.session-cta-btn--done:hover{background:#f4faeb}.hw-modal .ant-modal-content{border-radius:20px!important;padding:0!important}.hw-modal-body{padding:20px 18px 24px;font-family:Sarabun,Noto Sans Thai,sans-serif}.hw-modal-title{margin:0 0 16px!important;font-size:18px!important;font-weight:800!important;color:#222!important;text-align:center}.hw-img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:18px}.hw-img-cell{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:1;background:#f0f0f0}.hw-img{width:100%;height:100%;object-fit:cover;display:block}.hw-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;gap:10px}.hw-img-action{width:32px;height:32px;border-radius:50%;border:none;background:#ffffffe6;color:#555;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.hw-img-action:hover{background:#fff}.hw-img-action--delete{color:#e74c3c}.hw-img-upload{border:2px dashed #8dc44b;background:#f9fdf2;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;transition:background .2s}.hw-img-upload:hover{background:#f0fadf}.hw-upload-icon{font-size:20px;color:#8dc44b}.hw-upload-label{font-size:11px;color:#8dc44b;font-weight:600;text-align:center}.hw-detail-section{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.hw-detail-label{font-size:14px;font-weight:700;color:#222}.hw-required{color:#e74c3c}.hw-detail-textarea{width:100%;border:1.5px solid #e0e0e0;border-radius:10px;padding:12px 14px;font-size:12px;color:#555;line-height:1.7;font-family:Sarabun,Noto Sans Thai,sans-serif;resize:vertical;outline:none;background:#f7f7f7;box-sizing:border-box;transition:border-color .2s,background .2s}.hw-detail-textarea:focus{border-color:#8dc44b;background:#fff}.hw-actions,.confirm-actions{display:flex;gap:10px}.hw-btn{flex:1;height:48px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;border:none;font-family:Sarabun,Noto Sans Thai,sans-serif;transition:opacity .2s,transform .15s}.hw-btn:active{transform:scale(.97)}.hw-btn--outline{background:#fff;border:1.5px solid #8dc44b;color:#8dc44b}.hw-btn--outline:hover{background:#f4faeb}.hw-btn--primary{background:#8dc44b;color:#fff;box-shadow:0 4px 12px #8dc44b4d}.hw-btn--primary:hover{background:#7ab53a}.hw-btn--full{width:100%;flex:unset}.confirm-modal .ant-modal-content{border-radius:8px!important;padding:0!important}.confirm-modal-body{padding:28px 20px 24px;font-family:Sarabun,Noto Sans Thai,sans-serif;display:flex;flex-direction:column;align-items:center;gap:10px}.confirm-icon-wrap{width:64px;height:64px;border-radius:50%;border:3px solid #8dc44b;display:flex;align-items:center;justify-content:center;margin-bottom:4px}.confirm-icon{font-size:32px;color:#8dc44b}.confirm-title{margin:0!important;font-size:17px!important;font-weight:800!important;color:#222!important;text-align:center}.confirm-desc{font-size:13px;color:#888;text-align:center;line-height:1.6}.confirm-actions{width:100%;margin-top:8px}.success-modal .ant-modal-content{border-radius:20px!important;padding:0!important}.success-modal-body{padding:28px 20px 24px;font-family:Sarabun,Noto Sans Thai,sans-serif;display:flex;flex-direction:column;align-items:center;gap:10px}.success-icon-wrap{width:64px;height:64px;border-radius:50%;border:3px solid #8dc44b;display:flex;align-items:center;justify-content:center;margin-bottom:4px}.success-icon{font-size:32px;color:#8dc44b}.success-title{margin:0!important;font-size:17px!important;font-weight:800!important;color:#222!important;text-align:center}.success-desc{font-size:13px;color:#888;text-align:center;line-height:1.6}.success-modal-body .hw-btn--full{margin-top:8px}.hw-file-input{display:none}.hw-img-upload{cursor:pointer}.checkin-wrapper{font-family:Sarabun,sans-serif;min-height:100vh;background:#fff;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.checkin-wrapper:before,.checkin-wrapper:after{content:"";position:absolute;width:120px;height:180px;background:linear-gradient(135deg,#c8e6a0,#e8f5d0);border-radius:20px;opacity:.6}.checkin-wrapper:before{top:-30px;right:-30px;transform:rotate(-15deg)}.checkin-wrapper:after{bottom:-30px;left:-30px;transform:rotate(-15deg)}.corner-top-left{position:absolute;top:-30px;left:-30px;width:120px;height:180px;background:linear-gradient(135deg,#c8e6a0,#e8f5d0);border-radius:20px;opacity:.6;transform:rotate(15deg)}.checkin-container{width:100%;max-width:420px;padding:40px 32px;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;min-height:100vh;justify-content:center}.state-pending{display:flex;flex-direction:column;align-items:center;gap:20px;animation:fadeIn .4s ease}.icon-wrapper{animation:bounce 1s ease-in-out infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.pending-title{font-size:20px;font-weight:700;color:#2d2d2d;text-align:center;margin:0}.pending-subtitle{font-size:15px;color:#888;text-align:center;margin:0}.state-success{display:flex;flex-direction:column;align-items:center;gap:20px;animation:fadeIn .4s ease}.success-icon-wrapper{animation:popIn .5s cubic-bezier(.34,1.56,.64,1)}@keyframes popIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.success-title{font-size:22px;font-weight:700;color:#2d2d2d;text-align:center;margin:0}.success-subtitle{font-size:15px;color:#888;text-align:center;margin:0}.state-result{display:flex;flex-direction:column;gap:16px;width:100%;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.result-date-card{background:#fff;border-radius:16px;padding:20px 24px;text-align:center;box-shadow:0 2px 16px #00000012;border:1px solid #f0f0f0}.result-date{font-size:14px;color:#888;margin-bottom:6px}.result-time{font-size:48px;font-weight:700;color:#1a1a1a;letter-spacing:-1px;line-height:1}.result-detail-card{background:#fff;border-radius:16px;padding:20px 24px;box-shadow:0 2px 16px #00000012;border:1px solid #f0f0f0}.result-detail-title{font-size:16px;font-weight:700;color:#1a1a1a;padding-bottom:14px;border-bottom:1px solid #f0f0f0;margin-bottom:14px}.result-detail-row{display:flex;align-items:center;justify-content:space-between}.result-checkin-label{font-size:15px;color:#444}.result-checkin-time{font-size:15px;font-weight:600;color:#444}.result-status{font-size:14px;color:#52c41a;font-weight:600;display:flex;align-items:center;gap:4px}.result-status:before{content:"•";font-size:18px}.result-btn{width:100%;height:52px;background:linear-gradient(135deg,#7dc933,#5aad1e);border:none;border-radius:14px;font-size:17px;font-weight:600;font-family:Sarabun,sans-serif;color:#fff;cursor:pointer;transition:transform .1s,box-shadow .2s;box-shadow:0 4px 16px #5db42859;margin-top:4px}.result-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #5db42873}.result-btn:active{transform:translateY(1px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading-dots{display:inline-flex;gap:4px}.loading-dots span{width:6px;height:6px;background:#aaa;border-radius:50%;display:inline-block;animation:dot-pulse 1.2s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-pulse{0%,80%,to{transform:scale(.8);opacity:.4}40%{transform:scale(1.1);opacity:1}}*{box-sizing:border-box}.checkout-wrapper{font-family:Sarabun,sans-serif;min-height:100vh;background:#fff;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.checkout-wrapper:before,.checkout-wrapper:after{content:"";position:absolute;width:120px;height:180px;background:linear-gradient(135deg,#c8e6a0,#e8f5d0);border-radius:20px;opacity:.6}.checkout-wrapper:before{top:-30px;right:-30px;transform:rotate(-15deg)}.checkout-wrapper:after{bottom:-30px;left:-30px;transform:rotate(-15deg)}.checkout-corner-top-left{position:absolute;top:-30px;left:-30px;width:120px;height:180px;background:linear-gradient(135deg,#c8e6a0,#e8f5d0);border-radius:20px;opacity:.6;transform:rotate(15deg)}.checkout-container{width:100%;max-width:420px;padding:40px 32px;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;min-height:100vh;justify-content:center}.checkout-state-pending{display:flex;flex-direction:column;align-items:center;gap:20px;animation:co-fadeIn .4s ease}.checkout-icon-wrapper{animation:co-bounce 1s ease-in-out infinite alternate}@keyframes co-bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.checkout-pending-title{font-size:20px;font-weight:700;color:#2d2d2d;text-align:center;margin:0}.checkout-pending-subtitle{font-size:15px;color:#888;text-align:center;margin:0}.checkout-state-success{display:flex;flex-direction:column;align-items:center;gap:20px;animation:co-fadeIn .4s ease}.checkout-success-icon-wrapper{animation:co-popIn .5s cubic-bezier(.34,1.56,.64,1)}@keyframes co-popIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.checkout-success-title{font-size:22px;font-weight:700;color:#2d2d2d;text-align:center;margin:0}.checkout-success-subtitle{font-size:15px;color:#888;text-align:center;margin:0}.checkout-state-result{display:flex;flex-direction:column;gap:16px;width:100%;animation:co-slideUp .5s ease}@keyframes co-slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.checkout-date-card{background:#fff;border-radius:16px;padding:20px 24px;text-align:center;box-shadow:0 2px 16px #00000012;border:1px solid #f0f0f0}.checkout-date-text{font-size:14px;color:#888;margin-bottom:6px}.checkout-time-text{font-size:48px;font-weight:700;color:#1a1a1a;letter-spacing:-1px;line-height:1}.checkout-detail-card{background:#fff;border-radius:16px;padding:20px 24px;box-shadow:0 2px 16px #00000012;border:1px solid #f0f0f0}.checkout-detail-title{font-size:16px;font-weight:700;color:#1a1a1a;padding-bottom:14px;border-bottom:1px solid #f0f0f0;margin-bottom:14px}.checkout-detail-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.checkout-detail-row:last-child{margin-bottom:0}.checkout-row-label{font-size:15px;color:#444}.checkout-row-time{font-size:15px;font-weight:600;color:#444}.checkout-status-checkin{font-size:14px;color:#52c41a;font-weight:600;display:flex;align-items:center;gap:4px}.checkout-status-checkin:before{content:"•";font-size:18px}.checkout-status-checkout{font-size:14px;color:#52c41a;font-weight:600;display:flex;align-items:center;gap:4px}.checkout-status-checkout:before{content:"•";font-size:18px}.checkout-btn{width:100%;height:52px;background:linear-gradient(135deg,#7dc933,#5aad1e);border:none;border-radius:14px;font-size:17px;font-weight:600;font-family:Sarabun,sans-serif;color:#fff;cursor:pointer;transition:transform .1s,box-shadow .2s;box-shadow:0 4px 16px #5db42859;margin-top:4px}.checkout-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #5db42873}.checkout-btn:active{transform:translateY(1px)}@keyframes co-fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.checkout-loading-dots{display:inline-flex;gap:4px}.checkout-loading-dots span{width:6px;height:6px;background:#aaa;border-radius:50%;display:inline-block;animation:co-dot-pulse 1.2s ease-in-out infinite}.checkout-loading-dots span:nth-child(2){animation-delay:.2s}.checkout-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes co-dot-pulse{0%,80%,to{transform:scale(.8);opacity:.4}40%{transform:scale(1.1);opacity:1}}.qr-container{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;font-family:Sarabun,sans-serif}.qr-reader{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:hidden}#qr-reader video{object-fit:cover!important;width:100%!important;height:100%!important;border:none!important}#qr-reader img,#qr-reader__dashboard,#qr-reader__header_message,#qr-reader__status_span{display:none!important}#qr-reader__scan_region{width:100%!important;height:100%!important}.qr-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;pointer-events:none}.qr-back-btn{position:fixed;top:20px;left:20px;color:#fff;font-size:16px;font-family:Sarabun,sans-serif;cursor:pointer;z-index:100;display:flex;align-items:center;gap:4px;background:none;border:none;padding:0;letter-spacing:.02em;pointer-events:auto;text-shadow:0 1px 4px rgba(0,0,0,.6)}.qr-back-chevron{font-size:22px;line-height:1;display:inline-block}.qr-frame-wrap{position:relative;width:260px;height:260px}.qr-corner{position:absolute;width:48px;height:48px;border-color:#fff;border-style:solid}.qr-corner--tl{top:0;left:0;border-width:3px 0 0 3px}.qr-corner--tr{top:0;right:0;border-width:3px 3px 0 0}.qr-corner--bl{bottom:0;left:0;border-width:0 0 3px 3px}.qr-corner--br{bottom:0;right:0;border-width:0 3px 3px 0}.qr-error-box{margin-top:24px;text-align:center;pointer-events:auto}.qr-error-text{font-size:13px;color:#ff6b6b;margin-bottom:12px}.qr-retry-btn{background:transparent;border:1.5px solid rgba(255,255,255,.5);color:#fff;padding:8px 24px;border-radius:4px;font-family:Sarabun,sans-serif;font-size:14px;cursor:pointer}.qr-result-box{margin-top:32px;text-align:center;max-width:280px;word-break:break-all;background:#0009;padding:12px 20px;border-radius:8px;pointer-events:auto}.qr-result-label{font-size:12px;opacity:.6;margin-bottom:4px}.qr-result-value{font-size:15px;font-weight:600}.hw-page{display:flex;flex-direction:column;min-height:100vh;background:#fff;font-family:Sarabun,Noto Sans Thai,sans-serif}.hw-header{display:flex;align-items:center;padding:16px 20px 12px;border-bottom:1px solid #f0f0f0;position:relative}.hw-back-btn{background:none;border:none;font-size:24px;color:#555;cursor:pointer;padding:0;line-height:1;margin-right:8px}.hw-header-title{flex:1;text-align:center;font-size:17px;font-weight:700;color:#4caf50;margin:0 32px 0 0}.hw-body{padding:20px}.hw-lesson-title{font-size:16px;font-weight:700;color:#222;margin:0 0 8px}.hw-status-row{display:flex;align-items:center;gap:8px;margin-bottom:16px}.hw-status-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 14px;border-radius:20px;font-size:13px;font-weight:600;border:1.5px solid transparent}.hw-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.hw-tag-pass{color:#389e0d;border-color:#b7eb8f;background:#f6ffed}.hw-tag-fail{color:#cf1322;border-color:#ffa39e;background:#fff1f0}.hw-tag-pending{color:#d46b08;border-color:#ffd591;background:#fffbe6}.hw-image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}.hw-image-wrapper{border-radius:8px;overflow:hidden;aspect-ratio:1 / .85}.hw-image{width:100%;height:100%;object-fit:cover;display:block}.hw-details-section{padding:0}.hw-details-title{font-size:15px;font-weight:700;color:#222;margin:0 0 10px}.hw-details-list{margin:0;padding-left:20px;list-style:disc}.hw-details-list li{font-size:13.5px;color:#444;line-height:1.75}.hw-wrapper{max-width:390px;margin:0 auto;background-color:#fff;min-height:100vh;font-family:Sarabun,Noto Sans Thai,sans-serif}.hw-header{display:flex;align-items:center;gap:12px;padding:16px 16px 12px;background-color:#fff;border-bottom:1px solid #f0f0f0}.hw-back-icon{font-size:18px;color:#4caf50;cursor:pointer}.hw-header-title{font-size:17px;font-weight:600;color:#4caf50}.hw-section-title{padding:14px 16px 4px}.hw-section-num{font-size:16px;font-weight:700;color:#222}.hw-status-row{display:flex;align-items:center;gap:8px;padding:4px 16px 12px}.hw-status-label{font-size:14px;color:#555}.hw-status-tag{font-size:13px;border-radius:12px;padding:0 10px}.hw-image-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 16px}.hw-image-card{border-radius:10px;overflow:hidden;box-shadow:0 2px 6px #0000001a}.hw-image{width:100%;height:130px;object-fit:cover;display:block}.hw-divider{margin:16px 0 8px}.hw-ingredients{padding:0 16px 24px}.hw-ingredients-title{font-size:15px;font-weight:700;color:#222;margin-bottom:10px}.hw-ingredient-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:7px}.hw-ingredient-item{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:#333;line-height:1.5}.hw-bullet{color:#4caf50;font-size:16px;line-height:1.4;flex-shrink:0}.hw-ingredient-text{flex:1}.hw-ingredient-label{color:#222}.hw-ingredient-amount{color:#777;font-size:13px}.bg-text-red{background:#fff1f0;color:#e02b1d;border:1px solid #e02b1d;border-radius:16px;padding:4px 8px;font-size:13px;font-weight:700;cursor:pointer;font-family:Sarabun,Noto Sans Thai,sans-serif}.bg-text-green{background:#f1fbf8;color:#32c997;border:1px solid #32c997;border-radius:16px;padding:4px 8px;font-size:13px;font-weight:700;cursor:pointer;font-family:Sarabun,Noto Sans Thai,sans-serif}.bg-text-yellow{background:#fff8ec;color:#ffb240;border:1px solid #ffb240;border-radius:16px;padding:4px 8px;font-size:13px;font-weight:700;cursor:pointer;font-family:Sarabun,Noto Sans Thai,sans-serif}.hw-info-box{display:flex;align-items:center;margin:0 16px 14px;border:1.5px solid #4caf50;border-radius:10px;padding:10px 0;background:#fff}.hw-info-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.hw-info-label{font-size:12px;color:#888}.hw-info-value{font-size:14px;font-weight:700;color:#222}.hw-info-divider{width:1px;height:36px;background-color:#e0e0e0}.hw-image-grid-top{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:0 16px 8px}.hw-image-grid-bottom{display:flex;gap:8px;padding:0 16px}.hw-image-card-small{width:calc((100% - 16px) / 3)}.hw-suggestion{padding:0 16px 24px}.hw-suggestion-box{background:#f6fdf6;border-radius:10px;padding:14px;min-height:80px}.hw-suggestion-text{font-size:14px;color:#444;line-height:1.6}.profile-container{min-height:100vh;display:flex;flex-direction:column;max-width:430px;margin:0 auto;padding:0 16px 32px}.profile-menu-header{display:flex;flex-direction:column;align-items:center;padding:32px 0 24px}.profile-title{color:#52c41a!important;font-weight:700!important;margin-bottom:20px!important;font-size:20px!important}.profile-avatar-wrapper{margin-bottom:12px}.profile-avatar{border:3px solid #fff;box-shadow:0 4px 16px #0000001f;object-fit:cover}.profile-name{font-size:16px;font-weight:600;color:#1a1a1a;margin:0}.profile-menu{display:flex;flex-direction:column;gap:12px;margin-top:8px}.profile-menu .ant-list-items{display:flex;flex-direction:column;gap:12px}.profile-menu-item{background:#fff;border-radius:14px!important;padding:0!important;border:none!important;box-shadow:0 1px 6px #0000000f;cursor:pointer;transition:background .2s ease,transform .1s ease;overflow:hidden}.profile-menu-item:hover{background:#f6ffed;transform:translateY(-1px);box-shadow:0 4px 12px #52c41a26}.profile-menu-item:active{transform:translateY(0)}.menu-item-content{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;width:100%}.menu-item-left{display:flex;align-items:center;gap:14px}.menu-icon{font-size:18px;color:#52c41a!important;flex-shrink:0}.menu-item-label{font-size:15px;color:#1a1a1a;font-weight:500}.menu-arrow{font-size:12px;color:#52c41a!important}.profile-menu .ant-list-item{border-block-end:none!important}.profile-container{max-width:430px;margin:0 auto;min-height:100vh;font-family:Sarabun,sans-serif}.profile-header{display:flex;flex-direction:row;align-items:center;padding:16px;border-bottom:1px solid #f0f0f0;background:#fff;position:sticky;top:0;z-index:10}.profile-header h2{flex:1;text-align:center;margin:0;font-size:18px;font-weight:600;color:#333}.profile-header .back-btn{color:#4caf50;font-size:20px;border:none;background:none;cursor:pointer;padding:0;width:32px}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;padding:24px 16px 16px}.avatar-wrapper{position:relative;margin-bottom:12px}.avatar-wrapper .ant-avatar{border:3px solid #e8f5e9}.avatar-camera-btn{position:absolute;bottom:0;right:0;width:28px;height:28px;border-radius:50%;background:#4caf50;border:2px solid #fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:13px}.edit-profile-btn{background:#4caf50!important;border-color:#4caf50!important;border-radius:20px!important;padding:4px 24px!important;font-size:14px!important;color:#fff!important;height:34px!important}.edit-profile-btn:hover{background:#43a047!important;border-color:#43a047!important}.profile-view-section{margin-top:8px;padding:16px}.section-title{font-size:16px;font-weight:600;color:#333;margin-bottom:16px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f5f5f5}.info-row:last-child{border-bottom:none}.info-label{font-size:14px;color:#888;min-width:80px}.info-value{font-size:14px;color:#333;text-align:right}.profile-edit-form{margin-top:8px;padding:16px}.profile-edit-form .ant-form-item{margin-bottom:16px}.profile-edit-form .ant-form-item-label>label{font-size:14px;color:#333;font-weight:500}.profile-edit-form .ant-input,.profile-edit-form .ant-picker,.profile-edit-form .ant-select-selector{border-radius:8px!important;border-color:#e0e0e0!important;font-size:14px}.profile-edit-form .ant-input:focus,.profile-edit-form .ant-picker-focused,.profile-edit-form .ant-select-focused .ant-select-selector{border-color:#4caf50!important;box-shadow:0 0 0 2px #4caf5026!important}.profile-edit-form .ant-picker,.profile-edit-form .ant-select{width:100%}.save-btn{width:100%;background:#4caf50!important;border-color:#4caf50!important;border-radius:24px!important;height:44px!important;font-size:16px!important;font-weight:500!important;color:#fff!important;margin-top:8px}.save-btn:hover{background:#43a047!important;border-color:#43a047!important}.my-homework{max-width:430px;margin:0 auto;min-height:100vh;background:#f7f7f7;font-family:Sarabun,Noto Sans Thai,sans-serif}.my-homework__header{padding:20px 16px 12px;background:#fff}.my-homework__title{font-size:20px;font-weight:700;color:#1a1a1a;margin:0 0 14px}.my-homework .ant-tabs-nav{margin:0!important;padding:0 16px;background:#fff}.my-homework .ant-tabs-tab{flex:1;justify-content:center;margin:0!important;padding:10px 0!important;font-size:15px;font-weight:600;color:#999}.my-homework .ant-tabs-tab-active .ant-tabs-tab-btn{color:#fff!important}.my-homework .ant-tabs-tab.ant-tabs-tab-active{background:#5aac44;border-radius:8px}.my-homework .ant-tabs-ink-bar{display:none!important}.my-homework .ant-tabs-nav:before{border:none!important}.my-homework .ant-tabs-nav-list{width:100%;background:#ebebeb;border-radius:10px;padding:3px;gap:3px}.my-homework__search{padding:12px 16px;background:#f7f7f7}.my-homework__search .ant-input-affix-wrapper{border-radius:10px;border:1.5px solid #e0e0e0;background:#fff;padding:8px 12px}.my-homework__list{padding:0 16px 24px;display:flex;flex-direction:column;gap:14px}.course-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 8px #00000012}.course-card__image{width:100%;height:160px;object-fit:cover;display:block}.course-card__body{padding:12px 14px}.course-card__header{display:flex;justify-content:space-between;align-items:flex-start;cursor:pointer}.course-card__title{font-size:15px;font-weight:700;color:#1a1a1a;flex:1}.course-card__meta{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:13px;color:#777}.course-card__meta-icon{color:#5aac44;font-size:14px}.course-card__lessons{margin-top:12px;display:flex;flex-direction:column;gap:8px}.lesson-item{border-radius:10px;overflow:hidden;border:1.5px solid #b7e0a4;background:#f6fcf4}.lesson-item__header{padding:10px 12px 4px;font-size:13px;font-weight:700;color:#2e7d32}.lesson-item__body{padding:0 12px 10px;display:flex;flex-direction:column;gap:4px}.lesson-item__row{display:flex;align-items:center;gap:6px;font-size:12px;color:#555}.lesson-item__row .anticon{color:#5aac44;font-size:13px}.lesson-item__status-row{display:flex;align-items:center;gap:6px;font-size:12px;color:#555;margin-top:2px}.status-badge{border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600}.status-badge--sent{background:#d4edda;color:#2e7d32}.status-badge--reviewing{background:#fff3cd;color:#b45309}.status-badge--pending{background:#fde8e8;color:#b91c1c}.custom-tabs .ant-tabs-nav{height:48px;padding:0}.custom-tabs .ant-tabs-nav .ant-tabs-nav-wrap .ant-tabs-nav-list{background-color:#f4f9e8;border:1px solid #8cbf18}.custom-tabs .ant-tabs-nav .ant-tabs-nav-wrap .ant-tabs-nav-list .ant-tabs-tab .ant-tabs-tab-btn{color:#65605c;font-weight:600}.custom-tabs .ant-tabs-nav .ant-tabs-nav-wrap .ant-tabs-nav-list .ant-tabs-tab-active .ant-tabs-tab-btn,.custom-tabs .ant-tabs-nav .ant-tabs-nav-wrap .ant-tabs-nav-list .ant-tabs-tab-active{color:#fff;font-weight:600;background-color:#8cbf18}.ch-wrapper{font-family:Sarabun,Noto Sans Thai,sans-serif;background:#f5f7fa;min-height:100vh;max-width:420px;margin:0 auto}.ch-header{display:flex;align-items:center;background:#fff;padding:16px;border-bottom:1px solid #eee;position:sticky;top:0;z-index:10}.ch-back-btn{background:none;border:none;font-size:28px;color:#555;cursor:pointer;padding:0 8px 0 0;line-height:1}.ch-title{font-size:17px;font-weight:600;color:#222;margin:0}.ch-filters{background:#fff;padding:12px 16px 14px;border-bottom:1px solid #eee;display:flex;flex-direction:column;gap:10px}.ch-filter-row{display:flex;gap:10px}.ch-select{flex:1}.ch-select-full{width:100%}.ch-select .ant-select-selector{border-radius:8px!important;border-color:#ddd!important;font-size:14px}.ch-content{padding:16px;display:flex;flex-direction:column;gap:0}.ch-date-group{margin-bottom:8px}.ch-date-label{font-size:14px;font-weight:600;color:#333;margin-bottom:8px;margin-top:4px}.ch-card{background:#fff;border-radius:12px;padding:14px 16px;margin-bottom:10px;box-shadow:0 1px 4px #00000012}.ch-card-subject{font-size:13px;color:#888;margin-bottom:2px}.ch-card-room{font-size:14px;font-weight:600;color:#222;margin-bottom:10px}.ch-card-divider{height:1px;background:#f0f0f0;margin-bottom:10px}.ch-card-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.ch-mt{margin-top:10px}.ch-time-label{font-size:13px;color:#666}.ch-time-value{font-size:13px;color:#333;font-weight:500}.ch-status-badge{display:flex;align-items:center;gap:5px}.ch-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.ch-status-text{font-size:13px;font-weight:500}.ch-muted{color:#aaa!important}.ch-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px}.ch-empty-text{text-align:center}.ch-empty-main{font-size:16px;font-weight:600;color:#555;margin-bottom:4px}.ch-empty-sub{font-size:13px;color:#aaa}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:#fff;font-family:Sarabun,sans-serif;gap:20px}.loading-logo{width:80px;height:80px;border-radius:50%;background-color:#f0fae8;display:flex;align-items:center;justify-content:center;animation:pulse 1.5s ease-in-out infinite}.loading-logo svg{width:40px;height:40px}.loading-spinner{width:36px;height:36px;border:3px solid #e8f4d4;border-top-color:#88c126;border-radius:50%;animation:spin .8s linear infinite}.loading-text{font-size:14px;color:#999;letter-spacing:.02em}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.85}}
