*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--telus-purple: #4B286D;--telus-green: #2B8000;--telus-green-light: #6BC246;--bg: #F4F4F4;--surface: #FFFFFF;--border: #E0E0E0;--text: #1A1A1A;--text-muted: #666666;--radius: 10px;font-family:Inter,system-ui,sans-serif;color:var(--text);background:var(--bg)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:var(--text-muted)}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--telus-purple);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.header{background:var(--telus-purple);color:#fff;position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #00000026}.header-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px}.logo-telus{color:#fff}.logo-health{color:var(--telus-green-light)}.logo-divider{width:1px;height:18px;background:#ffffff4d}.logo-catalog{color:#ffffffbf;font-weight:400}.user-menu{display:flex;align-items:center;gap:12px}.avatar{width:34px;height:34px;background:var(--telus-green-light);color:var(--telus-purple);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.user-name{font-size:14px;color:#ffffffd9}.logout-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;padding:5px 12px;border-radius:6px;font-size:13px;cursor:pointer;transition:background .15s}.logout-btn:hover{background:#ffffff38}.main{max-width:1200px;margin:0 auto;padding:32px 24px 64px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}.page-title{font-size:26px;font-weight:700;color:var(--telus-purple)}.page-subtitle{font-size:14px;color:var(--text-muted);margin-top:4px}.search{padding:9px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;width:240px;outline:none;transition:border-color .15s}.search:focus{border-color:var(--telus-purple)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.empty{color:var(--text-muted);font-size:14px;grid-column:1/-1;padding:32px 0;text-align:center}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .15s,transform .15s}.card:hover{box-shadow:0 4px 16px #4b286d1a;transform:translateY(-2px)}.card-header{display:flex;align-items:center;justify-content:space-between}.category{font-size:12px;font-weight:500;color:var(--telus-purple);text-transform:uppercase;letter-spacing:.04em}.card-title{font-size:16px;font-weight:600;color:var(--text)}.card-description{font-size:14px;color:var(--text-muted);line-height:1.5;flex:1}.badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}.badge-active{background:#e6f4e0;color:var(--telus-green)}.badge-beta{background:#fff3e0;color:#e65100}.badge-deprecated{background:#f5f5f5;color:#9e9e9e}
