:root{--color-brand-purple: #4B1A6E;--color-brand-purple-dark: #3A1357;--color-brand-purple-light: #6A2A9A;--color-brand-teal: #2BB8B0;--color-brand-teal-dark: #1E8F89;--color-brand-teal-accessible: #0f7370;--color-brand-outline: #1A2A3A;--color-primary: var(--color-brand-purple);--color-primary-hover: var(--color-brand-purple-dark);--color-accent: var(--color-brand-teal);--color-accent-hover: var(--color-brand-teal-dark);--color-accent-text: var(--color-brand-teal-accessible);--color-bg: #f5f7fa;--color-text: #111827;--color-text-on-primary: #ffffff;--color-text-on-accent: #111827;--color-border: #e5e7eb;--color-error: #dc2626;--color-success: #22c55e;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-brand-purple-light) 0%,var(--color-brand-purple-dark) 100%);padding:1.5rem}.auth-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;padding:2.5rem 2rem;width:100%;max-width:420px}.auth-card__header{text-align:center;margin-bottom:2rem}.auth-card__title{font-size:1.6rem;font-weight:800;color:var(--color-primary);margin:0 0 .4rem}.auth-card__subtitle{font-size:.9rem;color:#6b7280;margin:0}.auth-card__footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:#6b7280}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form__error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:6px;padding:.65rem .875rem;font-size:.875rem}.auth-form__warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e;border-radius:6px;padding:.65rem .875rem;font-size:.875rem}.auth-form__forgot{text-align:right;margin-top:-.25rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-label{font-size:.875rem;font-weight:600;color:#374151}.form-input,.form-select{border:1px solid #d1d5db;border-radius:6px;padding:.6rem .75rem;font-size:.9rem;color:#111827;background:#fff;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4b1a6e1f}.btn{padding:.65rem 1.25rem;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.btn--primary{background:var(--color-primary);color:var(--color-text-on-primary)}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--primary:disabled{opacity:.6;cursor:not-allowed}.btn--full{width:100%}.auth-link{color:var(--color-primary);text-decoration:none;font-size:.875rem}.auth-link:hover{text-decoration:underline}.auth-link--bold{font-weight:600}.auth-card--wide{max-width:560px}.register-section{border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem 1rem;margin-bottom:.5rem}.register-section__title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;margin:0 0 1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.forgot-description{font-size:.9rem;color:#6b7280;margin:0 0 .5rem;line-height:1.5}.form-input--error{border-color:#dc2626}.form-error{font-size:.8rem;color:#dc2626;margin-top:.2rem}.forgot-confirmation{text-align:center;padding:1rem 0 .5rem}.forgot-confirmation__icon{font-size:2.5rem;margin-bottom:.75rem}.forgot-confirmation__message{font-size:.95rem;color:#111827;line-height:1.6;margin:0 0 .5rem}.forgot-confirmation__hint{font-size:.825rem;color:#9ca3af;margin:0}.auth-logo{display:block;margin:0 auto 1.25rem;height:56px;width:auto}.app-layout{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg)}.app-nav{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:56px;background-color:var(--color-primary);color:var(--color-text-on-primary);box-shadow:0 2px 4px #00000026}.app-nav__brand{display:flex;align-items:center;gap:10px}.nav-logo{height:32px;width:auto;display:block}.nav-brand-name{font-size:1.1rem;font-weight:700;letter-spacing:.02em;color:var(--color-text-on-primary)}.app-nav__links{display:flex;align-items:center;gap:.25rem}.app-nav__link{color:#ffffffbf;text-decoration:none;font-size:.875rem;padding:.3rem .75rem;border-radius:4px;transition:background .15s,color .15s}.app-nav__link:hover{background:#ffffff1f;color:var(--color-text-on-primary)}.app-nav__link--active{background:#ffffff2e;color:var(--color-text-on-primary);font-weight:600}.app-nav__right{display:flex;align-items:center;gap:1rem}.app-nav__user{font-size:.875rem;opacity:.85}.app-nav__logout{background:transparent;border:1px solid rgba(255,255,255,.5);color:var(--color-text-on-primary);padding:.3rem .85rem;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background .15s}.app-nav__logout:hover{background:#ffffff26}.app-main{flex:1;padding:2rem 1.5rem;max-width:1100px;width:100%;margin:0 auto}@media(max-width:640px){.app-nav{height:auto;flex-wrap:wrap;padding:.5rem 1rem;gap:.25rem}.nav-brand-name{font-size:.95rem}.nav-logo{height:26px}.app-nav__user{display:none}.app-nav__links{gap:.1rem}.app-nav__link{padding:.25rem .5rem;font-size:.8rem}.app-nav__logout{padding:.25rem .6rem;font-size:.8rem}}.top-batters__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.top-batters__item{display:grid;grid-template-columns:2.5rem 1fr auto auto;align-items:center;gap:.5rem}.top-batters__rank{font-size:.75rem;font-weight:700;color:#9ca3af;text-transform:uppercase}.top-batters__name{font-size:.95rem;font-weight:500;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-batters__avg{font-size:1rem;font-weight:700;color:var(--color-accent-text);white-space:nowrap}.top-batters__detail{font-size:.78rem;color:#9ca3af;white-space:nowrap}.stat-leader{display:flex;flex-direction:column;gap:.5rem;padding:.5rem 0}.stat-leader__name{font-size:1.05rem;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-leader__value{font-size:2rem;font-weight:700;color:var(--color-accent-text);line-height:1}.stat-leader__label{font-size:.85rem;font-weight:500;color:#6b7280}.upcoming-games{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0000000f}.upcoming-games__title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;margin:0 0 1rem}.upcoming-games__empty{font-size:.9rem;color:#9ca3af;margin:0}.upcoming-games__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}.upcoming-games__item{display:grid;grid-template-columns:3.5rem 1fr auto;align-items:center;gap:.75rem;padding:.625rem 0;border-bottom:1px solid #f3f4f6}.upcoming-games__item:last-child{border-bottom:none}.upcoming-games__date{display:flex;flex-direction:column;gap:.1rem}.upcoming-games__day{font-size:.85rem;font-weight:600;color:#111827}.upcoming-games__time{font-size:.72rem;color:#9ca3af}.upcoming-games__info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.upcoming-games__opponent{font-size:.95rem;font-weight:500;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upcoming-games__location{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .45rem;border-radius:4px;width:fit-content}.upcoming-games__location--home{background:#dcfce7;color:#166534}.upcoming-games__location--away{background:#dbeafe;color:var(--color-accent-text)}.upcoming-games__relative{font-size:.75rem;color:#9ca3af;white-space:nowrap;text-align:right}.dashboard{max-width:1100px;margin:0 auto;padding:2rem 1rem}.dashboard__heading{font-size:1.75rem;font-weight:700;color:#111827;margin:0 0 1.5rem}.dashboard__loading,.dashboard__error{padding:1.5rem;border-radius:8px;font-size:.95rem;text-align:center;margin-bottom:1.5rem}.dashboard__loading{background:#f3f4f6;color:#6b7280}.dashboard__error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.dashboard__stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}.dashboard__games-section{margin-top:1.5rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0000000f}.stat-card__title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;margin:0 0 1rem}.stat-card__empty{font-size:.9rem;color:#9ca3af;margin:0}.matches-page{max-width:720px;margin:0 auto;padding:2rem 1rem}.matches-page__title{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.matches-page__subtitle{color:#6b7280;margin-bottom:1.5rem;font-size:.9rem}.matches-page__section-title{font-size:1.1rem;font-weight:600;margin:1.5rem 0 .75rem}.matches-page__loading,.matches-page__empty{color:#6b7280;padding:1rem 0}.matches-page__error{color:#dc2626;padding:.5rem 0}.matches-page__list,.matches-page__admin-list{display:flex;flex-direction:column;gap:1rem}.match-card{border:1px solid #e5e7eb;border-radius:8px;padding:1rem 1.25rem;background:#fff;transition:border-color .15s}.match-card--signed-up{border-color:#22c55e;background:#f0fdf4}.match-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.match-card__opponent{font-size:1.1rem;font-weight:600}.match-card__location{font-size:.8rem;padding:2px 8px;border-radius:12px;font-weight:500}.match-card__location--home{background:#dbeafe;color:var(--color-accent-hover)}.match-card__location--away{background:#fef3c7;color:#92400e}.match-card__date{font-size:.875rem;color:#374151;margin-bottom:.25rem}.match-card__notes{font-size:.8rem;color:#6b7280;margin-bottom:.5rem}.match-card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem}.match-card__count{font-size:.8rem;color:#6b7280}.match-card__btn{padding:6px 16px;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:background .15s}.match-card__btn--signup{background:var(--color-accent);color:var(--color-text-on-accent)}.match-card__btn--signup:hover:not(:disabled){background:var(--color-accent-hover)}.match-card__btn--unsub{background:#e5e7eb;color:#374151}.match-card__btn--unsub:hover:not(:disabled){background:#d1d5db}.match-card__btn:disabled{opacity:.6;cursor:not-allowed}.match-card__error{color:#dc2626;font-size:.8rem;margin-top:.5rem}.create-match-form{border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem;background:#f9fafb;margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem}.create-match-form__title{font-size:1rem;font-weight:600;margin-bottom:.25rem}.create-match-form__label{display:flex;flex-direction:column;font-size:.875rem;font-weight:500;gap:.25rem}.create-match-form__input{padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background:#fff}.create-match-form__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #2bb8b040}.create-match-form__error{color:#dc2626;font-size:.8rem}.create-match-form__success{color:#16a34a;font-size:.8rem}.create-match-form__submit{padding:8px 20px;background:var(--color-accent);color:var(--color-text-on-accent);border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;align-self:flex-start}.create-match-form__submit:hover:not(:disabled){background:var(--color-accent-hover)}.create-match-form__submit:disabled{opacity:.6;cursor:not-allowed}.admin-match-row{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;gap:1rem}.admin-match-row__info{display:flex;flex-direction:column;gap:.2rem}.admin-match-row__meta{font-size:.8rem;color:#6b7280}.admin-match-row__count{font-size:.8rem;color:#374151}.admin-match-row__delete{padding:6px 14px;background:#fee2e2;color:#dc2626;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap}.admin-match-row__delete:hover:not(:disabled){background:#fecaca}.admin-match-row__delete:disabled{opacity:.6;cursor:not-allowed}.admin-match-row__error{color:#dc2626;font-size:.8rem;margin-top:.25rem}.profile-page{max-width:680px;margin:0 auto;padding:2rem 1rem}.profile-page__title-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.profile-page__stats-link{font-size:.875rem;font-weight:500;color:var(--color-primary, #7c3aed);text-decoration:none}.profile-page__stats-link:hover{text-decoration:underline}.profile-page__title{font-size:1.75rem;font-weight:700;color:#111827;margin:0}.profile-page__success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d;border-radius:6px;padding:.65rem .875rem;font-size:.875rem;margin-bottom:1.25rem}.profile-page__error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:6px;padding:.65rem .875rem;font-size:.875rem;margin-bottom:1.25rem}.profile-page__loading{padding:1.5rem;border-radius:8px;font-size:.95rem;text-align:center;background:#f3f4f6;color:#6b7280}.profile-form{display:flex;flex-direction:column;gap:1.5rem}.profile-form__section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1.5rem;box-shadow:0 1px 3px #0000000f}.profile-form__section h2{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;margin:0 0 1.25rem}.profile-form__field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.profile-form__field:last-child{margin-bottom:0}.profile-form__field label{font-size:.875rem;font-weight:600;color:#374151}.profile-form__field input,.profile-form__field select{border:1px solid #d1d5db;border-radius:6px;padding:.6rem .75rem;font-size:.9rem;color:#111827;background:#fff;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box;font-family:inherit}.profile-form__field input:focus,.profile-form__field select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4b1a6e1f}.profile-form__hint{font-size:.8rem;font-weight:400;color:#9ca3af}.profile-form__row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.profile-form__actions{display:flex;justify-content:flex-end}.profile-form__submit{padding:.65rem 1.75rem;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;background:var(--color-primary);color:var(--color-text-on-primary)}.profile-form__submit:hover:not(:disabled){background:var(--color-primary-hover)}.profile-form__submit:disabled{opacity:.6;cursor:not-allowed}.season-selector{display:flex;align-items:center;gap:.5rem}.season-selector__label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #6b7280);white-space:nowrap}.season-selector__select{padding:.375rem .75rem;border:1px solid var(--color-border, #d1d5db);border-radius:6px;background-color:var(--color-surface, #ffffff);color:var(--color-text, #111827);font-size:.875rem;cursor:pointer;min-width:140px}.season-selector__select:focus{outline:none;border-color:var(--color-primary, #7c3aed);box-shadow:0 0 0 2px #7c3aed33}.season-selector__loading{font-size:.875rem;color:var(--color-text-secondary, #6b7280)}.stats-table-wrapper{width:100%;overflow-x:auto;border-radius:8px;border:1px solid var(--color-border, #e5e7eb)}.stats-table{width:100%;border-collapse:collapse;font-size:.875rem;white-space:nowrap}.stats-table thead{background-color:var(--color-surface-raised, #f9fafb);border-bottom:2px solid var(--color-border, #e5e7eb)}.stats-table th{padding:.625rem .75rem;text-align:right;font-weight:600;color:var(--color-text-secondary, #6b7280);font-size:.8rem;letter-spacing:.02em;text-transform:uppercase}.stats-table th:first-child{text-align:left}.stats-table td{padding:.5rem .75rem;text-align:right;color:var(--color-text, #111827);border-bottom:1px solid var(--color-border, #f3f4f6)}.stats-table td:first-child{text-align:left}.stats-table tbody tr:last-child td{border-bottom:none}.stats-table tbody tr:hover{background-color:var(--color-surface-hover, #f9fafb)}.stats-table__ratio{font-variant-numeric:tabular-nums;color:var(--color-text-secondary, #6b7280)}.stats-table__highlight{font-weight:600;color:var(--color-primary, #7c3aed)!important}.stats-table__sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.stats-table__sortable:hover{background-color:var(--color-surface-hover, #f3f4f6);color:var(--color-text, #111827)}.stats-table__sorted{color:var(--color-primary, #7c3aed);background-color:#7c3aed0d}.stats-table__player-col{text-align:left!important;font-weight:500;min-width:140px;max-width:200px;overflow:hidden;text-overflow:ellipsis}.stats-table__player-link{color:inherit;text-decoration:none;font-weight:500}.stats-table__player-link:hover{color:var(--color-primary, #7c3aed);text-decoration:underline}.stats-table__empty{text-align:center!important;color:var(--color-text-secondary, #9ca3af);padding:2rem!important;font-style:italic}.stats-table__ip{font-variant-numeric:tabular-nums}.stats-edit-form{background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:10px;padding:1.5rem;margin-top:1.5rem}.stats-edit-form__header{margin-bottom:1rem}.stats-edit-form__title{font-size:1rem;font-weight:600;color:var(--color-text, #111827);margin:0}.stats-edit-form__error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;padding:.625rem .875rem;font-size:.875rem;margin-bottom:1rem}.stats-edit-form__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem;margin-bottom:1.25rem}.stats-edit-form__field{display:flex;flex-direction:column;gap:.25rem}.stats-edit-form__field--full{grid-column:1 / -1;max-width:200px}.stats-edit-form__field label{font-size:.75rem;font-weight:600;color:var(--color-text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.04em}.stats-edit-form__field input,.stats-edit-form__field select{padding:.375rem .5rem;border:1px solid var(--color-border, #d1d5db);border-radius:6px;font-size:.875rem;color:var(--color-text, #111827);background:var(--color-surface, #ffffff);text-align:right;width:100%}.stats-edit-form__field input:focus,.stats-edit-form__field select:focus{outline:none;border-color:var(--color-primary, #7c3aed);box-shadow:0 0 0 2px #7c3aed33}.stats-edit-form__field input[type=number]::-webkit-outer-spin-button,.stats-edit-form__field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.stats-edit-form__field input[type=number]{-moz-appearance:textfield}.stats-edit-form__actions{display:flex;justify-content:flex-end;gap:.75rem}.stats-edit-form__btn-cancel{padding:.5rem 1.25rem;border:1px solid var(--color-border, #d1d5db);border-radius:6px;background:transparent;color:var(--color-text-secondary, #6b7280);font-size:.875rem;cursor:pointer}.stats-edit-form__btn-cancel:hover{background:var(--color-surface-raised, #f9fafb)}.stats-edit-form__btn-save{padding:.5rem 1.25rem;border:none;border-radius:6px;background:var(--color-primary, #7c3aed);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer}.stats-edit-form__btn-save:hover:not(:disabled){background:var(--color-primary-dark, #6d28d9)}.stats-edit-form__btn-save:disabled{opacity:.6;cursor:not-allowed}.player-stats-page{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.player-stats-page__header{display:flex;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.player-stats-page__title{font-size:1.5rem;font-weight:700;color:var(--color-text, #111827);margin:0;flex:1;min-width:200px}.player-stats-page__controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.player-stats-page__badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.player-stats-page__badge--active{background:#10b9811a;color:#065f46;border:1px solid rgba(16,185,129,.3)}.player-stats-page__edit-btn{padding:.5rem 1rem;background:var(--color-primary, #7c3aed);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer}.player-stats-page__edit-btn:hover{background:var(--color-primary-dark, #6d28d9)}.player-stats-page__error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.875rem}.player-stats-page__tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border, #e5e7eb);margin-bottom:1.5rem}.player-stats-page__tab{padding:.625rem 1.25rem;border:none;background:none;font-size:.9rem;font-weight:500;color:var(--color-text-secondary, #6b7280);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.player-stats-page__tab:hover{color:var(--color-text, #111827)}.player-stats-page__tab--active{color:var(--color-primary, #7c3aed);border-bottom-color:var(--color-primary, #7c3aed)}.player-stats-page__content{min-height:200px}.player-stats-page__loading,.player-stats-page__empty{text-align:center;color:var(--color-text-secondary, #9ca3af);padding:3rem 0;font-style:italic}.stats-page{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.stats-page__header{display:flex;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.stats-page__title{font-size:1.5rem;font-weight:700;color:var(--color-text, #111827);margin:0;flex:1;min-width:200px}.stats-page__controls{display:flex;align-items:center;gap:.75rem}.stats-page__badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500;background:#10b9811a;color:#065f46;border:1px solid rgba(16,185,129,.3)}.stats-page__error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.875rem}.stats-page__tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border, #e5e7eb);margin-bottom:1.5rem}.stats-page__tab{padding:.625rem 1.25rem;border:none;background:none;font-size:.9rem;font-weight:500;color:var(--color-text-secondary, #6b7280);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.stats-page__tab:hover{color:var(--color-text, #111827)}.stats-page__tab--active{color:var(--color-primary, #7c3aed);border-bottom-color:var(--color-primary, #7c3aed)}.stats-page__content{min-height:200px}.stats-page__loading{text-align:center;color:var(--color-text-secondary, #9ca3af);padding:3rem 0;font-style:italic}.roster-list-wrapper{width:100%;overflow-x:auto;border-radius:8px;border:1px solid var(--color-border, #e5e7eb)}.roster-list{width:100%;border-collapse:collapse;font-size:.875rem;white-space:nowrap}.roster-list thead{background-color:var(--color-surface-raised, #f9fafb);border-bottom:2px solid var(--color-border, #e5e7eb)}.roster-list__th{padding:.625rem .75rem;text-align:left;font-weight:600;color:var(--color-text-secondary, #6b7280);font-size:.8rem;letter-spacing:.02em;text-transform:uppercase}.roster-list__td{padding:.5rem .75rem;text-align:left;color:var(--color-text, #111827);border-bottom:1px solid var(--color-border, #f3f4f6)}.roster-list__th--name,.roster-list__td--name{font-weight:500;min-width:140px;max-width:200px;overflow:hidden;text-overflow:ellipsis}.roster-list tbody tr:last-child td{border-bottom:none}.roster-list tbody tr:hover{background-color:var(--color-surface-hover, #f9fafb)}.roster-list__status{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.roster-list__status--active{background:#dcfce7;color:#166534}.roster-list__status--injured{background:#fef3c7;color:#92400e}.roster-list__status--inactive{background:#e5e7eb;color:#374151}.roster-list__remove-btn{padding:4px 12px;background:#fee2e2;color:#dc2626;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap}.roster-list__remove-btn:hover{background:#fecaca}.roster-list__empty{text-align:center;color:var(--color-text-secondary, #9ca3af);padding:2rem;font-style:italic}.roster-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.roster-modal{background:#fff;border-radius:10px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.roster-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 0}.roster-modal__title{font-size:1.125rem;font-weight:700;margin:0}.roster-modal__close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-secondary, #6b7280);line-height:1;padding:0}.roster-modal__close:hover{color:var(--color-text, #111827)}.roster-modal__form{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.roster-modal__label{display:flex;flex-direction:column;font-size:.875rem;font-weight:500;gap:.25rem;color:var(--color-text, #111827)}.roster-modal__input{padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background:#fff;color:var(--color-text, #111827)}.roster-modal__input:focus{outline:none;border-color:var(--color-accent, #2bb8b0);box-shadow:0 0 0 2px #2bb8b040}.roster-modal__error{color:#dc2626;font-size:.8rem;margin:0;padding:.5rem .75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:6px}.roster-modal__actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.5rem}.roster-modal__btn{padding:8px 20px;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.roster-modal__btn--submit{background:var(--color-accent, #2bb8b0);color:var(--color-text-on-accent, #fff)}.roster-modal__btn--submit:hover:not(:disabled){background:var(--color-accent-hover, #249e97)}.roster-modal__btn--cancel{background:#e5e7eb;color:#374151}.roster-modal__btn--cancel:hover:not(:disabled){background:#d1d5db}.roster-modal__btn:disabled{opacity:.6;cursor:not-allowed}.roster-modal__search{padding:1rem 1.5rem 0}.roster-modal__results{padding:.75rem 1.5rem 1.5rem;max-height:320px;overflow-y:auto}.roster-modal__loading,.roster-modal__empty{color:var(--color-text-secondary, #9ca3af);font-size:.875rem;text-align:center;padding:1.5rem 0;font-style:italic}.roster-modal__result-row{display:flex;align-items:center;justify-content:space-between;padding:.625rem 0;border-bottom:1px solid #f3f4f6;gap:.75rem}.roster-modal__result-row:last-child{border-bottom:none}.roster-modal__result-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.roster-modal__result-name{font-weight:500;font-size:.875rem;color:var(--color-text, #111827);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.roster-modal__result-meta{font-size:.75rem;color:var(--color-text-secondary, #6b7280)}.roster-page{max-width:900px;margin:0 auto;padding:2rem 1rem}.roster-page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.roster-page__title{font-size:1.5rem;font-weight:700;margin:0}.roster-page__actions{display:flex;gap:.5rem}.roster-page__btn{padding:8px 20px;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.roster-page__btn--primary{background:var(--color-accent, #2bb8b0);color:var(--color-text-on-accent, #fff)}.roster-page__btn--primary:hover{background:var(--color-accent-hover, #249e97)}.roster-page__btn--secondary{background:var(--color-surface-raised, #f3f4f6);color:var(--color-text, #111827);border:1px solid var(--color-border, #e5e7eb)}.roster-page__btn--secondary:hover{background:var(--color-surface-hover, #e5e7eb)}.roster-page__loading{color:var(--color-text-secondary, #6b7280);padding:1rem 0}.roster-page__error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.875rem}
