*,:before,:after{box-sizing:border-box}html,body{color:#111827;background:#f6f7fb;margin:0;padding:0;font-family:DM Sans,system-ui,-apple-system,sans-serif}#root{min-height:100vh}.app-shell{flex-direction:column;min-height:100vh;display:flex}.top-bar{z-index:10;background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex;position:sticky;top:0}.top-bar__main{align-items:center;gap:.75rem;min-width:0;display:flex}.top-bar__menu-toggle{flex-shrink:0;padding:.45rem .55rem;line-height:0;display:none}.top-bar__menu-icon{font-size:1.15rem;line-height:1;display:block}.top-bar__panel{flex:1;align-items:center;gap:1rem;min-width:0;display:flex}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.brand{align-items:center;gap:.75rem;display:flex}.brand-mark{object-fit:cover;border-radius:50%;flex-shrink:0;width:2.5rem;height:2.5rem}.brand-title{letter-spacing:-.02em;font-weight:700}.brand-sub{color:#6b7280;font-size:.85rem}.top-bar__controls{flex:1;justify-content:center;min-width:0;display:flex}.top-bar__controls-inner{flex-wrap:nowrap;gap:.5rem}.top-bar__controls-inner .field{min-width:0}.top-bar__controls-inner select{max-width:100%}.field--compare-players{min-width:160px;position:relative}.field--compare-players.is-open .compare-players-trigger{border-bottom-right-radius:0;border-bottom-left-radius:0}.compare-players-trigger{text-align:left;width:100%;font:inherit;line-height:inherit;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;color:#111827;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M3 4.5 6 7.5 9 4.5'/%3E%3C/svg%3E");background-position:right .55rem center;background-repeat:no-repeat;border:1px solid #e5e7eb;border-radius:.5rem;padding:.45rem 1.75rem .45rem .55rem;display:block;overflow:hidden}.compare-players-list{z-index:20;background:#fff;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 .5rem .5rem;max-height:220px;padding:.35rem 0;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 1px 2px #0f172a0f}.compare-players-list--floating{z-index:1000;border-top:1px solid #e5e7eb;position:fixed;right:auto;box-shadow:0 4px 16px #0f172a24}.compare-players-list label{color:#111827;cursor:pointer;align-items:center;gap:.45rem;padding:.35rem .65rem;font-size:.85rem;font-weight:500;display:flex}.compare-players-list label:hover{background:#dcfce7}.compare-players-list label input{accent-color:#16a34a}.top-nav{flex-shrink:0;gap:.5rem;display:flex}.nav-link{color:#374151;border-radius:.5rem;padding:.45rem .75rem;font-weight:500;text-decoration:none}.nav-link.active{color:#15803d;background:#dcfce7}.nav-link-admin{background:#fff;border:1px solid #e5e7eb}.nav-logout{align-self:center}.main-area--login{justify-content:center;align-items:center;padding:2rem 1rem;display:flex}.login-page{width:100%;max-width:420px!important}.login-panel{width:100%}.login-brand{align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.login-form{flex-direction:column;align-items:stretch}.main-area{flex:1;width:100%;margin:0 auto;padding:1rem 0 1.25rem}.main-area>*{max-width:960px;margin-left:auto;margin-right:auto}.panel{background:#fff;border:1px solid #e5e7eb;border-radius:14px;margin-bottom:1rem;padding:1rem 1.25rem;box-shadow:0 1px 2px #0f172a0f}.panel--wide{width:96vw;max-width:96vw}.panel-title{margin:0 0 .75rem;font-size:1.05rem}.controls-row{flex-wrap:wrap;gap:.75rem;display:flex}.field{flex-direction:column;gap:.35rem;min-width:160px;display:flex}.field.field--checkbox{flex-direction:row;align-self:center;align-items:center;gap:.45rem;min-width:auto;padding-bottom:.15rem}.field.field--checkbox label{cursor:pointer;font-weight:600}.field.field--checkbox input[type=checkbox]{accent-color:#16a34a;width:auto;margin:0}label{color:#6b7280;font-size:.8rem;font-weight:600}select,input[type=text],input[type=password],input[type=file],button{font:inherit}select,input[type=text],input[type=password]{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:.45rem .55rem}button.primary{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:.55rem;padding:.55rem .9rem;font-weight:600}button.primary:disabled{opacity:.55;cursor:not-allowed}button.ghost{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:.55rem;padding:.55rem .9rem}.pill-row{flex-wrap:wrap;gap:.5rem;display:flex}.pill{background:#dcfce7;border-radius:999px;padding:.35rem .65rem;font-size:.85rem}.cards-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;display:grid}.metric-card{background:#fafbff;border:1px solid #e5e7eb;border-radius:10px;padding:.75rem}.metric-card h4{margin:0 0 .35rem;font-size:.95rem}.metric-card .muted{color:#6b7280;margin:0;font-size:.8rem}.muted{color:#6b7280}.error{color:#b42318;font-size:.9rem}.success{color:#067647;font-size:.9rem}.chart-wrap{width:100%;height:360px}.chart-wrap--compare{height:520px}.chart-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:10px;min-width:120px;padding:.55rem .75rem;font-size:.85rem;box-shadow:0 1px 2px #0f172a0f}.chart-tooltip__name{color:#111827;font-weight:600}.chart-tooltip__value{color:#15803d;margin-top:.15rem;font-size:1rem;font-weight:700}.chart-tooltip__meta{color:#374151;margin-top:.2rem;font-size:.82rem}.last-updated{text-align:right;max-width:960px;margin:0 auto .75rem;padding:0 .25rem;font-size:.85rem}.field--wide{flex:260px;min-width:260px}.indicators-table-wrap,.data-table-wrap{width:100%;overflow-x:auto}.indicators-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.9rem}.indicators-table th,.indicators-table td{text-align:left;vertical-align:top;border-bottom:1px solid #e5e7eb;padding:.55rem .75rem}.indicators-table thead th{text-transform:uppercase;letter-spacing:.04em;color:#6b7280;background:#f9fafc;font-size:.75rem}.indicators-table tbody tr:nth-child(2n){background:#fafbff}.indicators-table tbody th[scope=row]{color:#374151;white-space:nowrap;font-weight:600}.indicator-strong{color:#111827;font-weight:700;display:block}.indicator-sub{color:#6b7280;font-size:.78rem;display:block}.indicator-chip{border-radius:999px;padding:.2rem .55rem;font-weight:700;display:inline-block}.indicator-chip--good{color:#166534;background:#dcfce7}.indicator-chip--bad{color:#991b1b;background:#fee2e2}.indicator-chip--sub{width:fit-content;margin-top:.15rem;font-size:.78rem;display:block}.data-table{border-collapse:collapse;width:100%;font-size:.85rem}.data-table th,.data-table td{text-align:right;border-bottom:1px solid #e5e7eb;padding:.5rem .65rem}.data-table th:first-child,.data-table td:first-child{text-align:left}.data-table thead th{color:#374151;background:#eef2ff;border-bottom:2px solid #e5e7eb;font-size:.78rem;font-weight:600}.data-table tbody th[scope=row]{color:#111827;white-space:nowrap;font-weight:600}.data-table tbody tr:nth-child(2n) td,.data-table tbody tr:nth-child(2n) th{background:#fafbff}.data-table__summary th,.data-table__summary td{font-weight:700;background:#f1f5f9!important}.data-table__summary--soft th,.data-table__summary--soft td{text-align:right;font-weight:600;background:#f8fafc!important}.data-table--narrow{max-width:360px}.data-table__highlight th,.data-table__highlight td{background:#dbeafe!important}.data-table__highlight-compare th,.data-table__highlight-compare td{background:#ffedd5!important}.indicator-compare{color:#c2410c;font-weight:600}@media (width>=721px) and (not ((height<=520px) and (orientation:landscape) and (width<=1200px))){.top-bar__main{flex-shrink:0}.top-bar__panel{display:contents}}@media (width<=720px),(height<=520px) and (orientation:landscape) and (width<=1200px){.top-bar{flex-direction:column;align-items:stretch;gap:0;padding:.65rem 1rem}.top-bar__main{justify-content:space-between;width:100%}.brand-sub{display:none}.brand-title{font-size:.95rem;line-height:1.25}.top-bar__menu-toggle{justify-content:center;align-items:center;display:inline-flex}.top-bar__panel{border-top:1px solid #e5e7eb;flex-direction:column;align-items:stretch;gap:.75rem;width:100%;max-height:min(70vh,100dvh - 5rem);margin-top:.65rem;padding-top:.75rem;display:none;overflow-y:auto}.top-bar--expanded .top-bar__panel{display:flex}.top-bar__controls{justify-content:flex-start;width:100%}.top-bar__controls-inner{flex-wrap:wrap;width:100%}.top-bar__controls-inner .field{flex:100%;min-width:0}.field--compare-players{min-width:0}.top-nav{flex-wrap:wrap;width:100%}.chart-wrap{height:280px}.chart-wrap--compare{height:420px}.indicators-table,.data-table{font-size:.78rem}}
