:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#0f172a;background:#eef2f6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#eef2f6}button,input,select{font:inherit}button{border:0}input,select{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:.72rem .78rem;background:#fff;color:#0f172a}label{display:grid;gap:.38rem;color:#475569;font-size:.78rem;font-weight:700}h1,h2,h3,p{margin:0}.loadingScreen,.loginShell{min-height:100vh;display:grid;place-items:center;padding:1rem}.loginPanel{width:min(100%,390px);background:#fff;border:1px solid #dbe3ec;border-radius:8px;padding:1.25rem;box-shadow:0 22px 70px #0f172a24}.loginPanel h1{margin-top:.8rem;font-size:2rem}.loginPanel p{margin:.35rem 0 1.1rem;color:#64748b;line-height:1.45}.mark{width:44px;height:44px;border-radius:8px;display:grid;place-items:center;background:#0f172a;color:#fff;overflow:hidden}.mark img{width:100%;height:100%;display:block}.appShell{width:min(100%,560px);min-height:100vh;margin:0 auto;padding:.85rem .85rem 5.5rem}.appHeader{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:-.85rem -.85rem .85rem;padding:.42rem .7rem;background:#eef2f6f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.appTitle{min-width:0;display:flex;align-items:center;gap:.5rem}.appLogo{width:32px;height:32px;border-radius:8px;display:block;flex:0 0 auto}.appHeader h1{font-size:1.08rem;line-height:1.1}.appHeader .iconButton{width:36px;min-height:36px}.appLabel{color:#2563eb;font-size:.62rem;font-weight:800;text-transform:uppercase}.viewStack{display:grid;gap:.85rem}.toolbarBand,.panel,.emptySetup{background:#fff;border:1px solid #dbe3ec;border-radius:8px;padding:.9rem}.toolbarBand{display:grid;gap:.7rem}.measureToolbar{padding:.65rem}.trainingSessionPanel{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:.45rem;align-items:center;padding:.55rem;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.trainingSessionPanel div{min-width:0;display:grid;gap:.08rem}.trainingSessionPanel strong{font-size:.86rem}.trainingSessionPanel span{color:#64748b;font-size:.72rem;font-weight:800}.compactSessionButton{min-height:36px;padding:.38rem .62rem;white-space:nowrap}.inlineToggle{width:fit-content;display:inline-flex;align-items:center;gap:.45rem}.inlineToggle input,.attendanceOption input{width:auto;flex:0 0 auto}.autoBottomToggle{justify-self:start}.toolbarBand p{color:#64748b;font-size:.86rem}.playerList{display:grid;gap:.58rem}.playerRow,.adminRow{min-height:76px;display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"name timer" "actions actions";gap:.55rem .7rem;align-items:center;padding:.82rem;background:#fff;border:1px solid #dbe3ec;border-left:5px solid #cbd5e1;border-radius:8px}.measurementList{gap:.42rem}.measurementList .playerRow{min-height:48px;grid-template-columns:minmax(0,1fr) max-content max-content max-content;grid-template-areas:"name lap timer actions";gap:.28rem;padding:.46rem .5rem;border-left-width:4px}.measurementList .playerRow>div:first-child{grid-area:name;min-width:0}.playerRow.running{border-left-color:#22c55e}.playerRow.stopped{border-left-color:#f97316}.playerRow h3,.adminRow h3{font-size:1rem;line-height:1.15}.measurementList .playerRow h3{display:flex;align-items:center;gap:.22rem;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playerNameButton{min-width:0;min-height:0;padding:0;background:transparent;color:inherit;font-weight:900;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.medalBadge{flex:0 0 auto;font-size:.9rem;line-height:1}.playerRow span,.adminRow span{color:#64748b;font-size:.78rem}.measurementList .playerRow span{font-size:.66rem}.measurementList .playerRow .medalBadge{color:inherit;font-size:.9rem}.measurementList .playerRow .measurementMeta{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-variant-numeric:tabular-nums;line-height:1.08}.measurementInfoLine{min-width:0;display:flex;align-items:center;gap:.34rem;flex-wrap:wrap}.lapCell{grid-area:lap;display:flex;align-items:center;justify-content:flex-end;min-width:0}.lapCell:empty{display:none}.lapControls{width:10.25rem;display:grid;grid-template-columns:38px 1.6rem 38px 4.05rem;align-items:center;gap:.26rem;color:#0f172a;font-variant-numeric:tabular-nums}.lapControls button{width:38px;min-height:34px;border-radius:6px;display:inline-grid;place-items:center;padding:0;background:#e0ecff;color:#1d4ed8;font-size:1.08rem;font-weight:900}.lapControls span{min-width:1.45rem;color:#0f172a;font-size:.9rem;font-weight:900;text-align:center}.measurementList .lapControls span{color:#0f172a;font-size:.9rem}.lapControls small{color:#64748b;font-size:.66rem;font-weight:800;min-width:0;overflow:hidden;text-align:right;white-space:nowrap}.measurementList .playerRow.stopped .measurementMeta{overflow:visible;text-overflow:clip;white-space:normal}.timerValue{grid-area:timer;font-variant-numeric:tabular-nums;font-size:clamp(1.1rem,7vw,1.68rem);color:#0f172a;text-align:right}.measurementList .timerValue{font-size:clamp(.95rem,4.6vw,1.22rem);min-width:4.25rem}.sharedRowPlaceholder{min-width:0}.sharedSessionControls{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.55rem;align-items:center}.sharedSessionControls .timerValue{text-align:left;font-size:clamp(1.3rem,7vw,1.82rem)}.sharedSessionControls .startButton,.sharedSessionControls .stopButton,.sharedSessionControls .dangerButton{min-height:42px}.rowActions{grid-area:actions;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.rowActions:has(.iconButton){grid-template-columns:minmax(0,1fr) 48px}.measurementList .rowActions{display:flex;align-items:center;justify-content:flex-end;gap:.32rem;flex-shrink:0}.primaryButton,.secondaryButton,.startButton,.stopButton,.dangerButton,.iconTextButton,.iconButton{min-height:44px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.68rem .82rem;font-weight:800;cursor:pointer}.measurementList .startButton,.measurementList .stopButton,.measurementList .iconTextButton,.measurementList .iconButton,.compactIcon{min-height:34px;border-radius:7px;padding:.35rem .52rem}.measurementList .iconButton,.compactIcon{width:34px}.primaryButton{background:#2563eb;color:#fff}.secondaryButton{background:#e2e8f0;color:#0f172a}.startButton{background:#16a34a;color:#fff}.stopButton{background:#f97316;color:#fff}.dangerButton{background:#dc2626;color:#fff}.iconTextButton{background:#2563eb;color:#fff}.iconButton{width:44px;padding:0;background:#fff;border:1px solid #dbe3ec;color:#0f172a}.dangerIcon{color:#dc2626}.resumeIcon{color:#16a34a}.gridForm{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}.wide{grid-column:1 / -1}.stack{display:grid;gap:.72rem}.inlineForm{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.55rem}.sectionTitle{display:flex;align-items:baseline;justify-content:space-between;gap:.8rem;margin-bottom:.7rem}.sectionTitle h2{font-size:1.05rem}.sectionTitle span{color:#64748b;font-size:.78rem;font-weight:800}.chartBox{height:230px;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem}.miniChart{width:100%;height:100%}.miniChart line{stroke:#cbd5e1;stroke-width:1}.miniChart .axisTick line{stroke:#e2e8f0}.miniChart text{fill:#64748b;font-size:.7rem;font-weight:800;font-variant-numeric:tabular-nums}.miniChart path{fill:none;stroke-linecap:round;stroke-linejoin:round}.miniChart .dataLine{stroke:#2563eb;stroke-width:4}.miniChart .trendLine{stroke:#f97316;stroke-width:2.5;stroke-dasharray:6 5;opacity:.9}.miniChart circle{fill:#fff;stroke:#2563eb;stroke-width:3}.bestList,.historyList,.sessionList{display:grid;gap:.48rem}.sessionRow{display:grid;border-bottom:1px solid #e2e8f0}.sessionSummaryButton{width:100%;min-height:54px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.7rem;align-items:center;padding:.56rem 0;background:transparent;color:#0f172a;text-align:left;cursor:pointer}.sessionSummaryButton>div,.sessionMeasurementRow>div{min-width:0;display:grid;gap:.14rem}.sessionSummaryButton strong,.sessionMeasurementRow strong{font-size:.92rem}.sessionSummaryButton small,.sessionMeasurementRow small,.sessionMeasurementRow span{color:#64748b;font-size:.74rem;font-weight:700}.sessionAverage{text-align:right}.sessionMeasurements{display:grid;gap:.35rem;padding:0 0 .65rem}.sessionMeasurements h3{color:#475569;font-size:.78rem}.sessionMeasurementRow{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.5rem;align-items:center;padding:.42rem .5rem;border-radius:7px;background:#f8fafc}.bestRow,.historyRow{display:grid;grid-template-columns:32px minmax(0,1fr) auto;gap:.5rem;align-items:center;padding:.62rem 0;border-bottom:1px solid #e2e8f0}.historyRow{grid-template-columns:minmax(0,1fr) auto 34px}.bestRow span{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:#dcfce7;color:#166534;font-weight:900}.bestRow small,.historyRow span,.historyRow small{color:#64748b;font-size:.75rem}.historyRow div,.measurementValueStack{display:grid;gap:.12rem}.adminRow{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"name actions"}.adminActions{grid-area:actions;display:flex;align-items:center;gap:.4rem}.adminTabs{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.3rem;padding:.28rem;background:#fff;border:1px solid #dbe3ec;border-radius:8px}.adminTabs button{min-height:38px;border-radius:7px;background:transparent;color:#64748b;font-size:.78rem;font-weight:800;cursor:pointer}.adminTabs button.active{background:#e0ecff;color:#1d4ed8}.compactAddButton{min-height:36px;padding:0 .72rem;white-space:nowrap}.adminFilters{display:grid;grid-template-columns:minmax(0,1fr);gap:.65rem;margin-bottom:.75rem}.adminSummaryList,.adminRankingList,.adminRankingBreakdown{display:grid;gap:.45rem}.adminRankingRow,.rankingBreakdownRow{width:100%;display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:.55rem;align-items:center;padding:.58rem 0;border-bottom:1px solid #e2e8f0;background:transparent;color:#0f172a;text-align:left}.adminRankingRow.active{color:#1d4ed8}.adminRankingRow h3,.rankingBreakdownRow h3{font-size:.94rem}.adminRankingRow small,.rankingBreakdownRow small,.exerciseRankingMeta{color:#64748b;font-size:.72rem;font-weight:700}.rankNumber{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:#e0ecff;color:#1d4ed8;font-weight:900}.adminRankingRow strong,.rankingBreakdownRow strong{font-variant-numeric:tabular-nums}.rankingBreakdownRow{grid-template-columns:minmax(0,1fr) auto}.exerciseRankingMeta{display:block;margin-top:.12rem}.adminSummaryRow{display:grid;grid-template-columns:minmax(0,1fr) minmax(118px,auto);gap:.6rem;align-items:center;padding:.58rem 0;border-bottom:1px solid #e2e8f0}.adminSummaryRow h3{font-size:.94rem}.adminSummaryRow small,.adminSummaryValue small{color:#64748b;font-size:.72rem;font-weight:700}.adminSummaryValue{min-width:0;display:grid;gap:.12rem;text-align:right;font-variant-numeric:tabular-nums}.adminDataActions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.adminDataPanel{display:grid;gap:.7rem}.fileImportButton{position:relative;display:inline-grid;place-items:center;grid-auto-flow:column;gap:.35rem;overflow:hidden;cursor:pointer}.fileImportButton input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.successText{color:#166534;background:#dcfce7;border:1px solid #bbf7d0;border-radius:8px;padding:.6rem;font-size:.84rem;font-weight:700}.emptyText{color:#64748b;padding:1rem;text-align:center}.emptySetup{display:grid;justify-items:start;gap:.65rem}.setupActions{display:flex;gap:.5rem;flex-wrap:wrap}.formError,.appError{color:#b91c1c;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;padding:.6rem;font-size:.86rem}.bottomTabs{position:fixed;left:50%;bottom:0;z-index:6;width:min(100%,560px);transform:translate(-50%);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.25rem;padding:.45rem .55rem max(.45rem,env(safe-area-inset-bottom));background:#fffffff5;border-top:1px solid #dbe3ec}.bottomTabs button{min-height:50px;display:grid;place-items:center;gap:.12rem;background:transparent;color:#64748b;border-radius:8px;font-size:.7rem;font-weight:800}.bottomTabs button.active{background:#e0ecff;color:#1d4ed8}.dialogBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:end center;padding:1rem;background:#0f172a7a}.dialog{width:min(100%,420px);display:grid;gap:.8rem;background:#fff;border-radius:8px;padding:1rem;box-shadow:0 24px 80px #0f172a47}.dialog h2{font-size:1.22rem}.dialog p{color:#64748b;line-height:1.45}.attendanceForm{display:grid;gap:.8rem}.attendanceList{max-height:min(56vh,420px);display:grid;gap:.42rem;overflow:auto;padding-right:.1rem}.attendanceOption{min-height:46px;display:flex;align-items:center;gap:.7rem;padding:.55rem .65rem;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;color:#0f172a;font-size:.9rem;font-weight:850}.attendanceOption span{min-width:0}.resumeDialogTimer{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.65rem 0 .2rem}.resumeDialogTimer span{color:#64748b;font-size:.78rem;font-weight:800}.resumeDialogTimer .timerValue{min-width:5.8rem;text-align:center;font-size:1.8rem}.dialogActions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}@media(min-width:720px){.appShell{padding-top:1.2rem}.playerRow{grid-template-columns:minmax(0,1fr) 150px 220px;grid-template-areas:"name timer actions"}.rowActions{grid-template-columns:repeat(2,minmax(0,1fr))}}
