@import url(https://fonts.googleapis.com/css2?family=Inter:wght@100&family=Montserrat&family=Poppins&display=swap);@import url(https://fonts.googleapis.com/css2?family=Montserrat&family=Poppins&display=swap);.calendar-wrapper[data-v-20174f8e]{background:#fff;border-radius:12px;padding:20px;-webkit-box-shadow:0 4px 10px rgba(0,0,0,.05);box-shadow:0 4px 10px rgba(0,0,0,.05);width:100%;margin:20px 0;-webkit-box-sizing:border-box;box-sizing:border-box}.calendar-headers[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:15px}.left-controls[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:10px}.left-controls button[data-v-20174f8e]{background:#f3f4f6;border:none;border-radius:6px;padding:6px 10px;cursor:pointer;font-weight:600}.month-title[data-v-20174f8e]{font-size:18px;font-weight:600}.today-btn[data-v-20174f8e]{background:#2563eb;color:#fff}.calendar-grid[data-v-20174f8e]{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:20px}.day[data-v-20174f8e]{text-align:center;padding:12px;border-radius:8px;cursor:pointer}.day.header[data-v-20174f8e]{font-weight:600;color:#6b7280;background:#f9fafb}.day[data-v-20174f8e]:hover{background:#f3f4f6}.today[data-v-20174f8e]{background:#e0e7ff;border:1px solid #2563eb}.selected[data-v-20174f8e]{background:#2563eb;color:#fff}.schedule-container[data-v-20174f8e]{margin-top:10px;background:#f9fafc;border-radius:12px;padding:15px}.schedule-header[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:12px}.schedule-header h3[data-v-20174f8e]{font-size:18px;font-weight:600}.date-label[data-v-20174f8e]{font-size:14px;color:#6b7280}.schedule-card[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;background:#fff;border-radius:10px;padding:12px;margin-bottom:10px;-webkit-box-shadow:0 2px 6px rgba(0,0,0,.05);box-shadow:0 2px 6px rgba(0,0,0,.05);-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between}.time-label[data-v-20174f8e]{width:80px;font-weight:600;font-size:14px;color:#374151}.class-info[data-v-20174f8e]{-webkit-box-flex:1;-ms-flex:1;flex:1}.class-status[data-v-20174f8e]{color:#dc2626;font-size:12px;margin-bottom:5px}.status-dot[data-v-20174f8e]{width:8px;height:8px;background:#dc2626;display:inline-block;border-radius:50%;margin-right:5px}.class-title[data-v-20174f8e]{font-weight:600;color:#111827}.class-teacher[data-v-20174f8e]{color:#4b5563;font-size:14px}.class-time[data-v-20174f8e]{color:#6b7280;font-size:13px}.action-buttons[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:6px;-ms-flex-wrap:wrap;flex-wrap:wrap}.start-btn[data-v-20174f8e],.upload-btn[data-v-20174f8e]{background:#2563eb;border:none;color:#fff;border-radius:6px;padding:6px 10px;font-size:13px;cursor:pointer}.upload-btn[data-v-20174f8e]{background:#fff;color:#2563eb;border:1px solid #2563eb}.start-btn[data-v-20174f8e]{background:#2563eb;color:#fff;border:1px solid #fff}@media (max-width:768px){.action-buttons[data-v-20174f8e]{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:6px;margin-top:10px}.start-btn[data-v-20174f8e],.upload-btn[data-v-20174f8e]{width:100%;display:block;font-size:12px;padding:5px 4px}}.no-class[data-v-20174f8e]{text-align:center;padding:20px;color:#6b7280}@media (max-width:768px){.calendar-grid[data-v-20174f8e]{gap:2px}.day[data-v-20174f8e]{padding:8px 0}.schedule-card[data-v-20174f8e]{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start}.action-buttons[data-v-20174f8e]{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;width:100%;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}}.class-count-badge[data-v-20174f8e]{position:absolute;bottom:5px;right:5px;background:#00bfff;color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:2px 6px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:3px}.class-count-badge i[data-v-20174f8e]{font-size:10px}@media (max-width:768px){.day[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}.class-count-badge[data-v-20174f8e]{position:relative;bottom:auto;right:auto;margin-bottom:2px;font-size:10px;padding:1px 5px}}.edit-btn[data-v-20174f8e],.upload-btn[data-v-20174f8e]{-webkit-box-flex:1;-ms-flex:1;flex:1;border:none;border-radius:8px;padding:8px 12px;font-weight:600;cursor:pointer;-webkit-transition:all .2s ease;transition:all .2s ease}.edit-btn[data-v-20174f8e]{background-color:#3b82f6;color:#fff}.edit-btn[data-v-20174f8e]:hover{background-color:#2563eb}.upload-btn[data-v-20174f8e]{background-color:#10b981;color:#fff}.upload-btn[data-v-20174f8e]:hover{background-color:#059669}.day[data-v-20174f8e]{position:relative}.modal-backdrop[data-v-20174f8e]{top:0;left:0;width:100%;height:100%;background-color:rgba(15,23,42,.7);z-index:9999}.modal-card[data-v-20174f8e]{max-width:500px;width:95%;padding:2rem;-webkit-box-shadow:0 10px 25px rgba(0,0,0,.2);box-shadow:0 10px 25px rgba(0,0,0,.2);position:relative;-webkit-transition:opacity .3s ease,-webkit-transform .3s ease;transition:opacity .3s ease,-webkit-transform .3s ease;transition:transform .3s ease,opacity .3s ease;transition:transform .3s ease,opacity .3s ease,-webkit-transform .3s ease}.modal-header[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:1rem}.modal-header h4[data-v-20174f8e]{font-size:1.25rem;font-weight:600;color:#0a1028}.close-btn[data-v-20174f8e]{width:25px;-webkit-transition:-webkit-transform .2s ease;transition:-webkit-transform .2s ease;transition:transform .2s ease;transition:transform .2s ease,-webkit-transform .2s ease}.close-btn[data-v-20174f8e]:hover{-webkit-transform:rotate(90deg);transform:rotate(90deg)}.modal-backdrop[data-v-20174f8e]{position:fixed;inset:0;background:rgba(0,0,0,.45);display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;z-index:1000}.modal-card[data-v-20174f8e]{background:#fff;border-radius:12px;width:550px;max-width:90%;-webkit-box-shadow:0 10px 30px rgba(0,0,0,.15);box-shadow:0 10px 30px rgba(0,0,0,.15);display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.upload-popup-overlay[data-v-20174f8e]{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.6);z-index:9999;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;overflow-y:auto;padding:40px 20px}.upload-popup-card[data-v-20174f8e]{background:#fff;border-radius:8px;width:450px;padding:25px 30px;position:relative;-webkit-box-shadow:0 10px 25px rgba(0,0,0,.15);box-shadow:0 10px 25px rgba(0,0,0,.15);text-align:center}.close-btn[data-v-20174f8e]{position:absolute;top:12px;right:18px;border:none;background:transparent;font-size:20px;cursor:pointer}.upload-title[data-v-20174f8e]{font-size:18px;font-weight:600;margin-bottom:5px;color:#111}.upload-subtitle[data-v-20174f8e]{color:#555;font-size:14px;margin:0}.upload-format-text[data-v-20174f8e]{color:#999;font-size:13px;margin-bottom:15px}.upload-dropzone[data-v-20174f8e]{border:2px dashed #ccc;border-radius:10px;padding:25px;cursor:pointer;-webkit-transition:.3s;transition:.3s}.upload-dropzone[data-v-20174f8e]:hover{border-color:#2563eb;background:#f9faff}.upload-icon[data-v-20174f8e]{width:35px;opacity:.7;margin-bottom:10px}.upload-text[data-v-20174f8e]{font-size:14px;font-weight:500;color:#2563eb}.file-list[data-v-20174f8e]{list-style:none;padding:0;margin-top:15px;text-align:left;border-top:1px solid #eee;padding-top:10px}.file-list li[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;background:#f8fafc;padding:8px 10px;border-radius:6px;margin-top:8px;font-size:14px;color:#333}.file-name i[data-v-20174f8e]{margin-right:8px;color:#2563eb}.remove-file[data-v-20174f8e]{border:none;background:transparent;color:#999;font-size:16px;cursor:pointer}.upload-submit-btn[data-v-20174f8e]{width:100%;margin-top:20px;background:#2563eb;color:#fff;border:none;border-radius:6px;padding:10px;font-size:15px;font-weight:500;cursor:pointer;-webkit-transition:.3s;transition:.3s}.upload-submit-btn[data-v-20174f8e]:disabled{opacity:.6;cursor:not-allowed}.upload-submit-btn[data-v-20174f8e]:hover:not(:disabled){background:#1e4ed8}@media (max-width:480px){.upload-popup-card[data-v-20174f8e]{width:90%;padding:20px}}.uploaded-files h4[data-v-20174f8e]{font-size:14px;font-weight:600;margin-top:8px}.uploaded-files ul[data-v-20174f8e]{padding-left:16px;margin:4px 0}.uploaded-files li a[data-v-20174f8e]{color:#2563eb;text-decoration:underline;font-size:13px}.modules-list[data-v-20174f8e]{margin-top:10px}.modules-title[data-v-20174f8e]{font-size:16px;font-weight:600;margin-bottom:10px;color:#333}.modules-grid[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;gap:10px}.module-badge[data-v-20174f8e]{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;background-color:#f3f6fa;border:1px solid #e3e8ef;border-radius:8px;padding:8px 12px;cursor:pointer;-webkit-transition:all .25s ease;transition:all .25s ease;min-width:180px;overflow:hidden}.module-badge[data-v-20174f8e]:hover{background-color:#e8f0fe;border-color:#c6d9ff;-webkit-box-shadow:0 2px 6px rgba(0,0,0,.08);box-shadow:0 2px 6px rgba(0,0,0,.08)}