/*
  Chess Club Manager app stylesheet.
  Updated for V5.1 responsive usability repair; preserves the existing app styling.
*/

/* ============================================================================
   ORC Management App Styles
   Preserves the V5.0 static-site file structure and adds V5.1 responsive repairs.
   ============================================================================ */

/* Theme variables and base layout */
:root{--bg:#111;--panel:#1c1c1f;--panel2:#25252a;--text:#f5f5f5;--muted:#b9b9c3;--accent:#d6b45d;--action:#d6b45d;--actionText:#15110a;--secondaryAction:#35506a;--secondaryActionText:#f5f8fb;--gold:#d6b45d;--danger:#b94a48;--ok:#3f8f63;--line:#3a3a40;--input:#0e0e10;--appMaxWidth:1880px;--appGutter:32px;--cardRadius:16px;--controlRadius:12px;--uiDensity:1}*{box-sizing:border-box}html{max-width:100%;overflow-x:hidden}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at top,#28282e,#101012 45%);color:var(--text);overflow-x:hidden}.app{width:min(calc(100vw - var(--appGutter)),var(--appMaxWidth));max-width:var(--appMaxWidth);margin:0 auto;padding:calc(18px * var(--uiDensity));min-width:0}.top{display:flex;gap:18px;align-items:center;margin-bottom:18px;padding-right:0;flex-wrap:wrap;min-width:0}.logo{height:104px;width:104px;object-fit:contain;background:#050505;border-radius:var(--cardRadius);padding:10px;border:1px solid var(--line);flex:0 0 auto}h1{font-size:34px;margin:0;overflow-wrap:anywhere}.tag{color:var(--muted);margin-top:6px;overflow-wrap:anywhere}.nav{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}.btn,button{background:var(--action);color:var(--actionText);border:0;border-radius:var(--controlRadius);padding:11px 15px;font-weight:800;cursor:pointer;box-shadow:0 2px 0 rgba(0,0,0,.25);max-width:100%;min-height:44px;white-space:normal;line-height:1.15}.btn:hover,button:hover{filter:brightness(1.08)}.btn.secondary,button.secondary{background:var(--secondaryAction);color:var(--secondaryActionText);border:1px solid #4f7190}.btn.secondary:hover,button.secondary:hover{filter:brightness(1.12)}button.danger{background:var(--danger);color:white}button.ok{background:var(--ok);color:white}.grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px;min-width:0}.card{background:linear-gradient(180deg,var(--panel),#151517);border:1px solid var(--line);border-radius:var(--cardRadius);padding:calc(18px * var(--uiDensity));box-shadow:0 8px 30px rgba(0,0,0,.25);min-width:0}.span4{grid-column:span 4}.span6{grid-column:span 6}.span8{grid-column:span 8}.span12{grid-column:span 12}@media(max-width:1180px){.app{width:calc(100vw - 20px);padding:16px}.top{padding-right:0}}
@media(max-width:820px){.app{width:100%;padding:12px}.span4,.span6,.span8{grid-column:span 12}.top{align-items:flex-start}.logo{height:78px;width:78px}h1{font-size:26px}}h2,h3{margin:0 0 12px;overflow-wrap:anywhere}.stat{font-size:34px;font-weight:900}.muted{color:var(--muted)}label{display:block;font-weight:800;margin:12px 0 6px;max-width:100%}input,select,textarea{width:100%;max-width:100%;background:var(--input);color:var(--text);border:1px solid var(--line);border-radius:10px;padding:10px;font-size:16px;min-width:0}textarea{resize:vertical}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid var(--line);padding:9px;text-align:left;vertical-align:top}th{color:var(--gold);font-size:13px;text-transform:uppercase}.screen{display:none;min-width:0}.screen.active{display:block}.msg{margin-top:12px;padding:12px;border-radius:12px;background:#222}.msg.ok{border:1px solid var(--ok)}.msg.bad{border:1px solid var(--danger)}.tempMsg{margin-top:10px;transition:opacity .25s ease}.tempMsg.fading{opacity:0}.pill{display:inline-block;border:1px solid var(--line);background:#111;padding:6px 9px;border-radius:999px;margin:3px;max-width:100%;overflow-wrap:anywhere}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;min-width:0}.row>*{min-width:0}.small{font-size:13px}.hidden{display:none!important}.bracket{display:flex;gap:14px;overflow:auto;padding-bottom:8px;max-width:100%}.round{min-width:230px}.match{background:#111;border:1px solid var(--line);border-radius:14px;padding:10px;margin-bottom:10px;min-width:0}.match .player{padding:7px;border-radius:8px;margin:4px 0;background:#202025;display:flex;justify-content:space-between;gap:8px;min-width:0;overflow-wrap:anywhere}.winner{outline:2px solid var(--ok)}.hr{height:1px;background:var(--line);margin:16px 0}.audit{max-height:300px;overflow:auto}.brandmark{max-height:220px;object-fit:contain;width:100%;opacity:.95}.kbd{font-family:ui-monospace,Menlo,Consolas,monospace;background:#050505;border:1px solid #333;border-radius:5px;padding:2px 5px}

/* Background watermark and top-level app shell */
.app{position:relative;z-index:1}
body::before{content:"";position:fixed;inset:-600px;z-index:0;pointer-events:none;opacity:var(--watermarkOpacity,.9);background-image:var(--watermarkImage);background-size:720px 180px;background-repeat:repeat;transform:rotate(-18deg)}
body{background:#0f0f11}
.topAction{position:relative;top:auto;right:auto;z-index:5;display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap;margin-bottom:10px}
.landingChoice{min-height:260px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.bigChoice{font-size:22px;padding:20px 24px;border-radius:18px;min-width:260px}

/* Tournament pairing modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:50;display:flex;align-items:flex-start;justify-content:center;padding:clamp(10px,4vw,40px);overflow:auto}
.modalCard{background:var(--pairingBackground,#f5f0df);color:var(--pairingText,#111);border-radius:20px;max-width:min(1500px,calc(100vw - 20px));width:100%;padding:clamp(14px,3vw,28px);box-shadow:0 20px 60px rgba(0,0,0,.45);min-width:0}
.modalCard h1,.modalCard h2,.modalCard h3{color:var(--pairingText,#111)}
.pairingGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));gap:18px}
.pairingMatch{border:2px solid color-mix(in srgb,var(--pairingCardBackground,#fff) 75%,#777);border-left:9px solid #2f4053;border-radius:18px;padding:18px 20px;background:var(--pairingCardBackground,#fff);color:var(--pairingCardText,#111);font-size:26px;font-weight:900;box-shadow:0 8px 20px rgba(0,0,0,.12)}
.pairingBoard{color:#2f4053;font-size:16px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.pairingPlayer{padding:10px 12px;border:1px solid color-mix(in srgb,var(--pairingCardBackground,#fff) 70%,#777);border-radius:12px;background:color-mix(in srgb,var(--pairingCardBackground,#fff) 86%,#fff);color:var(--pairingCardText,#111);display:flex;gap:10px;align-items:center}
.pairingPlayer.topPlayer{background:var(--pairingTopPlayerBackground,#ffffff);color:var(--pairingTopPlayerText,#111)}
.pairingPlayer.bottomPlayer{background:var(--pairingBottomPlayerBackground,#f5f0df);color:var(--pairingBottomPlayerText,#111)}
.pairingVs{text-align:center;font-size:17px;margin:10px 0;color:var(--pairingCardText,#111);opacity:.78;text-transform:uppercase;letter-spacing:.1em}
.pairingMatch .muted{color:var(--pairingCardText,#111);opacity:.78}
.colorTag{display:inline-flex;align-items:center;justify-content:center;min-width:48px;padding:3px 7px;border-radius:999px;background:color-mix(in srgb,var(--tournamentColor,#d6b45d) 26%,#111);border:1px solid color-mix(in srgb,var(--tournamentColor,#d6b45d) 70%,var(--line,#333));color:#fff;font-size:11px;font-weight:1000;text-transform:uppercase;letter-spacing:.04em}
.match .player>span{display:flex;gap:8px;align-items:center;min-width:0}
.pairingPlayer .colorTag{background:var(--pairingColor,#2f4053);border-color:color-mix(in srgb,var(--pairingColor,#2f4053) 72%,#111);color:#fff;flex:0 0 auto}
.playerNameText{min-width:0}
.modalCard.fullBracketModal{max-width:calc(100vw - 24px);min-height:calc(100vh - 80px);padding:20px}
.fullBracketViewport{background:var(--pairingBackground,#f5f0df);color:var(--pairingText,#111);border-radius:16px;padding:16px;overflow:auto;max-height:calc(100vh - 190px)}
.fullBracketViewport .swissBadge{background:#111;color:#fff;border-color:#333}
.fullBracketBoard{--fullRoundWidth:210px;--fullMatchFont:14px;--fullMatchPad:8px;display:grid;gap:14px;align-items:stretch;min-height:520px}
.fullBracketBoard.size32,.fullBracketBoard.size64{--fullRoundWidth:170px;--fullMatchFont:12px;--fullMatchPad:6px;min-height:620px}
.fullBracketBoard.standard{min-width:max(100%,calc(var(--fullRoundWidth) * var(--roundCount)))}
.fullBracketMirror{display:grid;grid-template-rows:minmax(230px,1fr) auto minmax(230px,1fr);gap:12px;min-width:max(100%,calc(var(--fullRoundWidth) * var(--roundCount)))}
.fullMirrorPath{display:grid;gap:12px;align-items:stretch}
.fullMirrorPath.bottom .fullRoundMatches{display:flex;flex-direction:column-reverse;justify-content:space-around}
.fullBracketFinal{display:flex;justify-content:center}
.fullRound{display:flex;flex-direction:column;min-width:0}
.fullRoundTitle{font-size:13px;font-weight:1000;text-transform:uppercase;color:var(--pairingText,#111);opacity:.78;margin:0 0 8px}
.fullRoundMatches{display:flex;flex-direction:column;justify-content:space-around;gap:8px;height:100%;min-height:130px}
.fullBracketMatch{background:var(--pairingCardBackground,#fff);color:var(--pairingCardText,#111);border:2px solid color-mix(in srgb,var(--pairingCardBackground,#fff) 70%,#777);border-left:7px solid var(--pairingColor,#2f4053);border-radius:12px;padding:var(--fullMatchPad);box-shadow:0 6px 16px rgba(0,0,0,.12);font-size:var(--fullMatchFont);min-height:74px}
.fullBracketBoard.size64 .fullBracketMatch{min-height:58px}
.fullBracketMeta{font-size:11px;font-weight:1000;text-transform:uppercase;color:var(--pairingColor,#2f4053);margin-bottom:5px}
.fullBracketPlayer{display:flex;gap:6px;align-items:center;justify-content:space-between;border:1px solid color-mix(in srgb,var(--pairingCardBackground,#fff) 70%,#777);border-radius:9px;padding:5px 7px;margin-top:4px;background:var(--pairingTopPlayerBackground,#fff);color:var(--pairingTopPlayerText,#111);min-width:0}
.fullBracketPlayer.bottomPlayer{background:var(--pairingBottomPlayerBackground,#f5f0df);color:var(--pairingBottomPlayerText,#111)}
.fullBracketPlayer.winner{outline:2px solid var(--ok);font-weight:1000}
.fullBracketWinner{font-size:11px;font-weight:1000;color:var(--pairingCardText,#111);opacity:.82;margin-top:5px}
@media(max-width:820px){.modalCard.fullBracketModal{padding:12px;max-width:calc(100vw - 12px);min-height:auto}.fullBracketViewport{max-height:calc(100vh - 140px);padding:10px}.fullBracketBoard{--fullRoundWidth:160px;--fullMatchFont:12px}.fullBracketMirror{min-width:760px}.pairingMatch{font-size:20px;padding:14px}.pairingBoard{font-size:13px}.pairingPlayer{align-items:flex-start;flex-wrap:wrap}}
.adminOnly{display:none}


/* Player standing cards */
.playerStatsCard{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;margin-top:14px}
.rankHero{grid-column:span 12;background:#0b0b0c;border:1px solid var(--gold);border-radius:18px;padding:18px}
.rankHero .rankNum{font-size:56px;font-weight:1000;color:var(--gold);line-height:1}
.statBox{grid-column:span 4;background:#111;border:1px solid var(--line);border-radius:14px;padding:14px}
.statBox .label{color:var(--muted);font-size:13px;text-transform:uppercase;font-weight:900}
.statBox .value{font-size:28px;font-weight:1000;margin-top:4px}
@media(max-width:820px){.statBox{grid-column:span 6}.rankHero{grid-column:span 12}}

.drawPill{}
.adminPlayerGrid{display:grid;grid-template-columns:1fr;gap:14px}
.adminPlayerBox{background:#111;border:1px solid var(--line);border-radius:14px;padding:14px}


/* Tournament seeding controls */
.seedControls{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:6px 0 10px}
.seedOption{display:inline-flex;gap:7px;align-items:center;margin:0;padding:7px 10px;border:1px solid var(--line);border-radius:999px;background:#111;cursor:pointer;font-size:13px;line-height:1}
.seedOption input{width:auto;margin:0;accent-color:var(--gold)}
.seedOption.activeSeed{outline:2px solid var(--gold);filter:brightness(1.08)}
.seedRow{display:grid;grid-template-columns:70px 1fr auto;gap:8px;align-items:center;margin:6px 0}
.seedRow input[type=number]{padding:7px;font-size:14px}
.seedMeta{color:var(--muted);font-size:12px}
.tournamentFactionGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:end;margin:8px 0 12px}
.tournamentFactionTag{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:999px;padding:2px 7px;margin-left:6px;font-size:11px;color:var(--muted);background:#111;vertical-align:middle}
.tournamentFactionTag.empty{color:#777}
.factionSeedSummary{display:block;margin-top:4px}
.tournamentCreationColors,.ratingRangePanel,.registrationPanel{background:#111;border:1px solid var(--line);border-radius:14px;padding:12px;margin:12px 0}
.tournamentColorDetails{background:#111;border:1px solid var(--line);border-radius:14px;padding:0;margin:12px 0;overflow:hidden}
.tournamentColorDetails summary{display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;padding:12px;font-weight:1000;list-style:none}
.tournamentColorDetails summary::-webkit-details-marker{display:none}
.tournamentColorDetails summary::after{content:"Expand";font-size:12px;color:var(--muted);text-transform:uppercase}
.tournamentColorDetails[open] summary::after{content:"Minimize"}
.tournamentColorDetails .tournamentColorGrid,.tournamentColorDetails .tournamentColorActions{margin:0 12px 12px}
.tournamentCreationColors h3{margin-bottom:10px}
.tournamentColorGrid{display:grid;grid-template-columns:repeat(2,minmax(130px,1fr));gap:10px}
.ratingRangeGrid{display:grid;grid-template-columns:repeat(3,minmax(90px,1fr));gap:10px;align-items:end}
.ratingRangeGrid label{margin-top:0}
@media(max-width:820px){.ratingRangeGrid,.tournamentColorGrid,.tournamentFactionGrid{grid-template-columns:1fr}}

/* Tournament and Swiss tournament displays */
.swissControls{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.swissStandingsTable td,.swissStandingsTable th{font-size:14px}
.swissBadge{display:inline-block;border:1px solid var(--line);border-radius:999px;padding:4px 8px;background:#111;margin:2px}
.match select{margin-top:8px}

.bracketTopScroll{overflow:auto;padding-top:8px;padding-right:8px;scrollbar-gutter:stable both-edges;max-height:72vh;max-width:100%;border:1px solid rgba(255,255,255,.06);border-radius:14px}
.bracketTopScroll .bracket{overflow:visible;padding-bottom:16px}
.winnerRounds{gap:14px;align-items:flex-start}
.winnerRounds .round{min-width:300px;flex:0 0 300px}
.winnerRounds .round h3{margin:0 0 10px}
.winnerRounds .match{position:static;top:auto;left:auto;width:auto;min-height:0;display:block;margin-bottom:10px}
.round.collapsed .roundMatches{display:none}
.roundHeader{display:flex;align-items:center;gap:8px;justify-content:space-between;border-left:5px solid var(--tournamentColor);padding:8px 8px 8px 9px}
.roundTitle{font-weight:1000}
.roundRemaining{color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase}
.roundToggle{padding:6px 9px;border-radius:9px}
.bracketTopScroll .round h3{position:sticky;top:0;z-index:3;background:#111;border-radius:10px;padding-top:8px;padding-bottom:8px}
.advanceHint{font-size:11px;color:color-mix(in srgb,var(--tournamentColor) 72%,var(--muted));border-top:1px dashed color-mix(in srgb,var(--tournamentColor) 45%,var(--line));margin-top:8px;padding-top:6px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.singlePrizePanel{background:#111;border:1px solid color-mix(in srgb,var(--tournamentColor) 45%,var(--line));border-radius:16px;padding:12px;margin:0 0 14px}
.singlePrizeGrid{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:12px}
.singlePrizeBox{background:#0b0b0c;border:1px solid var(--line);border-radius:14px;padding:12px}
.singlePrizeBox h3{margin-bottom:8px}
.singlePrizeBox label{margin-top:8px}
.thirdPlacePlayers{display:grid;gap:6px;margin:8px 0}
.thirdPlaceStatus{font-weight:900;color:color-mix(in srgb,var(--tournamentColor) 70%,var(--text))}
.tournamentPlayerManager{background:#111;border:1px solid color-mix(in srgb,var(--tournamentColor) 45%,var(--line));border-radius:16px;padding:12px;margin:0 0 14px}
.tournamentPlayerManager h3{margin-bottom:8px}
.tournamentPlayerManagerGrid{display:grid;grid-template-columns:1.1fr 1fr;gap:12px;align-items:start}
.tournamentPlayerEditBox,.tournamentPlayerRosterBox{background:#0b0b0c;border:1px solid var(--line);border-radius:14px;padding:12px}
.tournamentPlayerEditBox label{margin-top:8px}
.tournamentPlayerRoster{display:grid;gap:6px;max-height:260px;overflow:auto}
.tournamentPlayerRow{display:grid;grid-template-columns:72px minmax(0,1fr) auto;gap:8px;align-items:center;background:#151517;border:1px solid var(--line);border-radius:10px;padding:8px;min-width:0}
.tournamentPlayerRow.placeholder{border-color:color-mix(in srgb,var(--tournamentColor) 60%,var(--line));background:color-mix(in srgb,var(--tournamentColor) 12%,#151517)}
.slotBadge{font-size:12px;font-weight:1000;text-transform:uppercase;color:var(--muted)}
.lateBadge{font-size:11px;font-weight:900;border:1px solid var(--line);border-radius:999px;padding:3px 7px;color:var(--muted)}
@media(max-width:820px){.singlePrizeGrid{grid-template-columns:1fr}}
@media(max-width:820px){.tournamentPlayerManagerGrid{grid-template-columns:1fr}.tournamentPlayerRow{grid-template-columns:1fr}}
.resultControls{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}
.resultRecorded{border:1px solid var(--ok);background:rgba(63,143,99,.16);border-radius:12px;padding:10px;margin-top:8px}
.resultRecorded .resultLabel{font-weight:900}
.resultRecorded .row{margin-top:8px}
.adminGameFilter{margin-bottom:12px;background:#111;border:1px solid var(--line);border-radius:14px;padding:12px}
.autoBracketNote{margin-top:8px;color:var(--muted);font-size:13px}
.tournamentActionRow{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:14px}
.tournamentActionRow button{flex:1 1 180px}
.registrationPanel h3{margin-bottom:8px}
.registrationPanel label{margin-top:8px}


/* Club View header stats */
.clubHeaderWrap{display:flex;flex-direction:column;gap:6px}
.clubHeaderStats{margin-left:auto;margin-right:0;display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:8px;align-self:center;max-width:360px;min-width:0}
.clubHeaderStat{background:#111;border:1px solid var(--line);border-radius:14px;padding:10px 12px;min-height:56px}
.clubHeaderStat .label{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;font-weight:900;letter-spacing:.05em}
.clubHeaderStat .value{display:block;color:var(--text);font-size:18px;font-weight:1000;margin-top:2px}
.clubViewIntro{display:none}
@media(max-width:1180px){.clubHeaderStats{margin-right:0;grid-template-columns:repeat(2,minmax(120px,1fr));max-width:none}.top{padding-right:0}.topAction{justify-content:flex-end}}
@media(max-width:820px){.clubHeaderStats{width:100%;grid-template-columns:repeat(2,minmax(0,1fr));margin-left:0}.clubHeaderStat{padding:9px}.clubHeaderStat .label{font-size:11px}.top{flex-wrap:wrap;margin-top:8px}.clubHeaderWrap{width:calc(100% - 96px);min-width:0}}
@media(max-width:480px){.clubHeaderWrap{width:100%}.topAction{justify-content:stretch}.topAction button{flex:1 1 105px}.clubHeaderStats{grid-template-columns:1fr 1fr}.clubHeaderStat .value{font-size:16px}.bigChoice{width:100%;min-width:0}}


/* Full Club Rankings controls */
.rankingsControls{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin:10px 0 14px}
.rankingsControls label{margin:0;min-width:220px}
.statsScopeNote{color:var(--muted);font-size:13px;font-weight:800;margin:8px 0}
.rankingsPager{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap;margin:10px 0}
.rankingsPager .pageInfo{color:var(--muted);font-weight:800;margin-right:auto}
.rankingsPager button{min-width:42px;padding:8px 10px;border-radius:10px}
.rankingsPager button[disabled]{opacity:.45;cursor:not-allowed;filter:none}
.responsiveTableShell{position:relative;margin:10px 0 12px;max-width:100%}
.tableScrollHint{display:none;margin:0 0 6px;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}
.compactTableWrap{overflow-x:auto;max-width:100%;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#0b0b0c;scrollbar-gutter:stable}
.compactTableWrap table{min-width:760px}
.compactTableWrap::after{content:"";position:sticky;right:0;top:0;display:block;width:26px;height:1px;margin-left:auto;background:linear-gradient(90deg,rgba(11,11,12,0),rgba(214,180,93,.38));pointer-events:none}
@media(max-width:820px){.tableScrollHint{display:block}.compactTableWrap{box-shadow:inset -18px 0 18px -18px var(--gold)}}


/* Game history and search display */
.gameFilterGrid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:12px;align-items:end;margin-bottom:12px;background:#111;border:1px solid var(--line);border-radius:14px;padding:12px}
.gameFilterGrid label{margin:0}
.gameRowWin{border-left:4px solid var(--ok)}
.gameRowDraw{border-left:4px solid var(--muted)}
.gamePlayerLine{padding:4px 6px;border-radius:8px;margin:2px 0;display:inline-block}
.gamePlayerLine.win{background:rgba(63,143,99,.22);outline:1px solid rgba(63,143,99,.55)}
.gamePlayerLine.loss{background:rgba(185,74,72,.18);outline:1px solid rgba(185,74,72,.45)}
.gamePlayerLine.draw{background:rgba(185,185,195,.12);outline:1px solid rgba(185,185,195,.35)}
.ratingDelta{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13px;white-space:nowrap}
.ratingDelta.positive{color:#8bd6a8}.ratingDelta.negative{color:#ff9a96}.ratingDelta.neutral{color:var(--muted)}
.gameHistoryNote{color:var(--muted);font-size:13px;margin-top:8px}
.gameHistoryPager{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap;margin:10px 0}
.gameHistoryPager .pageInfo{color:var(--muted);font-weight:800;margin-right:auto}
.gameHistoryPager button{min-width:42px;padding:8px 10px;border-radius:10px}
.gameHistoryPager button[disabled]{opacity:.45;cursor:not-allowed;filter:none}
@media(max-width:1180px){.gameFilterGrid{grid-template-columns:repeat(2,minmax(180px,1fr))}}
@media(max-width:820px){.gameFilterGrid{grid-template-columns:1fr}}


/* Date range reports and game-night limit */
.reportPanel{background:#111;border:1px solid var(--line);border-radius:14px;padding:12px;margin-top:12px}
.reportPreview{max-height:260px;overflow:auto;background:#0b0b0c;border:1px solid var(--line);border-radius:12px;padding:12px;margin-top:12px;max-width:100%}
.reportPreview table{min-width:680px}
@media(max-width:820px){.reportPreview::before{content:"Scroll report preview horizontally to see more columns.";display:block;margin-bottom:8px;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}}
.limitWarning{border:1px solid var(--danger);background:rgba(185,74,72,.16);border-radius:12px;padding:12px;margin-top:12px}
.limitApprovalGrid{display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:10px;align-items:end;margin-top:10px}
@media(max-width:820px){.limitApprovalGrid{grid-template-columns:1fr}}


/* Expanded Admin player editor */
.playerEditForm{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}
.adminPlayerMeta{background:#0b0b0c;border:1px solid var(--line);border-radius:12px;padding:10px;margin-top:10px}


/* Tournament display color customization */
.tournamentColorPicker{display:block;margin:10px 0;background:#111;border:1px solid var(--line);border-radius:14px;padding:12px}
.tournamentColorPicker h3{margin-bottom:10px}
.tournamentColorPicker label{margin:0;min-width:150px}
.tournamentDisplay{--tournamentColor:var(--gold);padding-top:0}
.tournamentHero{background:linear-gradient(90deg,color-mix(in srgb,var(--tournamentColor) 28%,#111),#111);border:1px solid color-mix(in srgb,var(--tournamentColor) 60%,var(--line));border-radius:16px;padding:12px;margin:10px 0 14px}
.tournamentHero h3{margin:0;color:#fff}
.tournamentHero .muted{color:#e7e7e7}
.tournamentDisplay .round h3{border-left:5px solid var(--tournamentColor);padding-left:9px}
.tournamentDisplay .match{border-color:color-mix(in srgb,var(--tournamentColor) 45%,var(--line));box-shadow:0 0 0 1px rgba(255,255,255,.02),0 8px 22px rgba(0,0,0,.18)}
.tournamentDisplay .match .small.muted{color:color-mix(in srgb,var(--tournamentColor) 62%,var(--muted))}
.tournamentDisplay .player.winner,.tournamentDisplay .winner{outline:3px solid var(--ok);background:linear-gradient(90deg,rgba(63,143,99,.32),#202025)}
.tournamentDisplay .swissBadge{border-color:color-mix(in srgb,var(--tournamentColor) 55%,var(--line))}
.pairingMatch{border-left-color:var(--pairingColor,#2f4053)}
.pairingBoard{color:var(--pairingColor,#2f4053)}


/* Round Robin tournament display */
.roundRobinStandingsTable td,.roundRobinStandingsTable th{font-size:14px}
.formatNote{margin-top:8px;color:var(--muted);font-size:13px}

/* Branding and display customization */
.brandingGrid{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px;align-items:end}
.brandingGrid label{margin-top:0}
.colorField{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center;background:#0b0b0c;border:1px solid var(--line);border-radius:12px;padding:8px 10px}
.colorField span{grid-column:1 / -1;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.colorField input[type=color],.compactColorInput{width:56px!important;height:42px!important;min-width:56px;padding:3px!important;border-radius:10px;cursor:pointer}
.colorValue{font-family:ui-monospace,Menlo,Consolas,monospace;color:var(--text);font-size:13px}
.logoPreview{height:86px;width:86px;object-fit:contain;background:#050505;border:1px solid var(--line);border-radius:12px;padding:8px}
.displayField{background:#0b0b0c;border:1px solid var(--line);border-radius:12px;padding:8px 10px}
.displayField span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
@media(max-width:1180px){.brandingGrid{grid-template-columns:repeat(2,minmax(180px,1fr))}}
@media(max-width:820px){.brandingGrid{grid-template-columns:1fr}}


/* Admin screen organization */
.adminSectionHeader{grid-column:span 12;background:#111;border:1px solid var(--line);border-left:5px solid var(--gold);border-radius:16px;padding:14px 16px;margin-top:4px}
.adminSectionHeader h2{margin:0 0 6px}
.adminSettingsGrid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.adminSettingsCard{background:#111;border:1px solid var(--line);border-radius:14px;padding:14px}
.adminSettingsCard h3{margin-bottom:8px}
.adminSettingsPrimary{grid-column:span 4}
.adminSettingsWide{grid-column:span 8}
.adminSettingsFull{grid-column:span 12}
.adminManagementDivider{grid-column:span 12;margin-top:8px}
@media(max-width:1180px){.adminSettingsPrimary{grid-column:span 6}.adminSettingsWide{grid-column:span 12}}
@media(max-width:820px){.adminSettingsPrimary,.adminSettingsWide,.adminSettingsFull{grid-column:span 12}}
.seasonManagementGrid{display:grid;grid-template-columns:minmax(260px,1fr) minmax(260px,1fr);gap:14px;align-items:start}
.seasonEditorPanel{background:#0b0b0c;border:1px solid var(--line);border-radius:12px;padding:12px}
.seasonList{display:grid;gap:8px;margin-top:10px;max-height:330px;overflow:auto}
.seasonRow{border:1px solid var(--line);border-radius:12px;padding:10px;background:#0b0b0c}
.seasonRow.active{border-color:var(--gold);box-shadow:0 0 0 1px rgba(214,180,93,.18) inset}
.seasonMeta{color:var(--muted);font-size:12px;margin-top:4px}
.seasonActionRow{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.seasonActionRow button{width:auto}
@media(max-width:900px){.seasonManagementGrid{grid-template-columns:1fr}}
.factionAdminGrid{display:grid;grid-template-columns:minmax(240px,320px) minmax(0,1fr);gap:14px;align-items:start}
.factionList{display:grid;gap:10px}
.factionSelectorPanel{display:grid;grid-template-columns:minmax(220px,360px) 1fr;gap:12px;align-items:end;margin-bottom:12px}
.factionRow{border:1px solid var(--line);border-radius:12px;padding:12px;background:#0b0b0c}
.factionEditGrid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:10px;align-items:end;margin-top:10px;min-width:0}
.factionBadge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;border-radius:999px;border:1px solid currentColor;background:rgba(255,255,255,.06);font-weight:1000;margin-right:7px;vertical-align:middle}
.factionPlayerTag{white-space:nowrap}
.factionClubGrid{display:grid;grid-template-columns:minmax(260px,1fr) minmax(0,1.4fr);gap:14px;align-items:start}
.factionClubPanel{background:#111;border:1px solid var(--line);border-radius:14px;padding:12px}
.factionSearchGrid{display:grid;grid-template-columns:minmax(220px,1fr) minmax(180px,240px);gap:10px;align-items:end;margin-bottom:12px}
.factionSummaryGrid{display:grid;grid-template-columns:repeat(4,minmax(90px,1fr));gap:8px;margin-top:8px}
.factionSummaryBox{background:#151517;border:1px solid var(--line);border-radius:10px;padding:8px}
.factionSummaryBox .label{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;font-weight:900}
.factionSummaryBox .value{display:block;font-weight:1000;font-size:18px;margin-top:2px}
.factionRosterList{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
@media(max-width:980px){.factionAdminGrid,.factionEditGrid,.factionSelectorPanel{grid-template-columns:1fr}}
@media(max-width:980px){.factionClubGrid,.factionSearchGrid{grid-template-columns:1fr}.factionSummaryGrid{grid-template-columns:repeat(2,1fr)}}

/* Admin communication helpers */
.emailListTextarea{min-height:96px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:14px}
.emailListMeta{margin-top:8px;color:var(--muted);font-size:13px}

/* Admin tools and formula editor */
.adminActionButton{margin-top:12px}
#adminPanel button,#adminPanel .btn{margin-top:10px}
.backupButtonStack{display:grid;grid-template-columns:1fr;gap:12px;margin-top:8px}
.backupButtonStack button,.backupButtonStack .btn{width:100%;text-align:center}
.backupButtonStack .backupPrimary{font-size:18px;padding:17px 18px;border-radius:16px}
.backupButtonStack .backupReset{font-size:13px;padding:9px 11px;justify-self:start;width:auto}
.formulaGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.formulaGrid label{margin-top:0}
.formulaPreview{background:#111;border:1px solid var(--line);border-radius:14px;padding:12px;margin-top:12px}
@media(max-width:1180px){.formulaGrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:820px){.formulaGrid{grid-template-columns:1fr}}

/* V5.1 focused responsive usability repairs */
@media(max-width:640px){
  .app{padding:10px}
  .card,.adminSettingsCard,.seasonEditorPanel,.factionClubPanel,.tournamentPlayerManager,.registrationPanel,.reportPanel{padding:12px}
  .rankingsPager,.gameHistoryPager{justify-content:flex-start}
  .rankingsPager .pageInfo,.gameHistoryPager .pageInfo{flex:1 1 100%;margin-right:0}
  .rankingsPager button,.gameHistoryPager button{flex:1 1 44px}
  .tournamentActionRow button,.seasonActionRow button,.resultControls button,.modalCard button{flex:1 1 100%}
  .seedControls{align-items:stretch}
  .seedOption{flex:1 1 140px;justify-content:center}
  .round{min-width:260px}
  .winnerRounds .round{min-width:260px;flex-basis:260px}
  .swissControls{grid-template-columns:1fr}
  .colorTag{min-width:auto}
  .playerNameText{overflow-wrap:anywhere}
}

@media(max-width:390px){
  .clubHeaderStats{grid-template-columns:1fr}
  .statBox{grid-column:span 12}
  .round{min-width:240px}
  .winnerRounds .round{min-width:240px;flex-basis:240px}
}
