:root{--bg:#eef5fb;--surface:#fffffff0;--surface-strong:#fff;--line:#5c7ea629;--text:#20354d;--muted:#67809b;--accent:#3d81c2;--accent-soft:#e8f2fd;--warm:#5f90bf;--rose:#5b7a9e;--shadow:0 16px 36px #38628f14;--radius:18px;--radius-sm:12px;--font-sans:"Segoe UI", "Aptos", "Trebuchet MS", sans-serif;font-size:14px}html[data-font-size=compact]{font-size:12.5px}html[data-font-size=comfortable]{font-size:15.5px}*{box-sizing:border-box}html{min-height:100%}body{min-height:100vh;font-family:var(--font-sans);color:var(--text);background:radial-gradient(circle at 0 0,#3d81c214,#0000 28%),radial-gradient(circle at 100% 0,#84b1e31f,#0000 32%),linear-gradient(#f8fbff 0%,#eef5fb 100%);margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.page-shell{width:100%;padding:24px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.eyebrow{background:var(--accent-soft);color:var(--accent);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:8px 12px;font-size:.82rem;font-weight:700;display:inline-block}.button{background:var(--accent);color:#f7f6f3;cursor:pointer;border:0;border-radius:999px;justify-content:center;align-items:center;gap:10px;min-height:44px;padding:0 18px;display:inline-flex}.button.secondary{color:var(--accent);background:#3d81c21f}.input,.select,.textarea{border:1px solid #46301b29;border:1px solid var(--line);width:100%;color:var(--text);background:#f8fbfff5;border-radius:14px;padding:14px 16px}.table-wrap{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th,.table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:14px 12px}.roster-col-company{min-width:160px}.roster-col-contact{min-width:230px}.roster-col-edit{white-space:nowrap;width:72px;min-width:72px}@media (max-width:1180px){.roster-col-since{display:none}}@media (max-width:1020px){.roster-col-billing{display:none}}@media (max-width:880px){.roster-col-category{display:none}}@media (max-width:760px){.roster-col-website{display:none}}@media (max-width:620px){.roster-col-networker{display:none}}.table th{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.84rem}.status-pill{color:var(--accent);text-transform:capitalize;background:#3d81c21f;border-radius:999px;align-items:center;padding:6px 10px;font-size:.8rem;font-weight:700;display:inline-flex}.status-pill.warm{color:var(--warm);background:#5f90bf24}.status-pill.rose{color:var(--rose);background:#5b7a9e1f}.status-pill.category-membership{color:#247044;background:#dff5e7}.status-pill.category-snack-pack{color:#a35414;background:#ffedd5}.status-pill.category-donation{color:#9d3b68;background:#fce7f3}.status-pill.category-other{color:#51677f;background:#eef2f7}.status-pill.roster-ok{color:#247044;background:#dff5e7}.status-pill.roster-action{color:#8a5a00;background:#fff4c7}.status-pill.roster-warn{color:#a63d4b;background:#ffe4e6}.status-pill.roster-neutral{color:#51677f;background:#eef2f7}.portal-shell{grid-template-columns:auto minmax(0,1fr);min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;height:100vh;padding:14px;transition:width .2s;position:sticky;top:0;left:0}.sidebar-inner{align-content:start;gap:14px;height:100%;display:grid}.sidebar-toggle{border:1px solid var(--line);width:100%;color:var(--text);cursor:pointer;background:#f8fbff;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.sidebar-toggle-mark{gap:4px;display:inline-grid}.sidebar-toggle-mark span{background:var(--accent);border-radius:999px;width:16px;height:2px;display:block}.sidebar-brand{border:1px solid var(--line);background:linear-gradient(#fff 0%,#f5faff 100%);border-radius:16px;align-items:center;gap:12px;padding:14px;display:flex}.sidebar-brand img{object-fit:cover;border-radius:12px;width:44px;height:44px}.sidebar-nav{gap:8px;display:grid}.sidebar-link{color:var(--text);background:#f5faffb3;border:1px solid #0000;border-radius:14px;align-items:center;gap:12px;padding:12px 14px;display:flex}.sidebar-link.active{color:var(--accent);background:#e8f2fd;border-color:#3d81c233}.sidebar-icon{text-align:center;min-width:18px;font-size:1rem}.main-column{align-content:start;gap:18px;padding:24px;display:grid}.topbar{justify-content:space-between;align-self:start;align-items:center;gap:16px;width:100%;min-height:88px;display:flex}.topbar-meta{flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.section-grid{gap:18px;min-width:0;display:grid}.page-title{margin:0;font-size:1.8rem;line-height:1.1}.topbar-heading{flex-direction:column;flex:auto;justify-content:center;min-width:0;min-height:48px;display:flex}.page-subtitle{min-height:1.2em;color:var(--muted);margin-top:4px;font-size:.95rem;line-height:1.2}.user-menu{position:relative}.user-menu-trigger{min-height:40px;color:var(--muted);cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;padding:0 2px;display:inline-flex}.user-menu-panel{z-index:30;background:#fffffffa;border-radius:14px;min-width:160px;padding:8px;position:absolute;top:calc(100% + 10px);right:0}.user-menu-item{width:100%;color:var(--text);cursor:pointer;background:0 0;border:0;border-radius:10px;align-items:center;padding:10px 12px;display:flex}.user-menu-item:hover{background:var(--accent-soft)}.roster-toolbar{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:18px;display:grid}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.form-grid .full{grid-column:1/-1}.year-bubbles{flex-wrap:wrap;gap:10px;display:flex}.year-bubble{border:1px solid var(--line);min-width:74px;color:var(--muted);cursor:pointer;background:#f8fbff;border-radius:999px;padding:10px 14px;font-weight:700}.year-bubble.active{background:var(--accent);border-color:var(--accent);color:#fff}.modal-backdrop{z-index:40;background:#20354d5c;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-panel{flex-direction:column;width:min(760px,100%);max-height:calc(100vh - 48px);display:flex;overflow:hidden}.modal-header{flex-shrink:0;padding:22px 22px 0}.modal-body{flex:auto;min-height:0;padding:16px 22px;overflow-y:auto}.modal-footer{border-top:1px solid var(--line);background:var(--surface);border-radius:0 0 var(--radius) var(--radius);flex-shrink:0;gap:10px;padding:14px 22px;display:flex}.chevron-btn{width:28px;height:28px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;justify-content:center;align-items:center;font-size:.75rem;display:inline-flex}.chevron-btn:hover{background:var(--accent-soft);color:var(--accent)}.login-card{background:linear-gradient(#fffffffa 0%,#f6fbfffa 100%);gap:24px;width:min(720px,100%);margin:0 auto;padding:38px 36px 34px;display:grid}.login-brand{justify-items:center;gap:4px;padding:8px 0 2px;display:grid}.login-brand-mark{letter-spacing:.06em;color:#1f5fa8;text-transform:uppercase;font-family:Georgia,Times New Roman,serif;font-size:clamp(4.4rem,14vw,8rem);font-weight:800;line-height:.88}.login-brand-subtitle{letter-spacing:.3em;text-transform:uppercase;color:#2d6caf;text-align:center;font-size:clamp(1rem,2.2vw,1.5rem);line-height:1.1}.login-copy{text-align:center;gap:4px;display:grid}@media (max-width:980px){.roster-toolbar{grid-template-columns:1fr}}@media (max-width:860px){.page-shell{padding:16px}.portal-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid var(--line);height:auto;position:static}.main-column{padding:16px}.topbar{flex-direction:column;align-items:flex-start;min-height:0}.topbar-meta{flex-wrap:wrap;justify-content:flex-start}.form-grid{grid-template-columns:1fr}.login-card{padding:28px 20px 24px}.login-brand-subtitle{letter-spacing:.16em}}
