@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700;800&display=swap";:root{--font-ui: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-family:var(--font-ui);line-height:1.5;font-weight:400;color-scheme:dark;color:#f1f1f1;background-color:#090909;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100%}html{background:#090909}body{margin:0;min-width:320px;background:#090909;color:#f1f1f1}a{color:#9ec0ff;text-decoration:none}a:hover{color:#c0d5ff}button,input,select,textarea{font:inherit;color:inherit}button{border:1px solid #2f2f2f;background:#101010}input,select,textarea{background:#111;border:1px solid #2b2b2b}input::placeholder,textarea::placeholder{color:#8b8b8b}.page{max-width:980px;margin:28px auto;padding:16px;min-height:calc(100vh - 56px)}.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px}.topbarGroups{justify-content:center}.h1{margin:0;font-size:22px}.attendanceRate{margin-top:6px;font-size:34px;font-weight:800;line-height:1.1;text-align:center}.attendanceMeta{margin-top:4px;font-size:12px;color:#9a9a9a;text-align:center}.groupScreenTitle{margin-top:6px;font-size:34px;font-weight:800;line-height:1.1;text-align:center}.historyPageTitle{margin-top:6px;font-size:18px;font-weight:900;line-height:1.1;text-align:center;display:block}.appFooter{position:fixed;left:0;right:0;bottom:18px;text-align:center;pointer-events:none}.footerBrand{font-size:22px;font-weight:800}.footerBy{margin-top:2px;font-size:12px;color:#9a9a9a}.btn{border:1px solid #303030;background:#0e0e0e;color:#f1f1f1;padding:8px 10px;border-radius:10px;cursor:pointer}.btnPrimary{border-color:#555;background:#161616;font-weight:700}.logTimerButton{min-width:86px;font-variant-numeric:tabular-nums}.logTimerButtonRunning{border-color:#33d298;background:#123126;color:#f5fff9}.logTimerButtonLocked,.logTimerButtonLocked:disabled{border-color:#5b2d2d;background:#211111;color:#9c7474;cursor:default;opacity:1}.logTimerButtonLocked:hover,.logTimerButtonLocked:focus{border-color:#5b2d2d;background:#211111;color:#9c7474}.btn:disabled{opacity:.6;cursor:not-allowed}.iconBtn{width:40px;height:40px;padding:8px;display:inline-flex;align-items:center;justify-content:center}.inlineIcon{width:20px;height:20px}.menuIconBtn{width:40px;height:40px;padding:8px;display:inline-flex;align-items:center;justify-content:center}.menuCogIcon{width:20px;height:20px;opacity:.92}.menuGridItem{justify-self:stretch}.groupScreenControls{display:flex;align-items:center;justify-content:space-between;gap:10px}.insertMarker{border-top:2px solid #f1f1f1;margin:-6px 0 10px;border-radius:99px}.grid{margin-top:18px;display:grid;gap:16px}.card{border:1px solid #2b2b2b;border-radius:16px;padding:14px;background:#101010}.cardHeader{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}.groupTitle{font-weight:700}.rowCenter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.pill{border:1px solid #2d2d2d;background:#0d0d0d;color:#f1f1f1;border-radius:999px;padding:10px 12px;cursor:pointer;min-width:140px;text-align:center}.pill:hover{border-color:#505050}.dropdown{width:100%;margin-top:10px;border-top:1px solid #2a2a2a;padding-top:12px}.formRow{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:10px}.targetRow{display:grid;grid-template-columns:auto minmax(0,1fr) minmax(0,1fr);align-items:center;gap:10px}.targetRow .input{text-align:center}.dialField{display:grid;gap:6px}.dialLabel{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#8f8f8f;text-align:center}.dialShell{display:block}.dialWindow{border:1px solid #2c2c2c;background:linear-gradient(180deg,#ffffff0d,#fff0 18% 82%,#ffffff0d),linear-gradient(180deg,#0d0d0d,#171717,#0d0d0d);color:#f1f1f1;border-radius:14px;width:100%;min-height:156px;padding:16px 10px;display:grid;align-items:center;justify-items:center;gap:12px;cursor:ns-resize;-webkit-user-select:none;user-select:none;touch-action:none;box-shadow:inset 0 1px #ffffff0a,inset 0 -1px #000000a6;animation-duration:.28s;animation-timing-function:ease-out;animation-fill-mode:none}.dialWindowEditable{cursor:text}.dialGhost{font-size:16px;color:#666}.dialCurrent{font-size:28px;font-weight:800;line-height:1;color:#fafafa;text-shadow:0 0 12px rgba(255,255,255,.08)}.dialInput{border:1px solid #d0d0d0;background:#151515;color:#f5f5f5;border-radius:14px;width:100%;min-height:156px;padding:16px 10px;font-size:26px;font-weight:700;text-align:center;animation-duration:.28s;animation-timing-function:ease-out;animation-fill-mode:none}@keyframes dialMinPulseA{0%{border-color:#2c2c2c;box-shadow:inset 0 1px #ffffff0a,inset 0 -1px #000000a6}45%{border-color:#d14a4a;box-shadow:0 0 0 1px #d14a4a73,0 0 16px #d14a4a2e}to{border-color:#2c2c2c;box-shadow:inset 0 1px #ffffff0a,inset 0 -1px #000000a6}}@keyframes dialMinPulseB{0%{border-color:#2c2c2c;box-shadow:inset 0 1px #ffffff0a,inset 0 -1px #000000a6}45%{border-color:#d14a4a;box-shadow:0 0 0 1px #d14a4a73,0 0 16px #d14a4a2e}to{border-color:#2c2c2c;box-shadow:inset 0 1px #ffffff0a,inset 0 -1px #000000a6}}.input{border:1px solid #2c2c2c;background:#121212;color:#f1f1f1;border-radius:10px;padding:10px;font-size:14px}.actions{display:flex;justify-content:space-between;align-items:center;gap:10px}.small{font-size:12px;color:#b5b5b5}@media(max-width:640px){.dialCurrent{font-size:24px}.dialWindow,.dialInput{min-height:132px}}.modalRow{display:grid;gap:12px}.modalActions{display:flex;gap:10px;justify-content:flex-end}.modalOverlay{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:16px;background:#000000ad}.modalShell{width:min(520px,100%);max-height:calc(100vh - 32px);overflow-y:auto;border:1px solid #202327;border-radius:6px;background:#101113;color:#f6f8fb;padding:16px;box-shadow:0 18px 50px #00000057}.modalTitle{margin-bottom:12px;color:#f6f8fb;font-size:16px;font-weight:800;line-height:1.2}.modalSection{display:grid;gap:10px}.modalSectionLabel{color:#b7c2d0;font-size:12px;font-weight:500}.modalActionsCenter{justify-content:center}.modalActionsSpaced{margin-top:10px}.modalLibraryList{max-height:260px;overflow-y:auto;border:1px solid #202327;border-radius:6px;padding:10px;background:#0d0f11}.modalLibraryRows{display:grid;gap:8px}.modalLibraryButton{width:100%;text-align:left}.modalShell .input{border-color:#24282d;border-radius:5px;background:#0d0f11;padding:12px 10px;color:#f6f8fb}.modalShell .input:focus{outline:none;border-color:#c8ad62;box-shadow:0 0 0 1px #c8ad626b,0 0 18px #c8ad621f}.modalShell .input::placeholder{color:#7f8b99}.modalShell .targetRow{grid-template-columns:auto minmax(0,1fr) minmax(0,1fr)}.modalShell .targetRow .modalSectionLabel{align-self:center}.modalShell .btn{border-radius:5px}.historyChartWrap{display:grid;gap:6px;margin-bottom:10px}.historyChartHeader{display:flex;align-items:center;justify-content:space-between;gap:10px}.historyChartTitle{font-size:13px;font-weight:600}.historyChartFrame{width:100%;border:1px solid #2a2a2a;border-radius:12px;overflow:hidden;background:#000}.historyChartTick{font-size:16px;fill:#b0b0b0}.historyChartAxisLabel{font-size:16px;fill:#f5f5f5;font-weight:600}.historyChartModal{position:fixed;inset:0;z-index:1000;background:#000000eb;padding:14px;display:flex}.historyChartModalInner{width:100%;height:100%;display:grid;grid-template-rows:auto 1fr;gap:10px}.historyChartModalTop{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#fff}.historyChartFrameFullscreen{width:100%;height:calc(100vh - 78px);background:#000}@media(max-width:900px){.historyChartFrameFullscreen{height:calc(100vh - 88px)}}@media(max-width:900px)and (orientation:portrait){.historyChartModal{padding:8px}.historyChartFrameFullscreen{height:calc(100vw - 18px)}}.page{width:min(100%,450px);max-width:450px;margin:0 auto;padding:14px 20px 32px;min-height:100vh;background:#070809}.topbar{align-items:flex-start;min-height:50px}.topbarGroups{justify-content:space-between}.topbarAction{min-width:42px;display:flex;justify-content:flex-end}.brandTitle,.groupScreenTitle,.historyPageTitle{color:#f6f8fb;font-size:20px;font-weight:800;line-height:1.15;margin:0}.brandTitle{font-size:20px}.screenKicker,.sectionKicker,.cardMeta,.statLabel,.historyUnit,.historyDate,.statSub{color:#8390a0;font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase}.screenKicker{margin-top:8px}.textBack,.textAction{border:0;background:transparent;color:#8795a6;padding:0;cursor:pointer;letter-spacing:.22em;text-transform:uppercase;font-size:11px}.textBack{margin-bottom:10px}.textAction:hover,.textBack:hover{color:#f4f6f8}.grid{margin-top:18px;gap:8px}.sectionHeader{display:flex;align-items:center;justify-content:space-between;margin:18px 0 8px}.attendanceCard,.card,.historyEntryCard,.historyChartWrap{border:1px solid #202327;border-radius:5px;background:#101113}.attendanceCard{padding:20px 16px 16px}.attendanceCardTop,.attendanceCardBottom,.historyPanelTop,.historyEntryCardTop,.historyPanelActions{display:flex;align-items:center;justify-content:space-between;gap:12px}.attendanceRate{margin:0;color:#d1b15b;font-size:18px;font-weight:800;line-height:1}.attendanceRate span{font-size:28px}.attendanceWindowTabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;margin-top:16px}.attendanceWindowTab{border:1px solid #202327;background:#0d0f11;color:#8390a0;border-radius:4px;padding:6px 4px;cursor:pointer;font-size:10px;font-weight:700;letter-spacing:.12em}.attendanceWindowTabActive{border-color:#5f5130;background:#17140d;color:#d1b15b}.attendanceTrack{height:6px;background:#252017;margin:16px 0 10px;overflow:hidden}.attendanceFill{height:100%;background:#c8ad62}.attendanceDayGrid{display:grid;grid-template-columns:repeat(25,minmax(0,1fr));gap:3px;margin:12px 0}.attendanceDayCell{aspect-ratio:1;min-width:0;border:1px solid #202327;border-radius:2px;background:#0c0d0f}.attendanceDayCellActive{border-color:#7b693b;background:#c8ad62;box-shadow:0 0 8px #c8ad6229}.attendanceCardBottom{color:#8390a0;font-size:11px;letter-spacing:.16em;text-transform:uppercase}.card{padding:18px 16px}.cardHeader{margin:0}.groupTitle{color:#f7f9fc;font-size:16px;font-weight:800;line-height:1.2}.cardMeta{margin-top:6px;letter-spacing:.18em}.cardMeta span{color:#39404a;margin:0 8px}.arrowBtn,.ghostIconBtn{border:0;background:transparent;color:#8e9bad;cursor:pointer;padding:6px;min-width:28px;font-weight:800}.arrowBtn:hover,.ghostIconBtn:hover{color:#f5f7fa}.btn,.menuIconBtn{border-color:#22262b;background:#0d0e10;border-radius:5px}.menuIconBtn{width:36px;height:36px}.dropdown{border-top-color:#202327;margin-top:18px;padding-top:18px}.metricGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-bottom:1px solid #181b1f;margin-bottom:18px}.metricCell{padding:0 12px 14px;border-right:1px solid #1f2328}.metricCell:first-child{padding-left:0}.metricCell:last-child{border-right:0;padding-right:0}.metricHeader{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.metricDate{color:#8390a0;font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap}.metricValue{color:#f6f8fb;font-size:16px;font-weight:900;margin-top:6px}.metricValueLine,.metricSubline{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.metricValueLine{font-size:15px}.metricSubline{margin-top:7px;color:#f6f8fb;font-size:11px;font-weight:800;line-height:1.25}.metricParen{color:#8390a0;font-size:10px;font-weight:600;white-space:nowrap}.densityDeltaRow{display:grid;grid-template-columns:2fr 1fr 1fr;border:1px solid #202327;background:#111315;border-radius:4px;padding:10px 0;margin:-6px 0 18px}.densityDeltaSection{min-width:0;padding:0 10px;border-left:1px solid #202327;text-align:right}.densityDeltaSectionMain{border-left:0;text-align:left}.densityDeltaValue{color:#c3cbd4;margin-top:7px;font-size:14px;font-weight:900;letter-spacing:.03em;white-space:nowrap}.densityDeltaValue span{color:#8390a0;font-size:10px;font-weight:600}.densityDeltaValueMuted{color:#56606c}.densityDeltaPercent{margin-left:6px}.instructionText{color:#33d298;text-align:right}.instructionBlock{text-align:right}.instructionWarn{color:#ff6b6b}.formRow{gap:14px;margin:18px 0}.dialLabel{color:#8390a0;letter-spacing:.22em}.dialWindow,.dialInput{aspect-ratio:auto;min-height:142px;border-radius:5px;border-color:#22262b;background:linear-gradient(180deg,rgba(255,255,255,.035) 0%,transparent 22%,transparent 78%,rgba(255,255,255,.035) 100%),linear-gradient(180deg,#090a0c,#131518 46%,#15171a 54%,#090a0c);position:relative;padding:14px 8px;overflow:hidden;gap:11px;box-shadow:inset 0 1px #ffffff0a,inset 0 -1px #000000b8}.dialWindow:after{content:"";position:absolute;left:10px;right:10px;top:50%;height:42px;border-top:1px solid #252a30;border-bottom:1px solid #252a30;transform:translateY(-50%);pointer-events:none}.dialGhost{display:inline;color:#56606c;font-size:14px;font-weight:700;line-height:1}.dialCurrent{color:#f8fafc;font-size:30px;z-index:1;letter-spacing:.03em}.volumeInstruction{display:flex;justify-content:space-between;gap:18px;border:1px solid #202327;background:#141517;border-radius:4px;padding:12px;margin-bottom:16px}.volumeValue{color:#d2b45f;font-size:18px;font-weight:900;letter-spacing:.04em}.volumeValue span{color:#8390a0;font-size:10px;text-transform:uppercase}.actions{display:block}.logTimerButton{width:100%;min-height:64px;letter-spacing:.22em;text-transform:uppercase}.exerciseCardFoot{display:flex;justify-content:space-between;margin-top:16px;color:#8390a0;font-size:10px;letter-spacing:.22em;text-transform:uppercase}.appFooter{position:static;display:flex;justify-content:space-between;margin-top:48px;padding-top:32px;border-top:1px solid #202327;text-align:left}.footerBrand,.footerBy{margin:0;color:#9fb0c4;font-size:11px;font-weight:700;letter-spacing:.28em;text-transform:uppercase}.historyChartWrap{border:0;background:transparent;padding:0;gap:10px;margin:0 0 18px}.historyChartFrame{border:0;border-radius:0;background:transparent;overflow:visible}.historyPanelTop{margin:0 0 8px}.historyEntryCount{color:#9fb0c4;font-size:11px;letter-spacing:.14em}.historyLogKicker{margin:18px 0 6px}.historyEntryCard{position:relative;padding:14px;overflow:hidden}.historyEntryCardCorrection{border-color:#33d29873}.historyEntryCardLast{border-color:#f4f2e8;box-shadow:0 0 0 1px #f4f2e814}.correctionTag{display:inline-block;border:1px solid #33d298;border-radius:4px;color:#33d298;padding:2px 7px;margin-bottom:8px;font-size:10px;letter-spacing:.18em;text-transform:uppercase}.historyVolume{color:#d2b45f;font-size:22px;font-weight:900}.historyUnit{margin-left:6px}.historyEntryStats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));margin-top:16px}.historyEntryStats>div{text-align:center;border-right:1px solid #202327;min-width:0}.historyEntryStats>div:last-child{border-right:0}.statValue{color:#f6f8fb;font-size:13px;font-weight:900;margin-top:6px}.statSub{display:block;margin-top:8px;font-size:9px;letter-spacing:.16em}.attendanceRate,.attendanceCardBottom,.metricDate,.metricValue,.metricSubline,.metricParen,.densityDeltaValue,.densityDeltaValue span,.volumeValue,.dialGhost,.dialCurrent,.dialInput,.logTimerButton,.historyEntryCount,.historyDate,.historyVolume,.historyUnit,.statValue,.statSub,.historyChartTick,.historyChartAxisLabel{font-family:var(--font-mono);font-variant-numeric:tabular-nums}@media(max-width:380px){.page{padding-left:13px;padding-right:13px}.formRow{gap:9px}.dialCurrent{font-size:26px}.historyEntryStats{grid-template-columns:repeat(2,minmax(0,1fr));row-gap:18px}}
