.sm-wrapper{background:#fff;min-height:100vh;padding:20px}.sm-container{max-width:1000px;margin:0 auto}.sm-header{margin-bottom:32px;animation:.4s ease-out sm-fade-in}.sm-header-content{align-items:flex-start;gap:16px;display:flex}.sm-header-icon{color:#d97706;background:#fef3c7;border:2px solid #fbbf24;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;animation:.5s ease-out sm-scale-in;display:flex}.sm-header-text{flex:1;animation:.5s ease-out sm-slide-up}.sm-title{color:#000;letter-spacing:-.02em;margin:0 0 6px;font-size:32px;font-weight:800}.sm-subtitle{color:#6b7280;margin:0;font-size:15px;font-weight:500}.sm-materials-list{flex-direction:column;gap:16px;display:flex}.sm-semester-block{background:#fff;border:2px solid #e5e7eb;border-radius:14px;transition:all .2s;animation:.4s ease-out sm-slide-in;overflow:hidden}.sm-semester-block:hover{border-color:#d1d5db}.sm-semester-btn{cursor:pointer;background:#fff;border:none;justify-content:space-between;align-items:center;width:100%;padding:18px 20px;transition:all .2s;display:flex}.sm-semester-btn:hover{background:#f9fafb}.sm-semester-btn.sm-semester-open{background:#eff6ff;border-bottom:2px solid #e5e7eb}.sm-semester-left{flex:1;align-items:center;gap:12px;display:flex}.sm-semester-left svg{color:#1e40af;flex-shrink:0}.sm-semester-name{color:#111827;font-size:17px;font-weight:700}.sm-subject-count{color:#6b7280;background:#f3f4f6;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.sm-semester-icon{color:#6b7280;align-items:center;transition:transform .2s;display:flex}.sm-semester-btn.sm-semester-open .sm-semester-icon{color:#1e40af}.sm-subjects-wrapper{background:#f9fafb;padding:12px;animation:.3s ease-out sm-expand}.sm-subject-block{background:#fff;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:10px;transition:all .2s;overflow:hidden}.sm-subject-block:last-child{margin-bottom:0}.sm-subject-block:hover{border-color:#cbd5e1}.sm-subject-btn{cursor:pointer;background:#fff;border:none;justify-content:space-between;align-items:center;width:100%;padding:14px 16px;transition:all .2s;display:flex}.sm-subject-btn:hover{background:#f9fafb}.sm-subject-btn.sm-subject-open{background:#fef3c7;border-bottom:2px solid #e5e7eb}.sm-subject-left{flex:1;align-items:center;gap:10px;display:flex}.sm-subject-left svg{color:#1e40af;flex-shrink:0}.sm-subject-name{color:#111827;font-size:15px;font-weight:600}.sm-file-count{color:#92400e;background:#fde68a;border-radius:5px;padding:3px 8px;font-size:11px;font-weight:600}.sm-subject-icon{color:#6b7280;align-items:center;transition:transform .2s;display:flex}.sm-subject-btn.sm-subject-open .sm-subject-icon{color:#d97706}.sm-files-list{background:#fffbeb;padding:12px;animation:.3s ease-out sm-expand}.sm-file-card{background:#fff;border:2px solid #e5e7eb;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:8px;transition:all .2s;animation:.3s ease-out sm-fade-in;display:flex;overflow:hidden}.sm-file-card:last-child{margin-bottom:0}.sm-file-card:hover{border-color:#1e40af;transform:translate(4px)}.sm-file-link{min-width:0;color:inherit;flex:1;align-items:center;padding:12px 14px;text-decoration:none;transition:background .2s;display:flex}.sm-file-link:hover{background:#f9fafb}.sm-file-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.sm-file-icon{flex-shrink:0;font-size:18px}.sm-file-name{color:#374151;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.sm-file-actions{flex-shrink:0;align-items:center;gap:8px;padding-right:14px;display:flex}.sm-action-btn{cursor:pointer;border:2px solid #0000;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;text-decoration:none;transition:all .2s;display:inline-flex}.sm-view-btn{color:#1e40af;background:#eff6ff}.sm-view-btn:hover{color:#fff;background:#1e40af;border-color:#1e40af;transform:scale(1.05)}.sm-download-btn{color:#d97706;background:#fef3c7}.sm-download-btn:hover{color:#000;background:#fbbf24;border-color:#fbbf24;transform:scale(1.05)}@keyframes sm-fade-in{0%{opacity:0}to{opacity:1}}@keyframes sm-slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes sm-slide-in{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes sm-scale-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes sm-expand{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.sm-subject-content{background:#fffbeb;animation:.3s ease-out sm-expand}.sm-unofficial-block{border-bottom:2px dashed #e5e7eb;overflow:hidden}.sm-unofficial-btn{cursor:pointer;background:linear-gradient(135deg,#f5f3ff 0%,#ede9fe 100%);border:none;justify-content:space-between;align-items:center;width:100%;padding:11px 16px;transition:all .2s;display:flex}.sm-unofficial-btn:hover{background:linear-gradient(135deg,#ede9fe 0%,#ddd6fe 100%)}.sm-unofficial-btn.sm-unofficial-open{background:linear-gradient(135deg,#ede9fe 0%,#ddd6fe 100%);border-bottom:1px solid #c4b5fd}.sm-unofficial-left{flex:1;align-items:center;gap:8px;display:flex}.sm-unofficial-left svg{color:#7c3aed;flex-shrink:0}.sm-unofficial-label{color:#5b21b6;letter-spacing:.01em;text-transform:uppercase;font-size:13px;font-weight:700}.sm-unofficial-badge{color:#5b21b6;background:#c4b5fd;border-radius:5px;padding:2px 7px;font-size:11px;font-weight:600}.sm-unofficial-chevron{color:#7c3aed;align-items:center;display:flex}.sm-unofficial-files-list{background:#faf5ff;padding:10px 12px;animation:.3s ease-out sm-expand}.sm-unofficial-files-list .sm-file-card:hover{border-color:#7c3aed}.sm-unofficial-files-list .sm-view-btn{color:#7c3aed;background:#ede9fe}.sm-unofficial-files-list .sm-view-btn:hover{color:#fff;background:#7c3aed;border-color:#7c3aed}.sm-unofficial-files-list .sm-download-btn{color:#7c3aed;background:#ede9fe}.sm-unofficial-files-list .sm-download-btn:hover{color:#fff;background:#a78bfa;border-color:#a78bfa}@media (max-width:768px){.sm-wrapper{padding:16px}.sm-title{font-size:26px}.sm-subtitle{font-size:14px}.sm-header-icon{width:48px;height:48px}.sm-semester-btn{padding:16px}.sm-semester-name{font-size:16px}.sm-subject-btn{padding:12px 14px}.sm-subject-name{font-size:14px}.sm-file-card{padding:10px 12px}.sm-file-name{font-size:13px}.sm-action-btn{width:34px;height:34px}}
