.app-layout{min-height:100vh;display:flex;flex-direction:column;background-color:#fff}.app-header{background-color:var(--color-primary-dark);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #00000026}.header-content{max-width:1200px;margin:0 auto;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.logo-link{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.logo{height:40px;width:auto}.nav-bar{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.nav-link{color:#fff;text-decoration:none;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;font-weight:500;transition:background-color .2s ease;white-space:nowrap}.nav-link:hover,.nav-link.active{background-color:var(--color-accent);color:var(--color-primary-dark)}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:1rem}@media(max-width:480px){.header-content{flex-direction:column;padding:.5rem .75rem;gap:.5rem}.nav-bar{width:100%;justify-content:center;gap:.125rem}.nav-link{font-size:.8rem;padding:.4rem .5rem}.logo{height:32px}}@media(min-width:768px){.header-content{padding:.75rem 1.5rem}.nav-bar{gap:.5rem}.nav-link{font-size:.9375rem;padding:.5rem 1rem}.logo{height:48px}}.pyramid{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 0}.pyramid-level{display:flex;justify-content:center;gap:.5rem}.pyramid-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--color-primary-dark);color:#fff;border:2px solid var(--color-accent);border-radius:8px;padding:.5rem .75rem;min-width:5rem;cursor:pointer;transition:background-color .2s ease,transform .15s ease;font-family:inherit}.pyramid-cell:hover{background-color:var(--color-accent);color:var(--color-primary-dark);transform:translateY(-2px)}.pyramid-cell--hovered{background-color:var(--color-accent);color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 0 12px #ffffff4d}.pyramid-cell--challengeable{background-color:var(--color-primary-dark);border-color:var(--color-accent);box-shadow:0 0 10px #00c5bd59;position:relative}.pyramid-cell-challenge-label{font-size:.6rem;font-weight:600;color:var(--color-accent);letter-spacing:.02em;margin-top:.15rem;visibility:hidden}.pyramid-cell--challengeable .pyramid-cell-challenge-label{visibility:visible}.pyramid-cell:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.pyramid-cell-rank{font-size:.75rem;font-weight:700;opacity:.8}.pyramid-cell-name{font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:6rem}.pyramid-empty{text-align:center;padding:2rem;color:var(--color-text-light);font-style:italic}@media(max-width:480px){.pyramid{gap:.375rem;padding:.5rem 0}.pyramid-level{gap:.375rem}.pyramid-cell{min-width:4rem;padding:.375rem .5rem}.pyramid-cell-rank{font-size:.6875rem}.pyramid-cell-name{font-size:.75rem;max-width:4.5rem}}@media(min-width:768px){.pyramid,.pyramid-level{gap:.625rem}.pyramid-cell{min-width:6.5rem;padding:.625rem 1rem}.pyramid-cell-rank{font-size:.8125rem}.pyramid-cell-name{font-size:1rem;max-width:8rem}}.list-view{display:flex;flex-direction:column;gap:0;padding:1rem 0}.list-view--with-stats .list-view-header,.list-view--with-stats .list-view-row{display:grid;grid-template-columns:2.5rem 1fr 3rem 3rem 3rem 3.5rem 5.5rem;align-items:center}.list-view:not(.list-view--with-stats) .list-view-row{display:flex;align-items:center;gap:.75rem}.list-view-header{padding:.5rem 1rem;border-bottom:2px solid var(--color-primary-dark);font-size:.75rem;font-weight:700;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0;background:var(--color-bg, #fff);z-index:1}.list-view-header-rank{text-align:center}.list-view-header-name{padding-left:.25rem}.list-view-header-stat{text-align:right}.list-view-row{padding:.75rem 1rem;background:none;border:none;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background-color .2s ease;width:100%;text-align:left;font-family:inherit;color:var(--color-text)}.list-view-row:first-of-type{border-top:none}.list-view-row--level-end{border-bottom:3px solid var(--color-primary-dark)}.list-view-row:hover{background-color:#00c5bd1a}.list-view-row:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.list-view-rank{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background-color:var(--color-primary-dark);color:#fff;font-size:.8125rem;font-weight:700;flex-shrink:0}.list-view-name{font-size:.9375rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:.25rem}.list-view--with-stats .list-view-stats{display:contents}.list-view-stat{text-align:right;font-size:.8125rem;font-variant-numeric:tabular-nums;color:var(--color-text)}.list-view-challenge-label{text-align:right;font-size:.7rem;font-weight:600;color:var(--color-accent);letter-spacing:.02em}.list-view-row--hovered{background-color:#00c5bd2e;box-shadow:inset 3px 0 0 var(--color-accent)}.list-view-row--challengeable{background-color:#fff;box-shadow:inset 3px 0 #00c5bd80}.list-view-empty{text-align:center;padding:2rem;color:var(--color-text-light);font-style:italic}@media(max-width:480px){.list-view--with-stats .list-view-header,.list-view--with-stats .list-view-row{grid-template-columns:2rem 1fr 2.25rem 2.25rem 2.25rem 2.75rem 0}.list-view-header{padding:.375rem .75rem;font-size:.6875rem}.list-view-row{padding:.625rem .75rem}.list-view-rank{width:1.75rem;height:1.75rem;font-size:.75rem}.list-view-name{font-size:.875rem}.list-view-stat{font-size:.75rem}.list-view-challenge-label{display:none}}@media(min-width:768px){.list-view--with-stats .list-view-header,.list-view--with-stats .list-view-row{grid-template-columns:3rem 1fr 3.5rem 3.5rem 3.5rem 4rem 6rem}.list-view-header{padding:.5rem 1.25rem}.list-view-row{padding:.875rem 1.25rem}.list-view-rank{width:2.25rem;height:2.25rem;font-size:.875rem}.list-view-name{font-size:1rem}.list-view-stat{font-size:.875rem}}.player-preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#002d2b80;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.player-preview-panel{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;width:100%;max-width:24rem;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column}.player-preview-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.25rem .75rem;border-bottom:1px solid var(--color-border)}.player-preview-name{font-size:1.125rem;font-weight:700;color:var(--color-primary-dark);margin:0}.player-preview-rank{font-size:.8125rem;color:var(--color-text-light);font-weight:500}.player-preview-close{background:none;border:none;font-size:1.25rem;color:var(--color-text-light);padding:.25rem;line-height:1;border-radius:4px;transition:color .2s ease,background-color .2s ease}.player-preview-close:hover{color:var(--color-primary-dark);background-color:var(--color-border)}.player-preview-close:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.player-preview-loading,.player-preview-error{padding:1.5rem 1.25rem;text-align:center;font-size:.875rem;color:var(--color-text-light)}.player-preview-error{color:#c0392b}.player-preview-body{padding:.75rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.player-preview-section h3{font-size:.8125rem;font-weight:600;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.375rem}.player-preview-empty{font-size:.8125rem;color:var(--color-text-light);font-style:italic}.player-preview-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.player-preview-list li{font-size:.875rem;color:var(--color-text);padding:.25rem 0}.player-preview-list-rank{display:inline-block;min-width:2.25rem;font-weight:600;color:var(--color-accent)}.player-preview-footer{padding:.75rem 1.25rem 1.25rem;border-top:1px solid var(--color-border);text-align:center}.player-preview-detail-link{display:inline-block;padding:.5rem 1.25rem;background-color:var(--color-accent);color:var(--color-primary-dark);font-weight:600;font-size:.875rem;border-radius:6px;text-decoration:none;transition:opacity .2s ease}.player-preview-detail-link:hover{opacity:.9;text-decoration:none}.player-preview-last-match{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;font-size:.875rem;color:var(--color-text)}.player-preview-last-match-date{color:var(--color-text-light);font-size:.8125rem}.player-preview-last-match-outcome--won{color:#27ae60;font-weight:600}.player-preview-last-match-outcome--lost{color:#c0392b;font-weight:600}.player-preview-last-match-score{color:var(--color-text-light);font-size:.8125rem}@media(max-width:480px){.player-preview-backdrop{align-items:flex-end;padding:0}.player-preview-panel{border-radius:12px 12px 0 0;max-width:100%;max-height:70vh}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-dialog{background:#fff;border-radius:10px;padding:1.5rem;width:100%;max-width:340px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;gap:1rem}.modal-label{font-size:.875rem;font-weight:500;color:var(--color-text-light)}.modal-date-input{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;color:var(--color-text);background:#fff;width:100%}.modal-date-input:focus{outline:2px solid var(--color-accent);outline-offset:1px}.modal-actions{display:flex;gap:.5rem;justify-content:flex-end}.modal-apply-btn{padding:.5rem 1.25rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-size:.875rem;font-weight:500;transition:opacity .2s ease}.modal-apply-btn:hover{opacity:.9}.modal-cancel-btn{padding:.5rem 1.25rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text-light);font-size:.875rem;font-weight:500;transition:background-color .2s ease}.modal-cancel-btn:hover{background-color:var(--color-border)}.ranking-page{display:flex;flex-direction:column;gap:1rem}.ranking-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.view-toggle{display:flex;border-radius:6px;overflow:hidden;border:1px solid var(--color-border)}.view-toggle-btn{padding:.5rem 1rem;border:none;background:#fff;color:var(--color-text);font-size:.875rem;font-weight:500;transition:background-color .2s ease,color .2s ease}.view-toggle-btn:hover{background-color:var(--color-border)}.view-toggle-btn.active{background-color:var(--color-accent);color:var(--color-primary-dark)}.date-info-group{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text-light)}.date-link-btn{background:none;border:none;padding:0;font-size:.875rem;color:var(--color-accent);text-decoration:underline;cursor:pointer}.date-link-btn:hover{color:var(--color-primary-dark)}.date-reset-btn{background:none;border:none;padding:0;font-size:.875rem;color:var(--color-accent);text-decoration:underline;cursor:pointer}.date-reset-btn:hover{color:var(--color-primary-dark)}.ranking-loading,.ranking-error{text-align:center;padding:3rem 1rem;color:var(--color-text-light);font-size:1rem}.ranking-error{color:#c0392b}.ranking-error button{margin-top:.75rem;padding:.5rem 1.25rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-weight:500;font-size:.875rem}.ranking-error button:hover{opacity:.9}@media(max-width:480px){.ranking-controls{flex-direction:column;align-items:stretch}.view-toggle{align-self:center}.date-info-group{flex-wrap:wrap;justify-content:center}}.rank-chart-container{width:100%;height:300px}.rank-chart-empty{text-align:center;padding:2rem 1rem;color:var(--color-text-light);font-size:.875rem;background:#f9fafa;border:1px solid var(--color-border);border-radius:8px}.rank-chart-empty p{margin:0}@media(max-width:600px){.rank-chart-container{height:220px}}.player-detail-page{display:flex;flex-direction:column;gap:1.5rem}.player-detail-back{color:var(--color-accent);text-decoration:none;font-size:.875rem;font-weight:500}.player-detail-back:hover{text-decoration:underline}.player-detail-header{display:flex;flex-direction:column;gap:.75rem}.player-detail-header h1{margin:0;font-size:1.75rem;color:var(--color-primary-dark)}.player-detail-stats{display:flex;gap:1.5rem}.stat{display:flex;flex-direction:column;gap:.15rem}.stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-light)}.stat-value{font-size:1.25rem;font-weight:600;color:var(--color-primary-dark)}.player-detail-status{text-align:center;padding:3rem 1rem;color:var(--color-text-light);font-size:1rem}.player-detail-error{color:#c0392b}.player-detail-error a{display:inline-block;margin-top:.75rem;color:var(--color-accent);text-decoration:none;font-weight:500}.player-detail-eligibility{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.eligibility-section{background:#f9fafa;border:1px solid var(--color-border);border-radius:8px;padding:1rem}.eligibility-section h2{margin:0 0 .75rem;font-size:1rem;color:var(--color-primary-dark)}.eligibility-empty{color:var(--color-text-light);font-size:.875rem;margin:0}.eligibility-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.eligibility-list li a{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--color-text);font-size:.875rem;padding:.25rem .5rem;border-radius:4px;transition:background-color .15s ease}.eligibility-list li a:hover{background-color:#00c5bd1a}.eligibility-rank{font-weight:600;color:var(--color-accent);min-width:2rem}.player-detail-matches h2{margin:0 0 .75rem;font-size:1.125rem;color:var(--color-primary-dark)}.matches-empty{color:var(--color-text-light);font-size:.875rem}.matches-table-wrapper{overflow-x:auto}.matches-table{width:100%;border-collapse:collapse;font-size:.875rem}.matches-table th{text-align:left;padding:.6rem .75rem;border-bottom:2px solid var(--color-border);color:var(--color-text-light);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.matches-table td{padding:.6rem .75rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.matches-table td a{color:var(--color-accent);text-decoration:none;font-weight:500}.matches-table td a:hover{text-decoration:underline}.result-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.8rem;font-weight:600}.result-badge.won{background-color:#d4edda;color:#155724}.result-badge.lost{background-color:#f8d7da;color:#721c24}@media(max-width:600px){.player-detail-eligibility{grid-template-columns:1fr}.player-detail-header h1{font-size:1.35rem}.matches-table{font-size:.8rem}.matches-table th,.matches-table td{padding:.5rem}}.player-detail-rank-chart h2{margin:0 0 .75rem;font-size:1.125rem;color:var(--color-primary-dark)}.match-history-page{display:flex;flex-direction:column;gap:1.5rem}.match-history-page h1{margin:0;font-size:1.75rem;color:var(--color-primary-dark)}.match-history-status{text-align:center;padding:3rem 1rem;color:var(--color-text-light);font-size:1rem}.match-history-error{color:#c0392b}.match-history-error button{margin-top:.75rem;padding:.5rem 1.25rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-weight:500;font-size:.875rem;cursor:pointer}.match-history-error button:hover{opacity:.9}.match-history-empty{text-align:center;padding:3rem 1rem;color:var(--color-text-light);font-size:1rem}.match-history-table-wrapper{overflow-x:auto}.match-history-table{width:100%;border-collapse:collapse;font-size:.875rem}.match-history-table th{text-align:left;padding:.6rem .75rem;border-bottom:2px solid var(--color-border);color:var(--color-text-light);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.match-history-table td{padding:.6rem .75rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.match-history-table td a{color:var(--color-accent);text-decoration:none;font-weight:500}.match-history-table td a:hover{text-decoration:underline}.winner-name{font-weight:600;color:#155724}.match-history-pagination{display:flex;align-items:center;justify-content:center;gap:1rem}.match-history-pagination button{padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.match-history-pagination button:hover:not(:disabled){background-color:var(--color-accent);color:var(--color-primary-dark);border-color:var(--color-accent)}.match-history-pagination button:disabled{opacity:.4;cursor:not-allowed}.match-history-pagination .page-info{font-size:.875rem;color:var(--color-text-light)}@media(max-width:600px){.match-history-page h1{font-size:1.35rem}.match-history-table{font-size:.8rem}.match-history-table th,.match-history-table td{padding:.5rem}}.result-entry-page{display:flex;flex-direction:column;gap:1.5rem}.result-entry-page h1{margin:0;font-size:1.75rem;color:var(--color-primary-dark)}.result-entry-form{display:flex;flex-direction:column;gap:1.25rem;max-width:480px}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--color-text)}.form-group select,.form-group input[type=text]{padding:.55rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;color:var(--color-text);background:#fff}.form-group select:focus,.form-group input[type=text]:focus{outline:2px solid var(--color-accent);outline-offset:1px}.form-group select.field-error,.form-group input[type=text].field-error{border-color:#c0392b}.challenge-in-toggle{display:flex;align-items:center;gap:.5rem}.challenge-in-toggle input[type=checkbox]{width:1.1rem;height:1.1rem;accent-color:var(--color-accent);cursor:pointer}.challenge-in-toggle label{font-size:.875rem;font-weight:500;color:var(--color-text);cursor:pointer}.new-player-input{margin-top:.25rem}.winner-options{display:flex;flex-direction:column;gap:.5rem}.winner-option{display:flex;align-items:center;gap:.5rem}.winner-option input[type=radio]{accent-color:var(--color-accent);cursor:pointer}.winner-option label{font-size:.875rem;color:var(--color-text);cursor:pointer;font-weight:400}.field-error-msg{font-size:.8rem;color:#c0392b;margin:0}.submit-btn{padding:.65rem 1.5rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-weight:600;font-size:.95rem;cursor:pointer;transition:opacity .2s ease;align-self:flex-start}.submit-btn:hover:not(:disabled){opacity:.9}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.result-entry-status{text-align:center;padding:3rem 1rem;color:var(--color-text-light);font-size:1rem}.result-entry-error{color:#c0392b}.result-entry-error button{margin-top:.75rem;padding:.5rem 1.25rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-weight:500;font-size:.875rem;cursor:pointer}.result-entry-error button:hover{opacity:.9}.result-success{padding:.75rem 1rem;background-color:#d4edda;color:#155724;border-radius:6px;font-size:.875rem;font-weight:500}.result-submit-error{padding:.75rem 1rem;background-color:#f8d7da;color:#721c24;border-radius:6px;font-size:.875rem;font-weight:500}@media(max-width:600px){.result-entry-page h1{font-size:1.35rem}.result-entry-form{max-width:100%}}.result-pyramid-preview{margin-top:.5rem}.result-pyramid-preview h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--color-primary-dark)}.admin-panel{display:flex;flex-direction:column;gap:1.5rem}.admin-panel h1{margin:0;font-size:1.75rem;color:var(--color-primary-dark)}.admin-create-form{display:flex;flex-direction:column;gap:.5rem;max-width:480px}.admin-create-form label{font-size:.875rem;font-weight:600;color:var(--color-text)}.admin-create-row{display:flex;gap:.5rem}.admin-create-row input[type=text]{flex:1;padding:.55rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;color:var(--color-text);background:#fff}.admin-create-row input[type=text]:focus{outline:2px solid var(--color-accent);outline-offset:1px}.admin-create-row button{padding:.55rem 1.25rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-weight:600;font-size:.875rem;cursor:pointer;white-space:nowrap;transition:opacity .2s ease}.admin-create-row button:hover:not(:disabled){opacity:.9}.admin-create-row button:disabled{opacity:.5;cursor:not-allowed}.admin-create-error{font-size:.8rem;color:#c0392b;margin:0}.admin-table-wrapper{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{text-align:left;padding:.6rem .75rem;border-bottom:2px solid var(--color-border);color:var(--color-text-light);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.admin-table td{padding:.6rem .75rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.admin-table tbody tr:hover{background-color:#f8f9fa}.admin-place-btn{padding:.3rem .75rem;border:1px solid #2980b9;border-radius:4px;background:#fff;color:#2980b9;font-size:.8rem;font-weight:500;cursor:pointer;margin-right:.5rem;transition:background-color .2s ease,color .2s ease}.admin-place-btn:hover{background-color:#2980b9;color:#fff}.admin-remove-btn{padding:.3rem .75rem;border:1px solid #c0392b;border-radius:4px;background:#fff;color:#c0392b;font-size:.8rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,color .2s ease}.admin-remove-btn:hover{background-color:#c0392b;color:#fff}.admin-rerank-btn{padding:.3rem .75rem;border:1px solid #8e44ad;border-radius:4px;background:#fff;color:#8e44ad;font-size:.8rem;font-weight:500;cursor:pointer;margin-right:.5rem;transition:background-color .2s ease,color .2s ease}.admin-rerank-btn:hover{background-color:#8e44ad;color:#fff}.rerank-no-change{margin:0;font-size:.85rem;color:var(--color-text-light);font-style:italic}.admin-status{text-align:center;padding:3rem 1rem;color:var(--color-text-light);font-size:1rem}.admin-error{color:#c0392b}.admin-error button{margin-top:.75rem;padding:.5rem 1.25rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-weight:500;font-size:.875rem;cursor:pointer}.admin-error button:hover{opacity:.9}.admin-empty{text-align:center;color:var(--color-text-light);padding:2rem 1rem}@media(max-width:600px){.admin-panel h1{font-size:1.35rem}.admin-create-form{max-width:100%}.admin-create-row{flex-direction:column}.admin-create-row button{align-self:flex-start}}.rank-selector{max-width:480px;padding:1.25rem;border:1px solid var(--color-border);border-radius:8px;background:#fff;display:flex;flex-direction:column;gap:.75rem}.rank-selector h3{margin:0;font-size:1rem;color:var(--color-primary-dark)}.rank-selector label{font-size:.8rem;font-weight:600;color:var(--color-text-light)}.rank-selector select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;color:var(--color-text);background:#fff;max-width:120px}.rank-selector select:focus{outline:2px solid var(--color-accent);outline-offset:1px}.neighbor-preview{display:flex;flex-direction:column;gap:.35rem;padding:.75rem;border:1px solid var(--color-border);border-radius:6px;background:#f8f9fa}.neighbor-empty{margin:0;font-size:.85rem;color:var(--color-text-light);font-style:italic}.neighbor-row{display:flex;justify-content:space-between;align-items:center;padding:.3rem 0;font-size:.85rem}.neighbor-label{font-weight:600;color:var(--color-text-light);min-width:140px}.neighbor-player{color:var(--color-text)}.neighbor-absent{font-style:italic;color:var(--color-text-light)}.rank-selector-actions{display:flex;gap:.5rem;margin-top:.25rem}.rank-confirm-btn{padding:.45rem 1.25rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-weight:600;font-size:.85rem;cursor:pointer;transition:opacity .2s ease}.rank-confirm-btn:hover:not(:disabled){opacity:.9}.rank-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.rank-cancel-btn{padding:.45rem 1.25rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-weight:500;font-size:.85rem;cursor:pointer;transition:background-color .2s ease}.rank-cancel-btn:hover{background-color:#f0f0f0}.rank-selector-error{margin:0;font-size:.8rem;color:#c0392b;font-weight:500}.checkpoint-loading,.checkpoint-empty{text-align:center;color:var(--color-text-light);padding:1.5rem 1rem;font-size:.9rem}.checkpoint-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.checkpoint-badge-manual{background-color:#eaf2f8;color:#2980b9}.checkpoint-badge-auto{background-color:#fef9e7;color:#b7950b}.checkpoint-restore-btn{padding:.3rem .75rem;border:1px solid #27ae60;border-radius:4px;background:#fff;color:#27ae60;font-size:.8rem;font-weight:500;cursor:pointer;margin-right:.5rem;transition:background-color .2s ease,color .2s ease}.checkpoint-restore-btn:hover{background-color:#27ae60;color:#fff}.checkpoint-delete-btn{padding:.3rem .75rem;border:1px solid #c0392b;border-radius:4px;background:#fff;color:#c0392b;font-size:.8rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,color .2s ease}.checkpoint-delete-btn:hover{background-color:#c0392b;color:#fff}.rules-page{display:flex;flex-direction:column;gap:1.5rem}.rules-page h1{margin:0;font-size:1.75rem;color:var(--color-primary-dark)}.rules-intro{color:var(--color-text);line-height:1.6}.rules-intro p{margin-bottom:.75rem}.rules-intro>ul{margin:.75rem 0;padding-left:1.5rem}.rules-intro>ul li{margin-bottom:.35rem;color:var(--color-text-light)}.rules-prizes{margin-top:1rem;padding:1rem;background:#f9fafa;border:1px solid var(--color-border);border-radius:8px}.rules-prizes p{font-weight:600;color:var(--color-primary-dark);margin-bottom:.5rem}.rules-prizes ol{padding-left:1.5rem}.rules-prizes ol li{margin-bottom:.25rem;color:var(--color-text-light);font-size:.9375rem}.rules-section{border-top:1px solid var(--color-border);padding-top:1.25rem}.rules-section h2{margin:0 0 .75rem;font-size:1.125rem;color:var(--color-primary-dark)}.rules-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.rules-list>li{color:var(--color-text);line-height:1.6;padding-left:.25rem}.rules-list ol,.rules-list ul{margin-top:.5rem;padding-left:1.5rem}.rules-list ol li,.rules-list ul li{margin-bottom:.35rem;color:var(--color-text-light);line-height:1.5}.rules-image{display:block;max-width:100%;height:auto;margin-top:.75rem;border-radius:8px;border:1px solid var(--color-border)}@media(max-width:600px){.rules-page h1{font-size:1.35rem}.rules-section h2{font-size:1rem}.rules-list>li{font-size:.9375rem}}@media(max-width:320px){.rules-page{gap:1rem}.rules-intro>ul,.rules-prizes ol,.rules-list ol,.rules-list ul{padding-left:1rem}.rules-prizes{padding:.75rem}}.password-gate{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:1rem}.password-gate-form{background:#fff;border-radius:10px;padding:2rem 1.5rem;width:100%;max-width:340px;box-shadow:0 4px 20px #0000001a;display:flex;flex-direction:column;gap:1rem}.password-gate-form h2{font-size:1.25rem;font-weight:700;color:var(--color-primary-dark);text-align:center;margin:0}.password-gate-form label{font-size:.875rem;font-weight:500;color:var(--color-text-light)}.password-gate-form input[type=password]{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;color:var(--color-text);background:#fff;width:100%}.password-gate-form input[type=password]:focus{outline:2px solid var(--color-accent);outline-offset:1px}.password-gate-form button[type=submit]{padding:.5rem 1.25rem;border:none;border-radius:6px;background-color:var(--color-accent);color:var(--color-primary-dark);font-size:.875rem;font-weight:600;transition:opacity .2s ease}.password-gate-form button[type=submit]:hover{opacity:.9}.password-gate-form button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.password-gate-error{font-size:.8125rem;color:#c0392b;text-align:center;margin:0}:root{--color-primary-dark: #002d2b;--color-accent: #00c5bd;--color-bg: #ffffff;--color-text: #002d2b;--color-text-light: #4a6a68;--color-border: #e0e8e7}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{color:var(--color-primary-dark);line-height:1.3}button{cursor:pointer;font-family:inherit}#root{min-height:100vh}
