.error-message{text-align:center;flex-direction:column;justify-content:center;align-items:center;max-width:480px;margin:0 auto;padding:4rem 2rem;display:flex}.error-message-icon{color:var(--color-error);margin-bottom:1.5rem}.error-message-title{color:var(--color-text);margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.error-message-text{color:var(--color-text-light);margin:0 0 1.5rem;font-size:.9375rem;line-height:1.5}.error-message-action{background-color:var(--color-navy);color:var(--color-white);cursor:pointer;border:none;border-radius:4px;margin-bottom:1.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600}.error-message-action:hover{background-color:var(--color-navy-hover)}.error-message-support{color:var(--color-text-light);font-size:.8125rem}.error-message-support a{color:var(--color-link);text-decoration:underline}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-navy:#102e5e;--color-navy-hover:#1a4178;--color-teal:#15a3a7;--color-teal-hover:#0f8a8e;--color-teal-light:#d0ebec;--color-bg:#f7f8fa;--color-white:#fff;--color-text:#212121;--color-text-light:#666;--color-border:#d1d5db;--color-link:#15a3a7;--color-error:#dc2626;--header-height:64px}html,body{height:100%;color:var(--color-text);background-color:var(--color-bg);font-family:Open Sans,sans-serif}#root{height:100%}a{color:inherit;text-decoration:none}button{font-family:inherit}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-main{flex:1}.footer{background-color:var(--color-white);color:var(--color-text-light);border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-top:auto;padding:1rem 1.5rem;font-size:.8125rem;display:flex}.footer-left{align-items:center;gap:.5rem;display:flex}.footer-right{font-size:.8125rem}@media (width<=768px){.footer{text-align:center;flex-direction:column;gap:.5rem}}.notification-bell{position:relative}.notification-bell-btn{width:40px;height:40px;color:var(--color-white);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background-color .15s;display:flex;position:relative}.notification-bell-btn:hover{background-color:var(--color-teal)}.notification-dot{background-color:var(--color-teal);border:2px solid var(--color-navy);border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.notification-panel{background:var(--color-white);z-index:200;border-radius:8px;width:320px;max-height:400px;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden;box-shadow:0 4px 16px #00000026}.notification-panel-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:1rem;display:flex}.notification-panel-header h3{color:var(--color-text);margin:0;font-size:.875rem}.mark-all-read-btn{color:var(--color-teal);cursor:pointer;background:0 0;border:none;font-size:.75rem}.notification-list{max-height:340px;overflow-y:auto}.notification-empty{text-align:center;color:var(--color-text-light);padding:2rem;font-size:.875rem}.notification-item{border-bottom:1px solid #f5f5f5;padding:1rem}.notification-item h4{color:var(--color-text);margin:0 0 .25rem;font-size:.875rem}.notification-message{color:var(--color-text-light);font-size:.8125rem;line-height:1.4}.notification-message p{margin:0 0 .5rem}.notification-message p:last-child{margin-bottom:0}.notification-message a{color:var(--color-teal);text-decoration:underline}.notification-message blockquote{border-left:3px solid var(--color-teal);color:var(--color-text);margin:.25rem 0;padding-left:.625rem}.notification-message ul,.notification-message ol{margin:.25rem 0;padding-left:1.25rem}.notification-message li{margin:.125rem 0}.notification-message code{background-color:#f5f5f5;border-radius:3px;padding:.0625rem .25rem;font-size:.75rem}.notification-message pre{background-color:#f5f5f5;border-radius:4px;margin:.25rem 0;padding:.5rem;overflow-x:auto}.notification-message pre code{background:0 0;padding:0}.notification-date{color:var(--color-text-light);text-align:right;margin-top:.25rem;font-size:.75rem;display:block}.user-menu{position:relative}.user-menu-avatar{background-color:var(--color-teal);width:36px;height:36px;color:var(--color-white);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.875rem;font-weight:700;transition:background-color .15s;display:flex}.user-menu-avatar:hover{background-color:var(--color-teal-hover)}.user-menu-dropdown{background:var(--color-white);z-index:200;border-radius:8px;min-width:160px;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden;box-shadow:0 4px 16px #00000026}.user-menu-item{text-align:left;width:100%;color:var(--color-text);cursor:pointer;background:0 0;border:none;padding:.75rem 1rem;font-size:.875rem;display:block}.user-menu-item:hover{background-color:#f9fafb}.user-menu-item+.user-menu-item{border-top:1px solid #f0f0f0}.header{height:var(--header-height);background-color:var(--color-navy);color:var(--color-white);z-index:100;border-bottom:1px solid #e3e3e3;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:.625rem;display:flex}.header-wordmark{letter-spacing:.15em;color:var(--color-white);font-size:1.125rem;font-weight:700}.header-logo{object-fit:contain;width:auto;height:40px}.header-right{align-items:center;gap:.5rem;display:flex}.loading{justify-content:center;align-items:center;width:100%;display:flex}.loading-spinner{animation:1.4s linear infinite loading-rotate}.loading-circle{stroke:var(--color-navy);stroke-dasharray:80 200;stroke-dashoffset:0;stroke-linecap:round;animation:1.4s ease-in-out infinite loading-dash}@keyframes loading-rotate{to{transform:rotate(360deg)}}@keyframes loading-dash{0%{stroke-dasharray:1 200;stroke-dashoffset:0}50%{stroke-dasharray:80 200;stroke-dashoffset:-35px}to{stroke-dasharray:80 200;stroke-dashoffset:-124px}}.resource-card{background-color:var(--color-white);border:1px solid var(--color-border);border-radius:8px;flex-direction:column;gap:.75rem;height:180px;padding:1.5rem;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex}.resource-card:hover{border-color:var(--color-teal);transform:translateY(-4px);box-shadow:0 4px 16px #0000001a}.resource-card-title{color:var(--color-text);white-space:nowrap;margin:0;font-size:1.375rem;font-weight:700}.resource-card-description{color:var(--color-text);flex:1;margin:0;font-size:.875rem;line-height:1.5}.resource-card-actions{justify-content:flex-end;display:flex}.resource-card-arrow{background-color:var(--color-teal);cursor:pointer;border:none;border-radius:18px;justify-content:center;align-items:center;width:36px;height:36px;transition:background-color .15s;display:flex}.resource-card-arrow:hover{background-color:var(--color-teal-hover)}.product-tile{background-color:var(--color-white);border:1px solid var(--color-border);border-radius:8px;flex-direction:column;gap:1rem;height:220px;padding:1.5rem;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex}.product-tile:hover{border-color:var(--color-teal);transform:translateY(-4px);box-shadow:0 4px 16px #0000001a}.product-tile-header{align-items:flex-start;gap:.75rem;display:flex}.product-tile-icon{background-color:var(--color-teal-light);width:40px;height:40px;color:var(--color-teal);border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.product-tile-name{color:var(--color-text);margin:0;font-size:1.375rem;font-weight:700}.product-tile-description{color:var(--color-text);flex:1;margin:0;font-size:.875rem;line-height:1.5}.product-tile-actions{justify-content:flex-end;display:flex}.product-tile-arrow{background-color:var(--color-teal);cursor:pointer;border:none;border-radius:18px;justify-content:center;align-items:center;width:36px;height:36px;transition:background-color .15s;display:flex}.product-tile-arrow:hover{background-color:var(--color-teal-hover)}.tile-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.tile-grid--two-columns{grid-template-columns:repeat(2,1fr)}.tile-grid-loading{color:var(--color-text-light);justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.tile-grid-empty{text-align:center;color:var(--color-text-light);flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.tile-grid-empty a{color:var(--color-teal);text-decoration:underline}@media (width<=1024px){.tile-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.tile-grid{grid-template-columns:1fr}}.home-container{max-width:1200px;margin:0 auto;padding:2.5rem 3rem}.home-welcome{color:var(--color-text);margin-bottom:2.5rem;font-size:1.75rem;font-weight:700;line-height:1.5}.home-section{margin-bottom:3rem}.home-section-heading{color:var(--color-text);letter-spacing:.32px;margin-bottom:1.5rem;font-size:1rem;font-weight:700}.home-resources-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.home-resources-grid--two-columns{grid-template-columns:repeat(2,1fr)}@media (width<=900px){.home-container{padding:2rem 1.5rem}.home-resources-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.home-resources-grid{grid-template-columns:1fr}}.confirm-modal{border:none;border-radius:10px;width:calc(100% - 32px);max-width:440px;padding:0;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 20px 40px #0000001a}.confirm-modal::backdrop{background-color:#00000080}.confirm-modal-content{text-align:center;padding:2rem}.confirm-modal-title{color:var(--color-text);letter-spacing:.5px;margin:0 0 1rem;font-size:1.25rem;font-weight:700}.confirm-modal-body{color:var(--color-text);letter-spacing:.25px;font-size:.875rem;line-height:1.5}.confirm-modal-body p{margin:0 0 .5rem}.confirm-modal-body p:last-child{margin-bottom:0}.confirm-modal-actions{background-color:var(--color-bg);border-top:1px solid var(--color-border);border-radius:0 0 10px 10px;justify-content:center;gap:.75rem;padding:1rem 2rem;display:flex}.confirm-modal-cancel{background-color:var(--color-white);color:var(--color-text);border:2px solid var(--color-border);cursor:pointer;text-transform:none;border-radius:8px;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s}.confirm-modal-cancel:hover{background-color:var(--color-bg)}.confirm-modal-confirm{background-color:var(--color-navy);color:var(--color-white);cursor:pointer;text-transform:none;border:none;border-radius:8px;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s}.confirm-modal-confirm:hover{background-color:var(--color-navy-hover)}@media (width<=768px){.confirm-modal{width:calc(100% - 32px)}.confirm-modal-content{padding:1.5rem}.confirm-modal-actions{padding:1rem 1.5rem}}.profile-container{max-width:1200px;margin:0 auto;padding:2.5rem 3rem}.profile-back-link{color:var(--color-navy);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.9375rem;font-weight:600;text-decoration:none;display:inline-flex}.profile-back-link:hover{text-decoration:underline}.profile-card{background-color:var(--color-white);border:1px solid var(--color-border);border-radius:8px;padding:2.5rem}.profile-header{align-items:center;gap:1.5rem;margin-bottom:2.5rem;display:flex}.profile-avatar{border:3px solid var(--color-navy);background-color:var(--color-bg);width:80px;height:80px;color:var(--color-navy);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-name{color:var(--color-text);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.profile-title{color:var(--color-text);opacity:.7;margin:0;font-size:.9375rem}.profile-fields{flex-direction:column;gap:1.75rem;display:flex}.profile-field{align-items:flex-start;gap:1rem;display:flex}.profile-field-icon{color:var(--color-navy);flex-shrink:0;margin-top:.125rem}.profile-field-label{color:var(--color-text);letter-spacing:.5px;opacity:.6;margin-bottom:.25rem;font-size:.75rem;font-weight:600;display:block}.profile-field-value{color:var(--color-text);margin:0;font-size:.9375rem}.profile-divider{border:none;border-top:1px solid var(--color-border);margin:2rem 0}.profile-change-password{background-color:var(--color-navy);color:var(--color-white);cursor:pointer;border:none;border-radius:6px;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;transition:opacity .15s}.profile-change-password:hover{opacity:.9}.profile-reset-success{color:var(--color-teal);margin:.75rem 0 0;font-size:.875rem;font-weight:600}.profile-reset-error{color:var(--color-error);margin:.75rem 0 0;font-size:.8125rem}.profile-change-password:disabled{opacity:.6;cursor:not-allowed}@media (width<=600px){.profile-container{padding:2rem 1.5rem}.profile-card{padding:1.5rem}}
