:root{--bg:#0f0f13;--surface:#1a1a2e;--card:#242442;--card-hover:#2c2c52;--primary:#4facfe;--primary-hover:#3d9aee;--primary-dim:#4facfe26;--text:#e8e8ed;--text-secondary:#9ca3af;--text-muted:#6b7280;--border:#2a2a4a;--border-light:#3a3a5a;--danger:#ef4444;--danger-hover:#dc2626;--success:#10b981;--warning:#f59e0b;--orange:#f97316;--green-zone:#10b981;--yellow-zone:#f59e0b;--red-zone:#ef4444;--orange-zone:#f97316;--font:system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius:8px;--radius-sm:4px;--radius-lg:12px;--shadow:0 2px 8px #0000004d;--shadow-lg:0 4px 16px #0006;--transition:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font);cursor:pointer;border:none;outline:none}input,select,textarea{font-family:var(--font);background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition);outline:none;padding:8px 12px;font-size:14px}input:focus,select:focus,textarea:focus{border-color:var(--primary)}input::placeholder,textarea::placeholder{color:var(--text-muted)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.btn{border-radius:var(--radius);transition:all var(--transition);white-space:nowrap;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;display:inline-flex}.btn-primary{background:var(--primary);color:#0f0f13}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--card-hover);border-color:var(--border-light)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{color:var(--text);background:var(--card)}.btn-sm{padding:4px 10px;font-size:12px}.btn-icon{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition);background:0 0;justify-content:center;align-items:center;padding:0;display:inline-flex}.btn-icon:hover{color:var(--text);background:var(--card)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.pill{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;transition:all var(--transition);white-space:nowrap;border-radius:999px;align-items:center;padding:4px 12px;font-size:12px;font-weight:500;display:inline-flex}.pill:hover{border-color:var(--primary);color:var(--text)}.pill.active{background:var(--primary-dim);border-color:var(--primary);color:var(--primary)}.page{max-width:1400px;margin:0 auto;padding:24px 32px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{font-size:24px;font-weight:600}.grid{gap:16px;display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (width<=768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page{padding:16px}}.spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{justify-content:center;align-items:center;min-height:200px;display:flex}.empty-state{text-align:center;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state svg{opacity:.5;width:48px;height:48px;margin-bottom:16px}.empty-state h3{color:var(--text);margin-bottom:8px;font-size:16px}.tabs{background:var(--surface);border-radius:var(--radius);gap:2px;padding:2px;display:flex;overflow-x:auto}.tab{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition);white-space:nowrap;cursor:pointer;background:0 0;border:none;padding:8px 16px;font-size:13px;font-weight:500}.tab:hover{color:var(--text)}.tab.active{background:var(--card);color:var(--text)}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;color:var(--text-muted);transition:all var(--transition);justify-content:center;align-items:center;min-height:80px;padding:24px;display:flex}.drop-zone.drag-over{border-color:var(--primary);background:var(--primary-dim);color:var(--primary)}.modal-backdrop{z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:480px;max-height:90vh;padding:24px;animation:.2s slideUp;overflow-y:auto}.modal h2{margin-bottom:16px;font-size:18px}.modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-group{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.form-group label{color:var(--text-secondary);font-size:13px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px}.stat-card .label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:12px}.stat-card .value{color:var(--text);font-size:28px;font-weight:700}.stat-card .sub{color:var(--text-muted);margin-top:2px;font-size:12px}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:360px;padding:12px 16px;font-size:14px;animation:.2s slideUp}.toast.error{border-color:var(--danger);color:var(--danger)}.toast.success{border-color:var(--success);color:var(--success)}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-main{flex:1;overflow-y:auto}.nav{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;max-width:1400px;height:56px;margin:0 auto;padding:0 24px;display:flex}.nav-left{align-items:center;gap:32px;display:flex}.nav-brand{color:var(--primary);letter-spacing:-.01em;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;font-size:16px;font-weight:700;display:flex}.nav-brand:hover{opacity:.9}.nav-links{gap:4px;display:flex}.nav-link{border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:8px 14px;font-size:14px;font-weight:500}.nav-link:hover{color:var(--text);background:var(--card)}.nav-link.active{color:var(--primary);background:var(--primary-dim)}.nav-right{align-items:center;gap:12px;display:flex}.nav-user{color:var(--text-secondary);font-size:13px}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:40px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{margin-top:12px;margin-bottom:4px;font-size:24px;font-weight:700}.login-header p{color:var(--text-secondary);font-size:14px}.login-error{border:1px solid var(--danger);border-radius:var(--radius-sm);color:var(--danger);background:#ef44441a;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-btn{justify-content:center;width:100%;margin-top:8px;padding:12px;font-size:15px}.dashboard-grid{grid-template-columns:1fr;gap:24px;display:grid}.dashboard-stats{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.dashboard-actions{gap:12px;display:flex}.dashboard-feed{max-width:640px}.dashboard-feed h2{margin-bottom:16px;font-size:18px}.feed{flex-direction:column;gap:12px;display:flex}.feed-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.feed-item-header{align-items:center;gap:10px;margin-bottom:8px;display:flex}.feed-avatar{background:var(--primary-dim);width:32px;height:32px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.feed-name{font-size:14px;font-weight:600}.feed-time{color:var(--text-muted);margin-left:8px;font-size:12px}.feed-title{margin-bottom:4px;font-size:14px;font-weight:500}.feed-desc{color:var(--text-secondary);margin-bottom:8px;font-size:13px}.feed-reactions{gap:6px;display:flex}.feed-reaction{background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all var(--transition);border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:14px;display:inline-flex}.feed-reaction:hover,.feed-reaction.active{border-color:var(--primary);background:var(--primary-dim)}.feed-reaction span{color:var(--text-secondary);font-size:12px}.program-card{cursor:pointer;transition:all var(--transition)}.program-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}.program-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.program-card-header h3{font-size:16px;font-weight:600}.program-card-actions{gap:4px;display:flex}.program-card-desc{color:var(--text-secondary);margin-bottom:12px;font-size:13px;line-height:1.4}.program-card-meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.program-card-date{color:var(--text-muted);font-size:12px}.builder-layout{grid-template-columns:300px 1fr 280px;height:calc(100vh - 56px);display:grid;overflow:hidden}.builder-left{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;display:flex;overflow:hidden}.builder-left-header{justify-content:space-between;align-items:center;padding:16px 16px 0;display:flex}.builder-left-header h3{font-size:14px;font-weight:600}.builder-count{color:var(--text-muted);background:var(--card);border-radius:999px;padding:2px 8px;font-size:12px}.builder-search{width:calc(100% - 32px);margin:12px 16px}.builder-filters{flex-wrap:wrap;gap:4px;padding:0 16px 12px;display:flex}.builder-exercises{flex:1;padding:0 12px 12px;overflow-y:auto}.exercise-card{border-radius:var(--radius);background:var(--card);cursor:grab;transition:all var(--transition);-webkit-user-select:none;user-select:none;border:1px solid #0000;align-items:center;gap:10px;margin-bottom:4px;padding:10px 12px;display:flex}.exercise-card:hover{border-color:var(--border);background:var(--card-hover)}.exercise-card:active{cursor:grabbing;opacity:.7}.exercise-card-icon{width:28px;height:28px;color:var(--text-muted);background:var(--surface);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.exercise-card-info{flex:1;min-width:0}.exercise-card-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.exercise-card-meta{color:var(--text-muted);gap:8px;font-size:11px;display:flex}.exercise-card-muscle{color:var(--primary)}.exercise-card-grip{opacity:.4;flex-shrink:0}.exercise-card:hover .exercise-card-grip{opacity:.8}.builder-center{flex-direction:column;display:flex;overflow:hidden}.builder-center-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:16px 20px;display:flex}.builder-name{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition);padding:4px 8px;font-size:18px;font-weight:600}.builder-name:hover{background:var(--card)}.builder-name-input{background:var(--card);border:1px solid var(--primary);border-radius:var(--radius-sm);color:var(--text);width:300px;padding:4px 8px;font-size:18px;font-weight:600}.builder-tabs{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:2px;padding:8px 20px;display:flex;overflow-x:auto}.builder-tab{align-items:center;gap:4px;display:flex;position:relative}.builder-tab-btn{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:0 0;border:none;padding:6px 14px;font-size:13px;font-weight:500}.builder-tab-btn:hover{color:var(--text)}.builder-tab.active .builder-tab-btn{color:var(--primary);background:var(--primary-dim)}.builder-tab-input{background:var(--card);border:1px solid var(--primary);border-radius:var(--radius-sm);width:120px;color:var(--text);padding:4px 8px;font-size:13px}.builder-tab-close{width:18px;height:18px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.builder-tab-close:hover{background:var(--danger);color:#fff}.builder-tab-add{border-radius:var(--radius-sm);border:1px dashed var(--border);width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;justify-content:center;align-items:center;margin-left:4px;display:flex}.builder-tab-add:hover{border-color:var(--primary);color:var(--primary)}.builder-template{transition:background var(--transition);flex:1;padding:16px 20px;overflow-y:auto}.builder-template.drag-over{background:#4facfe08}.builder-template-actions{gap:8px;margin-bottom:12px;display:flex}.builder-rows{flex-direction:column;gap:4px;display:flex}.template-row{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);align-items:center;gap:10px;padding:10px 14px;display:flex;position:relative}.template-row:hover{border-color:var(--border-light)}.template-row.drag-over{border-color:var(--primary);background:var(--primary-dim)}.template-row.superset-member{margin-left:16px}.superset-bar{background:var(--primary);border-radius:2px;width:3px;position:absolute;top:0;bottom:0;left:-8px}.template-row-grip{cursor:grab;opacity:.4;flex-shrink:0;padding:4px}.template-row:hover .template-row-grip{opacity:.8}.template-row-grip:active{cursor:grabbing}.template-row-name{flex-shrink:0;min-width:160px}.template-row-name span:first-child{font-size:14px;font-weight:500}.template-row-equip{color:var(--text-muted);font-size:11px;display:block}.template-row-fields{flex-wrap:wrap;flex:1;align-items:center;gap:10px;display:flex}.template-field{flex-direction:column;gap:2px;display:flex}.template-field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:10px}.template-field input{text-align:center;width:56px;padding:4px 6px;font-size:13px}.template-field select{min-width:80px;padding:4px 6px;font-size:12px}.rep-range{align-items:center;gap:4px;display:flex}.rep-range span{color:var(--text-muted);font-size:12px}.rep-range input{width:44px}.template-row-remove{opacity:0;transition:opacity var(--transition);flex-shrink:0}.template-row:hover .template-row-remove{opacity:1}.builder-right{background:var(--surface);border-left:1px solid var(--border);padding:16px;overflow-y:auto}.volume-panel-title{margin-bottom:2px;font-size:14px;font-weight:600}.volume-panel-subtitle{color:var(--text-muted);margin-bottom:16px;font-size:12px}.volume-legend{color:var(--text-secondary);flex-wrap:wrap;gap:8px;margin-bottom:16px;font-size:11px;display:flex}.volume-legend span{align-items:center;gap:4px;display:flex}.volume-legend i{border-radius:2px;width:8px;height:8px;display:inline-block}.volume-bars{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.volume-bar-row{flex-direction:column;gap:2px;display:flex}.volume-bar-label{justify-content:space-between;align-items:center;display:flex}.volume-bar-name{font-size:12px;font-weight:500}.volume-bar-sets{font-size:12px;font-weight:600}.volume-bar-zone{opacity:.7;font-size:10px;font-weight:400}.volume-bar-track{background:var(--bg);border-radius:3px;height:14px;position:relative;overflow:hidden}.volume-bar-fill{z-index:2;border-radius:3px;height:100%;transition:width .3s;position:relative}.volume-marker{background:var(--text-muted);opacity:.4;z-index:1;width:1px;position:absolute;top:0;bottom:0}.volume-marker.mrv{background:var(--danger);opacity:.5}.volume-optimal-zone{background:var(--success);opacity:.08;z-index:0;position:absolute;top:0;bottom:0}.volume-bar-ref{color:var(--text-muted);opacity:.6;justify-content:space-between;font-size:9px;display:flex}.volume-ratio{background:var(--card);border-radius:var(--radius);text-align:center;padding:12px}.volume-ratio-title{color:var(--text-secondary);margin-bottom:4px;font-size:12px}.volume-ratio-value{justify-content:center;align-items:center;gap:6px;font-size:20px;font-weight:700;display:flex}.volume-ratio-sep{color:var(--text-muted)}.volume-ratio-label{color:var(--text-secondary);font-size:12px;font-weight:400}.meso-card{position:relative}.meso-card.active-meso{border-color:var(--primary)}.meso-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.meso-card-header h3{font-size:16px}.pill.completed{border-color:var(--success);color:var(--success);background:#10b98126}.meso-card-details{color:var(--text-secondary);flex-direction:column;gap:4px;margin-bottom:12px;font-size:13px;display:flex}.meso-label{color:var(--text-muted)}.meso-progress{background:var(--bg);border-radius:3px;height:6px;margin-bottom:16px;overflow:hidden}.meso-progress-bar{background:var(--primary);border-radius:3px;height:100%;transition:width .3s}.meso-card-actions{gap:8px;display:flex}.meso-week-preview{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);margin-top:8px;padding:16px}.meso-week-preview h4{color:var(--text-secondary);margin-bottom:12px;font-size:13px}.meso-weeks-grid{gap:8px;display:flex}.meso-week{text-align:center;flex:1}.meso-week-num{margin-bottom:4px;font-size:12px;font-weight:600}.meso-week-vol{justify-content:center;align-items:flex-end;height:60px;margin-bottom:4px;display:flex}.meso-week-bar{background:var(--primary);border-radius:3px 3px 0 0;width:100%;max-width:32px;transition:height .3s}.meso-week.deload .meso-week-bar{background:var(--success)}.meso-week-rpe{color:var(--text-secondary);font-size:10px}.meso-week-vol-label{color:var(--text-muted);font-size:10px}.analytics-exercise-layout{grid-template-columns:240px 1fr;gap:24px;min-height:500px;display:grid}.analytics-exercise-list{flex-direction:column;gap:8px;display:flex}.analytics-exercise-scroll{flex-direction:column;flex:1;gap:2px;max-height:calc(100vh - 240px);display:flex;overflow-y:auto}.analytics-exercise-item{text-align:left;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;padding:8px 12px;font-size:13px;overflow:hidden}.analytics-exercise-item:hover{color:var(--text);background:var(--card)}.analytics-exercise-item.active{color:var(--primary);background:var(--primary-dim)}.analytics-exercise-charts{min-width:0}.mobile-wrapper-outer{justify-content:center;padding:24px;display:flex}.mobile-wrapper{background:var(--bg);border:2px solid var(--border);border-radius:40px;width:390px;min-height:calc(100vh - 104px);padding:12px;position:relative;overflow-y:auto}.mobile-notch{background:var(--border);border-radius:3px;width:120px;height:6px;margin:4px auto 16px}.mobile-mode .builder-layout{flex-direction:column;height:auto;display:flex}.mobile-mode .builder-left,.mobile-mode .builder-right{display:none}.mobile-mode .builder-center{width:100%}.mobile-mode .grid-2,.mobile-mode .grid-3,.mobile-mode .grid-4,.mobile-mode .analytics-exercise-layout{grid-template-columns:1fr}.mobile-mode .analytics-exercise-scroll{max-height:200px}@media (width<=1024px){.builder-layout{grid-template-columns:260px 1fr}.builder-right{display:none}}@media (width<=768px){.builder-layout{grid-template-columns:1fr;height:auto}.builder-left{border-right:none;border-bottom:1px solid var(--border);max-height:300px}.nav-links{display:none}.analytics-exercise-layout{grid-template-columns:1fr}}
