.csv-export-button{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#48c774;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.csv-export-button:hover:not(:disabled){background:#3abb67;transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.1)}.csv-export-button:disabled{background:#dbdbdb;color:#7a7a7a;cursor:not-allowed}.csv-export-button .icon{font-size:16px}.csv-export-button .count{font-size:12px;opacity:.9}.csv-export-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.csv-export-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column}.csv-export-modal .modal-header{padding:20px 24px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between}.csv-export-modal .modal-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.csv-export-modal .close-button{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.csv-export-modal .close-button:hover{background:#f5f5f5;color:#333}.csv-export-modal .modal-body{padding:24px;overflow-y:auto;flex:1 1}.csv-export-modal .export-info{margin-bottom:24px;padding:12px;background:#f9f9f9;border-radius:4px}.csv-export-modal .export-info p{margin:4px 0;color:#555}.csv-export-modal .scope-info{font-size:13px;color:#777}.csv-export-modal .column-selection{margin-top:20px}.csv-export-modal .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.csv-export-modal .section-header h3{margin:0;font-size:16px;font-weight:600;color:#333}.csv-export-modal .select-all-button{background:none;border:1px solid #3273dc;color:#3273dc;padding:6px 12px;border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s ease}.csv-export-modal .select-all-button:hover{background:#3273dc;color:#fff}.csv-export-modal .column-group{margin-bottom:20px}.csv-export-modal .column-group h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.csv-export-modal .column-checkbox{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:8px;border-radius:4px;cursor:pointer;transition:background .2s ease}.csv-export-modal .column-checkbox:hover{background:#f5f5f5}.csv-export-modal .column-checkbox.required{opacity:.7;cursor:default;background:#fafafa}.csv-export-modal .column-checkbox input[type=checkbox]{cursor:pointer}.csv-export-modal .column-checkbox.required input[type=checkbox]{cursor:not-allowed}.csv-export-modal .column-label{flex:1 1;font-size:14px;color:#333}.csv-export-modal .required-badge{background:#ff3860}.csv-export-modal .required-badge,.csv-export-modal .role-badge{font-size:11px;padding:2px 8px;color:#fff;border-radius:12px;font-weight:600}.csv-export-modal .role-badge{background:#3273dc}.csv-export-modal .modal-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;align-items:center;justify-content:flex-end;gap:12px}.csv-export-modal .cancel-button{padding:10px 20px;background:#fff;border:1px solid #dbdbdb;color:#363636;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.csv-export-modal .cancel-button:hover:not(:disabled){border-color:#b5b5b5;background:#f5f5f5}.csv-export-modal .export-button{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:#48c774;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.csv-export-modal .export-button:hover:not(:disabled){background:#3abb67;transform:translateY(-1px);box-shadow:0 2px 6px rgba(72,199,116,.3)}.csv-export-modal .export-button:disabled{background:#dbdbdb;cursor:not-allowed;opacity:.6}.csv-export-modal .export-button .spinner{animation:spin 1s linear infinite}@media (max-width:768px){.csv-export-modal{margin:10px;max-height:95vh}.csv-export-modal .modal-body,.csv-export-modal .modal-footer,.csv-export-modal .modal-header{padding:16px}.csv-export-modal .section-header{flex-direction:column;align-items:flex-start;gap:12px}.csv-export-button .text{display:none}.csv-export-button .count{display:inline}}.filter-presets-panel{position:relative;display:inline-block}.filter-presets-button{display:flex;align-items:center;gap:8px;padding:8px 16px;border:1px solid #dbdbdb;border-radius:4px;background-color:#fff;cursor:pointer;transition:all .2s}.filter-presets-button:hover{border-color:#b5b5b5;background-color:#f5f5f5}.filter-presets-button.is-active{border-color:#3273dc;background-color:#f0f5ff}.filter-presets-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:350px;max-width:450px;max-height:500px;overflow-y:auto;background:#fff;border:1px solid #dbdbdb;border-radius:4px;box-shadow:0 8px 16px rgba(0,0,0,.15);z-index:100}.filter-presets-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:40px 20px;color:#7a7a7a}.filter-presets-create{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border:none;background:#f0f5ff;color:#3273dc;font-weight:600;cursor:pointer;transition:background .2s}.filter-presets-create:hover{background:#e0ebff}.filter-presets-divider{height:1px;background:#efefef;margin:8px 0}.filter-presets-section{padding:8px 0}.filter-presets-section-title{display:flex;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:600;color:#7a7a7a;text-transform:uppercase}.filter-preset-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 16px;border:none;background:#fff;text-align:left;cursor:pointer;transition:background .2s}.filter-preset-item:hover{background:#f9f9f9}.filter-preset-item.is-active{background:#f0f5ff;border-left:3px solid #3273dc}.filter-preset-content{flex:1 1;min-width:0}.filter-preset-name{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:#363636;margin-bottom:4px}.filter-preset-description{font-size:12px;color:#7a7a7a;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-preset-meta{font-size:11px;color:#b5b5b5}.filter-preset-actions{display:flex;gap:4px;margin-left:8px}.filter-preset-action{padding:4px 8px;border:none;background:transparent;color:#7a7a7a;cursor:pointer;border-radius:4px;transition:all .2s}.filter-preset-action:hover{background:#efefef;color:#363636}.filter-presets-empty{display:flex;flex-direction:column;align-items:center;padding:40px 20px;color:#b5b5b5;text-align:center}.filter-presets-empty .icon{margin-bottom:12px}.filter-builder-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1000}.filter-builder-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:900px;max-height:90vh;background:#fff;border-radius:6px;box-shadow:0 16px 48px rgba(0,0,0,.3);z-index:1001;display:flex;flex-direction:column}.filter-builder-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #efefef}.filter-builder-body{flex:1 1;overflow-y:auto;padding:24px}.filter-builder-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid #efefef}.filter-builder-section-title{font-size:14px;font-weight:600;color:#363636;margin-bottom:12px}.filter-builder-conditions{margin-bottom:24px}.filter-builder-empty{align-items:center;padding:40px 20px;color:#b5b5b5;text-align:center;border:2px dashed #efefef;border-radius:4px}.filter-builder-empty,.filter-conditions-list{display:flex;flex-direction:column;margin-bottom:16px}.filter-conditions-list{gap:12px}.filter-condition-row{display:flex;flex-direction:column;gap:8px}.filter-logic-operator{padding-left:20px}.filter-condition-inputs{display:grid;grid-template-columns:1fr 1fr 2fr auto;grid-gap:8px;gap:8px;align-items:center}.filter-builder-preview{padding:16px;background:#f9f9f9;border:1px solid #efefef;border-radius:4px}.filter-preview-content{display:flex;flex-direction:column;gap:6px;font-family:monospace;font-size:13px}.filter-preview-line{display:flex;align-items:baseline;gap:8px}.filter-preview-logic{font-weight:700;color:#3273dc}.filter-preview-condition{color:#363636}.save-filter-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:1100}.save-filter-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:600px;max-height:90vh;background:#fff;border-radius:6px;box-shadow:0 16px 48px rgba(0,0,0,.3);z-index:1101;display:flex;flex-direction:column}.save-filter-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #efefef}.save-filter-body{flex:1 1;overflow-y:auto;padding:24px}.save-filter-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid #efefef}.save-filter-summary{margin-top:20px;padding:16px;background:#f9f9f9;border:1px solid #efefef;border-radius:4px}.save-filter-summary-title{font-size:13px;font-weight:600;color:#7a7a7a;margin-bottom:12px;text-transform:uppercase}.save-filter-summary-content{font-size:13px;color:#363636}.save-filter-summary-content ul{list-style:none;padding-left:0}.save-filter-summary-content li{padding:4px 0}@media screen and (max-width:768px){.filter-presets-dropdown{position:fixed;top:50%;left:50%;right:auto;transform:translate(-50%,-50%);width:90%;max-width:400px}.filter-condition-inputs{grid-template-columns:1fr}.filter-logic-operator{padding-left:0}.filter-builder-modal,.save-filter-modal{width:95%;max-height:95vh}}.user-profile-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.user-profile-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);max-width:700px;width:100%;max-height:90vh;display:flex;flex-direction:column}.user-profile-modal .modal-header{padding:20px 24px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between}.user-profile-modal .header-content h2{margin:0 0 4px;font-size:20px;font-weight:600;color:#333}.user-profile-modal .user-name{margin:0;font-size:14px;color:#666}.user-profile-modal .close-button{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.user-profile-modal .close-button:hover{background:#f5f5f5;color:#333}.user-profile-modal .modal-tabs{display:flex;border-bottom:1px solid #e0e0e0;padding:0 24px;gap:8px}.user-profile-modal .tab{background:none;padding:12px 20px;font-size:14px;font-weight:500;color:#666;cursor:pointer;border:none;border-bottom:3px solid transparent;transition:all .2s ease;display:flex;align-items:center;gap:6px}.user-profile-modal .tab:hover{color:#3273dc;background:#f9f9f9}.user-profile-modal .tab.active{color:#3273dc;border-bottom-color:#3273dc}.user-profile-modal .tab-icon{font-size:16px}.user-profile-modal .error-banner{padding:12px 24px;background:#ffe0e0;border-bottom:1px solid #fcc;color:#c00;display:flex;align-items:center;gap:8px}.user-profile-modal .error-icon{font-size:18px}.user-profile-modal .modal-body{padding:24px;overflow-y:auto;flex:1 1}.profile-view{display:flex;flex-direction:column;gap:24px}.profile-view .profile-header{display:flex;align-items:center;gap:20px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.profile-view .avatar-section{flex-shrink:0}.profile-view .avatar,.profile-view .avatar-placeholder{width:80px;height:80px;border-radius:50%;object-fit:cover}.profile-view .avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600}.profile-view .basic-info h3{margin:0 0 4px;font-size:24px;font-weight:600;color:#333}.profile-view .email{margin:0 0 4px;color:#666;font-size:14px}.profile-view .student-id{margin:0;color:#999;font-size:13px}.profile-view .status-section{margin:-8px 0 0}.profile-view .status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:16px;font-size:13px;font-weight:600}.profile-view .status-badge.active{background:#d4edda;color:#155724}.profile-view .status-badge.inactive{background:#f8d7da;color:#721c24}.profile-view .info-section{display:flex;flex-direction:column;gap:12px}.profile-view .info-section h4{margin:0;font-size:16px;font-weight:600;color:#333;padding-bottom:8px;border-bottom:2px solid #e0e0e0}.profile-view .info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:16px;gap:16px}.profile-view .info-item label{display:block;font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.profile-view .info-item p{margin:0;font-size:14px;color:#333}.profile-view .info-item .role-badge{display:inline-block;padding:4px 10px;background:#3273dc;color:#fff;border-radius:12px;font-size:12px;font-weight:600}.profile-view .info-item .monospace{font-family:Courier New,monospace;font-size:12px;color:#666;background:#f5f5f5;padding:4px 8px;border-radius:4px}.profile-view .edit-button-container{display:flex;justify-content:flex-end;padding-top:8px}.profile-view .edit-button{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:#3273dc;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.profile-view .edit-button:hover{background:#2366d1;transform:translateY(-1px);box-shadow:0 2px 6px rgba(50,115,220,.3)}.profile-edit{display:flex;flex-direction:column;gap:20px}.profile-edit .form-header h3{margin:0 0 4px;font-size:20px;font-weight:600;color:#333}.profile-edit .help-text{margin:0;font-size:13px;color:#999}.profile-edit .form-group{display:flex;flex-direction:column;gap:6px}.profile-edit .form-group label{font-size:14px;font-weight:600;color:#333}.profile-edit .form-group input[type=email],.profile-edit .form-group input[type=tel],.profile-edit .form-group input[type=text]{padding:10px 12px;border:1px solid #dbdbdb;border-radius:4px;font-size:14px;transition:all .2s ease}.profile-edit .form-group input:focus{outline:none;border-color:#3273dc;box-shadow:0 0 0 3px rgba(50,115,220,.1)}.profile-edit .form-group input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.profile-edit .checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.profile-edit .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.profile-edit .checkbox-label input[type=checkbox]:disabled{cursor:not-allowed}.profile-edit .form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:12px;border-top:1px solid #e0e0e0}.profile-edit .cancel-button{padding:10px 20px;background:#fff;border:1px solid #dbdbdb;color:#363636;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.profile-edit .cancel-button:hover:not(:disabled){border-color:#b5b5b5;background:#f5f5f5}.profile-edit .save-button{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;background:#48c774;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.profile-edit .save-button:hover:not(:disabled){background:#3abb67;transform:translateY(-1px);box-shadow:0 2px 6px rgba(72,199,116,.3)}.profile-edit .save-button:disabled{background:#dbdbdb;cursor:not-allowed;opacity:.6}.profile-edit .spinner{animation:spin 1s linear infinite}.activity-log{display:flex;flex-direction:column;gap:20px}.activity-log .activity-header h3{margin:0 0 4px;font-size:20px;font-weight:600;color:#333}.activity-log .subtitle{margin:0;font-size:13px;color:#999}.activity-log .activity-timeline{display:flex;flex-direction:column;gap:16px}.activity-log .activity-item{display:flex;gap:12px;padding:12px;border-radius:4px;transition:background .2s ease}.activity-log .activity-item:hover{background:#f9f9f9}.activity-log .activity-icon{font-size:24px;flex-shrink:0}.activity-log .activity-content{flex:1 1}.activity-log .activity-description{font-size:14px;color:#333;margin-bottom:4px}.activity-log .activity-time{font-size:12px;color:#999}.activity-log .activity-footer{display:flex;justify-content:center;padding-top:12px;border-top:1px solid #e0e0e0}.activity-log .view-all-button{padding:8px 16px;background:none;border:1px solid #3273dc;color:#3273dc;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.activity-log .view-all-button:hover{background:#3273dc;color:#fff}.activity-log.empty,.activity-log.error,.activity-log.loading{min-height:200px;display:flex;align-items:center;justify-content:center}.activity-log .empty-state,.activity-log .error-message,.activity-log .loading-spinner{text-align:center}.activity-log .empty-state .icon,.activity-log .error-message .icon,.activity-log .loading-spinner .spinner{font-size:48px;display:block;margin-bottom:12px}.activity-log .retry-button{margin-top:12px;padding:8px 16px;background:#3273dc;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px}.roles-tab h3{margin:0 0 16px;font-size:20px;font-weight:600;color:#333}.roles-tab .roles-list{display:flex;flex-direction:column;gap:12px}.roles-tab .role-item{padding:16px;background:#f9f9f9;border-radius:6px;border-left:4px solid #3273dc}.roles-tab .role-badge{display:inline-block;padding:4px 10px;background:#3273dc;color:#fff;border-radius:12px;font-size:13px;font-weight:600;margin-bottom:8px}.roles-tab .role-details{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:#666}.roles-tab .role-details .status{padding:2px 8px;border-radius:12px;font-weight:600}.roles-tab .role-details .status.active{background:#d4edda;color:#155724}.roles-tab .role-details .status.inactive{background:#f8d7da;color:#721c24}.roles-tab .empty-state{text-align:center;color:#999;padding:40px 0}.user-profile-modal .modal-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end}.user-profile-modal .close-footer-button{padding:10px 24px;background:#3273dc;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.user-profile-modal .close-footer-button:hover{background:#2366d1}@media (max-width:768px){.user-profile-modal{margin:10px;max-height:95vh}.user-profile-modal .modal-body,.user-profile-modal .modal-footer,.user-profile-modal .modal-header{padding:16px}.profile-view .profile-header{flex-direction:column;text-align:center}.profile-view .info-grid{grid-template-columns:1fr}.user-profile-modal .modal-tabs{padding:0 16px}.user-profile-modal .tab{padding:12px;font-size:13px}.user-profile-modal .tab-icon{display:none}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}