@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-color:#0f172a;--surface-color:#1e293b;--surface-color-light:#334155;--primary:#38bdf8;--primary-glow:#38bdf866;--accent:#22d3ee;--text-main:#f8fafc;--text-muted:#94a3b8;--border-color:#334155;--glass-bg:#1e293bb3;--glass-border:#ffffff14;--radius-lg:16px;--radius-md:12px;--radius-sm:8px;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Outfit,-apple-system,sans-serif}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0003}.heading{color:var(--text-main);font-weight:600}.subtext{color:var(--text-muted);font-size:.9rem}.btn-success{color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.5px;background:#22c55e;border:none;padding:.75rem 1.5rem;font-weight:700;box-shadow:0 4px 12px #ffffff40}.btn-success:hover{background:#16a34a;transform:translateY(-2px);box-shadow:0 6px 16px #fff6}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--accent));color:#000;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);box-shadow:0 4px 12px var(--primary-glow);border:none;padding:.75rem 1.5rem;font-weight:600}.btn-primary:hover{box-shadow:0 6px 16px var(--primary-glow);opacity:.9;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-outline{border:1px solid var(--border-color);color:var(--text-main);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:0 0;padding:.75rem 1.5rem;font-weight:500}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:#38bdf80d}.sm-btn{border-radius:4px;padding:.4rem .8rem;font-size:.75rem}.icon-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:6px;display:flex}.icon-btn:hover{color:var(--text-main);background:#ffffff1a}.icon-btn.primary{color:var(--primary)}.icon-btn.primary:hover{background:var(--primary-glow)}.input-field{background:var(--surface-color);border:1px solid var(--border-color);color:var(--text-main);border-radius:var(--radius-sm);transition:var(--transition);width:100%;padding:.75rem 1rem;font-family:inherit}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow);outline:none}.sidebar{border-top:none;border-bottom:none;border-left:none;border-radius:0;flex-direction:column;flex-shrink:0;width:260px;padding:1.5rem;display:flex}.sidebar-header{justify-content:space-between;align-items:center;width:100%;display:flex}.logo-icon{color:var(--primary)}.role-toggle-wrapper{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:1.5rem;display:flex;overflow:hidden}.role-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;flex:1;padding:.5rem;font-family:inherit;font-size:.85rem;font-weight:500}.role-btn.active{background:var(--primary-glow);color:var(--primary)}.client-selector{margin-bottom:1.5rem}.client-selector .subtext{text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem;font-size:.75rem}.sidebar-nav{flex-direction:column;flex:1;gap:.5rem;display:flex}.nav-item{color:var(--text-muted);border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:1rem;width:100%;padding:.8rem 1rem;font-family:inherit;font-size:1rem;text-decoration:none;display:flex}.nav-item:hover{background:var(--surface-color-light);color:var(--text-main)}.nav-item.active{background:var(--primary-glow);color:var(--primary);font-weight:500}.sign-out-btn{opacity:.8;color:#ef4444!important;margin-top:auto!important}.sign-out-btn:hover{opacity:1;color:#ef4444!important;background:#ef44441a!important}.mobile-close-btn{display:none}@media (width<=768px){.sidebar{z-index:50;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#141419f2;flex-direction:column;width:280px;height:100vh;padding:1.5rem;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-nav{flex:1;overflow-y:auto}.sign-out-btn{flex-shrink:0;margin-top:.5rem!important}.mobile-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;display:block}}.workouts-page{flex-direction:column;gap:1.25rem;display:flex}.workouts-header{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.week-tabs{border-bottom:1px solid var(--border-color);gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.week-tab{border-radius:var(--radius-sm) var(--radius-sm) 0 0;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:var(--transition);background:0 0;border:1px solid #0000;padding:.6rem 1.25rem;font-weight:500}.week-tab:hover{background:var(--surface-color-light);color:var(--text-main)}.week-tab.active{background:var(--surface-color);border-color:var(--border-color);border-bottom-color:var(--surface-color);color:var(--primary);box-shadow:0 -2px 10px #0000001a}.week-tab-add{border:1px dashed var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;align-items:center;gap:.4rem;padding:.6rem 1rem;display:flex}.week-tab-add:hover{color:var(--text-main);border-color:var(--text-muted)}.day-accordion{border:1px solid var(--glass-border);transition:var(--transition);margin-bottom:1.5rem;overflow:hidden}.day-accordion.finished{opacity:.7}.day-accordion.finished:hover{opacity:.9}.day-header{width:100%;color:var(--text-main);cursor:pointer;transition:var(--transition);background:0 0;border:none;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.day-header:hover{background:var(--surface-color-light)}.day-body{flex-direction:column;gap:1.25rem;padding:0 1.5rem 1.5rem;display:flex}.add-inline-form{align-items:center;gap:.75rem;margin-bottom:1rem;padding:1rem;display:flex}.exercise-card{background:var(--surface-color);border-radius:var(--radius-md);border:1px solid var(--glass-border);flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.ex-sets-chip{background:var(--surface-color-light);border:1px solid var(--border-color);color:var(--text-muted);white-space:nowrap;border-radius:999px;padding:.2rem .55rem;font-size:.7rem;font-weight:600}.exercise-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.exercise-unit-toggle{background:var(--bg-color);border:1px solid var(--border-color);border-radius:999px;display:flex;overflow:hidden}.sm-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;padding:.25rem .6rem;font-family:inherit;font-size:.75rem;font-weight:500}.sm-btn.active{background:var(--primary);color:#000}.btn-success{color:#fff!important;background:#22c55e!important;box-shadow:0 4px 12px #ffffff40!important}.btn-success:hover{background:#16a34a!important;box-shadow:0 6px 16px #fff6!important}.yt-btn{color:#f44;transition:var(--transition);background:#ff000026;border:1px solid #ff00004d;border-radius:999px;align-items:center;gap:.4rem;padding:.35rem .8rem;font-size:.8rem;font-weight:500;text-decoration:none;display:flex}.yt-btn:hover{background:#ff000040}.exercise-thumbnail{border-radius:var(--radius-sm);border:1px solid var(--glass-border);width:54px;height:96px;transition:var(--transition);flex-shrink:0;display:block;overflow:hidden}.exercise-thumbnail img{object-fit:cover;width:100%;height:100%;display:block}.exercise-thumbnail:hover{border-color:var(--primary);opacity:.8}.exercise-thumbnail--placeholder{background:var(--surface-color-light);justify-content:center;align-items:center;display:flex}.exercise-thumbnail--empty{visibility:hidden}.sets-table{flex-direction:column;gap:.5rem;display:flex}.sets-row{grid-template-columns:40px 1fr 1fr 70px;align-items:center;gap:.75rem;min-height:44px;display:grid}.sets-row-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border-color);padding:0 0 .25rem;font-size:.8rem}.set-number{color:var(--primary);text-align:center;font-weight:600}.set-input{padding:.5rem .75rem;font-size:.95rem}.set-input:disabled{opacity:.6;cursor:not-allowed;color:var(--primary);background:#0000001a;border-color:#0000;font-weight:600}.add-exercise-form{background:var(--surface-color);border-radius:var(--radius-md);border:1px dashed var(--border-color);flex-direction:column;gap:.75rem;padding:1rem;display:flex}.btn-add-exercise{border:1px dashed var(--border-color);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:0 0;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.25rem;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;display:flex}.btn-add-exercise:hover{background:var(--surface-color-light);color:var(--text-main)}.btn-outline{border:1px solid var(--border-color);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:0 0;padding:.75rem 1.5rem;font-family:inherit}.btn-outline:hover{border-color:var(--primary);color:var(--text-main)}.ghost-stats,.rest-timer{background:var(--primary-glow);color:var(--primary);border:1px solid rgba(var(--primary-rgb), .2);white-space:normal;word-break:keep-all;border-radius:999px;align-items:center;gap:.35rem;max-width:none;padding:.25rem .6rem;font-size:.7rem;font-weight:600;display:flex}.rest-timer{color:#000;background:#f59e0b;border-color:#f59e0b;padding:.4rem 1rem;font-size:1.1rem;animation:2s ease-in-out infinite timerPulse;box-shadow:0 0 20px #f59e0b4d}@keyframes timerPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.spin{animation:2s linear infinite spin}.trainer-add-actions{margin-top:1rem}.library-picker{background:var(--surface-color-light);border:1px solid var(--primary-glow);padding:1.25rem}.library-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;max-height:200px;padding-right:.5rem;display:grid;overflow-y:auto}.lib-item{background:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-main);cursor:pointer;transition:var(--transition);text-align:left;padding:.6rem;font-size:.85rem}.lib-item:hover{border-color:var(--primary);background:var(--primary-glow)}.day-comments-section{border-top:1px solid var(--border-color);margin-top:2rem;padding-top:1rem}.comments-header{color:var(--text-muted);cursor:pointer;transition:var(--transition);align-items:center;gap:.5rem;padding:.5rem 0;font-size:.85rem;font-weight:600;display:flex}.comments-header:hover{color:var(--primary)}.comments-body{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.comments-list{flex-direction:column;gap:.75rem;max-height:250px;padding-right:.5rem;display:flex;overflow-y:auto}.comment-bubble{border-radius:var(--radius-md);max-width:80%;padding:.75rem 1rem;position:relative}.comment-bubble.trainer{background:var(--surface-color-light);border:1px solid var(--border-color);border-bottom-left-radius:2px;align-self:flex-start}.comment-bubble.client{background:var(--primary-glow);border:1px solid rgba(var(--primary-rgb), .2);color:var(--primary);border-bottom-right-radius:2px;align-self:flex-end}.comment-input-area{gap:.5rem;margin-top:.5rem;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.week-tab{align-items:center;gap:.5rem;display:flex;position:relative}.week-completion-chip{color:#22c55e;white-space:nowrap;background:#22c55e26;border-radius:999px;padding:.15rem .4rem;font-size:.65rem;font-weight:600}.next-badge{background:linear-gradient(135deg, var(--primary), var(--accent));color:#000;text-transform:uppercase;letter-spacing:.5px;border-radius:999px;padding:.15rem .5rem;font-size:.65rem;font-weight:700}.day-card.highlighted{border:1px solid var(--primary);box-shadow:0 0 20px #38bdf826,inset 0 0 0 1px #38bdf81a}.day-card.highlighted .day-header{background:#38bdf80d}.btn-start-workout{color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;align-items:center;gap:.75rem;padding:.85rem 2rem;font-family:inherit;font-size:1rem;font-weight:700;display:flex;box-shadow:0 4px 16px #22c55e59}.btn-start-workout:hover{transform:translateY(-2px);box-shadow:0 6px 24px #22c55e80}.btn-start-workout:active{transform:translateY(0)}.readiness-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#000000a6;justify-content:center;align-items:center;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.readiness-modal{text-align:center;width:90%;max-width:420px;padding:2.5rem;animation:.3s cubic-bezier(.4,0,.2,1) slideUp}.readiness-title{color:var(--text-main);margin-bottom:2rem;font-size:1.4rem;font-weight:600}.readiness-options{justify-content:center;gap:1rem;display:flex}.readiness-btn{background:var(--surface-color);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);flex-direction:column;align-items:center;gap:.6rem;min-width:90px;padding:1.25rem 1.5rem;font-family:inherit;display:flex}.readiness-btn:hover{border-color:var(--btn-color);background:var(--btn-glow);box-shadow:0 8px 24px var(--btn-glow);transform:translateY(-4px)}.readiness-emoji{font-size:2rem}.readiness-label{color:var(--text-main);font-size:.9rem;font-weight:600}.workout-timer-bar{background:#38bdf814;border:1px solid #38bdf840;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:.85rem 1.25rem;animation:3s ease-in-out infinite timerBarGlow;display:flex}.workout-timer-left{align-items:center;gap:.6rem;display:flex}.workout-timer-badge{font-size:1.3rem}.workout-timer-label{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.workout-timer-clock{align-items:center;gap:.5rem;display:flex}.workout-timer-icon{color:var(--primary)}.workout-timer-digits{color:var(--text-main);font-variant-numeric:tabular-nums;letter-spacing:1px;font-size:1.5rem;font-weight:700}@keyframes timerBarGlow{0%,to{box-shadow:0 0 8px #38bdf81a}50%{box-shadow:0 0 20px #38bdf833}}.focus-mode-workouts{max-width:700px;margin:0 auto}.focus-day-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.focus-finish-area{justify-content:center;margin-top:2rem;padding:1.5rem 0;display:flex}.btn-finish-workout{color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#22c55e,#16a34a,#22d3ee) 0 0/200% 200%;border:none;align-items:center;gap:.75rem;padding:1rem 3rem;font-family:inherit;font-size:1.15rem;font-weight:700;animation:3s infinite finishGradient;display:flex;box-shadow:0 4px 20px #22c55e66}.btn-finish-workout:hover{transform:translateY(-3px)scale(1.02);box-shadow:0 8px 32px #22c55e80}@keyframes finishGradient{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.workout-complete-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;background:#000000bf;justify-content:center;align-items:center;animation:.4s fadeIn;display:flex;position:fixed;inset:0}.workout-complete-card{text-align:center;padding:3rem 4rem;animation:.5s cubic-bezier(.34,1.56,.64,1) celebrateIn}.complete-trophy{margin-bottom:1rem;font-size:4rem;animation:1s infinite trophyBounce;display:block}.workout-complete-card .heading{background:linear-gradient(135deg,#22c55e,#38bdf8,#fbbf24);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.75rem;font-size:2rem}.complete-time{color:var(--text-muted);font-size:1.1rem}.complete-time strong{color:var(--text-main);font-size:1.3rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes celebrateIn{0%{opacity:0;transform:scale(.5)translateY(30px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes trophyBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (width<=768px){.workouts-header{flex-direction:column;align-items:stretch;gap:1rem}.workouts-header-actions{justify-content:space-between;width:100%;display:flex}.day-header{padding:1rem}.day-body{padding:0 1rem 1rem}.sets-row{grid-template-columns:32px 1fr 1fr 60px;gap:.4rem}.input-field.slim{padding:.4rem .5rem;font-size:.85rem}.input-field.slim::placeholder{opacity:.7;font-size:.75rem}.exercise-header{flex-direction:column;align-items:flex-start}.exercise-unit-toggle{margin-top:.5rem}.day-comments-section{margin-top:1.5rem}.readiness-options{flex-direction:column;align-items:center}.readiness-btn{flex-direction:row;justify-content:center;width:100%}.readiness-modal{padding:1.5rem}.workout-complete-card{padding:2rem}.btn-finish-workout{padding:.85rem 2rem;font-size:1rem}.btn-start-workout{justify-content:center;width:100%}.ghost-stats{flex-wrap:wrap}}.app-container{width:100vw;min-height:100vh;display:flex;position:relative;overflow:hidden}.main-content{flex:1;width:100%;padding:2rem;overflow-y:auto}.mobile-header{border-bottom:1px solid var(--border-color);align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;display:none}.menu-trigger{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:.25rem;display:flex}.menu-trigger:hover{background:var(--surface-color-light);border-radius:var(--radius-sm)}.sidebar-overlay{display:none}@media (width<=768px){.app-container{flex-direction:column}.main-content{padding:1.25rem}.mobile-header{display:flex}.sidebar-overlay{z-index:40;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:block;position:fixed;inset:0}}.app-container.focus-mode .sidebar{display:none}.app-container.focus-mode .mobile-header{display:none!important}.app-container.focus-mode .main-content{max-width:800px;margin:0 auto;padding:1rem 1.5rem}
