:root{--demo-primary:#1e3c72;--demo-secondary:#2a5298;--demo-accent:#ff6b35;--demo-light:#f5f7fa;--demo-dark:#2c3e50;--bg:#eef2f7;--surface:#fff;--border:#e0e4ea;--text:var(--demo-dark);--muted:#5c6b7a;--accent:var(--demo-accent);--accent-dim:#e55a2b;--line:#2c3e501f;--player:#1a2530;--drop-highlight:#ff6b3538;--court-slot-pad-y:clamp(6px, 1.5vw, 10px);--court-chip-block-h:calc((1.85rem * 44 / 36) + 16px);--court-position-slot-min-h:calc(var(--court-chip-block-h) + 2 * var(--court-slot-pad-y) + 2px);--page-pad-x:clamp(.75rem, 4vw, 2rem);--page-pad-y:clamp(.75rem, 3vw, 2.5rem);color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:0 0;font-family:Segoe UI,PingFang SC,Microsoft YaHei,system-ui,sans-serif;line-height:1.5}*,:before,:after{box-sizing:border-box}html{overflow-x:clip}body{min-height:100dvh;color:var(--text);background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);margin:0;overflow-x:clip}#root{min-width:0;min-height:100dvh}.page{width:100%;max-width:1200px;padding:var(--page-pad-y) var(--page-pad-x);padding-top:calc(env(safe-area-inset-top,0px) + var(--app-fixed-topbar-content-h) + var(--page-pad-y));padding-bottom:max(var(--page-pad-y), env(safe-area-inset-bottom,0px));padding-left:max(var(--page-pad-x), env(safe-area-inset-left,0px));padding-right:max(var(--page-pad-x), env(safe-area-inset-right,0px));flex-direction:column;gap:clamp(1.1rem,3vw,1.75rem);min-height:100dvh;margin:0 auto;display:flex}:root{--app-fixed-topbar-content-h:clamp(2.95rem, 10vw, 3.45rem);--dingtalk-nav-blue:#0089ff;--dingtalk-nav-blue-mid:#007ee8;--dingtalk-nav-blue-deep:#0070d2}.app-fixed-topbar{z-index:150;box-sizing:border-box;padding-top:env(safe-area-inset-top,0px);background:linear-gradient(180deg, #1a9fff 0%, var(--dingtalk-nav-blue) 46%, var(--dingtalk-nav-blue-deep) 100%);border-bottom:1px solid #003c7838;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 16px #0064c838,inset 0 1px #ffffff1f}.app-fixed-topbar__inner{z-index:1;max-width:1200px;min-height:var(--app-fixed-topbar-content-h);padding:.35rem max(var(--page-pad-x), env(safe-area-inset-right,0px)) .5rem max(var(--page-pad-x), env(safe-area-inset-left,0px));justify-content:flex-end;align-items:center;gap:.75rem;margin:0 auto;display:flex;position:relative}.app-fixed-topbar__center{z-index:2;text-align:center;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(.22rem,1.5vw,.55rem) clamp(.35rem,2vw,.55rem);max-width:min(92vw,100% - clamp(5.25rem,20vw,7.5rem));display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.app-fixed-topbar__center .title{color:#fffffffa;font-size:clamp(.95rem,3.6vw,1.65rem)}.app-fixed-topbar__center .title__icon{color:#fffffff2}.app-fixed-topbar__detail-btn{cursor:pointer;width:clamp(1.28rem,4.2vw,1.62rem);height:clamp(1.28rem,4.2vw,1.62rem);color:var(--demo-accent);background:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin:0;padding:0;font-size:clamp(.82rem,3.1vw,1.08rem);line-height:1;transition:color .18s,background .18s,box-shadow .18s,transform .18s;display:inline-flex;box-shadow:0 1px 3px #1e3c721f,0 0 0 1px #ff6b3561}.app-fixed-topbar__detail-btn:hover{color:var(--accent-dim);background:#fffaf7;transform:translateY(-1px);box-shadow:0 2px 10px #ff6b3552,0 0 0 1px #ff6b358c}.app-fixed-topbar__detail-btn:focus-visible{outline-offset:2px;outline:2px solid #ff6b35cc}.app-fixed-topbar__trailing{z-index:3;flex-shrink:0;margin-left:auto;position:relative}.app-fixed-topbar__profile{flex-shrink:0;justify-content:flex-end;align-items:center;display:flex}.app-fixed-topbar__profile-dropdown{position:relative}.app-fixed-topbar__user--avatar-only{max-width:none;box-shadow:none;background:0 0;border:none;border-radius:999px;gap:.3rem;padding:.15rem .2rem .15rem .15rem}.app-fixed-topbar__user--avatar-only:hover{box-shadow:none;background:#ffffff24}.app-fixed-topbar__virtual-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2.4rem;height:2.4rem;display:flex;box-shadow:0 2px 12px #0003,0 0 0 2px #ffffffeb}.app-fixed-topbar__virtual-avatar-text{color:#fff;letter-spacing:-.03em;font-variant-numeric:tabular-nums;text-shadow:0 1px 3px #00000059;font-size:clamp(.72rem,2.8vw,.9rem);font-weight:800;line-height:1}.app-fixed-topbar__user{z-index:1;align-items:center;gap:.4rem;line-height:1.2;display:inline-flex;position:relative}.app-fixed-topbar__user-btn{font:inherit;cursor:pointer;appearance:none;-webkit-tap-highlight-color:transparent;text-align:left}.app-fixed-topbar__user-btn:focus-visible{outline-offset:2px;border-radius:999px;outline:2px solid #ffffffe0}.app-fixed-topbar__user-caret{opacity:.92;color:#ffffffeb;flex-shrink:0;font-size:.6rem;transition:transform .2s}.app-fixed-topbar__user-caret--open{transform:rotate(180deg)}.app-fixed-topbar__menu{background:var(--surface);border:1px solid var(--border);z-index:200;border-radius:.65rem;min-width:11.5rem;margin:0;padding:0;position:absolute;top:calc(100% + .35rem);right:0;overflow:hidden;box-shadow:0 8px 28px #0000002e}.app-fixed-topbar__menu-profile{border-bottom:1px solid var(--border);background:linear-gradient(#f8fafc 0%,#fff 52%);padding:.7rem .9rem .72rem}.app-fixed-topbar__menu-meta{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:.45rem .65rem;width:100%;min-width:0;display:grid}.app-fixed-topbar__menu-label{letter-spacing:.08em;color:var(--muted);white-space:nowrap;justify-self:end;font-size:.72rem;font-weight:600;line-height:1.35}.app-fixed-topbar__menu-label:after{content:"：";letter-spacing:0;color:#b0b8c4;margin-left:.02em;font-weight:500}.app-fixed-topbar__menu-value{color:#1e2938;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;line-height:1.4;overflow:hidden}.app-fixed-topbar__menu-value--jersey{font-variant-numeric:tabular-nums;letter-spacing:.03em;color:var(--demo-primary);font-size:.84rem;font-weight:700}.app-fixed-topbar__menu-item{text-align:left;width:100%;font:inherit;color:var(--text);cursor:pointer;background:0 0;border:none;padding:.55rem .9rem;font-size:.88rem;display:block}.app-fixed-topbar__menu-item:hover,.app-fixed-topbar__menu-item:focus-visible{background:#1e3c7214;outline:none}.app-fixed-topbar__menu-item--danger:hover,.app-fixed-topbar__menu-item--danger:focus-visible{color:#c0392b;background:#c0392b14}.app-fixed-topbar__menu-item:last-child{padding-bottom:.65rem}.app-fixed-topbar .app-fixed-topbar__login-btn{min-height:clamp(1.85rem,5vw,2.65rem);font:inherit;letter-spacing:.02em;cursor:pointer;appearance:none;-webkit-tap-highlight-color:transparent;color:var(--dingtalk-nav-blue);background-color:#fff;background-image:none;border:1px solid #fffffff2;border-radius:999px;justify-content:center;align-items:center;gap:clamp(.22rem,1vw,.4rem);padding:clamp(.26rem,1.6vw,.45rem) clamp(.45rem,2.8vw,1rem);font-size:clamp(.7rem,2.9vw,.86rem);font-weight:600;transition:background .18s,box-shadow .18s,border-color .18s,transform .15s,color .18s;display:inline-flex;box-shadow:0 1px 4px #0000001f,inset 0 1px #fff}.app-fixed-topbar .app-fixed-topbar__login-btn:hover{color:var(--dingtalk-nav-blue-deep);background-color:#fffffffa;border-color:#fff;transform:translateY(-1px);box-shadow:0 3px 10px #00000024,inset 0 1px #fff}.app-fixed-topbar .app-fixed-topbar__login-btn:active{color:var(--dingtalk-nav-blue-deep);background-color:#f0f7ff;transform:translateY(0);box-shadow:0 1px 3px #0000001f,inset 0 1px 2px #0050a014}.app-fixed-topbar .app-fixed-topbar__login-btn:focus-visible{outline-offset:2px;outline:2px solid #fffffff2}.header-subtitle{max-width:44rem;color:var(--demo-secondary);text-wrap:balance;margin:.65rem auto 0;font-size:clamp(.85rem,2.8vw,.98rem);line-height:1.55}.page-content{flex:1;grid-template-columns:1fr 1fr;align-items:start;gap:clamp(1rem,2.5vw,1.55rem);width:100%;min-width:0;display:grid}@media (width<=900px){.page-content{grid-template-columns:1fr}}.app-panel{background:var(--surface);border-radius:12px;min-width:0;padding:clamp(1rem,3vw,1.5rem);box-shadow:0 4px 12px #00000014}.app-panel__title{color:var(--demo-primary);letter-spacing:.03em;border-bottom:2px solid #eee;align-items:center;gap:.5rem;margin:0 0 clamp(.85rem,2.5vw,1.15rem);padding-bottom:.65rem;font-size:clamp(1.05rem,3.2vw,1.25rem);font-weight:600;display:flex}.app-panel__title-icon{color:var(--demo-accent);font-size:.95em}.app-panel__subtitle{color:var(--demo-primary);align-items:center;gap:.45rem;margin:0 0 .5rem;font-size:clamp(.88rem,2.8vw,.98rem);font-weight:600;display:flex}.app-panel__subtitle--warn{color:#c0392b}.app-panel__subtitle--warn+.infirmary-pool-desc{color:#7f8c8d}.pool-stack>.app-panel__section+.app-panel__section{margin-top:clamp(.65rem,2vw,.85rem)}.app-panel__empty{text-align:center;color:#888;padding:clamp(1.5rem,5vw,2.5rem) clamp(.75rem,3vw,1.25rem);font-size:clamp(.88rem,2.8vw,.95rem);line-height:1.55}.app-panel__empty-icon{opacity:.45;color:var(--demo-secondary);margin-bottom:.85rem;font-size:clamp(2.5rem,10vw,3.25rem);display:block}.app-panel__empty p{margin:0;max-width:22rem;margin-inline:auto}.app-panel__teams-header{border-bottom:2px solid #eee;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.65rem 1rem;margin-bottom:clamp(.85rem,2.5vw,1.15rem);padding-bottom:.65rem;display:flex}.app-panel__teams-header .app-panel__title--teams{border:none;flex:auto;min-width:min(12rem,100%);margin:0;padding:0}.btn-group-start{font:inherit;letter-spacing:.05em;cursor:pointer;color:#fff;background:linear-gradient(145deg, #ff8f5a 0%, var(--demo-accent) 42%, #e85a28 100%);border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;gap:.45rem;min-height:2.65rem;padding:.45rem 1.05rem .45rem .55rem;font-size:clamp(.82rem,2.4vw,.92rem);font-weight:700;transition:transform .15s,box-shadow .2s,filter .2s;display:inline-flex;box-shadow:0 2px 10px #ff6b3561,inset 0 1px #ffffff38}.btn-group-start:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 4px 16px #ff6b3573,inset 0 1px #ffffff40}.btn-group-start:focus-visible{outline:2px solid var(--demo-accent);outline-offset:3px}.btn-group-start:active{filter:brightness(.98);transform:translateY(0)}.btn-group-start__icon{background:#ffffff38;border-radius:50%;justify-content:center;align-items:center;width:1.85rem;height:1.85rem;display:flex;box-shadow:inset 0 1px 1px #00000014}.btn-group-start__icon .fa-random{font-size:.85em}.btn-group-start__text{padding-right:.15rem}@media (width<=480px){.app-panel__teams-header{flex-direction:column;align-items:stretch}.btn-group-start{justify-content:center;width:100%;padding-inline:1rem}}.app-panel--court .positions{margin-bottom:.25rem}.infirmary-pool{background:0 0;border-top:1px solid #c0392b33;border-radius:0;flex-shrink:0;min-width:0;padding:clamp(.65rem,2vw,.85rem) 0 0}.infirmary-pool-desc{color:var(--muted);margin:0 0 .65rem;font-size:clamp(.72rem,2.5vw,.82rem);line-height:1.35}.player-chip--infirmary-rail{border-color:#dc646480;box-shadow:0 0 0 1px #dc646426}.title{letter-spacing:.04em;text-wrap:balance;color:var(--demo-primary);flex-wrap:wrap;justify-content:center;align-items:center;gap:.45em;margin:0;font-size:clamp(1.35rem,4.5vw,2.1rem);font-weight:600;line-height:1.2;display:inline-flex}.title__icon{color:var(--demo-accent);font-size:.92em}.subtitle{color:var(--muted);margin:.4rem 0 0;padding:0 .25rem;font-size:clamp(.85rem,3.2vw,.95rem);line-height:1.45}.title-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:.55rem .85rem;display:flex}.btn-detail{font:inherit;letter-spacing:.06em;cursor:pointer;min-height:36px;color:var(--demo-dark);box-shadow:none;background:#e8eaed;border:1px solid #d0d5dc;border-radius:8px;padding:.4rem .95rem;font-size:clamp(.78rem,2.6vw,.88rem);font-weight:600;transition:color .15s,border-color .15s,background .15s}.btn-detail:hover{color:var(--demo-primary);border-color:var(--demo-secondary);background:#dfe3e8}.btn-detail:focus-visible{outline:2px solid var(--demo-secondary);outline-offset:3px}.detail-modal-backdrop{z-index:2040}.detail-modal-dialog{background:#fff;border:1px solid #e0e4ea;border-radius:16px;flex-direction:column;width:min(100%,460px);max-height:min(88dvh,640px);padding:0;display:flex;overflow:hidden;box-shadow:0 24px 48px #1e3c722e,0 0 0 1px #ff6b351f}.detail-modal-header{background:linear-gradient(#ff6b3514 0%,#fff 100%);border-bottom:1px solid #eee;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1.15rem 1.15rem .85rem 1.25rem;display:flex}.detail-modal-header-main{text-align:left;align-items:center;gap:.75rem;min-width:0;display:flex}.detail-modal-icon-wrap{width:2.75rem;height:2.75rem;color:var(--demo-primary);background:#1e3c7214;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:inset 0 0 0 1px #1e3c721f}.detail-modal-icon{width:1.45rem;height:1.45rem}.detail-modal-kicker{letter-spacing:.2em;text-transform:uppercase;color:var(--demo-secondary);margin:0;font-size:.68rem;font-weight:600}.detail-modal-title{letter-spacing:.06em;color:#1a2530;margin:.15rem 0 0;font-size:1.28rem;font-weight:700;line-height:1.25}.detail-modal-close{cursor:pointer;color:#5c6b7a;background:#f0f2f5;border:none;border-radius:10px;flex-shrink:0;width:2.25rem;height:2.25rem;margin:-.2rem -.15rem 0 0;padding:0;font-size:1.45rem;line-height:1;transition:color .15s,background .15s}.detail-modal-close:hover{color:#1a2530;background:#e4e7ec}.detail-modal-close:focus-visible{outline:2px solid var(--demo-secondary);outline-offset:2px}.detail-modal-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:#fafbfc;flex:1;min-height:0;padding:.85rem 1.25rem 1rem;overflow-y:auto}.detail-modal-section{border:1px solid #e8eaed;border-left:3px solid var(--demo-accent);background:#fff;border-radius:10px;margin-bottom:1rem;padding:.75rem .9rem;box-shadow:0 1px 4px #0000000d}.detail-modal-section:last-of-type{margin-bottom:.35rem}.detail-modal-section-title{letter-spacing:.06em;color:var(--demo-primary);margin:0 0 .4rem;font-size:.88rem;font-weight:700}.detail-modal-section-body{color:#3d4f5f;margin:0;font-size:.92rem;line-height:1.65}.detail-modal-footer{background:#fff;border-top:1px solid #eee;flex-shrink:0;justify-content:center;padding:.85rem 1.25rem 1.15rem;display:flex}.player-info-modal-backdrop{z-index:2038;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.player-info-modal-dialog{background:linear-gradient(165deg,#fff 0%,#f6f8fc 100%);border:1px solid #1e3c721f;border-radius:18px;flex-direction:column;width:min(100%,380px);max-height:min(88dvh,520px);padding:0;display:flex;overflow:hidden;box-shadow:0 28px 56px #1e3c7233,inset 0 0 0 1px #fff9}.player-info-modal-header{background:linear-gradient(125deg,#0089ff1f 0%,#1e3c720f 48%,#ff6b3514 100%);border-bottom:1px solid #0059ff1a;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1.2rem 1rem 1rem 1.25rem;display:flex;position:relative}.player-info-modal-header-accent{background:linear-gradient(180deg, var(--dingtalk-nav-blue) 0%, var(--demo-accent) 100%);border-radius:18px 0 0;width:4px;position:absolute;top:0;bottom:0;left:0}.player-info-modal-header-text{text-align:left;min-width:0;padding-left:.35rem}.player-info-modal-kicker{letter-spacing:.28em;text-transform:uppercase;color:var(--demo-secondary);opacity:.9;margin:0;font-size:.7rem;font-weight:600}.player-info-modal-title{letter-spacing:.04em;color:#14232f;font-variant-numeric:tabular-nums;margin:.2rem 0 0;font-size:1.65rem;font-weight:800;line-height:1.2}.player-info-modal-close{cursor:pointer;color:#5c6b7a;background:#ffffffbf;border:none;border-radius:12px;flex-shrink:0;width:2.25rem;height:2.25rem;margin:-.15rem -.1rem 0 0;padding:0;font-size:1.45rem;line-height:1;transition:color .15s,background .15s;box-shadow:0 1px 3px #0000000f}.player-info-modal-close:hover{color:#1a2530;background:#fff}.player-info-modal-close:focus-visible{outline:2px solid var(--demo-secondary);outline-offset:2px}.player-info-modal-body{background:#fafbfd;padding:1.1rem 1.25rem 1.2rem}.player-info-modal-dl{flex-direction:column;gap:.85rem;margin:0;display:flex}.player-info-modal-row{background:#fff;border:1px solid #e8eaed;border-radius:12px;grid-template-columns:5rem 1fr;align-items:start;gap:.65rem 1rem;padding:.75rem .85rem;display:grid;box-shadow:0 2px 8px #1e3c720d}.player-info-modal-row--note{border-left:3px solid #ff6b35a6}.player-info-modal-row dt{letter-spacing:.12em;color:var(--muted);text-transform:uppercase;margin:0;font-size:.78rem;font-weight:700}.player-info-modal-row dd{color:#1a2530;word-break:break-word;margin:0;font-size:.98rem;line-height:1.55}.player-info-modal-dd-num{font-variant-numeric:tabular-nums;color:var(--demo-primary);font-size:1.15rem;font-weight:800}.player-info-modal-desc-empty{color:var(--muted);font-size:.92rem;font-style:italic}.player-info-modal-footer{background:#fffffff2;border-top:1px solid #e8eaed;flex-shrink:0;justify-content:center;padding:.75rem 1.25rem 1.1rem;display:flex}.player-info-modal-ok{min-width:7.5rem}.toolbar{margin-top:clamp(.85rem,2.5vw,1.1rem)}.toolbar--row{flex-wrap:wrap;justify-content:center;align-items:center;gap:.65rem 1rem;display:flex}.toolbar .btn-primary,.toolbar .btn-outline,.toolbar .btn-accent{justify-content:center;align-items:center;gap:.45rem;display:inline-flex}.login-modal-backdrop{z-index:2020;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-modal-dialog{background:#fff;border:1px solid #e0e4ea;border-radius:14px;width:min(100%,280px);padding:0;animation:.22s ease-out login-modal-in;overflow:hidden;box-shadow:0 24px 48px #1e3c722e,0 0 0 1px #ff6b351f}@keyframes login-modal-in{0%{opacity:0;transform:scale(.96)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.login-modal-header{background:linear-gradient(#ff6b350f 0%,#fff 100%);border-bottom:1px solid #e8eaed;padding:.55rem .65rem 0}.login-modal-header-top{justify-content:space-between;align-items:center;gap:.5rem;width:100%;display:flex}.login-modal-tabs{flex-wrap:wrap;flex:1;align-items:flex-end;gap:.25rem 1.35rem;min-width:0;display:flex}.login-modal-tab{font:inherit;cursor:pointer;color:#8b94a3;letter-spacing:.02em;background:0 0;border:none;border-bottom:3px solid #0000;margin:0;padding:.4rem 0 .55rem;font-size:clamp(1.05rem,3.2vw,1.18rem);font-weight:700;transition:color .15s,border-color .15s}.login-modal-tab:hover:not(:disabled){color:#4a5568}.login-modal-tab--active{color:#07090d;border-bottom-color:var(--demo-primary);font-weight:800}.login-modal-tab:focus-visible{outline:2px solid var(--demo-secondary);outline-offset:3px;border-radius:4px}.login-modal-tab:disabled{opacity:.55;cursor:not-allowed}.login-modal-header-main{align-items:center;gap:.85rem;min-width:0;display:flex}.login-modal-icon-wrap{width:2.6rem;height:2.6rem;color:var(--demo-primary);background:#1e3c7214;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:inset 0 0 0 1px #1e3c721f}.login-modal-icon{width:1.45rem;height:1.45rem}.login-modal-kicker{letter-spacing:.14em;text-transform:uppercase;color:var(--demo-secondary);margin:0;font-size:.72rem;font-weight:600}.login-modal-title{letter-spacing:.06em;color:var(--text);margin:.15rem 0 0;font-size:1.35rem;font-weight:700;line-height:1.2}.login-modal-close{font:inherit;cursor:pointer;color:#5c6b7a;background:#f0f2f5;border:none;border-radius:10px;flex-shrink:0;width:2.25rem;height:2.25rem;padding:0;font-size:1.45rem;line-height:1;transition:color .15s,background .15s}.login-modal-close:hover{color:var(--text);background:#e4e7ec}.login-modal-close:focus-visible{outline:2px solid var(--demo-secondary);outline-offset:2px}.login-modal-hint{color:var(--muted);margin:0;padding:.65rem .65rem 0;font-size:.82rem;line-height:1.5}.login-modal-field{background:linear-gradient(#fafbfd 0%,#f3f5f8 100%);border:1px solid #e2e6ed;border-radius:12px;grid-template-columns:max-content minmax(0,1fr);align-items:center;column-gap:.55rem;margin:.7rem .65rem 0;padding:.5rem .55rem;display:grid;box-shadow:0 1px 2px #1e3c720d}.login-modal-register-fields{grid-template-columns:max-content minmax(0,1fr);gap:.55rem;margin:.7rem .65rem 0;display:grid}.login-modal-field--paired{grid-column:1/-1;grid-template-columns:subgrid;margin:0;display:grid}.login-modal-register-fields .login-modal-field+.login-modal-field{margin-top:0}.login-modal-field+.login-modal-field{margin-top:.55rem}.login-modal-field-label{text-align:right;white-space:nowrap;color:#243447;letter-spacing:.03em;justify-self:stretch;padding-right:.1rem;font-size:.84rem;font-weight:600}.login-modal-input{box-sizing:border-box;width:100%;min-width:0;min-height:2.35rem;font:inherit;color:var(--text);background:#fff;border:1px solid #dce1e8;border-radius:9px;padding:.42rem .55rem;font-size:.92rem;transition:border-color .15s,box-shadow .15s;box-shadow:inset 0 1px 2px #1e3c720f}.login-modal-input:focus{border-color:#2a529873;outline:none;box-shadow:inset 0 1px 2px #1e3c720f,0 0 0 2px #2a52982e}.login-modal-input::placeholder{color:var(--muted);opacity:.75}.login-modal-error{margin:.55rem .65rem 0}.login-modal-dialog .modal-error.login-modal-error{color:#b83232;text-align:center;letter-spacing:.02em;word-wrap:break-word;background:#c0392b12;border-radius:10px;margin:.65rem .65rem 0;padding:.45rem .65rem;font-size:.9rem;font-weight:700;line-height:1.45}.login-modal-actions{flex-wrap:wrap;gap:.65rem;margin-top:.25rem;padding:.85rem .65rem 1rem;display:flex}.login-modal-actions--single{justify-content:center}.login-modal-actions--single .login-modal-btn-primary{flex:0 auto;width:auto;min-width:9.5rem;max-width:100%;padding-inline:1.5rem}.login-modal-btn-primary{border-radius:12px;flex:1;min-width:8rem}.login-modal-btn-primary:disabled{cursor:not-allowed;opacity:.72;filter:grayscale(.08)}@media (width<=420px){.login-modal-actions{flex-direction:column}.login-modal-actions--single .login-modal-btn-primary{width:100%;min-width:0}.login-modal-field{grid-template-columns:1fr;align-items:stretch;row-gap:.45rem}.login-modal-register-fields{grid-template-columns:1fr;row-gap:.55rem}.login-modal-register-fields .login-modal-field--paired{grid-column:auto;grid-template-columns:1fr}.login-modal-field-label{text-align:left;justify-self:start;padding-right:0}}.btn-primary,.btn-outline{font:inherit;letter-spacing:.04em;cursor:pointer;color:#fff;background:var(--demo-primary);border:none;border-radius:8px;min-height:44px;padding:.55rem 1.25rem;font-weight:600;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 3px 10px #1e3c7240}.btn-primary:hover,.btn-outline:hover{background:var(--demo-secondary);transform:translateY(-1px)}.btn-primary:focus-visible,.btn-outline:focus-visible{outline:2px solid var(--demo-secondary);outline-offset:3px}.btn-accent{font:inherit;letter-spacing:.04em;cursor:pointer;color:#fff;background:var(--demo-accent);border:none;border-radius:8px;min-height:44px;padding:.55rem 1.25rem;font-weight:600;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 3px 10px #ff6b354d}.btn-accent:hover{background:var(--accent-dim);transform:translateY(-1px)}.btn-accent:focus-visible{outline:2px solid var(--demo-accent);outline-offset:3px}.btn-secondary{font:inherit;letter-spacing:.04em;cursor:pointer;min-height:44px;color:var(--text);border:1px solid var(--border);background:#e8eaed;border-radius:10px;padding:.55rem 1.1rem;font-weight:600}.btn-secondary:hover{background:#dde1e6}.btn-secondary:focus-visible{outline:2px solid var(--muted);outline-offset:2px}.modal-backdrop{z-index:2000;padding:var(--page-pad-x);padding-bottom:max(var(--page-pad-x), env(safe-area-inset-bottom,0px));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-dialog{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:min(100%,400px);max-height:min(90dvh,560px);padding:1.25rem 1.35rem;overflow:auto;box-shadow:0 20px 50px #00000073}.modal-title{letter-spacing:.04em;margin:0 0 .5rem;font-size:1.2rem;font-weight:600}.modal-hint{color:var(--muted);margin:0 0 1rem;font-size:.85rem;line-height:1.45}.modal-label{color:var(--muted);margin-bottom:.35rem;font-size:.9rem;font-weight:600;display:block}.modal-input{width:100%;font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:10px;margin-bottom:.5rem;padding:.65rem .75rem;font-size:1rem}.modal-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #e85d0440}.modal-input::placeholder{color:var(--muted);opacity:.75}.modal-error{color:#ff8a8a;word-wrap:break-word;margin:0 0 .75rem;font-size:.88rem;line-height:1.4}.modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:.65rem;margin-top:.25rem;display:flex}.modal-actions--row{justify-content:center}.btn-modal-ok{min-width:6.5rem}.modal-backdrop--grouping-notice{z-index:2100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#16243e6b}@keyframes grouping-notice-in{0%{opacity:0;transform:scale(.97)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-dialog--grouping-notice{text-align:left;border:1px solid #2a52981f;border-left:4px solid var(--demo-accent);background:linear-gradient(165deg,#fffbf8 0%,#fff 38%,#f5f8fc 100%);border-radius:14px;width:min(100%,400px);padding:1.35rem 1.35rem 1.2rem;animation:.26s cubic-bezier(.22,1,.36,1) grouping-notice-in;box-shadow:0 22px 48px #1e3c7224,0 8px 20px #0000000f,inset 0 1px #fffffff2}.grouping-notice-header{align-items:flex-start;gap:.85rem;margin-bottom:.7rem;display:flex}.grouping-notice-icon{color:#e85d28;background:linear-gradient(145deg,#ff6b3533 0%,#ff8c5a1a 55%,#2a52980f 100%);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:2.75rem;height:2.75rem;display:flex;box-shadow:inset 0 0 0 1px #ff6b3538,0 4px 12px #ff6b351f}.grouping-notice-icon-svg{width:1.45rem;height:1.45rem}.grouping-notice-title{letter-spacing:.04em;color:var(--demo-primary);margin:0;padding-top:.25rem;font-size:1.13rem;font-weight:700;line-height:1.35}.grouping-notice-message{color:#4a5568;margin:0 0 1.15rem;padding-left:3.6rem;font-size:.92rem;line-height:1.68}.modal-actions--grouping-notice{border-top:1px solid #2a529814;justify-content:flex-end;margin-top:.1rem;padding-top:.35rem}.modal-actions--grouping-notice .btn-modal-ok{letter-spacing:.06em;border-radius:10px;min-width:7rem;font-weight:700;box-shadow:0 3px 12px #ff6b3561,inset 0 1px #ffffff40}.modal-actions--grouping-notice .btn-modal-ok:hover{box-shadow:0 5px 16px #ff6b3573,inset 0 1px #ffffff47}@media (width<=420px){.grouping-notice-message{margin-bottom:.85rem;padding-left:0}.modal-actions--grouping-notice{justify-content:stretch;padding-top:.5rem}.modal-actions--grouping-notice .btn-modal-ok{width:100%;min-width:0}}.modal-backdrop--api-http-error{z-index:2200}.modal-dialog--api-http-error{text-align:left;background:var(--surface);border:1px solid #ff787859;border-left:4px solid #e85d5d;flex-direction:column;width:min(100%,520px);max-height:min(88dvh,640px);padding:1.2rem 1.25rem 1.1rem;display:flex;box-shadow:0 24px 56px #00000080}.api-http-error-title{letter-spacing:.05em;color:#ffb4b4;margin:0 0 .5rem;font-size:1.15rem;font-weight:700}.api-http-error-meta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:.5rem .85rem;margin:0 0 .35rem;font-size:.8rem;display:flex}.api-http-error-label{color:#c8d6e8;font-weight:600}.api-http-error-status{font-variant-numeric:tabular-nums;color:#ff9a9a;background:#e85d5d33;border-radius:6px;padding:.12rem .45rem;font-weight:700}.api-http-error-summary{color:var(--text);margin:0 0 .65rem;font-size:.92rem;line-height:1.5}.api-http-error-body-label{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 .35rem;font-size:.75rem;font-weight:700}.api-http-error-pre{color:#e0e8f0;border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;background:#0f141cd9;border-radius:8px;flex:1;min-height:0;max-height:min(42dvh,320px);margin:0 0 1rem;padding:.65rem .75rem;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:.78rem;line-height:1.45;overflow:auto}.modal-dialog--api-http-error .modal-actions{flex-shrink:0;margin-top:0}.admin-user-dialog{background:#fff;border:1px solid #e8edf5;border-radius:16px;width:min(92vw,720px);padding:0;overflow:hidden;box-shadow:0 24px 60px #00000038,inset 0 0 0 1px #ffffffa6}.admin-shell-dialog{background:#fff;border:1px solid #e6ebf2;border-radius:14px;flex-direction:column;width:min(94vw,980px);min-height:0;max-height:min(86dvh,760px);padding:0;display:flex;overflow:hidden;box-shadow:0 24px 60px #0000002e,inset 0 0 0 1px #ffffffb3}.admin-shell__header{background:linear-gradient(#fbfdff 0%,#fff 100%);border-bottom:1px solid #eef2f7;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.95rem 1.1rem;display:flex}.admin-shell__kicker{letter-spacing:.14em;text-transform:uppercase;color:#7f8c8d;margin:0;font-size:.72rem;font-weight:800}.admin-shell__title{letter-spacing:.04em;color:var(--demo-primary);margin:.2rem 0 0;font-size:1.25rem;font-weight:800}.admin-shell__header-left{min-width:0}.admin-shell__header-right{flex-shrink:0;align-items:center;gap:.55rem;display:inline-flex}.admin-shell__ghost-btn{font:inherit;cursor:pointer;color:#2c3e50;background:#f3f7ff;border:1px solid #d7e3ff;border-radius:10px;padding:.5rem .75rem;font-size:.9rem;font-weight:700}.admin-shell__ghost-btn:hover{background:#eaf1ff;border-color:#c6d9ff}.admin-shell__ghost-btn:disabled{cursor:not-allowed;opacity:.55}.admin-shell__ghost-btn--accent{color:#8b3a18;background:linear-gradient(#fff6f0 0%,#ffe8dc 100%);border-color:#ff6b3573}.admin-shell__ghost-btn--accent:hover:not(:disabled){border-color:var(--demo-accent);background:linear-gradient(#fff2e8 0%,#ffdccc 100%)}.admin-shell__restore-banner{color:#1a4d2e;background:linear-gradient(90deg,#27ae6029,#27ae600f);border-bottom:1px solid #27ae6038;flex-shrink:0;margin:0;padding:.55rem 1.25rem;font-size:.88rem;line-height:1.45}.admin-shell__close{font:inherit;cursor:pointer;color:#607089;background:#f2f6fc;border:none;border-radius:10px;width:2.25rem;height:2.25rem;font-size:1.45rem;line-height:1}.admin-shell__close:hover{color:#2c3e50;background:#eaf1ff}.admin-shell{flex:auto;grid-template-columns:200px 1fr;height:auto;min-height:0;display:grid;overflow:hidden}.admin-shell__sidebar{-webkit-overflow-scrolling:touch;background:#fbfdff;border-right:1px solid #eef2f7;min-height:0;padding:.85rem .75rem;overflow-y:auto}.admin-shell__nav-title{letter-spacing:.08em;color:#607089;margin-bottom:.65rem;font-size:.78rem;font-weight:800}.admin-shell__nav-item{text-align:left;width:100%;font:inherit;color:#2c3e50;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;padding:.65rem .75rem;font-weight:700}.admin-shell__nav-item:disabled{cursor:not-allowed;opacity:.5}.admin-shell__nav-item:hover:not(:disabled){background:#f3f7ff}.admin-shell__nav-item--active{color:#1f3a93;background:#eef5ff;border-color:#d7e3ff}.admin-shell__content{flex-direction:column;flex:auto;min-width:0;min-height:0;display:flex;overflow:hidden}.admin-shell__users{flex-direction:column;flex:auto;min-height:0;display:flex;overflow:hidden}.admin-shell__toolbar{background:#fff;border-bottom:1px solid #eef2f7;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex}.admin-shell__search{flex:320px;align-items:center;gap:.55rem;min-width:min(360px,100%);display:flex}.admin-shell__search-label{color:#607089;flex-shrink:0;font-size:.9rem;font-weight:700}.admin-shell__search-input{min-width:0;font:inherit;color:#2c3e50;background:#fff;border:1px solid #d7deea;border-radius:10px;flex:1;padding:.6rem .75rem}.admin-shell__search-input:focus{border-color:#ff6b358c;outline:none;box-shadow:0 0 0 3px #ff6b351f}.admin-shell__stats{color:#607089;font-size:.9rem}.admin-shell__switch{-webkit-user-select:none;user-select:none;color:#2c3e50;background:#f7f9fc;border:1px solid #e6ebf2;border-radius:12px;align-items:center;gap:.55rem;padding:.35rem .5rem;font-size:.88rem;font-weight:800;display:inline-flex}.admin-shell__switch input{opacity:0;pointer-events:none;position:absolute}.admin-shell__switch-ui{background:#d7deea;border:1px solid #c9d3e4;border-radius:999px;width:40px;height:22px;transition:background .15s,border-color .15s;position:relative}.admin-shell__switch-ui:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .15s;position:absolute;top:2px;left:2px;box-shadow:0 2px 6px #0000001f}.admin-shell__switch input:checked+.admin-shell__switch-ui{background:#ff6b353d;border-color:#ff6b358c}.admin-shell__switch input:checked+.admin-shell__switch-ui:after{transform:translate(18px)}.admin-shell__switch-text{white-space:nowrap}.admin-shell__state{color:#607089;flex:auto;min-height:0;padding:1rem;overflow-y:auto}.admin-shell__state--error{color:#c0392b}.admin-shell__table-wrap{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:auto;min-height:0;padding:.85rem 1rem 1rem;overflow:auto}.admin-shell__table{border-collapse:separate;border-spacing:0;background:#fff;border:1px solid #e6ebf2;border-radius:12px;width:100%;min-width:640px;overflow:hidden}.admin-shell__table thead th{z-index:1;text-align:left;letter-spacing:.12em;text-transform:uppercase;color:#607089;background:#f7f9fc;border-bottom:1px solid #e6ebf2;padding:.75rem .85rem;font-size:.78rem;font-weight:800;position:sticky;top:0}.admin-shell__table tbody td{color:#2c3e50;vertical-align:middle;border-bottom:1px solid #eef2f7;padding:.75rem .85rem;font-size:.92rem}.admin-shell__table tbody tr:nth-child(2n) td{background:#fbfdff}.admin-shell__table tbody tr:hover td{background:#fff6f0}.admin-shell__table tbody tr:last-child td{border-bottom:none}.admin-shell__pill{color:#d35400;background:#ff6b351f;border:1px solid #ff6b3547;border-radius:999px;align-items:center;padding:.35rem .6rem;font-weight:800;display:inline-flex}.admin-shell__role{color:#34495e;font-weight:700}.admin-shell__role-editor{flex-wrap:wrap;align-items:center;gap:.45rem;display:flex}.admin-shell__role-select{font:inherit;color:#2c3e50;background:#fff;border:1px solid #d7deea;border-radius:10px;padding:.45rem .55rem;font-weight:700}.admin-shell__role-select:focus{border-color:#ff6b358c;outline:none;box-shadow:0 0 0 3px #ff6b351f}.admin-shell__btn--primary{color:#d35400;border-color:#ff6b3559}.admin-shell__btn--primary:hover{background:#ff6b3514;border-color:#ff6b3580}.admin-shell__btn:disabled{cursor:not-allowed;opacity:.65}.admin-shell__row-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.admin-shell__btn{font:inherit;cursor:pointer;color:#2c3e50;background:#fff;border:1px solid #d7deea;border-radius:10px;padding:.5rem .7rem;font-size:.9rem;font-weight:800}.admin-shell__btn:hover{background:#f4f8ff;border-color:#c6d4ea}.admin-shell__btn--warn{color:#b35c00;border-color:#ff980059}.admin-shell__btn--warn:hover{background:#ff980014;border-color:#ff980080}.admin-shell__btn--danger{color:#c0392b;border-color:#e74c3c59}.admin-shell__btn--danger:hover{background:#e74c3c14;border-color:#e74c3c80}.admin-shell__footer{background:#fff;border-top:1px solid #eef2f7;flex-shrink:0;justify-content:flex-end;padding:.75rem 1rem;display:flex}.admin-shell__mock{-webkit-overflow-scrolling:touch;flex-direction:column;flex:auto;min-height:0;display:flex;overflow-y:auto}.admin-shell__mock-body{padding:1rem}.admin-shell__mock-actions{flex-wrap:wrap;gap:.75rem;display:flex}.admin-shell__mock-message{color:#2c3e50;background:#f6fbff;border:1px solid #d7e3ff;border-radius:12px;margin-top:.85rem;padding:.75rem .85rem;font-weight:700}.admin-shell__mock-tip{color:#607089;margin-top:.85rem;font-size:.9rem;line-height:1.6}@media (width<=820px){.admin-shell{grid-template-columns:170px 1fr}}@media (width<=640px){.admin-shell-dialog{width:min(96vw,720px);max-height:min(90dvh,760px)}.admin-shell{flex:auto;grid-template-columns:1fr;min-height:0}.admin-shell__sidebar{border-bottom:1px solid #eef2f7;border-right:none;max-height:min(28dvh,220px);overflow-y:auto}.admin-shell__table{min-width:0}.admin-shell__row-actions{justify-content:flex-start}}.admin-user-dialog__header{background:linear-gradient(#fbfdff 0%,#fff 100%);border-bottom:1px solid #eef2f8;justify-content:space-between;align-items:flex-start;gap:.85rem;padding:1.05rem 1.15rem .85rem;display:flex}.admin-user-dialog__kicker{letter-spacing:.14em;text-transform:uppercase;color:#7f8c8d;margin:0;font-size:.72rem;font-weight:700}.admin-user-dialog__title{letter-spacing:.06em;color:var(--demo-primary);margin:.2rem 0 0;font-size:1.35rem;font-weight:800;line-height:1.15}.admin-user-dialog__close{font:inherit;cursor:pointer;color:#607089;background:#f2f6fc;border:none;border-radius:10px;flex-shrink:0;width:2.25rem;height:2.25rem;padding:0;font-size:1.45rem;line-height:1;transition:color .15s,background .15s}.admin-user-dialog__close:hover{color:#2c3e50;background:#eaf1ff}.admin-user-dialog__close:focus-visible{outline-offset:2px;outline:2px solid #ff6b358c}.admin-user-dialog__hint{color:#7f8c8d;margin:0;padding:.85rem 1.15rem 0;font-size:.9rem;line-height:1.55}.admin-user-table-wrap{padding:.85rem 1.15rem .25rem;overflow:auto}.admin-user-table{border-collapse:separate;border-spacing:0;background:#fff;border:1px solid #e8edf5;border-radius:14px;width:100%;min-width:560px;overflow:hidden}.admin-user-table thead th{z-index:1;text-align:left;letter-spacing:.12em;text-transform:uppercase;color:#607089;background:#f7f9fc;border-bottom:1px solid #e8edf5;padding:.75rem .85rem;font-size:.78rem;font-weight:800;position:sticky;top:0}.admin-user-table tbody td{color:#2c3e50;vertical-align:middle;border-bottom:1px solid #eef2f8;padding:.75rem .85rem;font-size:.92rem}.admin-user-table tbody tr:nth-child(2n) td{background:#fbfdff}.admin-user-table tbody tr:hover td{background:#fff6f0}.admin-user-table tbody tr:last-child td{border-bottom:none}.admin-user-table__actions-col{white-space:nowrap;width:1%}.admin-user-badge{letter-spacing:.02em;color:#d35400;background:#ff6b351f;border:1px solid #ff6b3547;border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .6rem;font-weight:800;display:inline-flex}.admin-user-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}@media (width<=620px){.admin-user-table{min-width:0}.admin-user-actions{justify-content:flex-start}}.admin-user-btn{color:#2c3e50;background:#fff;border:1px solid #d7deea;border-radius:12px;min-height:40px;box-shadow:inset 0 1px #fff}.admin-user-btn:hover{background:#f4f8ff;border-color:#c6d4ea}.admin-user-btn--danger{color:#c0392b;border-color:#e74c3c73}.admin-user-btn--danger:hover{background:#e74c3c14;border-color:#e74c3ca6}@media (width<=520px){.admin-user-table-wrap{padding:.75rem .85rem .15rem}}.positions.court-positions-list,.court-positions-list{background:#fff;border:1px solid #eee;border-radius:clamp(8px,2vw,12px);flex-direction:column;flex:0 auto;gap:0;width:100%;min-width:0;min-height:0;padding:clamp(.85rem,2.2vw,1.25rem);display:flex;box-shadow:0 1px 3px #0000000f}.court-position-row{border-bottom:1px solid #eee;flex-direction:row;align-items:stretch;gap:clamp(.75rem,2.5vw,1.15rem);min-width:0;padding:clamp(.65rem,2vw,.85rem) 0;display:flex}.court-position-row:last-child{border-bottom:none;padding-bottom:0}.court-position-row:first-child{padding-top:0}.court-position-label{min-width:2.75rem;color:var(--demo-primary);letter-spacing:.04em;word-break:keep-all;flex:none;align-self:center;margin:0;font-size:clamp(.85rem,2.8vw,1rem);font-weight:600;line-height:1.25}.court-position-inner{min-width:0;min-height:var(--court-position-slot-min-h);flex-direction:column;flex:auto;display:flex;position:relative}.court-position-drop{z-index:1;width:100%;min-height:var(--court-position-slot-min-h);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:#f8f9fa;border:1px dashed #1e3c7238;border-radius:8px;flex-wrap:wrap;flex:auto;place-content:center flex-start;align-items:center;gap:clamp(6px,1.5vw,8px);padding:clamp(6px,1.5vw,10px) clamp(8px,2vw,12px);transition:background .15s,box-shadow .15s;display:flex;position:relative;overflow:auto visible}.court-position-drop.slot-drop--active,.team-drop--active{background:var(--drop-highlight);box-shadow:inset 0 0 0 2px var(--accent)}.teams-result{border-top:none;width:100%;min-width:0;padding:0}.teams-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:clamp(.75rem,2vw,1.25rem);display:grid}.team-card{border:1px solid var(--border);background:#f8f9fa;border-radius:12px;min-width:0;padding:.85rem;box-shadow:0 2px 8px #0000000a}.team-card-title{color:var(--demo-primary);letter-spacing:.06em;margin:0 0 .65rem;font-size:.95rem;font-weight:600}.team-starters{grid-template-columns:repeat(5,minmax(0,1fr));gap:.4rem;margin-bottom:.75rem;display:grid}.team-starters--slots-3{grid-template-columns:repeat(3,minmax(0,1fr))}.team-starters--slots-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (width<=520px){.team-starters{grid-template-columns:repeat(3,minmax(0,1fr))}.team-starters--slots-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=380px){.team-starters{grid-template-columns:repeat(2,minmax(0,1fr))}}.team-starter-cell{background:#fff;border:1px dashed #1e3c7240;border-radius:8px;flex-direction:column;gap:.25rem;min-height:118px;padding:.35rem;transition:background .15s,box-shadow .15s;display:flex}.team-starter-label{color:#5c6b7a;text-align:center;word-break:keep-all;font-size:clamp(.62rem,2.4vw,.72rem);line-height:1.15}.team-starter-body{flex:1;justify-content:center;align-items:center;min-width:0;display:flex}.team-starter-body .player-chip{max-width:100%}.team-slot-empty{color:var(--muted);opacity:.65;font-size:.72rem}.team-subs{background:#fff;border:1px dashed #1e3c7233;border-radius:8px;padding:.45rem;transition:background .15s,box-shadow .15s}.team-subs-label{color:#5c6b7a;letter-spacing:.06em;margin-bottom:.4rem;font-size:.78rem;font-weight:600;display:block}.team-subs-chips{flex-wrap:wrap;align-items:center;gap:6px;min-height:2.5rem;display:flex}.player-chip{width:auto;min-width:0;max-width:fit-content;height:auto;min-height:auto;color:var(--player);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;background:#f8f9fa;border:1px solid #e0e4ea;border-radius:8px;flex-direction:row;flex:none;justify-content:flex-start;align-items:center;gap:5px;padding:3px 5px;display:flex;box-shadow:0 1px 2px #0000000d}.player-chip-avatar-wrap{flex-shrink:0;justify-content:center;align-items:center;line-height:0;display:flex}.player-chip-avatar{filter:drop-shadow(0 1px 1px #1e3c721f);width:1.85rem;height:auto;display:block}.player-chip-avatar__head{fill:#eef2fa;stroke:#c5d0e8;stroke-width:.9px}.player-chip-avatar__jersey{fill:var(--demo-secondary)}.player-chip-avatar__shorts{fill:#243a63;opacity:.92}.player-chip-avatar__legs{stroke:#4a5a72}.player-chip-avatar__num{fill:#fff;letter-spacing:-.02em;paint-order:stroke fill;stroke:#00000047;stroke-width:.75px;font-family:system-ui,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}.player-chip--on-court-grouped .player-chip-avatar__jersey{fill:#1e8449}.player-chip--on-court-grouped .player-chip-avatar__shorts{fill:#145a32}.player-chip--on-court-grouped .player-chip-avatar__head{fill:#e8f5ec;stroke:#a8d4b8}.player-chip--on-court-grouped .player-chip-avatar__legs{stroke:#3d7a52}.player-chip--infirmary-rail .player-chip-avatar__jersey{fill:#c0392b}.player-chip--infirmary-rail .player-chip-avatar__shorts{fill:#7b241c}.player-chip--infirmary-rail .player-chip-avatar__head{fill:#fdecea;stroke:#e8b4b0}.player-chip--infirmary-rail .player-chip-avatar__legs{stroke:#a04040}.team-player-info{flex-direction:column;flex:auto;justify-content:center;gap:1px;min-width:0;max-width:4.5em;font-size:.68rem;display:flex}.team-player-meta{flex-wrap:nowrap;align-items:center;gap:3px;min-width:0;display:flex}.team-player-tag{letter-spacing:.02em;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;font-size:.85em;font-weight:600;line-height:1.15;overflow:hidden}.team-player-tag--grouped{color:#7ec8a0}.team-player-tag--infirmary{color:#e8a0a0}.player-chip--on-court-grouped{background:#e8f5e9d9;border-color:#27ae6073;box-shadow:0 0 0 1px #27ae6026}@media (pointer:coarse){.player-chip{padding:4px 6px}}.player-chip:active{cursor:grabbing}.player-chip:focus-visible{outline:2px solid var(--demo-secondary);outline-offset:2px}.player-chip--drag-source{opacity:.28}.player-chip--no-drag{opacity:.9}.pool-stack{flex-direction:column;flex-shrink:0;gap:.25rem;min-width:0;margin-top:0;display:flex}.pending-pool{border-top:1px solid #eee;min-width:0;padding:clamp(.65rem,2vw,.85rem) 0 0}.bench-title{color:var(--muted);letter-spacing:.06em;margin:0 0 .65rem;font-size:clamp(.85rem,3vw,.95rem);font-weight:600}.bench-title--pending{color:var(--demo-secondary)}.pool-chips{background:#f8f9fa;border:1px solid #e8eaed;border-radius:8px;flex-wrap:wrap;align-items:center;gap:clamp(8px,2vw,10px);min-width:0;min-height:clamp(64px,16vw,72px);margin:0;padding:8px;transition:background .15s,box-shadow .15s;display:flex}.pool-chips--active{box-shadow:inset 0 0 0 2px var(--demo-accent);background:#ff6b351f}.infirmary-pool .pool-chips.infirmary-chips{background:#fdf2f299;border:1px dashed #c0392b59;align-content:flex-start;min-height:clamp(64px,16vw,72px)}.drag-ghost{z-index:1000;box-sizing:border-box;pointer-events:none;color:var(--demo-dark);border:1px solid var(--demo-secondary);filter:drop-shadow(0 6px 14px #1e3c7233);background:#fff;border-radius:10px;flex-direction:row;justify-content:flex-start;align-items:center;gap:5px;padding:3px 5px;display:flex;position:fixed}
