.communications-page{max-width:1200px;margin:0 auto;padding:2rem}.communications-page__header{margin-bottom:2rem}.communications-page__title{font-size:2rem;font-weight:700;color:#2c3e50;margin-bottom:.5rem}.communications-page__subtitle{font-size:1rem;color:#7f8c8d}.communications-page__tabs{display:flex;gap:1rem;border-bottom:2px solid #ecf0f1;margin-bottom:2rem}.communications-page__tab{padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#7f8c8d;transition:all .3s ease}.communications-page__tab:hover{color:#3498db;background-color:#f8f9fa}.communications-page__tab--active{color:#2c3e50;border-bottom-color:#3498db;font-weight:700}.communications-page__content{min-height:500px}.communications-page__tab-panel{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.temp-placeholder{padding:3rem;text-align:center;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.temp-placeholder h2{font-size:1.5rem;color:#2c3e50;margin-bottom:1rem}.temp-placeholder p{font-size:1rem;color:#7f8c8d;margin-bottom:.5rem}.temp-status{font-weight:600;color:#f39c12;margin-top:1rem}.communications-page__dev-notes{margin-top:3rem;padding:1.5rem;background:#fff3cd;border-radius:8px;border-left:4px solid #ffc107}.communications-page__dev-notes summary{cursor:pointer;font-weight:600;color:#856404}.communications-page__dev-notes ul{margin-top:1rem;padding-left:1.5rem}.communications-page__dev-notes li{margin-bottom:.5rem;color:#856404}.temp-completion-marker{background-color:rgba(0,255,0,.1);border:2px solid rgba(0,200,0,.5);border-radius:8px;padding:1rem;margin-bottom:1rem}.temp-completion-marker__header{color:#28a745;font-weight:700;font-size:1.1rem;margin-bottom:.5rem}@media (max-width:768px){.communications-page{padding:1rem}.communications-page__title{font-size:1.5rem}.communications-page__tabs{flex-direction:column;gap:0}.communications-page__tab{border-bottom:1px solid #ecf0f1;border-left:3px solid transparent;padding:1rem}.communications-page__tab--active{border-left-color:#3498db;border-bottom-color:transparent;background-color:#f8f9fa}}.inbox{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);padding:1.5rem}.inbox__filters{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.inbox__filter-btn{padding:.5rem 1rem;background:#fff;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;transition:all .2s ease}.inbox__filter-btn:hover{background:#f8f9fa}.inbox__filter-btn--active{background:#3498db;color:#fff;border-color:#3498db}.inbox__item{padding:1rem;border:1px solid #ecf0f1;border-radius:6px;margin-bottom:1rem;cursor:pointer;transition:all .2s ease}.inbox__item:hover{box-shadow:0 2px 8px rgba(0,0,0,.1);border-color:#3498db}.inbox__item--message{border-left:4px solid #3498db}.inbox__item--announcement{border-left:4px solid #f39c12}.inbox__item--unread{background:#f8f9fa;font-weight:600}.composer{background:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);padding:2rem}.composer__field{margin-bottom:1.5rem}.composer__label{display:block;font-weight:600;color:#2c3e50;margin-bottom:.5rem}.composer__input,.composer__textarea{width:100%;padding:.75rem;border:1px solid #dee2e6;border-radius:4px;font-size:1rem;font-family:inherit}.composer__textarea{min-height:150px;resize:vertical}.composer__btn{padding:.75rem 1.5rem;background:#3498db;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.composer__btn:hover{background:#2980b9}.composer__btn:disabled{background:#95a5a6;cursor:not-allowed}.composer__btn--secondary{background:#fff;color:#3498db;border:2px solid #3498db}.composer__btn--secondary:hover{background:#f0f8ff}.composer__btn--primary{background:#3498db;color:#fff}.composer__description{color:#7f8c8d;margin-bottom:1.5rem}.composer__recipient-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#e3f2fd;border:1px solid #90caf9;border-radius:20px;font-size:.9rem}.composer__recipient-chip__name{font-weight:600;color:#1976d2}.composer__recipient-chip__role{color:#64b5f6;font-size:.85rem}.composer__recipient-chip__remove{background:#1976d2;color:#fff;border:none;border-radius:50%;width:20px;height:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;transition:background .2s}.composer__recipient-chip__remove:hover{background:#0d47a1}.composer__help-text{font-size:.85rem;color:#95a5a6;margin-top:.5rem}.composer__char-count{font-size:.75rem;color:#95a5a6;text-align:right;margin-top:.25rem}.composer__error{background:#ffebee;border-left:4px solid #f44336;color:#c62828}.composer__error,.composer__success{padding:1rem;border-radius:4px;margin-bottom:1rem}.composer__success{background:#e8f5e9;border-left:4px solid #4caf50;color:#2e7d32}.composer__actions{display:flex;flex-direction:column;gap:.5rem}.composer__dev-notes{margin-top:2rem;padding:1rem;background:#fff3cd;border-left:4px solid #ffc107;border-radius:4px}.composer__dev-notes summary{cursor:pointer;font-weight:600;color:#856404}.composer__dev-notes ul{margin-top:1rem;padding-left:1.5rem}.composer__dev-notes li{margin-bottom:.5rem;color:#856404;font-size:.9rem}.composer__group-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;border:1px solid #dee2e6;border-radius:4px;padding:1rem;background:#f8f9fa}.composer__group-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fff;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:all .2s ease}.composer__group-item:hover{border-color:#3498db;background:#f0f8ff}.composer__group-item--selected{border-color:#3498db;background:#e3f2fd}.composer__group-item input[type=checkbox]{cursor:pointer}.composer__group-label{flex:1 1;font-weight:600;color:#2c3e50}.composer__group-count{color:#7f8c8d;font-size:.85rem}.composer__selected-summary{margin-top:1rem;padding:.75rem;background:#e3f2fd;border-left:4px solid #3498db;border-radius:4px;font-weight:600;color:#1976d2}.inbox__empty,.inbox__loading{padding:3rem;text-align:center;color:#7f8c8d;font-size:1.1rem}.inbox__items{display:flex;flex-direction:column;gap:1rem}.inbox__item-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.inbox__item-icon{font-size:1.2rem}.inbox__item-sender{font-weight:600;color:#2c3e50;flex:1 1}.inbox__item-timestamp{font-size:.85rem;color:#95a5a6}.inbox__item-unread-badge{background:#3498db;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.inbox__item-subject{font-weight:600;color:#2c3e50;margin-bottom:.5rem;font-size:1rem}.inbox__item-preview{color:#7f8c8d;font-size:.9rem;line-height:1.4}.inbox__pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding-top:1rem;border-top:1px solid #ecf0f1}.inbox__pagination-btn{padding:.5rem 1rem;background:#fff;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;transition:all .2s ease}.inbox__pagination-btn:hover:not(:disabled){background:#3498db;color:#fff;border-color:#3498db}.inbox__pagination-btn:disabled{opacity:.5;cursor:not-allowed}.inbox__pagination-info{font-weight:600;color:#2c3e50}.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)}}.temp-completion-marker{background-color:rgba(34,197,94,.05)!important;border:2px solid rgba(34,197,94,.3)!important;position:relative}.temp-completion-marker:after{content:"[TEMP COMPLETION MARKER]";position:absolute;top:4px;right:4px;background:#22c55e;color:#fff;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;z-index:1000;pointer-events:none}.temp-completion-marker.dark-bg:after{background:#22c55e;color:#fff}