: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 300px;grid-template-rows:64px 1fr auto;grid-template-areas:"top    top" "court  roster" "notes  notes";gap:10px;padding:12px;color:var(--ink);background:var(--bg)}.topbar{grid-area:top;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:6px 12px;min-width:0}.topbar__brand{display:flex;align-items:center;gap:10px}.brand-mark{width:32px;height:32px;border-radius:8px;background:var(--paper);border:1px solid var(--line);display:grid;place-items:center}.brand-mark svg{width:22px;height:22px}.brand-title{font-family:Fraunces,serif;font-weight:600;font-size:17px;line-height:1;color:var(--ink);letter-spacing:-.01em}.brand-sub{font-size:11px;color:var(--ink-dim);margin-top:2px}.rot-bar{display:flex;gap:6px;align-items:center;min-width:0;overflow-x:auto}.rot-bar__label{font-size:11px;font-weight:700;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase;margin-right:4px}.rot-btn{background:var(--paper);border:1.5px solid var(--line);border-radius:10px;padding:3px 8px;display:flex;flex-direction:row;align-items:center;gap:5px;flex-shrink:0;min-width:60px;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:17px;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:5px 12px;border-radius:999px;font-size:11px;font-weight:700;color:var(--ink-dim);letter-spacing:.02em}.phase-btn.is-active{background:var(--ink);color:var(--paper)}.util-btn{padding:5px 11px;border-radius:999px;background:transparent;border:1.5px solid var(--line-2);font-size:11px;font-weight:700;color:var(--ink-dim);white-space:nowrap}.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:32px;font-weight:700;pointer-events:none}.tok-slot{fill:var(--paper);font-family:Nunito Sans,sans-serif;font-size:9px;font-weight:800;letter-spacing:.06em}.court-controls{position:absolute;top:12px;right:14px;left:calc(50% + 90px);display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;z-index:2;pointer-events:none}.court-controls>*{pointer-events:auto}.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:12px}.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:15px;font-weight:600;opacity:.6}.tok-num{fill:var(--ink);font-family:Fraunces,serif;font-size:18px;font-weight:700}.tok-name{fill:var(--ink-dim);font-family:Nunito Sans,sans-serif;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.tok-pos{fill:var(--paper);font-family:Nunito Sans,sans-serif;font-size:10px;font-weight:800;letter-spacing:.04em}.tok-star{fill:var(--paper);font-family:Nunito Sans,sans-serif;font-size:12px;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:8px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:10px;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:180px 1fr 220px;gap:12px;align-items:start;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:8px 14px}.notes-strip__meta{align-self:center;display:flex;flex-direction:column;gap:6px;align-items:flex-start}.notes-strip__hint{align-self:center}.notes-strip__label{font-family:Fraunces,serif;font-size:14px;font-weight:600;color:var(--ink)}.notes-strip__recap{padding:4px 10px;border-radius:8px;background:var(--bg-2);border:1px solid var(--line);color:var(--ink-dim);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.notes-strip__recap:hover{background:var(--panel);color:var(--ink);border-color:var(--line-2)}.notes-strip__input{background:var(--paper);border:1.5px solid var(--line);border-radius:10px;padding:8px 12px;color:var(--ink);font-size:13px;font-family:inherit;line-height:1.4;width:100%;min-height:40px;resize:vertical;outline:none}.notes-strip__input:focus{border-color:var(--accent)}.notes-strip__hint{font-size:11px;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:8px;flex-wrap:nowrap;justify-content:flex-end}.util-btn--save{min-width:82px;text-align:center}.util-btn--dirty{background:var(--accent);color:var(--paper);border-color:var(--accent)}.util-btn--dirty:hover{background:var(--accent-2);border-color:var(--accent-2)}.canvas-flip-btn{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:3;padding:6px 14px;border-radius:999px;background:var(--panel);border:1px solid var(--line-2);color:var(--ink);font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;box-shadow:0 3px 10px #2c221726;transition:background .12s ease,transform .12s ease}.canvas-flip-btn:hover{background:var(--paper);transform:translate(-50%,-1px);box-shadow:0 5px 14px #2c221733}.canvas-flip-btn:active{transform:translate(-50%);box-shadow:0 2px 6px #2c221733}.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}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--paper);padding:10px 16px;border-radius:999px;font-size:13px;font-weight:600;box-shadow:0 6px 24px #2c221759;z-index:200;animation:toast-pop .2s ease-out}@keyframes toast-pop{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.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}.boards-panel{width:min(520px,92vw);padding:0}.boards-panel__header,.share-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--line)}.boards-panel__header h2,.share-dialog__header h2{margin:0;font-family:Fraunces,serif;font-size:20px;font-weight:600;color:var(--ink)}.icon-btn{width:32px;height:32px;border-radius:16px;font-size:22px;line-height:1;color:var(--ink-dim);background:transparent;border:none;cursor:pointer}.icon-btn:hover{background:var(--bg-2);color:var(--ink)}.boards-panel__actions{padding:12px 20px;border-bottom:1px solid var(--line)}.boards-panel__list{overflow-y:auto;padding:8px 0;max-height:60vh}.boards-panel__empty{padding:32px 24px;text-align:center;color:var(--ink-dim);font-size:14px}.board-row{display:flex;align-items:stretch;gap:2px;padding:0 20px;border-bottom:1px solid var(--line)}.board-row.is-active{background:var(--accent-soft)}.board-row__main{flex:1;text-align:left;padding:12px 4px;background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column;gap:3px}.board-row__main:hover{background:var(--bg-2)}.board-row__name{font-weight:700;font-size:14px;color:var(--ink)}.board-row__meta{font-size:11px;color:var(--ink-dim);display:flex;align-items:center;gap:8px}.board-row__pill{padding:1px 7px;background:var(--accent);color:var(--paper);border-radius:999px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:9px}.board-row__pill--editor{background:var(--ink-dim)}.board-row__delete{padding:0 12px;background:transparent;border:none;color:var(--ink-faint);cursor:pointer;font-size:15px}.board-row__delete:hover{background:var(--accent-soft);color:var(--accent)}.board-row__delete:disabled{opacity:.4;cursor:not-allowed}.share-dialog{width:min(540px,92vw);padding:0}.share-dialog__body{padding:8px 20px 20px}.share-link{padding:14px 0;border-bottom:1px solid var(--line)}.share-link:last-child{border-bottom:none}.share-link__label{font-weight:700;font-size:13px;color:var(--ink);margin-bottom:3px}.share-link__desc{font-size:12px;color:var(--ink-dim);margin-bottom:10px;line-height:1.45}.share-link__row{display:flex;gap:6px}.share-link__input{flex:1;font-family:Menlo,Consolas,monospace;font-size:11px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);min-width:0}.share-link__input:focus{outline:2px solid var(--accent);outline-offset:-1px}.brand-sub--mode{font-weight:600;display:inline-block;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand-sub--mode-editing{color:var(--accent)}.brand-sub--mode-sandbox{color:var(--warn)}.util-btn--saved{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft)}@media (max-width: 1180px){.rot-bar__label,.rot-btn__meta{display:none}.rot-btn{padding:4px 0;min-width:34px;justify-content:center}.rot-btn__num{font-size:15px}.topbar{gap:10px}}.ring-overlap{animation:ring-overlap-pulse 1.4s ease-in-out infinite}@keyframes ring-overlap-pulse{0%,to{opacity:.7}50%{opacity:1}}.overlap-toggle .phase-btn.is-active{background:var(--libero);color:var(--paper)}.boundary-line{animation:boundary-pulse .9s ease-in-out infinite;filter:drop-shadow(0 0 6px rgba(198,63,34,.55))}@keyframes boundary-pulse{0%,to{opacity:.6;stroke-width:4}50%{opacity:1;stroke-width:5.5}}.court-ctrl-toggle{display:inline-flex;gap:4px;background:var(--bg-2);border:1.5px solid var(--line);border-radius:999px;padding:2px}.court-ctrl-toggle .court-ctrl{border:none;background:transparent;padding:5px 11px;font-size:11px;letter-spacing:.04em;text-transform:none}.court-ctrl-toggle .court-ctrl.is-on{background:var(--ink);color:var(--paper);border:none}.court-ctrl-toggle .court-ctrl.is-on.is-learn{background:var(--libero)}.run-arrow{opacity:.85;filter:drop-shadow(0 1px 2px rgba(44,34,23,.25))}.court-ctrl.is-on.is-arrow{background:var(--accent);color:var(--paper);border-color:var(--accent)}.court-ctrl--play{background:var(--accent-soft);color:var(--accent);border-color:var(--accent);font-weight:800}.court-ctrl--play:hover{background:var(--accent);color:var(--paper)}.run-arrow-preview{opacity:.7;animation:arrow-preview-pulse 1s ease-in-out infinite}@keyframes arrow-preview-pulse{0%,to{opacity:.55}50%{opacity:.9}}
