.main-layout{background:#f0f2f5}.layout-header{background:#001529;padding:0 24px;height:64px;line-height:64px;display:flex;align-items:center;position:sticky;top:0;z-index:1000;width:100%;box-shadow:0 2px 8px #00000026}@media(max-width:768px){.layout-header{padding:0 12px;height:56px;line-height:56px}}@media(min-width:769px)and (max-width:1024px){.layout-header{padding:0 16px}}.user-info{cursor:pointer;padding:8px 12px;border-radius:6px;transition:all .3s;min-height:44px;display:flex;align-items:center}@media(max-width:768px){.user-info{padding:4px 8px;min-height:44px}}.user-info:hover{background:#ffffff1a}.user-details{margin-left:12px;color:#fff}@media(max-width:1024px){.user-details{display:none}}.user-name{font-weight:500;font-size:14px;line-height:1.4}.user-role{font-size:12px;color:#ffffffb3;line-height:1.4}.layout-sider{background:#fff;box-shadow:2px 0 8px #1d23290d;overflow:auto;height:calc(100vh - 64px);position:sticky;top:64px;left:0}@media(max-width:768px){.layout-sider{display:none}}@media(min-width:769px)and (max-width:1024px){.layout-sider{height:calc(100vh - 64px)}}.layout-content{margin:24px;min-height:calc(100vh - 112px);transition:all .3s}@media(max-width:768px){.layout-content{margin:12px;min-height:calc(100vh - 80px)}}@media(min-width:769px)and (max-width:1024px){.layout-content{margin:16px;min-height:calc(100vh - 96px)}}.content-container{padding:24px;background:#fff;border-radius:8px;min-height:100%;box-shadow:0 2px 8px #0000000f}@media(max-width:768px){.content-container{padding:12px;border-radius:6px}}@media(min-width:769px)and (max-width:1024px){.content-container{padding:16px}}.ant-drawer-body{padding:0!important}.ant-drawer-body .ant-menu{border:none}.mobile-menu .ant-menu-item{min-height:50px!important;display:flex!important;align-items:center!important;margin:4px 0!important;padding:0 16px!important}.mobile-menu .ant-menu-item .anticon{font-size:18px!important}.mobile-menu .ant-menu-item .ant-menu-title-content{font-size:15px!important;margin-left:8px}.admin-menu-item{background-color:#fff2e8!important}.admin-menu-item:hover{background-color:#ffd8bf!important}.ant-drawer-header{border-bottom:1px solid #f0f0f0;padding:16px}.ant-drawer-title{font-weight:600;font-size:16px}.ant-layout-sider-collapsed .ant-menu-item{padding:0 calc(50% - 8px)!important}.ant-layout-sider-collapsed .ant-menu-item .anticon{font-size:18px!important}.layout-sider::-webkit-scrollbar{width:4px}.layout-sider::-webkit-scrollbar-track{background:#f1f1f1}.layout-sider::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.layout-sider::-webkit-scrollbar-thumb:hover{background:#555}.layout-content{transition:margin-left .3s ease}@media print{.layout-header,.layout-sider,.ant-drawer{display:none!important}.layout-content{margin:0!important;padding:0!important}.content-container{box-shadow:none!important;padding:0!important}}:root{--mobile: 480px;--tablet: 768px;--desktop: 1024px;--large-desktop: 1200px;--touch-target-min: 44px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-xxl: 24px;--font-xs: 11px;--font-sm: 12px;--font-md: 14px;--font-lg: 16px;--font-xl: 18px;--font-xxl: 20px;--font-xxxl: 24px}.responsive-container{width:100%;padding:var(--spacing-md);margin:0 auto}@media(min-width:768px){.responsive-container{padding:var(--spacing-xxl);max-width:1200px;margin:0 auto}}@media(min-width:1200px){.responsive-container{max-width:1400px}}.responsive-grid{display:grid;gap:var(--spacing-md);grid-template-columns:1fr}@media(min-width:640px){.responsive-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.responsive-grid{grid-template-columns:repeat(4,1fr)}}.responsive-flex{display:flex;flex-direction:column;gap:var(--spacing-md)}@media(min-width:768px){.responsive-flex{flex-direction:row;align-items:center;justify-content:space-between}}.touch-target{min-height:var(--touch-target-min);min-width:var(--touch-target-min);display:inline-flex;align-items:center;justify-content:center}.touch-target-block{min-height:var(--touch-target-min);width:100%;display:flex;align-items:center;justify-content:center}.text-responsive{font-size:clamp(var(--font-sm),4vw,var(--font-lg));line-height:1.5}.text-responsive-sm{font-size:clamp(var(--font-xs),3.5vw,var(--font-sm));line-height:1.4}.text-responsive-lg{font-size:clamp(var(--font-lg),5vw,var(--font-xxl));line-height:1.3}.heading-responsive{font-size:clamp(var(--font-xl),6vw,var(--font-xxxl));line-height:1.2;font-weight:600}.m-responsive{margin:clamp(var(--spacing-sm),3vw,var(--spacing-lg))}.p-responsive{padding:clamp(var(--spacing-sm),3vw,var(--spacing-lg))}@media(max-width:480px){.hide-mobile{display:none!important}.show-mobile{display:block!important}}@media(min-width:481px)and (max-width:768px){.hide-tablet{display:none!important}.show-tablet{display:block!important}}@media(min-width:769px){.hide-desktop{display:none!important}.show-desktop{display:block!important}}.card-responsive{border-radius:8px;background:#fff;box-shadow:0 2px 8px #0000001a;padding:var(--spacing-md)}@media(min-width:768px){.card-responsive{padding:var(--spacing-xl)}}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(var(--spacing-md) * -1);padding:0 var(--spacing-md)}.table-responsive table{min-width:600px;width:100%}@media(max-width:768px){.ant-modal{max-width:90%!important;margin:var(--spacing-sm) auto!important}.ant-modal-content{padding:var(--spacing-md)!important}}.form-responsive{display:grid;gap:var(--spacing-md)}@media(min-width:768px){.form-responsive{grid-template-columns:repeat(2,1fr)}}.form-responsive .full-width{grid-column:1 / -1}.loading-responsive{display:flex;justify-content:center;align-items:center;min-height:200px;padding:var(--spacing-xl)}.empty-responsive{text-align:center;padding:var(--spacing-xl) var(--spacing-md)}.empty-responsive h4{font-size:clamp(var(--font-lg),5vw,var(--font-xl));margin-bottom:var(--spacing-sm)}.empty-responsive p{font-size:clamp(var(--font-sm),4vw,var(--font-md));color:#666}@media(max-height:500px)and (orientation:landscape){.responsive-container{padding:var(--spacing-sm)}.touch-target,.touch-target-block{min-height:36px}}@media print{.no-print{display:none!important}.responsive-container{max-width:100%;padding:0}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{color:#333;font-size:28px;margin-bottom:8px}.login-header p{color:#666;font-size:16px}.login-form .form-group{margin-bottom:20px}.login-form label{display:block;margin-bottom:8px;color:#555;font-weight:500}.login-form input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:all .3s}.login-form input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.login-form input:disabled{background-color:#f8f9fa;cursor:not-allowed}.error-message{background-color:#fff5f5;color:#e53e3e;padding:12px;border-radius:8px;margin-bottom:20px;border:1px solid #fed7d7}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:30px;text-align:center;color:#666}.login-footer p{margin-bottom:10px}.register-link{color:#667eea;text-decoration:none;font-weight:600}.register-link:hover{text-decoration:underline}.note{font-size:14px;color:#999}.dashboard-container{min-height:100vh;background-color:#f0f2f5}.welcome-card{margin-bottom:20px;border-radius:8px;overflow:hidden}@media(max-width:768px){.welcome-card{margin-bottom:12px}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:24px}@media(max-width:768px){.stats-grid{gap:8px;margin-bottom:16px}}.stat-card{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 8px #0000001a}@media(max-width:768px){.stat-card{padding:12px}}.stat-card .ant-statistic-title{font-size:14px;color:#666;margin-bottom:4px}@media(max-width:768px){.stat-card .ant-statistic-title{font-size:12px}}.stat-card .ant-statistic-content{font-size:24px;font-weight:600;color:#1890ff}@media(max-width:768px){.stat-card .ant-statistic-content{font-size:18px}}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-top:16px}@media(max-width:768px){.quick-actions-grid{grid-template-columns:repeat(2,1fr);gap:8px}}.action-card{background:#fff;border-radius:8px;padding:16px;text-align:center;cursor:pointer;transition:all .3s;border:1px solid #f0f0f0;height:100%;display:flex;flex-direction:column;align-items:center;gap:8px}@media(max-width:768px){.action-card{padding:12px}}.action-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.action-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:8px}@media(max-width:768px){.action-avatar{width:40px;height:40px;font-size:20px}}.action-title{font-weight:600;font-size:14px;margin:0}@media(max-width:768px){.action-title{font-size:13px}}.action-description{font-size:12px;color:#666;margin:0}@media(max-width:768px){.action-description{display:none}}.notification-card{margin:20px 0;padding:16px;border-radius:8px;border-left:4px solid #f5222d;background:#fff;box-shadow:0 2px 8px #0000001a}@media(max-width:768px){.notification-card{margin:12px 0;padding:12px}}.activities-list{margin-top:24px}@media(max-width:768px){.activities-list{margin-top:16px}}.activity-item{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0;gap:12px}@media(max-width:768px){.activity-item{padding:8px 0;gap:8px}}.activity-item:last-child{border-bottom:none}.activity-avatar{width:48px;height:48px;border-radius:50%;background-color:#f0f2f5;display:flex;align-items:center;justify-content:center;color:#1890ff;font-size:20px}@media(max-width:768px){.activity-avatar{width:40px;height:40px;font-size:16px}}.activity-details{flex:1}.activity-title{font-size:14px;font-weight:500;margin-bottom:2px}@media(max-width:768px){.activity-title{font-size:13px}}.activity-description{font-size:12px;color:#666}.activity-action{font-size:12px;color:#1890ff;padding:6px 12px;border-radius:4px;background-color:#e6f7ff;white-space:nowrap;min-width:44px;text-align:center}@media(max-width:768px){.activity-action{padding:4px 8px;font-size:11px}}.loading-container,.error-container{display:flex;justify-content:center;align-items:center;min-height:400px;padding:20px}@media(max-width:768px){.loading-container,.error-container{min-height:300px;padding:12px}}@media(max-width:768px){.ant-btn,.action-card,.activity-action{min-height:44px}.ant-card-body{padding:12px!important}.ant-statistic-content{font-size:18px!important}}@media(max-height:500px)and (orientation:landscape){.dashboard-container{padding:8px}.stats-grid,.quick-actions-grid{grid-template-columns:repeat(4,1fr)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.welcome-card,.stat-card,.action-card,.notification-card,.activities-list{animation:fadeIn .5s ease-out}.calendar-container{padding:clamp(8px,3vw,16px);background:#f0f2f5;min-height:100vh}@media(min-width:768px){.calendar-container{padding:16px}}.search-sidebar{height:auto;overflow-y:visible;position:static;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px}@media(min-width:768px){.search-sidebar{height:calc(100vh - 100px);overflow-y:auto;position:sticky;top:20px;margin-bottom:0}}.search-sidebar .ant-card-body{padding:clamp(12px,3vw,16px)}.search-results-section{max-height:400px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media(min-width:768px){.search-results-section{max-height:calc(100vh - 220px)}}.course-card{margin-bottom:12px;border-left-width:4px;border-left-style:solid;transition:all .3s}.course-card .ant-card-body{padding:12px}@media(min-width:768px){.course-card .ant-card-body{padding:16px}}.course-code{font-size:clamp(14px,4vw,16px);font-weight:600}.course-title{font-size:clamp(12px,3.5vw,14px);color:#666;margin-top:2px;word-break:break-word}.class-group{padding:clamp(8px,2vw,12px);margin-bottom:8px;border-radius:6px;border:1px solid #f0f0f0;background-color:#fafafa;cursor:pointer;transition:all .3s;-webkit-tap-highlight-color:transparent}.class-group.selected{background-color:#f6ffed;cursor:default}.class-group-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}.class-number-badge{display:inline-flex;align-items:center;background-color:#d9d9d9;color:#000;padding:2px 8px;border-radius:10px;font-size:clamp(10px,3vw,11px);font-weight:700}.class-number-badge.combined{background-color:#722ed1;color:#fff}.combined-info{font-size:clamp(10px,2.8vw,11px);color:#722ed1;display:inline-flex;align-items:center}.session-item{padding:8px;margin-bottom:4px;border-radius:4px;background-color:#fff;border:1px solid #e8e8e8;font-size:clamp(11px,3vw,12px)}.session-item:last-child{margin-bottom:0}.session-time{display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}.session-room{color:#666;display:inline-flex;align-items:center;gap:4px}.calendar-wrapper{min-height:500px;display:flex;align-items:center;justify-content:center;background-color:#fafafa;border-radius:8px;border:2px dashed #d9d9d9;padding:20px}.calendar-wrapper.has-events{min-height:400px;background-color:transparent;border:none;padding:0}.fc{background:#fff;border-radius:8px;padding:clamp(8px,2vw,16px);font-size:clamp(12px,3.5vw,14px)}.fc-toolbar{flex-wrap:wrap;gap:8px;margin-bottom:16px!important}.fc-toolbar-title{font-size:clamp(14px,4vw,18px)!important}.fc-button{padding:4px 8px!important;font-size:clamp(11px,3vw,12px)!important;min-height:32px;-webkit-tap-highlight-color:transparent}@media(min-width:768px){.fc-button{padding:4px 12px!important}}.fc-event{border-radius:4px!important;padding:2px 4px!important;font-size:clamp(10px,2.8vw,11px)!important;cursor:pointer;-webkit-tap-highlight-color:transparent}.selected-courses-list{margin-bottom:16px;padding:0 8px}.selected-course-item{display:flex;flex-direction:column;gap:8px;padding:12px 0;border-bottom:1px solid #f0f0f0}@media(min-width:640px){.selected-course-item{flex-direction:row;align-items:center;justify-content:space-between}}.selected-course-info{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.selected-course-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.empty-timetable{text-align:center;padding:30px 20px}.empty-timetable h4{font-size:clamp(16px,4.5vw,20px);color:#666;margin-bottom:8px}.empty-timetable p{font-size:clamp(13px,3.5vw,14px);color:#8c8c8c}@media(max-width:768px){.fc-button,.class-group,.ant-btn{min-height:44px}.session-item{padding:10px}.selected-course-tags .ant-tag{padding:4px 8px;font-size:12px}}@media(max-height:500px)and (orientation:landscape){.search-sidebar{height:auto;max-height:300px}.calendar-wrapper{min-height:300px}}.group-formation-container{padding:24px;min-height:100vh;background-color:#f0f2f5}.group-formation-container .ant-card{border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.group-formation-container .ant-card-head{border-bottom:2px solid #f0f0f0;background-color:#fafafa;border-radius:10px 10px 0 0}.group-formation-container .ant-card-head-title{font-weight:600;color:#262626;font-size:20px}.group-formation-container .ant-card-body{padding:24px}.group-formation-container .ant-table{border-radius:8px;overflow:hidden}.group-formation-container .ant-table-thead>tr>th{background-color:#fafafa;font-weight:600;color:#262626;border-bottom:2px solid #f0f0f0}.group-formation-container .ant-table-tbody>tr>td{border-bottom:1px solid #f0f0f0}.group-formation-container .ant-table-tbody>tr:hover>td{background-color:#fafafa}.group-formation-container .ant-avatar{background-color:#1890ff;color:#fff;font-weight:600}.group-formation-container .ant-tag{border-radius:4px;font-weight:500;border:none}.group-formation-container .ant-space-vertical>.ant-space-item{margin-bottom:4px}.group-formation-container .anticon{color:#1890ff;margin-right:8px}.group-formation-container .ant-modal-content{border-radius:12px}.group-formation-container .ant-modal-header{border-radius:12px 12px 0 0;border-bottom:1px solid #f0f0f0}.group-formation-container .ant-modal-title{font-weight:600;color:#262626}.group-formation-container .ant-form-item-label>label{font-weight:500;color:#262626}.group-formation-container .ant-input,.group-formation-container .ant-input-number,.group-formation-container .ant-input-textarea{border-radius:8px;border-color:#d9d9d9}.group-formation-container .ant-input:focus,.group-formation-container .ant-input-number:focus,.group-formation-container .ant-input-textarea:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.group-formation-container .ant-btn-primary{border-radius:6px;font-weight:500}.group-formation-container .ant-btn-dangerous{border-radius:6px}.group-formation-container .ant-typography{color:#595959;font-size:14px}.group-formation-container .ant-typography strong{color:#262626}@media(max-width:768px){.group-formation-container{padding:16px}.group-formation-container .ant-card{margin-bottom:16px}.group-formation-container .ant-card-body{padding:16px}.group-formation-container .ant-table{font-size:14px}}.questionnaire-container{padding:24px;min-height:100vh;background-color:#f0f2f5}.questionnaire-container .ant-card{border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.questionnaire-container .ant-card-head{border-bottom:2px solid #f0f0f0;background-color:#fafafa;border-radius:10px 10px 0 0}.questionnaire-container .ant-card-head-title{font-weight:600;color:#262626;font-size:18px}.questionnaire-container .ant-card-body{padding:24px}.questionnaire-container .ant-table{border-radius:8px;overflow:hidden}.questionnaire-container .ant-table-thead>tr>th{background-color:#fafafa;font-weight:600;color:#262626;border-bottom:2px solid #f0f0f0}.questionnaire-container .ant-table-tbody>tr>td{border-bottom:1px solid #f0f0f0;vertical-align:middle}.questionnaire-container .ant-table-tbody>tr:hover>td{background-color:#fafafa}.questionnaire-container .ant-progress{margin-bottom:4px}.questionnaire-container .ant-progress-text{color:#8c8c8c;font-size:12px}.questionnaire-container .ant-tag{border-radius:4px;font-weight:500;border:none;padding:2px 8px;font-size:12px}.questionnaire-container .ant-badge-status-text{color:#262626;font-weight:500}.questionnaire-container .ant-badge-status-success{color:#52c41a}.questionnaire-container .ant-badge-status-processing{color:#1890ff}.questionnaire-container .ant-space{align-items:center}.questionnaire-container .anticon-user{color:#1890ff;font-size:16px}.questionnaire-container .ant-btn-link{color:#1890ff;font-weight:500;padding:0}.questionnaire-container .ant-btn-link:hover{color:#40a9ff}.questionnaire-container .ant-btn-link .anticon{margin-right:4px}.questionnaire-container .ant-btn-primary{border-radius:6px;font-weight:500;padding:4px 16px}.questionnaire-container .ant-btn-primary .anticon{font-size:14px;margin-right:4px}.questionnaire-container .ant-btn-primary:disabled{background-color:#f5f5f5;border-color:#d9d9d9;color:#bfbfbf}.questionnaire-container .ant-modal-content{border-radius:12px}.questionnaire-container .ant-modal-header{border-radius:12px 12px 0 0;border-bottom:1px solid #f0f0f0}.questionnaire-container .ant-modal-title{font-weight:600;color:#262626}.questionnaire-container .ant-form-item-label>label{font-weight:500;color:#262626}.questionnaire-container .ant-input,.questionnaire-container .ant-input-number,.questionnaire-container .ant-input-textarea{border-radius:8px;border-color:#d9d9d9}.questionnaire-container .ant-input:focus,.questionnaire-container .ant-input-number:focus,.questionnaire-container .ant-input-textarea:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.questionnaire-container .ant-input-prefix{color:#8c8c8c;margin-right:8px}.questionnaire-container .ant-typography-secondary strong{color:#f5222d}@media(max-width:768px){.questionnaire-container{padding:16px}.questionnaire-container .ant-card{margin-bottom:16px}.questionnaire-container .ant-card-body{padding:16px}.questionnaire-container .ant-table{font-size:14px}.questionnaire-container .ant-btn-primary{padding:2px 8px;font-size:12px}}.materials-container{padding:24px;min-height:100vh;background-color:#f0f2f5}.materials-container .ant-card{border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.materials-container .ant-row{align-items:center}.materials-container .ant-typography{margin-bottom:4px}.materials-container .ant-typography-secondary{color:#8c8c8c;font-size:16px}.materials-container .ant-input-search{border-radius:8px;overflow:hidden}.materials-container .ant-input-search .ant-input{border-radius:8px 0 0 8px;border-color:#d9d9d9;padding:12px 16px}.materials-container .ant-input-search .ant-input:focus{border-color:#1890ff;box-shadow:none}.materials-container .ant-input-search-button{border-radius:0 8px 8px 0;height:40px;border-color:#1890ff;background-color:#1890ff}.materials-container .ant-input-search-button:hover{background-color:#40a9ff;border-color:#40a9ff}.materials-container .ant-table{border-radius:8px;overflow:hidden}.materials-container .ant-table-thead>tr>th{background-color:#fafafa;font-weight:600;color:#262626;border-bottom:2px solid #f0f0f0}.materials-container .ant-table-tbody>tr>td{border-bottom:1px solid #f0f0f0;vertical-align:middle}.materials-container .ant-table-tbody>tr:hover>td{background-color:#fafafa}.materials-container .ant-tag{border-radius:4px;font-weight:500;border:none;padding:4px 8px;font-size:12px}.materials-container .ant-space-vertical{line-height:1.4}.materials-container .ant-typography strong{color:#262626;font-size:16px}.materials-container .ant-typography-secondary{color:#8c8c8c;font-size:12px}.materials-container .ant-btn-primary{border-radius:6px;font-weight:500;padding:4px 16px}.materials-container .ant-btn-primary .anticon{font-size:14px;margin-right:4px}.materials-container .ant-modal-content{border-radius:12px}.materials-container .ant-modal-header{border-radius:12px 12px 0 0;border-bottom:1px solid #f0f0f0}.materials-container .ant-modal-title{font-weight:600;color:#262626}.materials-container .ant-form-item-label>label{font-weight:500;color:#262626}.materials-container .ant-input,.materials-container .ant-select-selector,.materials-container .ant-input-textarea{border-radius:8px;border-color:#d9d9d9}.materials-container .ant-input:focus,.materials-container .ant-select-selector:focus,.materials-container .ant-input-textarea:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.materials-container .ant-upload{width:100%}.materials-container .ant-upload-btn{display:flex;align-items:center;justify-content:center;border:2px dashed #d9d9d9;border-radius:8px;padding:16px}.materials-container .ant-upload-btn:hover{border-color:#1890ff}@media(max-width:768px){.materials-container{padding:16px}.materials-container .ant-card{margin-bottom:16px}.materials-container .ant-table{font-size:14px}.materials-container .ant-btn-primary{padding:2px 8px;font-size:12px}}.profile-container{padding:clamp(12px,4vw,24px);min-height:100vh;background-color:#f0f2f5}.profile-header-card{margin-bottom:20px;overflow:hidden}.profile-header{display:flex;flex-direction:column;gap:16px}@media(min-width:640px){.profile-header{flex-direction:row;justify-content:space-between;align-items:center}}.profile-info{display:flex;flex-direction:column;gap:16px;align-items:center;text-align:center}@media(min-width:640px){.profile-info{flex-direction:row;text-align:left;align-items:center}}.profile-avatar{width:clamp(60px,15vw,80px);height:clamp(60px,15vw,80px);border-radius:50%;border:4px solid white;box-shadow:0 4px 12px #0000001a;display:flex;align-items:center;justify-content:center;background-color:#1890ff;color:#fff;font-size:clamp(24px,6vw,32px)}.profile-details{flex:1}.profile-name{font-size:clamp(20px,5vw,24px);margin:0 0 4px;word-break:break-word}.profile-email{font-size:clamp(13px,3.5vw,14px);color:#666;margin:0 0 4px;word-break:break-word}.profile-role-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:clamp(11px,3vw,12px);font-weight:600;background-color:#1890ff;color:#fff}.profile-role-tag.admin{background-color:#f5222d}.profile-actions{display:flex;gap:8px;justify-content:center}@media(min-width:640px){.profile-actions{justify-content:flex-end}}.profile-actions button{min-height:44px;padding:8px 16px;font-size:clamp(13px,3.5vw,14px);border-radius:6px;border:none;cursor:pointer;transition:all .3s;-webkit-tap-highlight-color:transparent}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,140px),1fr));gap:clamp(8px,2vw,16px);margin-top:16px}.stat-card{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:8px;padding:clamp(12px,3vw,16px);text-align:center}.stat-label{font-size:clamp(12px,3vw,14px);color:#666;margin-bottom:4px}.stat-value{font-size:clamp(20px,5vw,24px);font-weight:600;color:#1890ff}.profile-form-card{margin-top:20px}.form-title{font-size:clamp(16px,4.5vw,18px);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #f0f0f0}.form-grid{display:grid;grid-template-columns:1fr;gap:16px}@media(min-width:640px){.form-grid{grid-template-columns:repeat(2,1fr)}}.form-group{margin-bottom:16px}.form-group.full-width{grid-column:1 / -1}.form-label{display:block;font-size:clamp(13px,3.5vw,14px);font-weight:500;color:#262626;margin-bottom:8px}.form-control{width:100%;padding:clamp(10px,3vw,12px);font-size:clamp(13px,3.5vw,14px);border:1px solid #d9d9d9;border-radius:8px;transition:all .3s;-webkit-appearance:none;appearance:none}.form-control:focus{border-color:#1890ff;outline:none;box-shadow:0 0 0 2px #1890ff33}.form-control:disabled{background-color:#f5f5f5;cursor:not-allowed}.skills-container{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.skill-tag{background-color:#1890ff;color:#fff;padding:4px 12px;border-radius:4px;font-size:clamp(11px,3vw,12px);display:inline-flex;align-items:center;gap:4px}.skill-tag-remove{cursor:pointer;opacity:.8;font-size:14px;-webkit-tap-highlight-color:transparent}.skill-tag-remove:hover{opacity:1}.form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;justify-content:center}@media(min-width:640px){.form-actions{justify-content:flex-start}}.form-actions button{min-height:44px;padding:8px 24px;font-size:clamp(13px,3.5vw,14px);border-radius:6px;border:none;cursor:pointer;transition:all .3s;-webkit-tap-highlight-color:transparent}.btn-primary{background-color:#1890ff;color:#fff}.btn-primary:hover{background-color:#40a9ff;transform:translateY(-1px);box-shadow:0 4px 12px #1890ff4d}.btn-default{background-color:#f5f5f5;color:#262626}.btn-default:hover{background-color:#e8e8e8}.loading-container{display:flex;justify-content:center;align-items:center;min-height:400px}@media(max-width:768px){.form-control,.profile-actions button,.form-actions button{min-height:44px}.skill-tag{padding:6px 12px}.skill-tag-remove{font-size:16px}}@media(max-height:500px)and (orientation:landscape){.profile-container{padding:8px}.profile-header{flex-direction:row;align-items:center}.profile-info{flex-direction:row}.stats-grid{grid-template-columns:repeat(2,1fr)}}.admin-panel{padding:clamp(16px,4vw,24px);min-height:100vh;background-color:#f0f2f5}.admin-header h1{font-size:clamp(24px,5vw,28px);margin-bottom:8px}.admin-header p{color:#666;font-size:clamp(14px,3.5vw,16px)}.admin-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;border-bottom:2px solid #e8e8e8;padding-bottom:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.admin-tabs::-webkit-scrollbar{height:4px}.admin-tabs::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:4px}.tab-btn{padding:clamp(8px,2vw,12px) clamp(12px,3vw,24px);background:none;border:none;border-radius:6px;font-size:clamp(14px,3.5vw,16px);font-weight:500;color:#666;cursor:pointer;transition:all .3s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.tab-btn.active{color:#1890ff;font-weight:600}.admin-content{background:#fff;border-radius:12px;padding:clamp(16px,4vw,32px);box-shadow:0 4px 12px #00000014;overflow:hidden}.admin-content h2{font-size:clamp(18px,4vw,22px);margin-bottom:20px}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px}.accounts-list,.courses-list{display:flex;flex-direction:column;gap:12px}.account-card,.course-card{background:#fafafa;border-radius:8px;padding:clamp(12px,3vw,20px);display:flex;flex-direction:column;gap:12px;border-left:4px solid #1890ff;transition:all .3s}@media(min-width:640px){.account-card,.course-card{flex-direction:row;justify-content:space-between;align-items:center}}.account-info h3,.course-info h3{font-size:clamp(16px,4vw,18px);margin-bottom:4px}.account-info p,.course-info p{color:#666;font-size:clamp(13px,3.5vw,14px);margin-bottom:4px;word-break:break-word}.account-actions,.course-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-approve,.btn-reject{padding:clamp(6px,2vw,8px) clamp(12px,3vw,16px);font-size:clamp(13px,3.5vw,14px);border-radius:4px;border:none;font-weight:500;cursor:pointer;transition:all .3s;min-height:36px;-webkit-tap-highlight-color:transparent}.users-section{overflow-x:auto;-webkit-overflow-scrolling:touch}.users-table table{min-width:600px;width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:clamp(8px,2vw,12px) clamp(12px,3vw,16px);font-size:clamp(13px,3.5vw,14px)}.user-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-add-credits,.btn-delete{padding:clamp(4px,1.5vw,6px) clamp(8px,2vw,12px);font-size:clamp(11px,3vw,12px);min-height:32px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,200px),1fr));gap:16px}.stat-card{padding:clamp(16px,4vw,24px);background:#fafafa;border-radius:8px;display:flex;align-items:center;gap:16px}.stat-icon{font-size:clamp(24px,6vw,32px)}.stat-content h3{font-size:clamp(13px,3.5vw,14px);margin-bottom:4px}.stat-value{font-size:clamp(20px,5vw,28px);font-weight:700}.photo-preview-container{max-width:100%;overflow:hidden}.photo-preview-container img{max-width:100%;height:auto;object-fit:contain}@media(max-width:640px){.account-actions,.course-actions{width:100%;justify-content:stretch}.btn-approve,.btn-reject{flex:1;text-align:center}.user-actions{flex-direction:column}.btn-add-credits,.btn-delete{width:100%}.stat-card{flex-direction:column;text-align:center}}@media(max-width:768px){.tab-btn,.btn-approve,.btn-reject,.btn-add-credits,.btn-delete{min-height:44px}}.loading{text-align:center;padding:40px 20px;color:#666;font-size:clamp(14px,4vw,16px)}.admin-access-denied{text-align:center;padding:40px 20px;max-width:600px;margin:0 auto}.admin-access-denied h2{font-size:clamp(20px,5vw,24px)}.admin-access-denied p{font-size:clamp(14px,3.5vw,16px)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f5f5f5}#root{min-height:100vh}
