.notification-item{border:1px solid #ddd;border-radius:8px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s}.notification-item:hover{border-color:#06c;box-shadow:0 2px 8px rgba(0,102,204,.1)}.notification-item-unread{background-color:#f0f8ff;border-left:4px solid #06c}.notification-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.notification-item-meta{display:flex;gap:8px;align-items:center}.notification-item-priority{font-size:11px;font-weight:700;text-transform:uppercase;padding:3px 8px;border-radius:4px}.notification-item-priority-critical{background-color:#dc3545;color:#fff}.notification-item-priority-high{background-color:#fd7e14;color:#fff}.notification-item-priority-medium{background-color:#0d6efd;color:#fff}.notification-item-priority-low{background-color:#6c757d;color:#fff}.notification-item-type{font-size:13px;color:#666;text-transform:capitalize}.notification-item-actions{display:flex;gap:4px}.notification-item-action-btn{background:none;border:none;cursor:pointer;padding:4px 8px;font-size:18px;color:#666;transition:color .2s}.notification-item-action-btn:hover{color:#06c}.notification-item-delete:hover{color:#dc3545}.notification-item-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#333}.notification-item-message{margin:0 0 12px;font-size:14px;color:#666;line-height:1.5}.notification-item-footer{display:flex;justify-content:space-between;align-items:center}.notification-item-time{font-size:13px;color:#999}.notification-item-link{font-size:13px;color:#06c;font-weight:500}.notification-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.notification-modal-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.2);max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.notification-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e8eaed}.notification-modal-title{font-size:1.5rem;font-weight:600;color:#1a202c;margin:0}.notification-modal-header-actions{display:flex;align-items:center;gap:1rem}.notification-modal-mark-all-btn{background:#2563eb;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.notification-modal-mark-all-btn:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px)}.notification-modal-mark-all-btn:disabled{opacity:.5;cursor:not-allowed}.notification-modal-close-btn{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s ease;color:#64748b}.notification-modal-close-btn:hover{background:#f1f5f9;color:#1a202c}.notification-modal-filters{display:flex;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid #e8eaed;background:#f8fafc;flex-wrap:wrap}.notification-modal-filter-group{display:flex;align-items:center;gap:.5rem}.notification-modal-filter-group label{font-size:.875rem;font-weight:500;color:#475569}.notification-modal-select{padding:.5rem .75rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.875rem;background:#fff;color:#1a202c;cursor:pointer;transition:all .2s ease}.notification-modal-select:hover{border-color:#94a3b8}.notification-modal-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}.notification-modal-content{flex:1 1;overflow-y:auto;padding:1.5rem}.notification-modal-list{display:flex;flex-direction:column;gap:1rem}.notification-modal-empty,.notification-modal-error,.notification-modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center}.notification-modal-loading .loader{border:3px solid #f3f4f6;border-top-color:#2563eb;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:1rem}.notification-modal-error p,.notification-modal-loading p{color:#64748b;font-size:.875rem}.notification-modal-empty{color:#94a3b8}.notification-modal-empty svg{margin-bottom:1rem;opacity:.5}.notification-modal-empty p{font-size:1rem;font-weight:500;color:#64748b;margin:.5rem 0}.notification-modal-empty-subtitle{font-size:.875rem;color:#94a3b8}@media (max-width:768px){.notification-modal-overlay{padding:0}.notification-modal-container{max-width:100%;max-height:100vh;border-radius:0}.notification-modal-header{padding:1rem}.notification-modal-title{font-size:1.25rem}.notification-modal-header-actions{gap:.5rem}.notification-modal-mark-all-btn{font-size:.75rem;padding:.4rem .75rem}.notification-modal-filters{padding:.75rem 1rem}.notification-modal-filter-group,.notification-modal-filters{flex-direction:column;align-items:stretch}.notification-modal-select{width:100%}.notification-modal-content{padding:1rem}}.notification-bell-container{position:relative;display:inline-block;padding:8px;border-radius:4px}.notification-bell-button{position:relative;background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;color:#333;transition:color .2s}.notification-bell-button:hover{color:#06c}.notification-bell-badge{position:absolute;top:0;right:0;background-color:#dc3545;color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:700;min-width:18px;text-align:center}.notification-bell-dropdown{position:absolute;top:100%;right:0;width:400px;max-height:600px;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:1000;margin-top:8px;overflow:hidden;display:flex;flex-direction:column}.notification-bell-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #eee}.notification-bell-header h3{margin:0;font-size:18px;font-weight:600}.notification-bell-view-all-link{color:#06c;background:none;border:none;text-decoration:none;font-size:14px;cursor:pointer;padding:0}.notification-bell-view-all-link:hover{text-decoration:underline}.notification-bell-list{flex:1 1;overflow-y:auto;max-height:400px}.notification-bell-empty,.notification-bell-loading{padding:32px;text-align:center;color:#666}.notification-bell-item{padding:16px;border-bottom:1px solid #eee;cursor:pointer;transition:background-color .2s}.notification-bell-item:hover{background-color:#f8f9fa}.notification-bell-item:last-child{border-bottom:none}.notification-bell-item-header{display:flex;gap:8px;margin-bottom:8px}.notification-bell-priority{font-size:11px;font-weight:700;text-transform:uppercase;padding:2px 6px;border-radius:3px}.notification-bell-priority-critical{background-color:#dc3545;color:#fff}.notification-bell-priority-high{background-color:#fd7e14;color:#fff}.notification-bell-priority-medium{background-color:#0d6efd;color:#fff}.notification-bell-priority-low{background-color:#6c757d;color:#fff}.notification-bell-type{font-size:12px;color:#666;text-transform:capitalize}.notification-bell-item h4{margin:0 0 4px;font-size:14px;font-weight:600;color:#333}.notification-bell-item p{margin:0 0 8px;font-size:13px;color:#666;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-bell-time{font-size:12px;color:#999}.notification-bell-footer{padding:12px 16px;border-top:1px solid #eee;text-align:center}.notification-bell-view-all-btn{color:#06c;background:none;border:none;text-decoration:none;font-size:14px;font-weight:500;cursor:pointer;width:100%;padding:0}.notification-bell-view-all-btn:hover{text-decoration:underline}.notification-bell-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;z-index:999}@media (max-width:768px){.notification-bell-dropdown{width:320px;max-height:500px}.notification-bell-list{max-height:350px}}.report-generator{background-color:#fff;border:1px solid #ddd;border-radius:8px;padding:24px;margin-bottom:24px}.report-generator h2{margin:0 0 24px;font-size:24px;font-weight:600}.report-generator-field{margin-bottom:20px}.report-generator-field label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:#333}.report-generator-field input[type=date],.report-generator-field input[type=text],.report-generator-field select,.report-generator-field textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit}.report-generator-field textarea{resize:vertical}.report-generator-hint{margin:8px 0 0;font-size:13px;color:#666;font-style:italic}.report-generator-radio-group{display:flex;gap:16px}.report-generator-radio-group label{display:flex;align-items:center;gap:6px;cursor:pointer}.report-generator-date-range{display:flex;align-items:center;gap:12px}.report-generator-date-range input{flex:1 1}.report-generator-message{padding:12px 16px;border-radius:6px;margin-bottom:16px;font-size:14px}.report-generator-message-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.report-generator-message-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.report-generator-submit{width:100%;padding:12px 24px;background-color:#06c;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.report-generator-submit:hover:not(:disabled){background-color:#0052a3}.report-generator-submit:disabled{background-color:#ccc;cursor:not-allowed}.report-item{border:1px solid #ddd;border-radius:8px;padding:20px;margin-bottom:16px}.report-item-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px}.report-item h3{margin:0;font-size:18px;font-weight:600}.report-item-type{margin:4px 0 0;font-size:13px;color:#666;text-transform:capitalize}.report-item-status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;color:#fff}.report-item-description{margin:0 0 12px;color:#666;font-size:14px}.report-item-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px;font-size:13px;color:#666}.report-item-error{background-color:#f8d7da;color:#721c24;padding:8px 12px;border-radius:4px;margin-bottom:12px;font-size:13px}.report-item-actions{display:flex;gap:8px}.report-item-btn{padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.report-item-download{background-color:#06c;color:#fff}.report-item-download:hover{background-color:#0052a3}.report-item-delete{background-color:#dc3545;color:#fff}.report-item-delete:hover{background-color:#c82333}.report-list{max-width:900px;margin:0 auto;padding:24px;border-radius:8px}.report-list h2{margin:0 0 24px;font-size:28px;font-weight:600}.report-list-filters{display:flex;gap:12px;margin-bottom:24px;padding:16px;background-color:#fff;border-radius:8px;border:1px solid #ddd}.report-list-filters select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;cursor:pointer}.report-list-empty,.report-list-error,.report-list-loading{padding:48px;text-align:center;background-color:#fff;border-radius:8px;border:1px solid #ddd}.portal-layout{min-height:100vh;background-color:#f8fafc;color:#0f172a}.portal-layout__container{display:flex;min-height:calc(100vh - 120px)}.portal-layout__content{flex:1 1;padding:2rem;overflow-y:auto}.portal-header{background-color:#fff;border-bottom:1px solid #e2e8f0;position:-webkit-sticky;position:sticky;top:64px;z-index:20;box-shadow:0 1px 3px rgba(0,0,0,.1)}.portal-header__top{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;gap:1rem}.portal-header__title{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0}.portal-header__search{flex:1 1;max-width:500px}.portal-header__search-trigger{width:100%;display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;font-size:.875rem;cursor:pointer;transition:all .15s ease}.portal-header__search-trigger:hover{background-color:#fff;border-color:#0ea5e9}.portal-header__actions{display:flex;align-items:center;gap:1rem}.portal-header__user-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:transparent;border:1px solid #e2e8f0;border-radius:8px;color:#0f172a;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.portal-header__user-button:hover{background-color:#f8fafc;border-color:#0ea5e9}.portal-context-banner{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;padding:.75rem 1.5rem;position:-webkit-sticky;position:sticky;top:121px;z-index:19}.portal-context-banner__content{display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.portal-context-banner__district,.portal-context-banner__item,.portal-context-banner__role,.portal-context-banner__schools{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.portal-context-banner__label{color:#64748b;font-weight:500}.portal-context-banner__selector,.portal-context-banner__value{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#0f172a;font-weight:600;cursor:pointer;transition:all .15s ease}.portal-context-banner__selector:hover,.portal-context-banner__value:hover{border-color:#0ea5e9}.portal-context-banner__school-radios{display:flex;align-items:center;gap:1rem}.portal-context-banner__radio{display:flex;align-items:center;gap:.375rem;cursor:pointer;color:#64748b;font-size:.875rem}.portal-context-banner__radio input{cursor:pointer}.portal-context-banner__radio input:checked+span,.portal-context-banner__role-name{color:#0f172a;font-weight:600}.portal-nav{width:280px;background-color:#fff;border-right:1px solid #e2e8f0;padding:1.5rem 0;flex-shrink:0;position:-webkit-sticky;position:sticky;top:64px;align-self:flex-start;max-height:calc(100vh - 64px);overflow-y:auto}.portal-nav__header{padding:0 1.5rem 1.5rem;border-bottom:1px solid #e2e8f0;margin-bottom:1rem}.portal-nav__title{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.portal-nav__subtitle{font-size:.8125rem;color:#64748b;margin:0}.portal-nav__list{list-style:none;margin:0;padding:0}.portal-nav__item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1.5rem;background-color:transparent;border:none;border-left:3px solid transparent;color:#64748b;font-size:.875rem;font-weight:500;text-align:left;cursor:pointer;transition:all .15s ease}.portal-nav__item:hover{background-color:#f8fafc;color:#0f172a}.portal-nav__item--active{background-color:#eff6ff;border-left-color:#0ea5e9;color:#0f172a;font-weight:600}.portal-nav__icon{display:flex;align-items:center;color:inherit}.portal-nav__label{flex:1 1}.portal-nav__badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background-color:#ef4444;border-radius:10px;color:#fff;font-size:.75rem;font-weight:600}.portal-search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(15,23,42,.5);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:4rem 1rem}.portal-search-modal{width:100%;max-width:650px;background-color:#fff;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,.1);max-height:80vh;display:flex;flex-direction:column}.portal-search-modal__header{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-bottom:1px solid #e2e8f0}.portal-search-modal__input-wrapper{flex:1 1;display:flex;align-items:center;gap:.75rem}.portal-search-modal__icon{color:#64748b}.portal-search-modal__input{flex:1 1;border:none;outline:none;font-size:1rem;color:#0f172a}.portal-search-modal__input::placeholder{color:#94a3b8}.portal-search-modal__close{background-color:transparent;border:none;color:#64748b;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .15s ease}.portal-search-modal__close:hover{background-color:#f8fafc;color:#0f172a}.portal-search-modal__results{flex:1 1;overflow-y:auto;padding:1rem}.portal-notifications{position:relative}.portal-notifications__button{position:relative;padding:.5rem;background-color:transparent;border:none;color:#64748b;cursor:pointer;border-radius:6px;transition:all .15s ease}.portal-notifications__button:hover{background-color:#f8fafc;color:#0f172a}.portal-notifications__badge{position:absolute;top:4px;right:4px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;background-color:#ef4444;border:2px solid #fff;border-radius:9px;color:#fff;font-size:.6875rem;font-weight:700}.portal-notifications__overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:150}.portal-notifications__dropdown{position:absolute;top:calc(100% + .5rem);right:0;width:380px;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1);z-index:160;max-height:500px;display:flex;flex-direction:column}.portal-notifications__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0}.portal-notifications__header h3{font-size:1rem;font-weight:600;color:#0f172a;margin:0}.portal-notifications__list{flex:1 1;overflow-y:auto}.portal-notifications__item{padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0;cursor:pointer;transition:background-color .15s ease}.portal-notifications__item:hover{background-color:#f8fafc}.portal-notifications__item--unread{background-color:#eff6ff}@media (max-width:768px){.portal-layout__container{flex-direction:column}.portal-nav{width:100%;border-right:none;border-bottom:1px solid #e2e8f0}.portal-layout__content{padding:1rem}.portal-header__top{flex-wrap:wrap}.portal-header__search{order:3;flex-basis:100%;max-width:100%}.portal-context-banner__content{flex-direction:column;align-items:flex-start;gap:.75rem}}@media (min-width:769px) and (max-width:1024px){.portal-nav{width:240px}.portal-layout__content{padding:1.5rem}}.portal-denied,.portal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;color:#64748b}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#0ea5e9;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}