:root{--bg: #f5ecd9;--bg-2: #efe4cb;--panel: #fbf5e7;--panel-2: #f2e7ca;--line: #e4d4ae;--line-2: #cfb988;--ink: #2c2217;--ink-dim: #7a6a50;--ink-faint: #ab9b7b;--accent: #d4613a;--accent-2: #b3492a;--accent-soft: #fbe2d1;--warn: #d99a2b;--libero: #c63f22;--court: #e9cfa3;--court-2: #dbb577;--court-line: #2c2217;--paper: #fffaf0;--radius-lg: 22px;--radius-md: 14px;--radius-sm: 10px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{margin:0;background:radial-gradient(1400px 800px at 50% 30%,#ede0c3,#d9c9a6 70%,#c7b78f);color:var(--ink);font-family:Nunito Sans,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;overscroll-behavior:none;-webkit-user-select:none;user-select:none}button{font-family:inherit;color:inherit;background:none;border:0;cursor:pointer}input{font-family:inherit;color:inherit}.app{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:1fr 340px;grid-template-rows:80px 1fr auto;grid-template-areas:"top    top" "court  roster" "notes  notes";gap:14px;padding:16px;color:var(--ink);background:var(--bg)}.topbar{grid-area:top;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:10px 18px}.topbar__brand{display:flex;align-items:center;gap:12px}.brand-mark{width:40px;height:40px;border-radius:10px;background:var(--paper);border:1px solid var(--line);display:grid;place-items:center}.brand-title{font-family:Fraunces,serif;font-weight:600;font-size:20px;line-height:1;color:var(--ink);letter-spacing:-.01em}.brand-sub{font-size:12px;color:var(--ink-dim);margin-top:3px}.rot-bar{display:flex;gap:8px;align-items:center}.rot-bar__label{font-size:11px;font-weight:700;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase;margin-right:6px}.rot-btn{background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:6px 12px;display:flex;flex-direction:row;align-items:center;gap:8px;min-width:68px;transition:background .15s ease,border-color .15s ease,transform .08s ease,box-shadow .15s ease}.rot-btn:active{transform:scale(.97)}.rot-btn.is-active{background:var(--accent);border-color:var(--accent);color:var(--paper);box-shadow:0 4px 12px #d4613a40}.rot-btn__num{font-family:Nunito Sans,sans-serif;font-size:20px;font-weight:800;line-height:1;letter-spacing:-.02em}.rot-btn__meta{display:flex;gap:3px;align-items:center}.rot-btn__s{font-size:9px;font-weight:800;background:var(--accent);color:var(--paper);padding:1px 5px;border-radius:4px;letter-spacing:.06em}.rot-btn.is-active .rot-btn__s{background:var(--paper);color:var(--accent)}.rot-btn__slot{font-size:10px;color:var(--ink-dim);font-weight:700}.rot-btn.is-active .rot-btn__slot{color:var(--paper)}.phase-toggle{display:inline-flex;background:var(--bg-2);border:1.5px solid var(--line);border-radius:999px;padding:3px;gap:2px}.phase-btn{padding:7px 14px;border-radius:999px;font-size:12px;font-weight:700;color:var(--ink-dim);letter-spacing:.02em}.phase-btn.is-active{background:var(--ink);color:var(--paper)}.util-btn{padding:8px 16px;border-radius:999px;background:transparent;border:1.5px solid var(--line-2);font-size:12px;font-weight:700;color:var(--ink-dim)}.util-btn:hover{background:var(--bg-2)}.util-btn--danger{border-color:var(--libero);color:var(--libero)}.util-btn--danger:hover{background:#fdecea}.util-btn{position:relative;overflow:hidden}.util-btn__label{position:relative;z-index:1}.util-btn.is-armed{background:var(--ink);color:var(--paper);border-color:var(--ink)}.util-btn--danger.is-armed{background:var(--libero);color:var(--paper);border-color:var(--libero)}.util-btn__arm-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff38;transform-origin:left center;animation-name:arm-shrink;animation-timing-function:linear;animation-fill-mode:forwards;pointer-events:none;z-index:0}@keyframes arm-shrink{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.tok-placeholder{opacity:.85}.tok-placeholder-plus{fill:var(--ink-faint);font-family:Nunito Sans,sans-serif;font-size:38px;font-weight:700;pointer-events:none}.tok-slot{fill:var(--paper);font-family:Nunito Sans,sans-serif;font-size:10px;font-weight:800;letter-spacing:.06em}.court-controls{position:absolute;top:12px;right:14px;display:flex;gap:6px;z-index:2}.court-ctrl{padding:6px 10px;border-radius:999px;background:var(--paper);border:1.5px solid var(--line);font-size:11px;font-weight:700;color:var(--ink-dim);letter-spacing:.02em}.court-ctrl:hover{background:var(--bg-2)}.court-ctrl.is-on{background:var(--ink);color:var(--paper);border-color:var(--ink)}.court-area{grid-area:court;position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;align-items:center;justify-content:center;padding:16px}.court-svg{width:100%;height:100%;max-height:100%;display:block;touch-action:none}.slot-ghost{fill:var(--ink-faint);font-family:Fraunces,serif;font-size:18px;font-weight:600;opacity:.6}.tok-num{fill:var(--ink);font-family:Fraunces,serif;font-size:22px;font-weight:700}.tok-name{fill:var(--ink-dim);font-family:Nunito Sans,sans-serif;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.tok-pos{fill:var(--paper);font-family:Nunito Sans,sans-serif;font-size:11px;font-weight:800;letter-spacing:.04em}.tok-star{fill:var(--paper);font-family:Nunito Sans,sans-serif;font-size:14px;font-weight:800}.ring-pulse{animation:pulse 1.1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.55}50%{opacity:1}}.roster-panel{grid-area:roster;display:flex;flex-direction:column;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px;overflow:hidden}.rp-section{display:flex;flex-direction:column;gap:6px;min-height:0;border-radius:12px;padding:2px;transition:background .15s,outline-color .15s}.rp-section.rp-zone.is-over{background:var(--accent-soft);outline:2px dashed var(--accent);outline-offset:-2px}.rp-section--bench{flex:1 1 auto;min-height:0}.rp-head{display:flex;align-items:baseline;justify-content:space-between;padding:0 4px}.rp-title{font-family:Fraunces,serif;font-size:15px;font-weight:600;color:var(--ink);letter-spacing:-.01em}.rp-count{font-size:12px;color:var(--ink-dim);font-weight:600}.serve-queue{display:flex;flex-direction:column;gap:3px}.serve-chip{display:grid;grid-template-columns:22px 38px 1fr 32px;gap:8px;align-items:center;padding:6px 10px;border-radius:8px;background:var(--bg-2);border:1px solid transparent;cursor:grab;text-align:left;color:inherit}.serve-chip:active{cursor:grabbing}.serve-chip.is-next{background:var(--accent-soft);border-color:var(--accent)}.serve-chip.is-over{outline:2px dashed var(--accent);outline-offset:-2px}.serve-chip__idx{font-size:11px;color:var(--ink-faint);font-weight:700}.serve-chip.is-next .serve-chip__idx{color:var(--accent-2)}.serve-chip__num{font-family:Fraunces,serif;font-size:15px;color:var(--ink);font-weight:700}.serve-chip__name{font-size:12px;color:var(--ink-dim);font-weight:700;letter-spacing:.02em;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.serve-chip__pos{font-size:10px;font-weight:800;text-align:right}.player-list{display:flex;flex-direction:column;gap:4px;overflow:auto;padding-right:2px}.player-list--dense{display:grid;grid-template-columns:1fr 1fr;gap:4px}.player-row{display:grid;grid-template-columns:14px 42px 1fr 36px;align-items:center;gap:8px;padding:8px 10px;background:var(--paper);border:1.5px solid var(--line);border-radius:12px;text-align:left;min-height:38px;transition:border-color .15s,background .15s,transform .08s;cursor:grab;color:inherit}.player-row:active{cursor:grabbing;transform:scale(.99)}.player-row--dense{padding:6px 8px;min-height:34px;grid-template-columns:14px 32px 1fr 28px;gap:6px}.player-row--lib{border-color:var(--libero);background:#fef1eb}.player-row.is-swap-target{border-color:var(--warn);border-style:dashed}.player-row.is-pending{border-color:var(--warn);background:#fdf1d8}.pr-grip{color:var(--ink-faint);font-size:11px;font-weight:900;letter-spacing:-2px;-webkit-user-select:none;user-select:none}.pr-num{font-family:Fraunces,serif;font-size:16px;font-weight:700;color:var(--ink)}.pr-name{font-size:13px;color:var(--ink);font-weight:700;letter-spacing:.01em;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-row--dense .pr-name{font-size:11px}.pr-pos{font-size:10px;font-weight:800;padding:3px 6px;border-radius:5px;text-align:center;letter-spacing:.04em}.pr-pos--lib{background:var(--libero);color:var(--paper)}.pr-pos--dim{background:transparent;color:var(--ink-faint);border:1px solid var(--line)}.notes-strip{grid-area:notes;display:grid;grid-template-columns:220px 1fr 280px;gap:14px;align-items:start;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:10px 18px}.notes-strip__meta,.notes-strip__hint{align-self:center}.notes-strip__label{font-family:Fraunces,serif;font-size:16px;font-weight:600;color:var(--ink)}.notes-strip__input{background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:12px 16px;color:var(--ink);font-size:15px;font-family:inherit;line-height:1.4;width:100%;min-height:48px;resize:vertical;outline:none}.notes-strip__input:focus{border-color:var(--accent)}.notes-strip__hint{font-size:12px;color:var(--ink-faint);text-align:right;font-style:italic}.notes-recap__list{display:flex;flex-direction:column;gap:14px}.notes-recap__item{display:flex;flex-direction:column;gap:6px}.notes-recap__item-label{font-family:Fraunces,serif;font-weight:600;font-size:14px;color:var(--ink)}.notes-recap__item-label.is-active{color:var(--accent)}.topbar__controls{display:flex;align-items:center;gap:10px}.court-side-label{fill:var(--ink-faint);font-family:Nunito Sans,sans-serif;font-size:14px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.court-empty{color:var(--ink-dim);font-size:14px;text-align:center;padding:40px 20px}.libero-override{display:inline-flex;gap:2px;background:var(--bg-2);border:1px solid var(--line);border-radius:999px;padding:2px}.libero-override__btn{padding:4px 10px;border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.04em;color:var(--ink-dim)}.libero-override__btn.is-active{background:var(--ink);color:var(--paper)}.libero-empty{font-size:12px;color:var(--ink-faint);font-style:italic;padding:10px 12px}.libero-error{background:#fdecea;border:1px solid var(--libero);color:var(--libero);font-size:12px;font-weight:700;padding:6px 10px;border-radius:8px;margin-top:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c221773;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);width:min(560px,92vw);max-height:85vh;display:flex;flex-direction:column;box-shadow:0 18px 40px #2c221740;color:var(--ink);overflow:hidden}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}.modal__header h2{margin:0;font-family:Fraunces,serif;font-size:20px;font-weight:600;color:var(--ink)}.modal__close{width:28px;height:28px;border-radius:14px;font-size:20px;line-height:1;color:var(--ink-dim)}.modal__close:hover{background:var(--bg-2)}.modal__body{padding:8px 18px;overflow-y:auto;flex:1 1 auto}.modal__footer{padding:12px 18px;border-top:1px solid var(--line);background:var(--panel-2)}.modal__empty{padding:32px 16px;text-align:center;color:var(--ink-dim);font-size:14px;display:flex;flex-direction:column;gap:12px;align-items:center}.roster-list{display:flex;flex-direction:column;gap:6px;padding:8px 0}.roster-row{display:grid;grid-template-columns:64px 1fr 72px 32px;gap:8px;align-items:center;padding:4px}.roster-row--add{grid-template-columns:64px 1fr 72px 64px}.roster-row__num,.roster-row__name,.roster-row__pos{padding:8px 10px;border:1.5px solid var(--line);border-radius:8px;background:var(--paper);font-size:14px;color:var(--ink);outline:none;font-family:inherit}.roster-row__num:focus,.roster-row__name:focus,.roster-row__pos:focus{border-color:var(--accent)}.roster-row__name{font-weight:700;letter-spacing:.02em;text-transform:uppercase}.roster-row__delete{width:28px;height:28px;border-radius:14px;font-size:18px;line-height:1;color:var(--ink-faint)}.roster-row__delete:hover{background:var(--accent-soft);color:var(--accent)}.roster-row__add{padding:8px 12px;border-radius:8px;background:var(--accent);color:var(--paper);font-weight:800;font-size:12px;letter-spacing:.04em;text-transform:uppercase}.roster-row__add:disabled{background:var(--line-2);cursor:not-allowed}
