:root{color:#0b1c30;background:#f8f9ff;font-family:Lexend,Pretendard,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--focus-ring: 0 0 0 4px rgb(74 222 128 / 18%)}*{box-sizing:border-box}html,body,#root{min-height:100%;overflow-x:hidden}body{margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button,input,select,textarea,a{min-width:0}button:disabled,select:disabled{cursor:not-allowed;opacity:.58}.shell{--app-bg: #f8f9ff;--app-surface: #ffffff;--app-surface-soft: #eff4ff;--app-surface-strong: #e5eeff;--app-text: #0b1c30;--app-muted: #526074;--app-subtle: #718096;--app-border: #d9e3f3;--app-border-strong: #b9c8dd;--app-primary: #007a3d;--app-primary-strong: #006d36;--app-primary-soft: #ddfbe8;--app-primary-text: #ffffff;--app-secondary: #213145;--app-danger: #ba1a1a;--app-danger-soft: #ffdad6;--app-warning: #895024;--app-shadow: 0 16px 40px rgb(30 41 59 / 8%);--app-shadow-soft: 0 8px 28px rgb(30 41 59 / 6%);background:var(--app-bg);color:var(--app-text);display:grid;grid-template-columns:264px minmax(0,1fr);min-height:100vh}@media(min-width:981px){.shell{height:100vh;overflow:hidden}.sidebar,.main{height:100vh;overflow-y:auto}}.theme-admin{--app-bg: #0b1326;--app-surface: #131b2e;--app-surface-soft: #171f33;--app-surface-strong: #222a3d;--app-text: #dae2fd;--app-muted: #b8c3da;--app-subtle: #8f9bae;--app-border: rgb(255 255 255 / 9%);--app-border-strong: rgb(107 251 154 / 30%);--app-primary: #6bfb9a;--app-primary-strong: #4de082;--app-primary-soft: rgb(107 251 154 / 13%);--app-primary-text: #003919;--app-secondary: #7bd0ff;--app-danger: #ff8f91;--app-danger-soft: rgb(255 143 145 / 13%);--app-warning: #ffd6a3;--app-shadow: 0 18px 50px rgb(0 0 0 / 28%);--app-shadow-soft: 0 10px 30px rgb(0 0 0 / 18%)}.sidebar{background:color-mix(in srgb,var(--app-surface) 94%,transparent);border-right:1px solid var(--app-border);display:grid;gap:12px;grid-template-rows:auto 1fr auto;height:100vh;padding:24px 18px;position:sticky;top:0}.theme-admin .sidebar{background:#0b1326}.brand{display:grid;gap:14px;margin-bottom:28px}.brand-row{align-items:center;display:flex;gap:12px;min-width:0}.brand-character{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:999px;flex:0 0 auto;height:52px;object-fit:contain;padding:3px;width:52px}.theme-admin .brand-character{background:var(--app-primary-soft);border-color:var(--app-border-strong)}.brand-title{color:var(--app-primary-strong);font-size:20px;font-weight:900;line-height:1.1}.theme-admin .brand-title{color:var(--app-text)}.brand-subtitle{color:var(--app-muted);font-size:13px;margin-top:4px}.brand-console-toggle{background:transparent;border:0;cursor:pointer;display:inline-block;font-weight:800;padding:0;text-align:left}.brand-console-toggle:hover{color:var(--app-primary)}.console-switch-menu,.profile-menu,.action-menu{background:var(--app-surface);border:1px solid var(--app-border);border-radius:var(--radius-md);box-shadow:var(--app-shadow);display:grid;padding:6px;position:absolute;z-index:8}.console-switch-menu{margin-top:8px;min-width:180px}.nav{align-content:start;display:grid;gap:6px}.nav-link{align-items:center;border:1px solid transparent;border-radius:var(--radius-md);color:var(--app-muted);display:flex;gap:10px;min-height:44px;padding:10px 12px}.nav-link:hover{background:var(--app-surface-soft);color:var(--app-text)}.nav-link.active{background:var(--app-primary-soft);border-color:var(--app-border-strong);color:var(--app-primary-strong);font-weight:900}.theme-admin .nav-link.active{box-shadow:0 0 18px #6bfb9a26;color:var(--app-primary)}.nav-icon{align-items:center;background:var(--app-surface-soft);border-radius:10px;display:inline-flex;flex:0 0 auto;height:28px;justify-content:center;width:28px}.nav-icon svg{display:block}.nav-link.active .nav-icon{background:var(--app-primary);color:var(--app-primary-text)}.sidebar-footer{margin-top:12px}.main{min-width:0;padding:32px}.main-topbar{align-items:center;display:flex;gap:10px;justify-content:flex-end;margin-bottom:12px}.profile-menu-wrap{display:inline-flex;position:relative}.profile-avatar-button{align-items:center;background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:999px;color:var(--app-primary-strong);cursor:pointer;display:inline-flex;height:42px;justify-content:center;overflow:hidden;padding:0;width:42px}.tennis-ball-avatar{background:radial-gradient(circle at 35% 32%,#fff9c8,#f6df55 68%,#d5bd30)}.tennis-ball-icon{font-size:20px;line-height:1}.profile-menu{min-width:168px}.profile-menu-above{bottom:calc(100% + 8px);left:0}.profile-menu-below{right:0;top:calc(100% + 8px)}.profile-menu a,.profile-menu button,.console-switch-menu button,.action-menu button{background:transparent;border:0;border-radius:var(--radius-sm);color:var(--app-muted);cursor:pointer;font-size:14px;font-weight:800;padding:9px 10px;text-align:left}.profile-menu a:hover,.profile-menu button:hover,.console-switch-menu button:hover,.action-menu button:hover{background:var(--app-surface-soft);color:var(--app-text)}.profile-menu .danger-link,.action-menu .danger-text{color:var(--app-danger)}.desktop-profile-control{display:inline-flex}.mobile-profile-control{display:none}.page{display:grid;gap:22px;margin:0 auto;max-width:1240px;min-width:0;width:100%}.page>*{min-width:0}.page-header{align-items:end;display:flex;gap:18px;justify-content:space-between;min-width:0}.page-title{color:var(--app-text);font-size:34px;font-weight:900;line-height:1.12;margin:0}.theme-admin .page-title{font-size:46px;letter-spacing:0}.page-description{color:var(--app-muted);font-size:15px;line-height:1.55;margin:8px 0 0;overflow-wrap:anywhere}.panel,.metric{background:var(--app-surface);border:1px solid var(--app-border);border-radius:var(--radius-xl);box-shadow:var(--app-shadow-soft);min-width:0;padding:22px}.theme-admin .panel,.theme-admin .metric{border-radius:var(--radius-md);box-shadow:none}.panel h2,.panel h3{color:var(--app-text);line-height:1.25;margin:0}.metric-grid{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}.metric{min-height:118px}.metric.fee-metric,.fee-overview,.pending-panel{background:linear-gradient(135deg,var(--app-primary-soft),color-mix(in srgb,var(--app-surface) 92%,transparent)),var(--app-surface)}.metric-label{color:var(--app-muted);font-size:13px;font-weight:800}.metric-value{color:var(--app-primary-strong);font-size:30px;font-weight:900;margin-top:10px}.metric-subline{color:var(--app-muted);font-size:12px;font-weight:800;margin-top:6px}.theme-admin .metric-value{color:var(--app-primary)}.fee-metric{display:grid;gap:10px}.fee-metric .metric-value{font-size:22px;margin-top:0}.fee-metric-topline,.fee-overview-summary,.fee-track-head{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between}.fee-pill,.admin-pill,.count-pill{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:999px;color:var(--app-muted);cursor:pointer;display:inline-flex;font-size:12px;font-weight:900;line-height:1.2;padding:6px 10px;text-decoration:none}.admin-pill.active{background:var(--app-surface-soft);border-color:var(--app-primary);border-width:2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--app-primary) 18%,transparent);color:var(--app-primary-strong);transform:translateY(-1px)}.fee-pill,.count-pill{cursor:default}.fee-track-list{display:grid;gap:12px}.fee-track{display:grid;gap:6px}.fee-track-head{color:var(--app-muted);font-size:12px;font-weight:800}.fee-track-bar{background:var(--app-surface-strong);border-radius:999px;height:9px;overflow:hidden}.fee-track-bar span{background:linear-gradient(90deg,var(--app-primary-strong),var(--app-primary));border-radius:inherit;display:block;height:100%}.fee-metric-footer{color:var(--app-muted);display:flex;font-size:12px;justify-content:space-between}.fee-overview{align-items:center;display:grid;gap:18px;grid-template-columns:minmax(180px,.35fr) minmax(0,1fr)}.fee-overview-value{color:var(--app-primary-strong);font-size:34px;font-weight:900;margin-top:8px}.fee-overview-body{display:grid;gap:12px}.table{border-collapse:separate;border-spacing:0;min-width:760px;width:100%}.list-only-layout{max-width:100%;min-width:0;overflow:hidden}.list-only-layout .panel{max-width:100%;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.table th,.table td{padding:14px 12px;text-align:left;vertical-align:middle}.table th{color:var(--app-subtle);font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.theme-admin .table tbody tr{background:color-mix(in srgb,var(--app-surface-soft) 48%,transparent)}.theme-admin .table tbody tr+tr td{border-top:6px solid var(--app-surface)}.sort-button{background:transparent;border:0;color:inherit;cursor:pointer;font:inherit;font-weight:900;padding:0;text-align:left}.sort-button:hover{color:var(--app-primary)}.table tr.clickable,.detail-list li.clickable{cursor:pointer}.table tr.clickable:hover,.detail-list li.clickable:hover,.choice-button:hover{background:var(--app-surface-soft)}.table tr.clickable.selected{background:var(--app-primary-soft)}.table tr.clickable.selected td:first-child{color:var(--app-primary-strong);font-weight:900}.staff-badge{background:var(--app-primary);border-radius:999px;color:var(--app-primary-text);display:inline-block;font-size:11px;font-weight:900;margin-right:6px;padding:4px 8px;vertical-align:middle}.member-name-emphasis{color:var(--app-primary-strong);font-weight:900}.theme-admin .member-name-emphasis{color:var(--app-primary)}.detail-list{display:grid;gap:10px;margin:0;padding:0}.detail-list.compact{max-height:240px;overflow:auto}.detail-list li{align-items:center;border:1px solid var(--app-border);border-radius:var(--radius-md);display:flex;gap:12px;justify-content:space-between;list-style:none;min-height:52px;min-width:0;padding:12px 14px}.detail-list li>*,.info-list dd,.meetup-row-left,.meetup-row-right{min-width:0}.theme-user .detail-list li{border-color:var(--app-border);box-shadow:none}.info-list{display:grid;gap:8px;margin:0}.info-list div{align-items:center;display:flex;gap:12px;justify-content:space-between;padding:10px 0}.info-list div+div{border-top:1px solid var(--app-border)}.info-list dt{color:var(--app-muted);font-weight:800}.info-list dd{margin:0}.info-list .info-list-note{align-items:start;display:grid;gap:6px;justify-content:stretch}.info-list .info-list-note dd{color:var(--app-muted);line-height:1.55;white-space:pre-wrap}.member-name-list{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);color:var(--app-muted);line-height:1.7;padding:12px 14px}.dashboard-list-block{display:grid;gap:10px}.dashboard-list-block+.dashboard-list-block{margin-top:20px;padding-top:6px}.panel h2+.detail-list,.panel h2+.member-name-list,.panel h2+.info-list,.panel h2+.table,.panel h2+.stack,.panel h2+.member-name-grid,.panel h3+.detail-list,.panel h3+.member-name-list,.panel h3+.info-list,.panel h3+.table,.panel h3+.stack,.panel h3+.member-name-grid{margin-top:12px}.level-member-group{gap:8px}.level-member-group h3+.member-name-list{margin-top:6px}.level-member-group+.level-member-group{margin-top:18px}.dashboard-list-block>h2{font-size:20px;font-weight:900;letter-spacing:-.01em}.level-member-group>h3{color:var(--app-muted);font-size:15px;font-weight:900}.dashboard-gender-sections{display:grid;gap:12px}.dashboard-gender-block{display:grid;gap:6px}.dashboard-gender-title{color:var(--app-subtle);font-size:12px;font-weight:900;letter-spacing:.01em;padding-left:2px}.activity-panel{display:grid;gap:12px}.activity-filter-bar,.pagination-bar{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.pagination-bar{justify-content:center}.pagination-bar span{color:var(--app-muted);font-size:13px;font-weight:900;min-width:64px;text-align:center}.sheet-sync-panel{align-items:start;display:grid;gap:16px;grid-template-columns:minmax(0,1fr) auto}.sheet-sync-panel h2{margin:0}.sheet-sync-panel .muted{margin:6px 0 0}.sheet-sync-actions{align-self:center}.sheet-sync-status-grid{display:grid;gap:10px;grid-column:1 / -1;grid-template-columns:repeat(4,minmax(0,1fr))}.sheet-sync-status-grid div{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);display:grid;gap:6px;min-width:0;padding:12px}.sheet-sync-status-grid span{color:var(--app-muted);font-size:12px;font-weight:900}.sheet-sync-status-grid strong{color:var(--app-text);font-size:14px;font-weight:900;line-height:1.35;overflow-wrap:anywhere}.activity-list{display:grid;gap:10px;margin:0;padding:0}.activity-item{align-items:start;background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);display:grid;gap:12px;grid-template-columns:12px minmax(0,1fr);list-style:none;min-width:0;padding:13px 14px}.activity-dot{background:var(--app-secondary);border-radius:999px;height:10px;margin-top:6px;width:10px}.activity-dot.create{background:var(--app-primary)}.activity-dot.update{background:var(--app-warning)}.activity-dot.danger{background:var(--app-danger)}.activity-content{display:grid;gap:6px;min-width:0}.activity-line{color:var(--app-text);display:flex;flex-wrap:wrap;gap:6px;line-height:1.45}.activity-line strong{color:var(--app-primary-strong);font-weight:900}.theme-admin .activity-line strong{color:var(--app-primary)}.activity-meta{color:var(--app-muted);display:flex;flex-wrap:wrap;font-size:12px;font-weight:800;gap:6px}.activity-meta span{background:var(--app-surface);border:1px solid var(--app-border);border-radius:999px;padding:4px 8px}.split-grid{display:grid;gap:16px;grid-template-columns:minmax(0,1.4fr) minmax(280px,.8fr)}.user-home-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stack{display:grid;gap:12px}.form-row,.toolbar,.modal-actions,.drawer-actions,.profile-edit-actions,.admin-meetup-summary{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.form-row{margin-bottom:16px}.toolbar{margin:0}.modal-actions,.profile-edit-actions{justify-content:flex-end}.input{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);color:var(--app-text);min-height:44px;padding:10px 12px;width:100%}.input::placeholder{color:var(--app-subtle)}.input:focus,.choice-button:focus,.button:focus,.icon-button:focus,.nav-link:focus-visible{border-color:var(--app-primary);box-shadow:var(--focus-ring);outline:0}.compact-select{min-height:36px;padding:6px 8px;width:auto}.textarea{font-family:inherit;line-height:1.45;resize:vertical}.checkbox-row{align-items:center;display:flex;gap:8px}.button{align-items:center;background:var(--app-primary);border:1px solid transparent;border-radius:var(--radius-md);color:var(--app-primary-text);cursor:pointer;display:inline-flex;font-weight:900;justify-content:center;min-height:44px;overflow-wrap:anywhere;padding:10px 16px;text-align:center}.theme-admin .button{color:#003919}.button:hover{filter:brightness(.96)}.button.secondary{background:var(--app-surface-soft);border-color:var(--app-border);color:var(--app-text)}.button.danger{background:var(--app-danger);color:#fff}.button.small{min-height:34px;padding:6px 10px}.button.full{width:100%}.status-text{color:var(--app-muted);padding:12px 0}.status-text.error{color:var(--app-danger)}.muted{color:var(--app-muted);line-height:1.55}.drawer-backdrop{background:#02061775;display:flex;top:0;right:0;bottom:0;left:0;justify-content:flex-end;position:fixed;z-index:18}.side-drawer{animation:drawer-slide-in .22s ease-out;background:var(--app-surface);border-left:1px solid var(--app-border);box-shadow:-18px 0 54px #0000003d;display:grid;grid-template-rows:auto minmax(0,1fr);height:100vh;height:100dvh;max-width:620px;overflow:auto;padding:24px;width:min(100vw,560px)}.side-drawer:has(.admin-court-roster-list){max-width:840px;width:min(100vw,800px)}.side-drawer-head{align-items:start;display:flex;gap:16px;justify-content:space-between;padding-bottom:18px}.side-drawer-head h2{font-size:26px;margin:4px 0 0}.drawer-eyebrow{color:var(--app-primary-strong);font-size:13px;font-weight:900}.drawer-body{display:grid;gap:18px;padding-top:18px}.drawer-section{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);display:grid;gap:12px;padding:14px}.drawer-section h3{margin:0}.active-profile-section{background:var(--app-surface);border:1px solid var(--app-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:14px;padding:16px}.active-profile-section h3{line-height:1.2}.profile-head-block .muted{margin:6px 0 0}.profile-summary-card{align-items:center;background:linear-gradient(135deg,var(--app-primary-soft),var(--app-surface-soft));border:1px solid var(--app-border-strong);border-radius:var(--radius-lg);display:flex;gap:14px;min-width:0;padding:16px}.profile-summary-card>div:last-child{min-width:0}.profile-avatar-large{align-items:center;background:var(--app-primary);border-radius:999px;color:var(--app-primary-text);display:inline-flex;flex:0 0 auto;font-size:24px;font-weight:900;height:56px;justify-content:center;width:56px}.profile-summary-name{color:var(--app-text);font-size:22px;font-weight:900;line-height:1.25;overflow-wrap:anywhere}.profile-summary-meta{color:var(--app-muted);font-size:13px;font-weight:800;margin-top:4px}.profile-info-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.profile-read-list,.profile-edit-form,.edit-field-grid,.choice-list{display:grid;gap:12px}.profile-read-list{margin:0;padding:0}.profile-read-row{align-content:start;align-items:start;background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);display:grid;gap:8px;grid-template-columns:1fr;min-width:0;min-height:78px;padding:14px}.profile-read-row dt,.profile-edit-field span,.edit-field-grid label span,.field-label{color:var(--app-muted);font-size:13px;font-weight:900}.profile-read-row dd{color:var(--app-text);font-weight:900;line-height:1.35;margin:0;overflow-wrap:anywhere;text-align:left}.profile-edit-note{color:var(--app-muted);font-size:13px}.profile-edit-field,.edit-field-grid label,.edit-field-group{display:grid;gap:7px}.menu-wrap{position:relative}.icon-button{align-items:center;background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);color:var(--app-text);cursor:pointer;display:inline-flex;font-weight:900;height:36px;justify-content:center;width:38px}.icon-button:hover{background:var(--app-surface-strong)}.close-button{font-size:20px;line-height:1}.action-menu{min-width:120px;right:0;top:calc(100% + 6px)}.inline-fields{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.staff-toggle{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);display:grid;gap:4px;grid-template-columns:repeat(2,minmax(0,1fr));padding:4px}.staff-toggle-option{background:transparent;border:0;border-radius:var(--radius-sm);color:var(--app-muted);cursor:pointer;font-weight:900;min-height:38px}.staff-toggle-option.active{background:var(--app-primary);color:var(--app-primary-text)}.theme-admin .staff-toggle-option.active{color:#003919}.fee-toggle-grid{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.fee-toggle-card{align-items:center;background:var(--app-surface);border:1px solid var(--app-border);border-radius:var(--radius-md);color:var(--app-text);cursor:pointer;display:flex;justify-content:space-between;min-height:52px;padding:10px 12px}.fee-toggle-card span{color:var(--app-muted);font-size:13px;font-weight:900}.fee-toggle-card strong{font-size:15px}.fee-toggle-card.paid{background:var(--app-primary-soft);border-color:var(--app-border-strong);color:var(--app-primary-strong)}@keyframes drawer-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.modal-backdrop{align-items:center;background:#02061785;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:20px;position:fixed;z-index:20}.modal{background:var(--app-surface);border:1px solid var(--app-border);border-radius:var(--radius-lg);box-shadow:var(--app-shadow);display:grid;gap:14px;max-width:520px;max-height:calc(100dvh - 40px);overflow:auto;padding:22px;width:min(100%,520px)}.modal:has(.court-roster-list){max-width:760px;width:min(100%,760px)}.modal .detail-list li{align-items:center;background:var(--app-surface-soft);border:1px solid var(--app-border);box-shadow:none;display:grid;gap:12px;grid-template-columns:minmax(110px,.42fr) minmax(0,1fr);justify-content:stretch;min-width:0;overflow:hidden;padding:12px;width:100%}.modal .detail-list li span{display:block;max-width:100%;min-width:0;overflow-wrap:anywhere;white-space:normal;word-break:keep-all}.modal .detail-list li span:first-child{color:var(--app-text);font-weight:900}.modal .detail-list li span:last-child{color:var(--app-muted);font-size:13px;line-height:1.4;text-align:right}.modal h2{margin:0}.confirm-backdrop{--app-bg: #f8f9ff;--app-surface: #ffffff;--app-surface-soft: #eff4ff;--app-surface-strong: #e5eeff;--app-text: #0b1c30;--app-muted: #526074;--app-subtle: #718096;--app-border: #d9e3f3;--app-border-strong: #b9c8dd;--app-primary: #007a3d;--app-primary-strong: #006d36;--app-primary-soft: #ddfbe8;--app-primary-text: #ffffff;--app-danger: #ba1a1a;--app-danger-soft: #ffdad6;--app-shadow: 0 16px 40px rgb(30 41 59 / 8%);z-index:40}.confirm-modal{align-items:start;gap:16px;grid-template-columns:48px minmax(0,1fr);max-width:460px}.confirm-modal .modal-actions{grid-column:1 / -1}.confirm-icon{align-items:center;background:var(--app-primary-soft);border:1px solid var(--app-border-strong);border-radius:999px;color:var(--app-primary-strong);display:inline-flex;font-size:24px;font-weight:900;height:48px;justify-content:center;line-height:1;width:48px}.confirm-modal.danger .confirm-icon{background:var(--app-danger-soft);border-color:color-mix(in srgb,var(--app-danger) 38%,transparent);color:var(--app-danger)}.confirm-body{display:grid;gap:6px;min-width:0}.confirm-body .muted{margin:0}.court-roster-list{display:grid;gap:14px;max-height:min(62dvh,620px);overflow:auto;padding-right:2px}.court-roster-card{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);display:grid;gap:10px;padding:12px}.court-roster-head{align-items:center;display:flex;gap:10px;justify-content:space-between}.court-roster-head strong{color:var(--app-text);font-size:15px;font-weight:900}.court-roster-head span{background:var(--app-surface);border:1px solid var(--app-border);border-radius:999px;color:var(--app-muted);font-size:12px;font-weight:900;padding:5px 9px}.tennis-court-roster{background:linear-gradient(90deg,transparent calc(50% - 1px),rgb(255 255 255 / 76%) calc(50% - 1px),rgb(255 255 255 / 76%) calc(50% + 1px),transparent calc(50% + 1px)),linear-gradient(0deg,transparent calc(50% - 1px),rgb(255 255 255 / 76%) calc(50% - 1px),rgb(255 255 255 / 76%) calc(50% + 1px),transparent calc(50% + 1px)),#0f8a50;border:2px solid rgb(255 255 255 / 82%);border-radius:var(--radius-sm);box-shadow:inset 0 0 0 8px #ffffff24;min-height:210px;overflow:hidden;padding:18px;position:relative}.tennis-court-roster:before,.tennis-court-roster:after{border:2px solid rgb(255 255 255 / 72%);content:"";top:28px;right:18px;bottom:28px;left:18px;pointer-events:none;position:absolute}.tennis-court-roster:after{border-left:0;border-right:0;top:56px;right:18px;bottom:56px;left:18px}.court-net{background:repeating-linear-gradient(90deg,rgb(11 28 48 / 36%) 0 2px,transparent 2px 8px);bottom:50%;height:5px;left:14px;position:absolute;right:14px;transform:translateY(50%);z-index:1}.court-gender-lanes{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr));min-height:174px;position:relative;z-index:2}.court-gender-lane{align-content:start;background:#ffffff29;border:1px solid rgb(255 255 255 / 34%);border-radius:var(--radius-sm);display:grid;gap:8px;min-width:0;padding:10px}.court-gender-lane.unknown{grid-column:1 / -1}.court-gender-title{color:#fff;font-size:12px;font-weight:900;text-shadow:0 1px 2px rgb(0 0 0 / 32%)}.court-player-list,.court-unassigned-list{display:grid;gap:8px}.court-player{align-items:center;background:#fffffff0;border:1px solid rgb(255 255 255 / 72%);border-left:4px solid var(--app-border-strong);border-radius:var(--radius-sm);box-shadow:0 8px 18px #02061724;color:var(--app-text);display:grid;gap:8px;grid-template-columns:34px minmax(0,1fr);min-height:48px;min-width:0;padding:7px 9px}.court-player.male{border-left-color:#2563eb}.court-player.female{border-left-color:#db2777}.court-player-avatar{align-items:center;background:var(--app-primary-soft);border:1px solid var(--app-border);border-radius:999px;color:var(--app-primary-strong);display:inline-flex;font-size:13px;font-weight:900;height:34px;justify-content:center;width:34px}.court-player strong,.court-player small{display:block;max-width:100%;min-width:0;overflow-wrap:anywhere}.court-player strong{color:var(--app-text);line-height:1.25}.court-player strong.member-name-emphasis,.court-roster-list .court-player strong.member-name-emphasis{color:var(--app-primary-strong)}.theme-admin .court-player strong.member-name-emphasis{color:var(--app-primary)}.theme-admin .court-player strong{color:#213145;font-weight:900}.theme-admin .court-roster-list .court-player strong.member-name-emphasis{color:#006d36}.court-player small{color:var(--app-muted);font-size:12px;font-weight:800;line-height:1.35;margin-top:2px}.court-empty{align-items:center;color:#fff;display:flex;font-weight:900;top:0;right:0;bottom:0;left:0;justify-content:center;position:absolute;text-shadow:0 1px 2px rgb(0 0 0 / 32%);z-index:2}.court-roster-card.unassigned{background:var(--app-surface)}.court-roster-card.unassigned .court-player{background:var(--app-surface-soft);border-color:var(--app-border);color:var(--app-text)}.court-roster-card.unassigned .court-player strong{color:var(--app-text)}.theme-admin .court-roster-card.unassigned .court-player{background:#171f33}.theme-admin .court-roster-card.unassigned .court-player strong{color:#f4f7ff}.theme-admin .court-roster-card.unassigned .court-player strong.member-name-emphasis{color:var(--app-primary)}.court-unassigned-list{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-court-roster-list{max-height:none;overflow:visible}.admin-court-player{grid-template-columns:34px minmax(0,1fr) minmax(122px,auto)}.admin-court-player-actions{align-items:center;display:flex;gap:6px;justify-content:flex-end;min-width:0}.admin-court-player-actions .compact-select{background:var(--app-surface);max-width:116px}.admin-court-player-actions .button.small{min-height:36px}.choice-list{max-height:280px;overflow:auto}.choice-button{align-items:center;background:var(--app-surface);border:1px solid var(--app-border);border-radius:var(--radius-md);color:var(--app-text);cursor:pointer;display:flex;justify-content:space-between;padding:10px 12px;text-align:left}.notice-item{display:block}.active-like{background:var(--app-surface-strong)}.meetup-row-left{display:grid;gap:4px}.meetup-row-left strong{color:var(--app-text)}.meetup-row-left small,.admin-meetup-sub{color:var(--app-muted);font-size:12px}.meetup-row-right{align-items:center;align-content:center;display:flex;flex-wrap:nowrap;gap:8px;justify-content:flex-end;white-space:nowrap}.meetup-row-right .status-chip,.meetup-row-right .count-pill,.meetup-row-right .button.small,.meetup-row-right .compact-select{align-items:center;box-sizing:border-box;flex:0 0 auto;min-height:34px}.meetup-row-right .status-chip,.meetup-row-right .count-pill{display:inline-flex;line-height:1}.meetup-list-panel{display:grid;gap:18px}.meetup-week-section{gap:12px}.meetup-week-title{font-size:17px}.meetup-card-list{gap:12px}.meetup-card-list .meetup-card{align-items:stretch;background:var(--app-surface);border:1px solid var(--app-border);box-shadow:var(--app-shadow-soft);display:grid;gap:18px;grid-template-columns:minmax(0,1fr) minmax(180px,220px);padding:16px}.theme-user .meetup-card-list .meetup-card{border-color:var(--app-border);box-shadow:var(--app-shadow-soft)}.meetup-card-main{display:grid;gap:8px;min-width:0}.meetup-card-title-row{align-items:center;display:flex;gap:10px;justify-content:space-between;min-width:0}.meetup-card-title-row strong{color:var(--app-text);font-size:17px;line-height:1.35;min-width:0;overflow-wrap:anywhere}.meetup-card-meta{color:var(--app-muted);display:flex;flex-wrap:wrap;font-size:12px;font-weight:800;gap:6px}.meetup-card-meta span{background:var(--app-surface-soft);border-radius:999px;padding:5px 8px}.meetup-card-actions{align-content:center;align-items:center;display:flex;gap:8px;justify-content:flex-end;min-width:0}.meetup-card-actions .count-pill{flex:0 0 auto}.meetup-card-actions .status-chip,.meetup-card-actions .count-pill{min-height:34px}.meetup-card-actions .button{flex:0 0 auto}.court-choice-group{background:var(--app-surface-soft);border:1px solid var(--app-border);border-radius:var(--radius-md);display:grid;gap:4px;grid-template-columns:repeat(2,minmax(0,1fr));padding:4px;flex:0 0 132px}.court-choice{background:transparent;border:0;border-radius:var(--radius-sm);color:var(--app-muted);cursor:pointer;font-size:12px;font-weight:900;min-height:32px;padding:5px 6px}.court-choice.active{background:var(--app-primary);color:var(--app-primary-text)}.status-chip,.admin-status-chip{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:900;line-height:1;overflow-wrap:normal;padding:5px 9px;vertical-align:middle;white-space:nowrap;word-break:keep-all}.admin-publish-chip,.admin-capacity-chip{border-radius:999px;display:inline-flex;font-size:12px;font-weight:900;justify-content:center;min-width:58px;padding:6px 10px}.admin-publish-chip.active{background:var(--app-primary-soft);color:var(--app-primary)}.admin-publish-chip.inactive{background:color-mix(in srgb,var(--app-muted) 16%,transparent);color:var(--app-muted)}.admin-capacity-chip{background:color-mix(in srgb,var(--app-secondary) 16%,transparent);color:var(--app-secondary)}.status-chip.upcoming,.admin-status-chip.scheduled,.admin-pill.scheduled{background:var(--app-primary-soft);border-color:var(--app-border-strong);color:var(--app-primary-strong)}.theme-admin .status-chip.upcoming,.theme-admin .admin-status-chip.scheduled,.theme-admin .admin-pill.scheduled{color:var(--app-primary)}.status-chip.done,.admin-status-chip.completed,.admin-pill.completed{background:color-mix(in srgb,var(--app-secondary) 16%,transparent);color:var(--app-secondary)}.admin-status-chip.canceled,.admin-pill.canceled{background:var(--app-danger-soft);color:var(--app-danger)}.admin-meetup-summary{margin-bottom:14px}.admin-meetup-title{color:var(--app-text);font-weight:900}.login-page{background:radial-gradient(circle at 20% 12%,rgb(74 222 128 / 18%),transparent 30%),radial-gradient(circle at 82% 88%,rgb(0 109 54 / 12%),transparent 36%),linear-gradient(145deg,#f8f9ff,#fff 52%,#eff4ff);min-height:100vh;padding:24px 16px;place-items:center}.auth-layout{align-items:stretch;display:grid;gap:18px;grid-template-columns:minmax(320px,390px) minmax(220px,280px)}.login-panel,.auth-image-panel{background:#fff;border:1px solid #d9e3f3;border-radius:var(--radius-xl);box-shadow:var(--app-shadow-soft)}.login-panel{display:grid;gap:14px;max-width:390px;padding:24px;width:min(100%,390px)}.auth-image-panel{align-items:center;display:flex;justify-content:center;padding:20px}.auth-character{filter:drop-shadow(0 8px 14px rgb(0 109 54 / 18%));max-width:100%;width:220px}.login-title{color:#0b1c30;font-size:28px;line-height:1.2;margin:0}.login-field{display:grid;gap:7px}.login-field span{color:#526074;font-size:13px;font-weight:900}.login-panel .input{background:#eff4ff;border-color:#d9e3f3;color:#0b1c30;min-height:48px}.login-submit{background:#007a3d;border-radius:var(--radius-md);margin-top:4px;min-height:48px}.login-links{align-items:center;color:#526074;display:flex;font-size:13px;justify-content:space-between;margin-top:4px}.login-links a,.link-button{color:#006d36;font-weight:900}.link-button{background:transparent;border:0;cursor:pointer;font-size:13px;padding:0}.link-button:hover,.login-links a:hover{text-decoration:underline}@media(max-width:980px){.shell{grid-template-columns:1fr}.sidebar{align-items:center;background:var(--app-surface);border:1px solid var(--app-border);border-radius:22px 22px 0 0;bottom:0;box-shadow:0 -12px 30px #1e293b1f;display:grid;gap:0;grid-template-columns:1fr;height:auto;left:0;padding:8px 12px calc(8px + env(safe-area-inset-bottom));position:fixed;right:0;top:auto;z-index:12}.brand,.sidebar-footer{display:none}.nav{display:grid;gap:4px;grid-template-columns:repeat(3,minmax(0,1fr));width:100%}.theme-admin .nav{grid-template-columns:repeat(6,minmax(0,1fr))}.nav-link{border-radius:16px;display:grid;gap:3px;justify-items:center;min-height:58px;padding:7px 4px;text-align:center}.nav-icon{height:26px;width:26px}.nav-label{font-size:10px;font-weight:900;line-height:1.15;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main{padding:20px 20px calc(96px + env(safe-area-inset-bottom))}.main-topbar{justify-content:flex-end;margin-bottom:10px}.theme-admin .main-topbar{justify-content:flex-end}.desktop-profile-control{display:none}.mobile-profile-control{display:inline-flex}.page{gap:18px}.page-header{align-items:stretch;display:grid}.page-title,.theme-admin .page-title{font-size:34px;line-height:1.15}.metric-grid,.split-grid,.user-home-grid,.sheet-sync-panel,.fee-overview{grid-template-columns:1fr}.sheet-sync-actions .button{width:100%}.sheet-sync-status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel,.metric{border-radius:var(--radius-xl);padding:20px}.side-drawer{max-width:100vw;width:100vw}.detail-list li{align-items:stretch;display:grid;gap:10px}.meetup-row-right{flex-wrap:wrap;justify-content:start}.meetup-card-list .meetup-card{grid-template-columns:1fr}.meetup-card-actions{display:grid;justify-items:stretch;min-width:0}.meetup-card-actions .button,.court-choice-group{flex-basis:auto;width:100%}.table{min-width:680px}}@media(max-width:560px){.main{padding-left:16px;padding-right:16px}.theme-admin .main{padding-left:14px;padding-right:14px}.page-title,.theme-admin .page-title{font-size:30px}.page-description{font-size:14px}.toolbar{align-items:stretch;display:grid}.toolbar .button{width:100%}.profile-menu-below{right:0;top:calc(100% + 8px);width:min(260px,calc(100vw - 32px))}.inline-fields,.fee-toggle-grid,.profile-read-row,.profile-info-grid,.sheet-sync-status-grid{grid-template-columns:1fr}.profile-summary-card{align-items:start}.active-profile-section{gap:12px;padding:14px}.profile-read-row{min-height:auto}.side-drawer{border-left:0;max-width:100vw;padding:20px 16px;width:100vw}.modal-backdrop{padding:14px}.modal{padding:18px;width:100%}.confirm-modal{grid-template-columns:42px minmax(0,1fr)}.confirm-icon{font-size:21px;height:42px;width:42px}.modal:has(.court-roster-list){max-width:100%}.modal .detail-list li{grid-template-columns:minmax(86px,.42fr) minmax(0,1fr)}.court-roster-list{max-height:64dvh}.court-roster-card{padding:10px}.tennis-court-roster{min-height:260px;padding:14px}.court-gender-lanes,.court-unassigned-list{grid-template-columns:1fr}.court-gender-lane.unknown{grid-column:auto}.admin-court-player{grid-template-columns:34px minmax(0,1fr)}.admin-court-player-actions{grid-column:1 / -1;justify-content:stretch}.admin-court-player-actions .compact-select,.admin-court-player-actions .button.small{max-width:none;width:100%}.table{min-width:620px}.theme-admin .nav-label{font-size:8px}.meetup-list-panel{gap:16px;padding:14px}.meetup-week-section,.meetup-card-list{gap:10px}.meetup-card-list .meetup-card{align-items:stretch;display:flex;flex-direction:column;gap:12px;padding:14px}.meetup-card-title-row{align-items:start;display:flex;gap:8px;justify-content:space-between}.meetup-card-meta{display:grid;gap:6px;grid-template-columns:1fr}.meetup-card-meta span{border-radius:var(--radius-sm);overflow-wrap:anywhere;padding:7px 9px}.meetup-card-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.meetup-card-actions .status-chip,.meetup-card-actions .count-pill{justify-content:center;justify-self:stretch;min-height:34px}.court-choice-group{flex:none;width:100%}.meetup-card-actions .button{min-height:42px;width:100%}.auth-layout{grid-template-columns:1fr}.auth-image-panel{display:none}.login-page{min-height:100dvh;padding:16px 12px}.login-panel{max-width:100%;padding:20px 16px;width:min(100%,430px)}}
