:root{color:#20211f;background:#f6f7f2;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--ink: #20211f;--muted: #676b61;--line: #dfe2d7;--surface: #ffffff;--surface-strong: #f0f3e8;--green: #2f6f5e;--green-dark: #245648;--red: #c4513f;--yellow: #d7aa33;--blue: #2d78aa;--shadow: 0 18px 40px rgba(31, 33, 30, .09)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.68}.screen{width:min(1440px,100%);min-height:100vh;margin:0 auto;padding:24px}.center-screen,.auth-screen{display:grid;place-items:center}.loading-mark,.brand-mark{display:grid;width:44px;height:44px;place-items:center;border:1px solid var(--line);border-radius:8px;color:#fff;background:var(--green)}.brand-mark.large{width:64px;height:64px}.loading-mark svg,.brand-mark svg{width:22px;height:22px}.brand-mark.large svg{width:32px;height:32px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.brand-lockup,.user-actions{display:flex;align-items:center;gap:12px}h1,h2,p{margin:0}h1{font-size:28px;line-height:1.1}h2{font-size:18px;line-height:1.2}.eyebrow{margin-bottom:4px;color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase}.user-chip{display:grid;min-width:160px;padding:9px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.user-chip span{font-weight:800}.user-chip small{color:var(--muted)}.icon-button,.primary-button{display:inline-flex;min-height:42px;align-items:center;justify-content:center;gap:8px;border:0;border-radius:8px}.icon-button{width:42px;color:var(--ink);background:var(--surface);border:1px solid var(--line)}.primary-button{padding:0 16px;color:#fff;font-weight:800;background:var(--green)}.primary-button:hover{background:var(--green-dark)}.danger-button{display:inline-flex;min-height:42px;align-items:center;justify-content:center;gap:8px;padding:0 16px;border:1px solid rgba(196,81,63,.35);border-radius:8px;color:var(--red);font-weight:800;background:#fff7f5}.danger-button:hover{border-color:#c4513f94;background:#fff1ee}.primary-button svg,.danger-button svg,.icon-button svg{width:18px;height:18px;flex:0 0 auto}.full-width{width:100%}.status-banner,.form-error{margin-bottom:16px;padding:12px 14px;border:1px solid rgba(196,81,63,.35);border-radius:8px;color:#8b2d21;background:#fff1ee}.form-message{margin-bottom:16px;padding:12px 14px;border:1px solid rgba(47,111,94,.24);border-radius:8px;color:var(--green);font-weight:800;background:#f1faf6}.auth-link-button{justify-self:start;padding:0;border:0;color:var(--green);font-size:13px;font-weight:900;background:transparent}.auth-link-button:hover{color:var(--ink)}.dashboard-grid{display:grid;grid-template-columns:minmax(300px,360px) 1fr;gap:20px;align-items:start}.challenge-rail,.challenge-detail,.leaderboard-panel,.recent-panel,.auth-form,.auth-brand,.new-challenge-form,.role-management-panel,.club-management-panel,.member-management-panel,.profile-panel,.challenge-create-panel{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.challenge-rail{display:grid;gap:14px;padding:16px}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-heading span,.panel-heading svg{color:var(--muted)}.panel-heading.compact{margin-bottom:2px}.panel-subtitle{margin-top:3px;color:var(--muted);font-size:12px;font-weight:800}.filter-clear-button{display:inline-flex;min-height:34px;align-items:center;justify-content:center;gap:7px;padding:0 10px;border:1px solid var(--line);border-radius:8px;color:var(--ink);font-size:12px;font-weight:800;background:var(--surface-strong)}.filter-clear-button:hover{border-color:#2f6f5e6b;background:#fff}.filter-clear-button svg{width:15px;height:15px}.challenge-list{display:grid;gap:10px}.challenge-card{display:grid;grid-template-columns:40px minmax(0,1fr) auto;gap:10px;align-items:center;width:100%;padding:10px;border:1px solid var(--line);border-radius:8px;color:var(--ink);text-align:left;background:var(--surface)}.challenge-card.active{border-color:#2f6f5e7a;background:var(--surface-strong)}.challenge-icon{display:grid;width:40px;height:40px;place-items:center;border-radius:8px;color:#fff;background:var(--blue)}.challenge-card:nth-child(3n+2) .challenge-icon{background:var(--red)}.challenge-card:nth-child(3n) .challenge-icon{background:var(--yellow);color:var(--ink)}.challenge-icon svg{width:19px;height:19px}.challenge-body{display:grid;min-width:0;gap:3px}.challenge-body strong,.row-main strong,.recent-row strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.challenge-body small,.row-main small,.recent-row small,.row-score small{overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap}.challenge-best{color:var(--green);font-weight:900;white-space:nowrap}.new-challenge-form,.role-management-panel,.auth-form{display:grid;gap:12px;padding:14px}.view-tabs{display:inline-grid;grid-auto-flow:column;grid-auto-columns:minmax(140px,1fr);gap:8px;margin-bottom:20px;padding:4px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.view-tabs button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:8px;border:0;border-radius:6px;color:var(--muted);font-weight:800;background:transparent}.view-tabs button.active{color:var(--ink);background:#fff;box-shadow:0 6px 16px #1f211e14}.view-tabs svg{width:18px;height:18px}.admin-page{display:grid;grid-template-columns:minmax(360px,.9fr) minmax(420px,1.1fr);gap:20px;align-items:start}.profile-page,.challenge-create-page{display:grid;grid-template-columns:minmax(320px,820px);justify-content:center}.profile-panel,.challenge-create-panel{display:grid;gap:16px;padding:18px}.profile-form,.challenge-create-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.wide-field{grid-column:1 / -1}.profile-password-fields{display:grid;grid-column:1 / -1;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding-top:4px}.profile-form .primary-button{justify-self:end}.challenge-create-form .primary-button{grid-column:1 / -1;justify-self:end}.target-picker{display:grid;gap:10px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.target-picker-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.target-picker-heading span{color:var(--muted);font-size:12px;font-weight:800}.target-option-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;max-height:280px;overflow:auto}.target-option{display:flex;min-width:0;min-height:38px;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;color:var(--ink);font-size:13px;background:#fff}.target-option input{width:16px;min-height:16px;flex:0 0 auto}.target-option span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.club-management-panel,.member-management-panel{display:grid;gap:14px;padding:16px}.new-club-form{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto;gap:12px;align-items:end}label{display:grid;gap:6px;color:var(--muted);font-size:13px;font-weight:800}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;color:var(--ink);background:#fff}input,select{min-height:42px;padding:0 12px}textarea{min-height:76px;resize:vertical;padding:10px 12px}input:focus,select:focus,textarea:focus{outline:2px solid rgba(47,111,94,.24);border-color:var(--green)}.work-area{display:grid;gap:20px}.challenge-detail{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:end;padding:18px}.challenge-detail p{max-width:680px;margin-top:7px;color:var(--muted)}.challenge-side{display:grid;gap:10px;min-width:0}.metric-strip{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:10px}.metric-strip div{min-width:130px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.metric-strip span{display:block;color:var(--muted);font-size:12px;font-weight:800}.metric-strip strong{display:block;margin-top:6px;font-size:22px}.metric-strip .date-range{font-size:14px;line-height:1.3}.entry-form{display:grid;grid-column:1 / -1;grid-template-columns:minmax(220px,1fr) auto;gap:12px;align-items:end;padding-top:4px}.content-columns{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:20px;align-items:start}.content-columns.history-mode{grid-template-columns:minmax(0,1fr)}.leaderboard-panel,.recent-panel{display:grid;gap:14px;padding:16px}.leaderboard-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;padding:4px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.leaderboard-tabs button{display:inline-flex;min-height:36px;align-items:center;justify-content:center;gap:7px;min-width:0;border:0;border-radius:6px;color:var(--muted);font-size:12px;font-weight:800;background:transparent}.leaderboard-tabs button.active{color:var(--ink);background:#fff;box-shadow:0 6px 16px #1f211e14}.leaderboard-tabs svg{width:15px;height:15px;flex:0 0 auto}.leaderboard-list,.recent-list{display:grid;gap:10px}.leaderboard-list{max-height:854px;overflow-y:auto;padding-right:4px}.leaderboard-list.compact{max-height:566px}.leaderboard-row{display:grid;grid-template-columns:42px minmax(0,1fr) auto;gap:12px;align-items:center;min-height:62px;padding:10px;border:1px solid var(--line);border-radius:8px}.rank{display:grid;width:34px;height:34px;place-items:center;border-radius:8px;color:#fff;font-weight:900;background:var(--green)}.row-main,.recent-row div{display:grid;min-width:0;gap:3px}.row-score{display:grid;justify-items:end;gap:3px;white-space:nowrap}.recent-row{display:grid;grid-template-columns:34px minmax(0,1fr) auto 34px;gap:10px;align-items:center;min-height:54px}.recent-row>svg{width:22px;height:22px;color:var(--yellow)}.recent-row>span{font-weight:900;white-space:nowrap}.entry-delete-button{display:grid;width:34px;height:34px;place-items:center;border:1px solid rgba(196,81,63,.28);border-radius:8px;color:var(--red);background:#fff7f5}.entry-delete-button:hover{border-color:#c4513f80;background:#fff1ee}.entry-delete-button svg{width:16px;height:16px}.club-list{display:grid;gap:10px;max-height:640px;overflow:auto}.club-row{display:grid;grid-template-columns:40px minmax(0,1fr) auto 34px 34px;gap:10px;align-items:center;min-height:58px;padding:10px;border:1px solid var(--line);border-radius:8px}.club-row[role=button]{cursor:pointer}.club-row[role=button]:hover,.club-row.selected{border-color:#2f6f5e7a;background:var(--surface-strong)}.club-row[role=button]:focus-visible{outline:2px solid rgba(47,111,94,.24);border-color:var(--green)}.club-row.selected .club-icon{background:var(--green)}.club-icon{display:grid;width:40px;height:40px;place-items:center;border-radius:8px;color:#fff;background:var(--blue)}.club-icon svg{width:19px;height:19px}.club-body{display:grid;min-width:0;gap:3px}.club-body strong,.club-body small,.club-country{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.club-body small,.club-country{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}.club-body small svg,.club-country svg{width:14px;height:14px;flex:0 0 auto}.club-country{justify-self:end;font-size:13px;font-weight:800}.club-edit-fields{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.club-edit-fields input{min-height:36px;padding:0 10px;font-size:13px}.club-edit-actions{display:inline-flex;gap:8px}.club-action-button{display:grid;width:34px;height:34px;place-items:center;border:1px solid var(--line);border-radius:8px;color:var(--ink);background:var(--surface-strong)}.club-action-button:hover{border-color:#2f6f5e6b;background:#fff}.club-action-button.save{color:#fff;border-color:var(--green);background:var(--green)}.club-action-button.danger{color:var(--red);border-color:#c4513f47;background:#fff7f5}.club-action-button.danger:hover{border-color:#c4513f80;background:#fff1ee}.club-action-button svg{width:16px;height:16px}.member-list{display:grid;gap:10px;max-height:320px;overflow:auto}.member-list.large{max-height:640px}.member-row{display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:10px;align-items:center;min-height:54px;padding:10px;border:1px solid var(--line);border-radius:8px}.member-row.with-delete{grid-template-columns:34px minmax(0,1fr) auto auto}.role-icon{display:grid;width:34px;height:34px;place-items:center;border-radius:8px;color:#fff;background:var(--blue)}.role-icon.clubLeader{background:var(--green)}.role-icon.challengeLeader{color:var(--ink);background:var(--yellow)}.role-icon svg{width:18px;height:18px}.member-body{display:grid;min-width:0;gap:3px}.member-body strong,.member-body small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-body small{color:var(--muted)}.role-select{width:150px;min-height:34px;padding:0 10px;border:1px solid var(--line);border-radius:8px;color:var(--ink);font-size:12px;font-weight:800;background:var(--surface-strong)}.member-delete-button{display:grid;width:34px;height:34px;place-items:center;border:1px solid #ffc8bf;border-radius:8px;color:var(--red);background:#fff7f5;cursor:pointer}.member-delete-button:hover:not(:disabled){background:#fff1ee}.member-delete-button:disabled{cursor:not-allowed;opacity:.45}.member-delete-button svg{width:16px;height:16px}.empty-state,.empty-selection{display:grid;min-height:120px;place-items:center;color:var(--muted);text-align:center}.empty-selection{gap:8px;align-content:center}.empty-selection svg{color:var(--yellow)}.auth-screen{min-height:100vh;padding:24px;background:linear-gradient(90deg,rgba(45,120,170,.06) 1px,transparent 1px),linear-gradient(0deg,rgba(45,120,170,.06) 1px,transparent 1px),#f6f7f2;background-size:40px 40px}.auth-shell{display:grid;grid-template-columns:minmax(280px,360px) minmax(320px,420px);gap:16px;width:min(840px,100%)}.auth-brand{align-content:space-between;min-height:470px;padding:24px;background:#222821;color:#fff}.auth-brand h1{margin-top:14px;font-size:42px}.auth-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.auth-stats span{padding:10px 8px;border:1px solid rgba(255,255,255,.18);border-radius:8px;text-align:center;font-size:13px;font-weight:800}.auth-form{align-content:start;min-height:470px}.mode-toggle{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:4px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.mode-toggle button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:8px;border:0;border-radius:6px;color:var(--muted);font-weight:800;background:transparent}.mode-toggle button.active{color:var(--ink);background:#fff;box-shadow:0 6px 16px #1f211e14}.mode-toggle svg{width:18px;height:18px}@media(max-width:980px){.dashboard-grid,.content-columns,.challenge-detail,.admin-page,.new-club-form,.profile-form,.profile-password-fields,.challenge-create-form,.target-option-list{grid-template-columns:1fr}.challenge-rail{order:2}.work-area{order:1}.metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.screen,.auth-screen{padding:14px}.app-header,.user-actions{align-items:stretch}.app-header{flex-direction:column}.brand-lockup,.user-actions{width:100%;justify-content:space-between}.user-chip{flex:1;min-width:0}.entry-form,.auth-shell{grid-template-columns:1fr}.auth-brand{min-height:250px}.auth-form{min-height:auto}.challenge-card{grid-template-columns:40px minmax(0,1fr)}.challenge-best{grid-column:2}.leaderboard-row{grid-template-columns:38px minmax(0,1fr)}.member-row{grid-template-columns:34px minmax(0,1fr)}.member-row .role-select,.member-delete-button{grid-column:1 / -1;width:100%}.row-score{grid-column:2;justify-items:start}.role-select{grid-column:2;justify-self:start}.view-tabs{grid-auto-flow:row;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-columns:unset;width:100%}.club-row{grid-template-columns:40px minmax(0,1fr) 34px 34px}.club-country{grid-column:2;justify-self:start}.club-edit-fields{grid-template-columns:1fr}.club-edit-actions{grid-column:3;grid-row:1 / span 2;flex-direction:column}}
