.notif-bell-wrapper{position:relative;display:inline-flex;align-items:center}.notif-bell-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:#ffffffd9;transition:background-color .15s,color .15s;padding:0;flex-shrink:0}.notif-bell-btn:hover{background-color:#ffffff1f;color:#fff}.notif-bell-btn:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:2px}.notif-bell-icon{width:1.25rem;height:1.25rem}.notif-bell-badge{position:absolute;top:.125rem;right:.125rem;min-width:1.125rem;height:1.125rem;padding:0 .25rem;background-color:var(--color-error, #dc2626);color:#fff;font-size:.6875rem;font-weight:700;line-height:1.125rem;text-align:center;border-radius:9999px;pointer-events:none;white-space:nowrap}.notif-unread-dot{display:inline-block;width:.5rem;height:.5rem;border-radius:50%;background-color:var(--color-primary, #1d4ed8);flex-shrink:0;margin-top:.375rem}.notif-dropdown{position:absolute;top:calc(100% + .5rem);right:0;width:360px;max-width:calc(100vw - 1rem);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:150;display:flex;flex-direction:column;overflow:hidden;animation:notif-dropdown-in .15s ease-out}@keyframes notif-dropdown-in{0%{opacity:0;transform:translateY(-.375rem)}to{opacity:1;transform:translateY(0)}}.notif-dropdown__header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-bottom:1px solid var(--color-border)}.notif-dropdown__title{font-size:.9375rem;font-weight:700;color:var(--color-text)}.notif-dropdown__unread-count{font-size:.8125rem;font-weight:600;color:var(--color-primary)}.notif-dropdown__body{flex:1;overflow-y:auto;max-height:360px}.notif-dropdown__loading,.notif-dropdown__empty{padding:2rem 1rem;text-align:center;color:var(--color-text-muted);font-size:.9375rem}.notif-dropdown__list{list-style:none;margin:0;padding:0}.notif-dropdown__item{display:flex;align-items:flex-start;gap:.625rem;width:100%;padding:.875rem 1rem;background:none;border:none;border-bottom:1px solid var(--color-border);cursor:pointer;text-align:left;transition:background-color .1s}.notif-dropdown__item:last-child{border-bottom:none}.notif-dropdown__item:hover{background-color:var(--color-bg, #f9fafb)}.notif-dropdown__item--unread{background-color:#eff6ff}.notif-dropdown__item--unread:hover{background-color:#dbeafe}.notif-dropdown__item-content{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.notif-dropdown__item-title{font-size:.875rem;font-weight:600;color:var(--color-text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-dropdown__item-body{font-size:.8125rem;color:var(--color-text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-dropdown__item-time{font-size:.75rem;color:var(--color-text-muted)}.notif-dropdown__footer{border-top:1px solid var(--color-border);padding:.625rem 1rem;text-align:center}.notif-dropdown__see-all{display:inline-block;font-size:.875rem;font-weight:600;color:var(--color-primary);background:none;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.notif-dropdown__see-all:hover{color:var(--color-primary-dark, #1e40af);background-color:#eff6ff}.notifications-page{max-width:800px}.notifications-page__header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.notifications-page__heading{font-size:1.75rem;margin:0}.notifications-page__mark-all{white-space:nowrap;flex-shrink:0}.notifications-page__error{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.notifications-page__error-dismiss{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--color-error);padding:0 .25rem;line-height:1;flex-shrink:0}.notifications-loading{display:flex;justify-content:center;padding:3rem 1rem}.notifications-empty{text-align:center;padding:3rem 1rem;color:var(--color-text-muted);font-size:1rem}.notifications-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-surface);box-shadow:var(--shadow-sm)}.notification-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);transition:background-color .1s}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:var(--color-bg, #f9fafb)}.notification-item--unread{background-color:#eff6ff}.notification-item--unread:hover{background-color:#dbeafe}.notification-item--archived{opacity:.7}.notification-item__left{display:flex;align-items:flex-start;gap:.75rem;flex:1;min-width:0}.notification-item__content{display:flex;flex-direction:column;gap:.25rem;min-width:0}.notification-item__module{display:inline-block;font-size:.75rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.125rem}.notification-item__title{font-size:.9375rem;font-weight:600;color:var(--color-text);margin:0;line-height:1.35}.notification-item__body{font-size:.875rem;color:var(--color-text-muted);margin:0;line-height:1.5}.notification-item__time{font-size:.8125rem;color:var(--color-text-muted)}.notification-item__actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.notification-item__action-btn{font-size:.8125rem;font-weight:600;color:var(--color-primary);background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.25rem .625rem;cursor:pointer;transition:background-color .15s,color .15s,border-color .15s;white-space:nowrap}.notification-item__action-btn:hover:not(:disabled){background-color:#eff6ff;border-color:var(--color-primary)}.notification-item__action-btn:disabled{opacity:.5;cursor:not-allowed}.notification-item__action-btn--muted{color:var(--color-text-muted)}.notification-item__action-btn--muted:hover:not(:disabled){background-color:var(--color-bg, #f9fafb);color:var(--color-text);border-color:var(--color-text-muted)}@media(max-width:768px){.notif-dropdown{position:fixed;top:var(--header-height, 60px);left:0;right:0;width:100%;max-width:100%;border-radius:0;border-left:none;border-right:none;border-top:none}.notifications-page__header{flex-direction:column;align-items:flex-start}.notification-item{flex-direction:column;gap:.75rem}.notification-item__actions{align-self:flex-end}}@media(max-width:480px){.notifications-page{max-width:100%}.notif-dropdown__body{max-height:calc(100vh - var(--header-height, 60px) - 6rem)}.notification-item__action-btn{font-size:.75rem;padding:.1875rem .5rem}}.update-banner{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:.75rem;padding:.625rem 1.25rem;background:var(--color-primary);color:#fff;border-radius:.5rem;box-shadow:var(--shadow-lg, 0 4px 12px rgba(0, 0, 0, .25));font-size:.875rem;animation:slide-up .3s ease-out}.update-banner-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);padding:.25rem .75rem;border-radius:.25rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:background .15s}.update-banner-btn:hover{background:#ffffff59}@keyframes slide-up{0%{opacity:0;transform:translate(-50%) translateY(1rem)}to{opacity:1;transform:translate(-50%) translateY(0)}}.error-fallback{display:block}.error-fallback--root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background-color:var(--color-bg)}.error-fallback__card{background-color:var(--color-surface);border-left:4px solid #f59e0b;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:1.5rem;width:100%}.error-fallback{margin:1rem}.error-fallback--root{margin:0}.error-fallback--root .error-fallback__card{max-width:480px}.error-fallback__icon-row{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.error-fallback__icon{width:20px;height:20px;flex-shrink:0;fill:#f59e0b}.error-fallback__heading{font-family:var(--font-heading);font-size:1.125rem;font-weight:700;color:var(--color-text);margin:0;line-height:1.3}.error-fallback__body{color:var(--color-text-muted);font-size:.9375rem;line-height:1.5;margin-bottom:1.25rem}.error-fallback__actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.error-fallback__reload,.error-fallback__home{width:100%;padding:.75rem 1.25rem}.error-fallback__report{display:inline-block;background:none;border:none;padding:0;margin-bottom:1rem;font:inherit;font-size:.9375rem;color:var(--color-primary);text-decoration:underline;cursor:pointer}.error-fallback__report:hover{color:var(--color-primary-dark)}.error-fallback__report[aria-disabled=true]{color:var(--color-text-muted);cursor:default;text-decoration:none}.error-fallback__ref{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--color-text-muted)}.error-fallback__ref-label code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.75rem;background:#0000000a;padding:.125rem .375rem;border-radius:var(--radius-sm);color:var(--color-text)}.error-fallback__ref-copy{display:inline-flex;align-items:center;gap:.25rem;background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.25rem .5rem;font-size:.75rem;cursor:pointer;color:var(--color-text)}.error-fallback__ref-copy:hover{background-color:#00000008}.error-fallback__ref-copy-text{font-size:.75rem}@media(min-width:640px){.error-fallback{max-width:480px;margin:2rem auto}.error-fallback__icon{width:24px;height:24px}.error-fallback__heading{font-size:1.25rem}.error-fallback__actions{flex-direction:row}.error-fallback__reload,.error-fallback__home{width:auto;padding:.625rem 1.25rem}}@media(min-width:1024px){.error-fallback{max-width:560px;margin:4rem auto}}.field-error{margin-top:.25rem;color:var(--color-error);font-size:.875rem;line-height:1.4}@media(max-width:640px){.field-error{font-size:.8125rem}}.error-banner{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:.75rem;padding:.875rem 1rem;margin-bottom:1rem;border-radius:var(--radius-md);border:1px solid var(--color-error);background-color:var(--color-error-bg);color:var(--color-text);line-height:1.5;overflow-wrap:break-word}.error-banner--warning{border-color:#d97706;background-color:#fffbeb}.error-banner--info{border-color:var(--color-accent-dark);background-color:#eff6ff}.error-banner__icon{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;font-size:1rem;font-weight:700;color:var(--color-error);line-height:1}.error-banner--warning .error-banner__icon{color:#d97706}.error-banner--info .error-banner__icon{color:var(--color-accent-dark)}.error-banner__message{margin:0;font-size:.9375rem;color:var(--color-text)}.error-banner__action{grid-column:2 / -1;justify-self:end;margin-top:.25rem;padding:.5rem .75rem;background:transparent;border:1px solid var(--color-error);color:var(--color-error);border-radius:var(--radius-sm);font:inherit;font-weight:600;cursor:pointer;min-height:36px}.error-banner__action:hover,.error-banner__action:focus-visible{background-color:var(--color-error);color:#fff;outline:none;box-shadow:var(--focus-ring)}.error-banner__dismiss{align-self:start;padding:0;width:32px;height:32px;background:transparent;border:none;color:var(--color-text-muted);font-size:1.25rem;line-height:1;cursor:pointer;border-radius:var(--radius-sm)}.error-banner__dismiss:hover{color:var(--color-text)}.error-banner__dismiss:focus-visible{outline:none;box-shadow:var(--focus-ring)}@media(max-width:640px){.error-banner{grid-template-columns:auto 1fr}.error-banner__dismiss{grid-column:2;justify-self:end}.error-banner__action{grid-column:1 / -1;justify-self:stretch;text-align:center;min-height:44px}}.toast-region{position:fixed;top:calc(var(--header-height) + 8px);right:16px;z-index:1000;display:flex;flex-direction:column;gap:.5rem;width:360px;max-width:calc(100vw - 32px);pointer-events:none}.toast{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:.5rem;padding:.75rem .875rem;background-color:var(--color-surface);color:var(--color-text);border-radius:var(--radius-md);box-shadow:var(--shadow-md);border-left:4px solid var(--color-primary);pointer-events:auto;animation:toast-slide-in .2s ease-out;overflow-wrap:break-word}.toast--success{border-left-color:var(--color-success);background-color:var(--color-success-bg)}.toast--info{border-left-color:var(--color-accent-dark);background-color:#eff6ff}.toast--warning{border-left-color:#d97706;background-color:#fffbeb}.toast--error{border-left-color:var(--color-error);background-color:var(--color-error-bg)}.toast__icon{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;font-size:1rem;font-weight:700;line-height:1}.toast--success .toast__icon{color:var(--color-success)}.toast--info .toast__icon{color:var(--color-accent-dark)}.toast--warning .toast__icon{color:#d97706}.toast--error .toast__icon{color:var(--color-error)}.toast__message{margin:0;font-size:.9375rem;line-height:1.4}.toast__action{padding:.375rem .625rem;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);font:inherit;font-weight:600;font-size:.875rem;cursor:pointer;min-height:32px}.toast__action:hover,.toast__action:focus-visible{background-color:var(--color-primary);color:#fff;outline:none;box-shadow:var(--focus-ring)}.toast__dismiss{width:32px;height:32px;padding:0;background:transparent;border:none;color:var(--color-text-muted);font-size:1.25rem;line-height:1;cursor:pointer;border-radius:var(--radius-sm)}.toast__dismiss:hover{color:var(--color-text)}.toast__dismiss:focus-visible{outline:none;box-shadow:var(--focus-ring)}@keyframes toast-slide-in{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:1023px){.toast-region{left:50%;right:auto;transform:translate(-50%);width:calc(100% - 48px);max-width:420px}}@media(max-width:640px){.toast-region{left:16px;right:16px;transform:none;width:auto;max-width:none}.toast__dismiss{width:44px;height:44px}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem 1rem;background-color:var(--color-bg)}.auth-card{width:100%;max-width:420px;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem 2rem}.auth-title{font-size:1.5rem;margin-bottom:1.75rem;color:var(--color-primary);text-align:center}.auth-subtitle{font-size:.9375rem;color:var(--color-text-muted);margin-bottom:1.5rem;text-align:center}.auth-link{margin-top:1.25rem;text-align:center;font-size:.9375rem;color:var(--color-text-muted)}.btn-okta{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-size:.9375rem;font-weight:600;color:#fff;background:#00297a;border:none;border-radius:var(--radius-md, 6px);cursor:pointer;transition:background .15s}.btn-okta:hover:not(:disabled){background:#001d5c}.btn-okta:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;margin:1.25rem 0;color:var(--color-text-muted, #6b7280);font-size:.8125rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border, #e5e7eb)}.auth-divider span{padding:0 .75rem;text-transform:uppercase;letter-spacing:.05em}@media(max-width:768px){.auth-card{padding:2rem 1.25rem}}@media(max-width:480px){.auth-page{padding:0;align-items:flex-start}.auth-card{max-width:100%;padding:1.5rem 1rem;box-shadow:none;border-radius:0}}.landing-page{max-width:960px;margin:0 auto;padding:48px 24px 60px}.landing-page__header{margin-bottom:32px}.landing-page__title{font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--color-primary);margin:0 0 8px}.landing-page__subtitle{font-size:1rem;color:var(--color-text-muted);margin:0}.landing-page__grid{display:grid;grid-template-columns:1fr;gap:20px}@media(min-width:768px){.landing-page__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.landing-page__grid{grid-template-columns:repeat(3,1fr)}}.landing-card{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);padding:24px;box-shadow:var(--shadow-sm);transition:box-shadow .15s ease,transform .15s ease}.landing-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.landing-card__name{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--color-primary);margin:0 0 8px}.landing-card__description{font-size:.9375rem;line-height:1.6;color:var(--color-text);margin:0 0 16px;flex:1}.landing-card__link{display:inline-block;align-self:flex-start;padding:8px 24px;background:var(--color-primary);color:#fff;font-size:.875rem;font-weight:600;text-decoration:none;border-radius:var(--radius-md);transition:background .15s ease}.landing-card__link:hover{background:var(--color-primary-dark)}.landing-card__link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(max-width:767px){.landing-page{padding:24px 16px 40px}.landing-page__title{font-size:1.5rem}.landing-card{padding:20px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}:root{--color-primary: #395542;--color-primary-dark: #2b4032;--color-primary-light: #4e7059;--color-accent: #9bcbeb;--color-accent-dark: #6aafdc;--color-text: #414141;--color-text-muted: #6b7280;--color-bg: #fafbfa;--color-surface: #ffffff;--color-border: #d1d5db;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-success-bg: #dcfce7;--color-success: #166534;--font-heading: "Libre Franklin", system-ui, sans-serif;--font-body: "Source Sans Pro", system-ui, sans-serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--header-height: 60px;--focus-ring: 0 0 0 3px rgba(57, 85, 66, .15)}body{font-family:var(--font-body);color:var(--color-text);background-color:var(--color-bg);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.25;color:var(--color-text)}a{color:var(--color-primary);text-decoration:underline}a:hover{color:var(--color-primary-dark)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-8{margin-top:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.spinner-container{display:flex;align-items:center;justify-content:center;min-height:50vh}.spinner{width:40px;height:40px;border:3px solid var(--color-accent);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{position:sticky;top:0;z-index:100;height:var(--header-height);background-color:var(--color-primary);box-shadow:var(--shadow-md)}.header-inner{display:flex;align-items:center;gap:2rem;height:100%;max-width:1280px;margin:0 auto;padding:0 1.5rem}.brand-logo{font-family:var(--font-heading);font-weight:800;font-size:1.25rem;color:#fff;letter-spacing:-.01em;flex-shrink:0;text-decoration:none}.brand-logo:hover,.brand-logo:focus{color:#fff;text-decoration:none}.brand-logo__opco{font-weight:400;font-size:1rem;opacity:.85}.module-nav{display:flex;align-items:center;gap:.25rem;flex:1}.module-tab{font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:#fffc;background:none;border:none;padding:.375rem .875rem;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .15s,color .15s;white-space:nowrap}.module-tab:hover{color:#fff;background-color:#ffffff1f}.module-tab--active{color:#fff;background-color:#ffffff2e}.sub-nav{background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:0 1px 2px #0000000a}.sub-nav__inner{display:flex;align-items:center;gap:0;max-width:1280px;margin:0 auto;padding:0 1.5rem}.sub-nav__link{font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;padding:.75rem 1rem;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.sub-nav__link:hover{color:var(--color-text)}.sub-nav__link--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.mobile-notif-bell{display:none}.hamburger{display:none;background:none;border:none;padding:.5rem;cursor:pointer;margin-left:auto}.hamburger__icon{display:block;width:22px;height:2px;background:#fff;position:relative;transition:background .2s}.hamburger__icon:before,.hamburger__icon:after{content:"";display:block;width:22px;height:2px;background:#fff;position:absolute;left:0;transition:transform .2s}.hamburger__icon:before{top:-6px}.hamburger__icon:after{top:6px}.hamburger__icon--open{background:transparent}.hamburger__icon--open:before{transform:rotate(45deg);top:0}.hamburger__icon--open:after{transform:rotate(-45deg);top:0}.mobile-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200}.mobile-menu__overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;padding:0;border:none;background:#0006;cursor:pointer}.mobile-menu__panel{position:absolute;top:0;right:0;width:280px;max-width:85vw;height:100%;background:var(--color-surface);box-shadow:-4px 0 16px #00000026;overflow-y:auto;padding:1rem 0;animation:slide-in .2s ease}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-menu__user{padding:.75rem 1.25rem}.mobile-menu__email{display:block;font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis}.mobile-menu__divider{height:1px;background:var(--color-border);margin:.5rem 0}.mobile-menu__module-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.75rem 1.25rem;font-size:.9375rem;font-weight:600;color:var(--color-text);background:none;border:none;cursor:pointer;text-align:left}.mobile-menu__module-header:hover{background:var(--color-bg)}.mobile-menu__module-header--active{color:var(--color-primary)}.mobile-menu__chevron{font-size:1.25rem;transition:transform .2s;color:var(--color-text-secondary)}.mobile-menu__chevron--open{transform:rotate(90deg)}.mobile-menu__sub-views{padding-left:1rem}.mobile-menu__item{display:block;width:100%;padding:.625rem 1.25rem;font-size:.875rem;color:var(--color-text-secondary);background:none;border:none;cursor:pointer;text-align:left}.mobile-menu__item:hover{background:var(--color-bg);color:var(--color-text)}.mobile-menu__item--active{color:var(--color-primary);font-weight:600}.mobile-menu__item--logout{color:var(--color-error)}.mobile-menu__item--logout:hover{background:#fef2f2}.nav-link{font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:#ffffffd9;text-decoration:none;padding:.375rem .75rem;border-radius:var(--radius-sm);transition:background-color .15s,color .15s}.nav-link:hover{color:#fff;background-color:#ffffff1f}.nav-link--active{color:#fff;background-color:#ffffff2e}.header-user{display:flex;align-items:center;gap:1rem;margin-left:auto}.user-info{font-size:.875rem;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.user-info--link{font-size:.875rem;color:#ffffffd9;background:none;border:none;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;padding:.25rem .375rem;border-radius:var(--radius-sm);transition:color .15s,background-color .15s;text-decoration:none}.user-info--link:hover{color:#fff;background-color:#ffffff1f}.app-main{flex:1;max-width:1280px;width:100%;margin:0 auto;padding:2rem 1.5rem}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-family:var(--font-body);font-weight:600;font-size:1rem;color:#fff;background-color:var(--color-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s,box-shadow .15s;text-decoration:none}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;font-family:var(--font-body);font-weight:600;font-size:1rem;color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s,border-color .15s;text-decoration:none}.btn-secondary:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;font-weight:600;font-size:.9375rem;color:#fff;background:var(--color-error);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.btn-sm{font-size:.875rem;padding:.375rem .875rem}.btn-full{width:100%;margin-top:1rem}.btn-logout{font-size:.875rem;font-weight:600;color:#ffffffe6;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-sm);padding:.3125rem .875rem;cursor:pointer;transition:background-color .15s;white-space:nowrap}.btn-logout:hover{background:#ffffff38}.form-field{margin-bottom:.875rem}.form-field label{display:block;font-size:.875rem;font-weight:600;color:var(--color-text);margin-bottom:.25rem}.form-field input,.form-field select,.form-field textarea{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);transition:border-color .15s,box-shadow .15s;outline:none}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring)}.form-field input:disabled,.form-field select:disabled{background:#f3f4f6;cursor:not-allowed}.form-field .input-error{border-color:var(--color-error)}.password-input-wrapper{position:relative;display:flex}.password-input-wrapper input{flex:1;padding-right:3.5rem}.password-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;padding:.25rem .5rem}.password-toggle:hover{color:var(--color-text)}.form-error,.field-error{display:block;font-size:.8125rem;color:var(--color-error);margin-top:.25rem}.form-error{background:var(--color-error-bg);border:1px solid #fecaca;border-radius:var(--radius-md);padding:.625rem .875rem;font-size:.9rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-row--thirds{grid-template-columns:1fr 1fr 1fr}.form-fieldset{border:1px solid var(--color-border, #d0d5dd);border-radius:6px;padding:.75rem;margin:0}.form-fieldset legend{font-size:.85rem;font-weight:600;color:var(--color-text-secondary, #475467);padding:0 .25rem}.status-badge{display:inline-flex;align-items:center;padding:.1875rem .625rem;border-radius:9999px;font-size:.8125rem;font-weight:600;white-space:nowrap}.status-badge--active{background-color:var(--color-success-bg);color:var(--color-success)}.status-badge--pending{background-color:#fef9c3;color:#713f12}.status-badge--disabled{background-color:#fee2e2;color:#991b1b}.status-badge--invited{background-color:#dbeafe;color:#1e40af}.status-badge--unconfirmed{background-color:#fef3c7;color:#92400e}.pending-banner{background-color:#fef9c3;color:#713f12;border-bottom:1px solid #fde68a;font-size:.875rem;font-weight:500;text-align:center;padding:.4375rem 1rem;width:100%;z-index:99}.pending-banner--page{border-radius:var(--radius-md);border:1px solid #fde68a;margin-bottom:1.5rem;padding:.75rem 1rem;text-align:left}.success-message{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:var(--color-success-bg);color:var(--color-success);border:1px solid #bbf7d0;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;margin-bottom:1rem}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;text-align:center;padding:2rem}.access-denied h1{font-size:2rem;color:var(--color-error)}.access-denied p{color:var(--color-text-muted);font-size:1.125rem}.tab-bar{display:flex;gap:.25rem;border-bottom:2px solid var(--color-border);margin-bottom:1.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-bar__btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:var(--color-text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.tab-bar__btn:hover{color:var(--color-primary)}.tab-bar__btn--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-bar__count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:.75rem;font-weight:700;color:#fff;background-color:var(--color-primary-light);border-radius:10px}.tab-bar__btn--active .tab-bar__count{background-color:var(--color-primary)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:300;padding:1rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:400;padding:1rem}.modal-backdrop-button{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;padding:0;border:none;background:transparent;cursor:pointer;font:inherit;color:inherit;z-index:0}.modal-backdrop-button:focus{outline:none}.modal-backdrop-button:focus-visible{outline:2px solid var(--color-focus, #3b82f6);outline-offset:-2px}.modal-backdrop-button~*{position:relative;z-index:1}.modal-dialog{background:var(--color-surface);border-radius:var(--radius-lg, .75rem);box-shadow:var(--shadow-lg, 0 4px 16px rgba(0,0,0,.15));max-width:28rem;width:100%;overflow:visible}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.modal-title{font-size:1.125rem;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--color-text-secondary);padding:.25rem}.modal-close:hover{color:var(--color-text)}.modal-body{padding:1rem 1.25rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--color-border)}.toast{position:fixed;top:1rem;right:1rem;z-index:500;padding:.75rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;box-shadow:var(--shadow-md);animation:toast-in .3s ease}.toast--success{background:var(--color-success-bg, #dcfce7);color:var(--color-success, #166534);border:1px solid #bbf7d0}.toast--error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}@keyframes toast-in{0%{opacity:0;transform:translateY(-.5rem)}to{opacity:1;transform:translateY(0)}}.inline-confirm{display:inline-flex;align-items:center;gap:.5rem;font-size:.8125rem}.users-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.opco-dropdown{position:relative;display:inline-block;width:100%}.opco-dropdown__trigger{width:100%;text-align:left;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;font-size:.875rem}.opco-dropdown__trigger:hover{border-color:var(--color-primary)}.opco-dropdown__menu{position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);margin-top:.25rem;max-height:16rem;display:flex;flex-direction:column}.opco-dropdown__search{padding:.5rem .75rem;border:none;border-bottom:1px solid var(--color-border);font-size:.875rem;outline:none}.opco-dropdown__list{overflow-y:auto;flex:1}.opco-dropdown__group{padding:.375rem .75rem;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg)}.opco-dropdown__item{display:block;width:100%;text-align:left;padding:.375rem .75rem .375rem 1.25rem;border:none;background:none;cursor:pointer;font-size:.875rem}.opco-dropdown__item:hover{background:var(--color-bg)}.opco-dropdown__item--selected{background:var(--color-primary-bg, #eff6ff);font-weight:600}.opco-dropdown__empty{padding:.75rem;text-align:center;color:var(--color-text-secondary);font-size:.875rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem 1.25rem;box-shadow:var(--shadow-sm)}.card:hover{box-shadow:var(--shadow-md)}@media(max-width:768px){.header-inner{gap:.75rem;padding:0 1rem}.brand-logo{font-size:1.1rem}.module-nav,.header-user{display:none}.mobile-notif-bell{display:flex;align-items:center;margin-left:auto}.hamburger{display:block;margin-left:0}.sub-nav__inner{padding:0 1rem}.sub-nav__link{font-size:.8125rem;padding:.625rem .75rem}.app-main{padding:1.25rem 1rem}.form-row{grid-template-columns:1fr}}@media(max-width:480px){:root{--header-height: 52px}.header-inner{gap:.5rem;padding:0 .75rem}.app-main{padding:1rem .75rem}.brand-logo__opco{display:none}.sub-nav__link{font-size:.75rem;padding:.5rem .625rem}}
