@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Mono:wght@300;400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #080b0f;--bg2: #0e1318;--bg3: #141c24;--border: rgba(255,255,255,.07);--border2: rgba(255,255,255,.12);--text: #e8edf2;--text2: #7a8a9a;--text3: #4a5a6a;--accent: #00e5ff;--accent2: #0099bb;--accent-glow: rgba(0,229,255,.15);--danger: #ff4466;--success: #00ff88;--radius: 12px;--radius-sm: 8px;--nav-w: 220px;--font: "Syne", sans-serif;--mono: "DM Mono", monospace}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;overflow:hidden}.app{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;overflow-y:auto;padding:2.5rem 2rem;background:radial-gradient(ellipse 60% 40% at 70% -10%,rgba(0,229,255,.04) 0%,transparent 70%),var(--bg)}.nav{width:var(--nav-w);min-width:var(--nav-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:2rem 1rem;gap:2rem}.nav-brand{display:flex;align-items:center;gap:.75rem;padding:0 .5rem}.nav-logo{width:36px;height:36px;background:var(--accent);color:var(--bg);display:grid;place-items:center;font-weight:800;font-size:.8rem;border-radius:8px;letter-spacing:.05em;box-shadow:0 0 16px var(--accent-glow)}.nav-title{font-size:1.1rem;font-weight:700;letter-spacing:.05em;color:var(--text)}.nav-links{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.7rem .75rem;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text2);font-family:var(--font);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:left}.nav-item:hover{background:var(--bg3);color:var(--text)}.nav-item.active{background:#00e5ff14;color:var(--accent);border:1px solid rgba(0,229,255,.15)}.nav-icon{font-size:1rem;width:20px;text-align:center}.nav-label{font-size:.875rem}.page{max-width:780px;margin:0 auto}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;gap:1rem}.page-title{font-size:1.75rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}.page-sub{color:var(--text2);font-size:.875rem;margin-top:.25rem;font-family:var(--mono)}.lock-screen{min-height:100vh;display:grid;place-items:center;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(0,229,255,.06) 0%,transparent 60%),var(--bg)}.lock-card{width:100%;max-width:380px;padding:3rem 2.5rem;background:var(--bg2);border:1px solid var(--border2);border-radius:20px;display:flex;flex-direction:column;align-items:center;gap:1rem;box-shadow:0 40px 80px #0009,0 0 40px #00e5ff0d}.lock-icon{width:64px;height:64px;background:#00e5ff14;border:1px solid rgba(0,229,255,.2);border-radius:16px;display:grid;place-items:center;color:var(--accent);margin-bottom:.5rem}.lock-title{font-size:2rem;font-weight:800;letter-spacing:-.02em}.lock-sub{color:var(--text2);font-size:.875rem;font-family:var(--mono);margin-bottom:.5rem}.lock-input{width:100%;padding:.875rem 1.25rem;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);font-family:var(--mono);font-size:1rem;outline:none;transition:border-color .15s,box-shadow .15s;text-align:center;letter-spacing:.2em}.lock-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.lock-input.err{border-color:var(--danger)}.lock-err{color:var(--danger);font-size:.8rem;font-family:var(--mono)}.lock-btn{width:100%;padding:.875rem;background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius-sm);font-family:var(--font);font-weight:700;font-size:.95rem;cursor:pointer;letter-spacing:.05em;transition:opacity .15s,box-shadow .15s;margin-top:.5rem}.lock-btn:hover{opacity:.9;box-shadow:0 0 20px var(--accent-glow)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.shake{animation:shake .5s ease}.btn-primary{display:flex;align-items:center;gap:.5rem;padding:.7rem 1.25rem;background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius-sm);font-family:var(--font);font-weight:700;font-size:.875rem;cursor:pointer;white-space:nowrap;transition:opacity .15s,box-shadow .15s}.btn-primary:hover{opacity:.9;box-shadow:0 0 16px var(--accent-glow)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{padding:.5rem .75rem;background:transparent;color:var(--text2);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:.85rem;cursor:pointer;transition:all .15s}.btn-ghost:hover{background:var(--bg3);color:var(--text);border-color:var(--border2)}.btn-ghost.btn-danger:hover{color:var(--danger);border-color:var(--danger)}.btn-ghost.btn-back{border:none;color:var(--text2);margin-bottom:.5rem;padding:0}.btn-ghost.btn-back:hover{color:var(--accent);background:transparent}.btn-ghost.btn-sm{padding:.3rem .6rem;font-size:.8rem}.btn-outline{padding:.7rem 1.25rem;background:transparent;color:var(--accent);border:1px dashed rgba(0,229,255,.3);border-radius:var(--radius-sm);font-family:var(--font);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .15s;width:100%}.btn-outline:hover{background:var(--accent-glow);border-style:solid}.btn-add-triset{margin-top:1rem}.field-label{display:block;font-size:.75rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.4rem;font-family:var(--mono)}.field-input,.field-select{width:100%;padding:.7rem 1rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:.9rem;outline:none;transition:border-color .15s,box-shadow .15s}.field-input:focus,.field-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.field-select option{background:var(--bg2)}.field-sm{width:90px;min-width:70px}.field-group{margin-bottom:1rem}.session-list{display:flex;flex-direction:column;gap:.75rem}.session-card{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .15s}.session-card:hover{border-color:var(--border2);background:var(--bg3);transform:translateY(-1px);box-shadow:0 4px 20px #0000004d}.session-card-left{display:flex;flex-direction:column;gap:.25rem}.session-date{font-weight:600;font-size:.95rem}.session-notes{font-size:.8rem;color:var(--text2);font-family:var(--mono)}.session-meta{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem;display:grid;grid-template-columns:1fr 2fr;gap:1rem}.trisets-container{display:flex;flex-direction:column;gap:1rem}.triset-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.triset-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;background:var(--bg3);border-bottom:1px solid var(--border)}.triset-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-family:var(--mono)}.triset-exercises{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.triset-exercise-row{display:flex;align-items:center;gap:.75rem}.ex-num{width:22px;height:22px;background:var(--bg3);border:1px solid var(--border2);border-radius:50%;display:grid;place-items:center;font-size:.7rem;font-weight:700;color:var(--text3);flex-shrink:0;font-family:var(--mono)}.triset-exercise-row .field-select{flex:1}.detail-exercise-row{display:flex;align-items:center;gap:1rem;padding:.25rem 0}.detail-ex-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.detail-ex-stats{display:flex;gap:.5rem;flex-wrap:wrap}.stat-chip{padding:.2rem .6rem;background:var(--bg3);border:1px solid var(--border);border-radius:20px;font-size:.75rem;font-family:var(--mono);color:var(--text2)}.stat-chip.accent{color:var(--accent);border-color:#00e5ff33}.exercise-list{display:flex;flex-direction:column;gap:2px}.exercise-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color .15s}.exercise-row:hover{border-color:var(--border2)}.exercise-info{display:flex;flex-direction:column;gap:.4rem}.exercise-name{font-weight:600;font-size:.95rem}.exercise-muscles{display:flex;flex-wrap:wrap;gap:.4rem}.exercise-actions{display:flex;gap:.5rem}.muscle-badge{padding:.15rem .5rem;background:#00e5ff0f;border:1px solid rgba(0,229,255,.15);border-radius:20px;font-size:.7rem;color:var(--accent);font-family:var(--mono)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;padding:1rem}.modal{width:100%;max-width:520px;background:var(--bg2);border:1px solid var(--border2);border-radius:16px;padding:2rem;box-shadow:0 40px 80px #0009}.modal-title{font-size:1.25rem;font-weight:800;margin-bottom:1.5rem}.muscle-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.muscle-tag{padding:.35rem .75rem;background:var(--bg3);border:1px solid var(--border);border-radius:20px;font-size:.8rem;font-family:var(--mono);color:var(--text2);cursor:pointer;transition:all .15s}.muscle-tag:hover{border-color:var(--border2);color:var(--text)}.muscle-tag.active{background:#00e5ff1a;border-color:var(--accent);color:var(--accent)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.stat-big{font-size:2.5rem;font-weight:800;color:var(--accent);letter-spacing:-.02em;font-family:var(--mono)}.stat-label{font-size:.75rem;color:var(--text2);text-transform:uppercase;letter-spacing:.1em;font-family:var(--mono)}.period-toggle{display:flex;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.toggle-btn{padding:.6rem 1.25rem;background:transparent;border:none;color:var(--text2);font-family:var(--font);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .15s}.toggle-btn.active{background:var(--accent);color:var(--bg)}.section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);font-family:var(--mono);margin:1.5rem 0 1rem}.muscle-bars{display:flex;flex-direction:column;gap:.75rem}.muscle-bar-row{display:flex;align-items:center;gap:1rem}.muscle-bar-label{width:140px;flex-shrink:0;font-size:.85rem;color:var(--text2);font-family:var(--mono)}.muscle-bar-track{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}.muscle-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent2),var(--accent));border-radius:3px;transition:width .6s cubic-bezier(.23,1,.32,1)}.muscle-bar-count{width:30px;text-align:right;font-size:.8rem;color:var(--text2);font-family:var(--mono)}.activity-list{display:flex;flex-direction:column;gap:.5rem}.activity-row{display:flex;align-items:center;gap:1rem}.activity-date{width:120px;flex-shrink:0;font-size:.8rem;color:var(--text2);font-family:var(--mono)}.activity-dots{display:flex;gap:4px;flex:1}.activity-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;opacity:.7}.activity-count{font-size:.8rem;color:var(--text3);font-family:var(--mono);width:24px;text-align:right}.loading{display:flex;justify-content:center;padding:3rem}.spinner{width:32px;height:32px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:4rem;color:var(--text2);text-align:center}.empty-text{color:var(--text3);font-family:var(--mono);font-size:.875rem}@media (max-width: 768px){body{overflow:hidden}.app{flex-direction:column;height:100dvh}.nav{order:2;width:100%;min-width:unset;height:64px;flex-direction:row;align-items:center;padding:0 .5rem;border-right:none;border-top:1px solid var(--border);gap:0;padding-bottom:env(safe-area-inset-bottom)}.nav-brand{display:none}.nav-links{flex-direction:row;width:100%;gap:0}.nav-item{flex:1;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:.5rem .25rem;border-radius:10px;font-size:.7rem;border:none}.nav-item.active{background:#00e5ff14;border:none}.nav-icon{font-size:1.2rem;width:auto}.nav-label{font-size:.65rem;letter-spacing:0}.main-content{order:1;flex:1;overflow-y:auto;padding:1.25rem 1rem;padding-top:max(1.25rem,env(safe-area-inset-top));-webkit-overflow-scrolling:touch}.page-header{flex-direction:column;align-items:stretch;gap:.75rem;margin-bottom:1.25rem}.page-title{font-size:1.4rem}.btn-primary{justify-content:center;width:100%}.session-meta{grid-template-columns:1fr}.triset-exercise-row{flex-wrap:wrap;gap:.5rem}.triset-exercise-row .field-select{width:100%;flex:unset}.field-sm{width:calc(33% - .5rem);min-width:60px}.stats-grid{gap:.5rem}.stat-big{font-size:1.75rem}.stat-card{padding:1rem .5rem}.muscle-bar-label{width:100px;font-size:.75rem}.activity-date{width:90px;font-size:.75rem}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:20px 20px 0 0;padding:1.75rem 1.25rem;padding-bottom:max(1.75rem,env(safe-area-inset-bottom));max-width:100%;width:100%;max-height:90dvh;overflow-y:auto}.lock-card{margin:1rem;padding:2.5rem 1.75rem}.detail-exercise-row{flex-wrap:wrap}.detail-ex-stats{width:100%;padding-left:30px}.period-toggle{width:100%}.toggle-btn{flex:1;text-align:center}}@media (max-width: 380px){.nav-label{display:none}.nav-item{padding:.5rem}.nav-icon{font-size:1.4rem}}.triset-preview{display:flex;flex-direction:column;gap:6px;padding:.875rem 1.25rem;background:#00e5ff08;border-bottom:1px solid var(--border)}.preview-row{display:flex;align-items:center;gap:.75rem}.preview-num{width:18px;font-size:.65rem;font-weight:700;color:var(--accent);font-family:var(--mono);flex-shrink:0;text-align:center}.preview-name{flex:1;font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-chips{display:flex;gap:.4rem;flex-shrink:0}.preview-chip{padding:.15rem .55rem;background:var(--bg3);border:1px solid var(--border2);border-radius:20px;font-size:.75rem;font-family:var(--mono);color:var(--text);white-space:nowrap}.preview-chip.accent{border-color:#00e5ff40;color:var(--accent);background:#00e5ff0f}.chip-unit{color:var(--text3);font-size:.7rem}.ex-fields{display:flex;gap:.5rem;flex-shrink:0}.ex-field-wrap{display:flex;flex-direction:column;gap:2px;align-items:center}.ex-field-label{font-size:.6rem;font-family:var(--mono);color:var(--text3);text-transform:uppercase;letter-spacing:.05em}@media (max-width: 768px){.triset-exercise-row{flex-wrap:wrap}.triset-exercise-row .field-select{width:100%;flex:unset}.ex-fields{width:100%;padding-left:30px;justify-content:flex-start}.field-sm{width:72px}}.ex-block{display:flex;flex-direction:column;gap:.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.ex-block:last-child{border-bottom:none;padding-bottom:0}.ex-top-row{display:flex;align-items:center;gap:.75rem}.ex-top-row .field-select{flex:1}.ex-inputs-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;padding-left:2rem}.ex-input-cell{display:flex;flex-direction:column;gap:3px}.ex-input-label{font-size:.6rem;font-weight:700;font-family:var(--mono);color:var(--accent);letter-spacing:.08em;text-align:center}.ex-input{text-align:center;padding:.6rem .25rem;font-size:1rem;font-family:var(--mono);font-weight:500;width:100%}.ex-input::-webkit-inner-spin-button,.ex-input::-webkit-outer-spin-button{-webkit-appearance:none}.ex-input[type=number]{-moz-appearance:textfield}.triset-preview{display:flex;flex-direction:column;gap:6px;padding:.75rem 1.25rem;background:#00e5ff08;border-bottom:1px solid var(--border)}.preview-row{display:flex;align-items:center;gap:.6rem}.preview-num{width:16px;font-size:.65rem;font-weight:700;color:var(--accent);font-family:var(--mono);flex-shrink:0;text-align:center}.preview-name{flex:1;font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-chips{display:flex;gap:.35rem;flex-shrink:0}.preview-chip{padding:.15rem .5rem;background:var(--bg3);border:1px solid var(--border2);border-radius:20px;font-size:.72rem;font-family:var(--mono);color:var(--text);white-space:nowrap}.preview-chip.accent{border-color:#00e5ff4d;color:var(--accent);background:#00e5ff12}.chip-val{font-weight:600}.chip-unit{color:var(--text3);font-size:.65rem}@media (max-width: 768px){.triset-exercise-row{display:none}.ex-inputs-row{padding-left:1.75rem}}
