@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap);:root{--primary:#4f46e5;--primary-hover:#4338ca;--primary-light:#818cf8;--primary-soft:#e0e7ff;--secondary:#0ea5e9;--secondary-hover:#0284c7;--accent:#f59e0b;--bg-body:#f8fafc;--bg-surface:#fff;--bg-surface-alt:#f1f5f9;--text-main:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--text-inverse:#fff;--border:#e2e8f0;--border-focus:#4f46e5;--success:#10b981;--success-bg:#d1fae5;--warning:#f59e0b;--warning-bg:#fef3c7;--danger:#ef4444;--danger-bg:#fee2e2;--info:#3b82f6;--info-bg:#dbeafe;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--shadow-inner:inset 0 2px 4px 0 #0000000d;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-normal:300ms cubic-bezier(0.4,0,0.2,1);--transition-slow:500ms cubic-bezier(0.4,0,0.2,1)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px;scroll-behavior:smooth}@media (max-width:480px){html{font-size:15px}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;background-color:var(--bg-body);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}body,h1,h2,h3,h4,h5,h6{color:#0f172a;color:var(--text-main)}h1,h2,h3,h4,h5,h6{font-weight:700;letter-spacing:-.025em;line-height:1.2;margin-bottom:1rem}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{color:#475569;color:var(--text-secondary);margin-bottom:1rem}button{font-family:inherit}.btn{align-items:center;border:1px solid #0000;border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;overflow:hidden;padding:.75rem 1.5rem;position:relative;text-decoration:none;transition:.15s cubic-bezier(.4,0,.2,1);transition:var(--transition-fast)}.btn:active{transform:scale(.98)}.btn-primary{background-color:#4f46e5;background-color:var(--primary);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--shadow-sm);color:#fff}.btn-primary:hover{background-color:#4338ca;background-color:var(--primary-hover);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md)}.btn-secondary{background-color:#fff;background-color:var(--bg-surface);border-color:#e2e8f0;border-color:var(--border);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--shadow-sm);color:#0f172a;color:var(--text-main)}.btn-secondary:hover{background-color:#f1f5f9;background-color:var(--bg-surface-alt);border-color:#94a3b8;border-color:var(--text-tertiary)}.btn-danger{background-color:#ef4444;background-color:var(--danger);color:#fff}.btn-danger:hover{background-color:#dc2626}.btn-success{background-color:#10b981;background-color:var(--success);color:#fff}.btn-success:hover{background-color:#059669}.btn-ghost{background-color:initial;color:#475569;color:var(--text-secondary)}.btn-ghost:hover{background-color:#f1f5f9;background-color:var(--bg-surface-alt);color:#0f172a;color:var(--text-main)}.btn-sm{font-size:.875rem;padding:.5rem 1rem}.btn-lg{font-size:1.125rem}input,select,textarea{background-clip:padding-box;background-color:#fff;background-color:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.5rem;border-radius:var(--radius-md);color:#0f172a;color:var(--text-main);display:block;font-family:inherit;font-size:.95rem;line-height:1.5;padding:.75rem 1rem;transition:.15s cubic-bezier(.4,0,.2,1);transition:var(--transition-fast);width:100%}input:focus,select:focus,textarea:focus{border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 3px #e0e7ff;box-shadow:0 0 0 3px var(--primary-soft);outline:0}input::placeholder,textarea::placeholder{color:#94a3b8;color:var(--text-tertiary)}label{color:#0f172a;color:var(--text-main);display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.card{background-color:#fff;background-color:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--shadow-sm);padding:1.5rem;transition:.3s cubic-bezier(.4,0,.2,1);transition:var(--transition-normal)}.card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.container{margin-left:auto;margin-right:auto;max-width:1280px;padding-left:1.5rem;padding-right:1.5rem;width:100%}.grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:#475569;color:var(--text-secondary)}.font-bold{font-weight:700}.font-medium{font-weight:500}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.badge{border-radius:9999px;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.badge-primary{background-color:#e0e7ff;background-color:var(--primary-soft);color:#4338ca;color:var(--primary-hover)}.badge-success{background-color:#d1fae5;background-color:var(--success-bg);color:#059669}.badge-warning{background-color:#fef3c7;background-color:var(--warning-bg);color:#d97706}.badge-danger{background-color:#fee2e2;background-color:var(--danger-bg);color:#dc2626}.modal-overlay{background-color:#0f172a99;z-index:50}.modal-content{background-color:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;box-shadow:var(--shadow-xl);overflow-y:auto;width:90%}.modal-header{border-bottom:1px solid #e2e8f0;padding:1.5rem}.modal-footer{background-color:#f1f5f9;border-bottom-left-radius:1rem;border-bottom-left-radius:var(--radius-xl);border-bottom-right-radius:1rem;border-bottom-right-radius:var(--radius-xl);border-top:1px solid #e2e8f0;padding:1.5rem}.glass{background:#ffffffb3;border:1px solid #ffffff4d}.glass,.glass-dark{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.glass-dark{background:#0f172ab3;border:1px solid #ffffff1a;color:#fff}@media (max-width:768px){.modal-content{border-radius:.75rem;border-radius:var(--radius-lg);max-height:95vh;width:95%}.modal-body,.modal-footer,.modal-header{padding:1.25rem}.modal-footer{flex-direction:column;gap:.75rem}.modal-footer .btn{width:100%}.modal-close{min-height:44px;min-width:44px}}@media (max-width:480px){.modal-content{animation:slideUp .3s cubic-bezier(.16,1,.3,1);border-radius:0;max-height:100vh;max-height:100%;width:100%}.modal-header{gap:.5rem;padding:1rem}.modal-header h3{font-size:1.2rem}.modal-body,.modal-footer{padding:1rem}.modal-overlay{align-items:flex-end}}@media (max-width:768px){html{font-size:14px}.container{padding-left:1rem;padding-right:1rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}input,select,textarea{font-size:16px;min-height:44px;padding:.85rem}.btn{min-height:44px;padding:.7rem 1.2rem}label{font-size:.85rem;margin-bottom:.4rem}}@media (max-width:480px){html{font-size:13px}body{line-height:1.6}.container{padding-left:.75rem;padding-right:.75rem}input,select,textarea{font-size:16px;padding:.8rem}.btn,input,select,textarea{border-radius:.5rem;border-radius:var(--radius-md);min-height:44px}.btn{font-size:.9rem;padding:.65rem 1rem}h1{font-size:1.8rem}h2{font-size:1.4rem}h3{font-size:1.1rem}h4{font-size:1rem}label{font-size:.8rem;margin-bottom:.35rem}.card{border-radius:.5rem;border-radius:var(--radius-md);padding:1rem}}.app{background-color:var(--bg-body);display:flex;flex-direction:column;min-height:100vh}.tabs-nav{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#fffc;border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);justify-content:center;padding:1rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.tab-btn,.tabs-nav{display:flex;gap:.5rem}.tab-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;min-height:44px;padding:.6rem 1.25rem;transition:all .2s ease}.tab-btn:hover{background-color:var(--bg-surface-alt);color:var(--text-main)}.tab-btn.active{background-color:var(--primary);box-shadow:var(--shadow-md);color:#fff;font-weight:600}.container{animation:fadeIn .4s ease-out;flex:1 1;padding-bottom:3rem;padding-top:2rem}.loading{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;font-weight:500;justify-content:center;padding:4rem 0}.loading:after{animation:spin .8s linear infinite;border:3px solid var(--border);border-radius:50%;border-top-color:var(--primary);content:"";height:2rem;margin-top:1rem;width:2rem}.error{animation:slideDown .3s ease-out;background-color:var(--danger-bg);border:1px solid #ef444433;border-radius:var(--radius-md);color:var(--danger);font-weight:500;margin:1rem auto;max-width:600px;padding:1rem;text-align:center}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.tabs-nav{-webkit-overflow-scrolling:touch;justify-content:flex-start;overflow-x:auto;padding:.75rem 1rem;scrollbar-width:none}.tabs-nav::-webkit-scrollbar{display:none}.tab-btn{flex-shrink:0;font-size:.85rem;min-height:44px;padding:.55rem .95rem;white-space:nowrap}}@media (max-width:600px){.tabs-nav{gap:.25rem;padding:.5rem .75rem}.tab-btn{font-size:.8rem;min-height:44px;padding:.5rem .8rem}}@media (max-width:480px){.tabs-nav{gap:.25rem;padding:.5rem}.tab-btn{font-size:.75rem;gap:.25rem;min-height:44px;padding:.5rem .75rem}.container{padding-bottom:2rem;padding-top:1.5rem}}@media (max-width:360px){.tab-btn{font-size:.7rem;padding:.5rem .65rem}}@media (max-width:320px){.tabs-nav{padding:.4rem .25rem}.tab-btn{font-size:.65rem;min-height:42px;padding:.4rem .5rem}}.header{background-color:var(--bg-surface);border-bottom:1px solid var(--border);padding:1.5rem 0;position:relative}.header-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:0 1.5rem}.logo{display:flex;flex-direction:column;gap:.25rem}.logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary) 0,var(--primary-hover) 100%);-webkit-background-clip:text;color:var(--text-main);display:inline-block;font-size:1.75rem;font-weight:800;letter-spacing:-.03em;margin:0}.logo p{color:var(--text-secondary);font-size:.95rem;font-weight:500;margin:0}@media (max-width:768px){.header{padding:1rem 0}.header-container{justify-content:center;padding:0 1rem;text-align:center}.logo h1{font-size:1.5rem}.logo p{font-size:.85rem}}.workout-calendar{padding:0}.calendar-header{align-items:center;background:linear-gradient(135deg,var(--bg-surface) 0,var(--bg-surface-alt) 100%);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.calendar-header h2{color:var(--text-main);font-size:1.5rem;font-weight:800;letter-spacing:-.03em;margin:0}.calendar-nav-btn{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:var(--transition-fast)}.calendar-nav-btn:hover{background:var(--bg-surface-alt);border-color:var(--primary-light);color:var(--primary);transform:translateY(-1px)}.template-actions{display:flex;gap:1rem;justify-content:flex-end;margin-bottom:2rem}.btn-template-apply,.btn-template-save{align-items:center;border:none;border-radius:var(--radius-full);cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.6rem 1.2rem;transition:var(--transition-normal)}.btn-template-save{background:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);color:var(--text-secondary)}.btn-template-save:hover{background:var(--bg-surface-alt);color:var(--text-main);transform:translateY(-2px)}.btn-template-apply{background:linear-gradient(135deg,var(--primary) 0,var(--primary-hover) 100%);box-shadow:0 4px 12px #4f46e54d;color:#fff}.btn-template-apply:hover{box-shadow:0 6px 16px #4f46e566;transform:translateY(-2px)}.calendar-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.day-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;min-height:220px;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.day-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.day-card:not(.has-workout){background:var(--bg-surface);border-style:dashed;opacity:.8}.day-card:not(.has-workout):hover{background:var(--bg-surface-alt);border-style:solid;opacity:1}.day-card.has-workout{background:linear-gradient(to bottom right,#fff,#f8fafc);border:1px solid var(--border)}.day-card.has-workout:before{background:var(--primary);content:"";height:100%;left:0;opacity:.5;position:absolute;top:0;transition:opacity .3s;width:4px}.day-card.has-workout:hover:before{opacity:1}.day-card.completed-session{background:linear-gradient(to bottom right,#f0fdf4,#fff);border-color:var(--success-bg)}.day-card.completed-session:before{background:var(--success)}.day-header{align-items:baseline;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:.75rem}.day-card h3{color:var(--text-main);font-size:1.2rem;font-weight:700;margin:0}.day-date{color:var(--text-tertiary);font-size:.85rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.workout-info{display:flex;flex:1 1;flex-direction:column;gap:.75rem}.workout-status-bar{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.btn-validate-mini{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;box-shadow:var(--shadow-sm);color:var(--text-tertiary);cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:32px}.btn-validate-mini:hover{box-shadow:0 0 0 3px var(--success-bg);transform:scale(1.1)}.btn-validate-mini.active,.btn-validate-mini:hover{background:var(--success);border-color:var(--success);color:#fff}.btn-validate-mini.active{box-shadow:0 4px 10px #10b9814d}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:.35rem .75rem;text-transform:uppercase}.badge-primary{background:var(--primary-soft);color:var(--primary)}.badge-success{background:var(--success-bg);color:var(--success)}.exercises-list{display:flex;flex-direction:column;gap:.5rem}.exercise-item{background:#ffffff80;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;justify-content:space-between;padding:.4rem .6rem;transition:background .2s}.day-card:hover .exercise-item{background:#fffc}.exercise-name{font-weight:500;max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exercise-sets{background:var(--bg-surface-alt);border-radius:4px;font-family:monospace;padding:.1rem .4rem}.exercise-sets,.more-exercises{color:var(--text-tertiary);font-size:.8rem}.more-exercises{font-weight:500;margin-top:.5rem;text-align:center}.no-workout{align-items:center;color:var(--text-tertiary);display:flex;flex:1 1;flex-direction:column;gap:1rem;justify-content:center;opacity:.6;transition:opacity .3s}.day-card:hover .no-workout{opacity:1}.no-workout p{font-size:.9rem;font-weight:500;margin:0}.btn-add-mini{align-items:center;background:var(--bg-surface-alt);border:none;border-radius:50%;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;transition:all .2s;width:40px}.day-card:hover .btn-add-mini{background:var(--primary);box-shadow:var(--shadow-md);color:#fff;transform:scale(1.1)}@media (max-width:768px){.calendar-header{flex-direction:column;gap:1rem;text-align:center}.template-actions{flex-direction:column;gap:.75rem}.btn-template-apply,.btn-template-save{justify-content:center;width:100%}.calendar-grid{grid-template-columns:1fr}}.workout-tracker-overlay{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1010}.workout-tracker{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:100%;z-index:1011}.tracker-header{align-items:center;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:16px 16px 0 0;color:#fff;display:flex;justify-content:space-between;padding:max(1.5rem,env(safe-area-inset-top,0)) 1.5rem 1.5rem}.tracker-header h2{font-size:1.5rem;margin:0}.close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;transition:background .3s ease;width:40px}.close-btn:hover{background:#ffffff4d}.timer-section{background:linear-gradient(135deg,#ef444414,#0ea5e914);border-bottom:2px solid var(--border);padding:2rem 1.5rem;text-align:center}.timer-display{margin-bottom:1.5rem}.timer-time{color:var(--primary);font-family:Courier New,monospace;font-size:3.5rem;font-weight:700;letter-spacing:2px}.timer-label{color:#666}.timer-controls{flex-wrap:wrap;justify-content:center}.btn-lg{border-radius:8px;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.btn-lg:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn-lg.resumed{animation:pulse .5s ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.progress-bar-container{border-bottom:1px solid var(--border);padding:1rem 1.5rem}.progress-info{color:#666;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:.5rem}.progress-bar{background:#ddd}.progress-fill{background:linear-gradient(90deg,var(--primary),var(--secondary))}.current-exercise{border-bottom:2px solid var(--border);padding:2rem 1.5rem}.exercise-header{margin-bottom:1.5rem}.exercise-name{color:var(--dark);flex:1 1;font-size:1.4rem;margin:0;min-width:0;text-transform:capitalize}.btn-exercise-demo{align-items:center;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border:none;border-radius:.5rem;box-shadow:0 4px 12px #8b5cf64d;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;min-height:44px;padding:.65rem 1.2rem;transition:all .2s ease;white-space:nowrap}.btn-exercise-demo:hover{background:linear-gradient(135deg,#7c3aed,#5b21b6);box-shadow:0 6px 16px #8b5cf666;transform:translateY(-2px)}.btn-exercise-demo:active{transform:translateY(0)}.exercise-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:1rem}.detail-box{background:linear-gradient(135deg,#ef444414,#0ea5e914);border:2px solid var(--border);border-radius:8px;padding:1rem;text-align:center}.detail-label{color:#999;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.detail-value{color:var(--primary);font-size:1.5rem;font-weight:700}.reps-counter-section{border-bottom:2px solid var(--border);padding:2rem 1.5rem;text-align:center}.reps-counter-section h4{color:var(--dark);margin:0 0 1.5rem}.reps-counter{gap:2rem;margin-bottom:1.5rem}.counter-btn,.reps-counter{align-items:center;display:flex;justify-content:center}.counter-btn{background:var(--primary);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:2rem;font-weight:700;height:60px;min-height:60px;min-width:60px;transition:all .3s ease;width:60px}.counter-btn:hover:not(:disabled){box-shadow:0 4px 12px #ef44444d;transform:scale(1.1)}.counter-btn:disabled{cursor:not-allowed;opacity:.5}.counter-display{color:var(--primary);font-family:Courier New,monospace;font-size:4rem;font-weight:700;min-width:120px}.counter-actions{display:flex;gap:1rem;justify-content:center}.exercise-navigation{align-items:center;border-bottom:2px solid var(--border);display:flex;gap:1rem;padding:1.5rem}.exercise-list{flex:1 1;gap:.5rem;overflow-x:auto;padding:.5rem 0}.exercise-item,.exercise-list{display:flex;justify-content:center}.exercise-item{align-items:center;background:#fff;border:2px solid #ddd;border-radius:50%;color:#666;cursor:pointer;flex:0 0 auto;font-weight:600;height:44px;min-height:44px;min-width:44px;position:relative;transition:all .3s ease;width:44px}.exercise-item:hover{border-color:var(--primary);color:var(--primary)}.exercise-item.active{background:var(--primary);border-color:var(--primary);box-shadow:0 4px 12px #ef44444d;color:#fff}.exercise-item.completed{background:var(--secondary);border-color:var(--secondary);color:#fff}.exercise-item.completed .checkmark{font-size:.9rem;position:absolute}.exercise-index{display:block}.exercise-item.completed .exercise-index{display:none}.exercise-notes{background:#f9731614;border-left:4px solid var(--accent);color:#666;font-style:italic;padding:1rem 1.5rem}.tracker-summary{background:#f9f9f9;border-radius:0 0 16px 16px;display:flex;gap:1rem;justify-content:space-around;padding:1.5rem}.summary-stat{align-items:center;display:flex;flex-direction:column;text-align:center}.summary-stat .label{color:#999;font-size:.85rem;margin-bottom:.5rem}.summary-stat .value{color:var(--primary);font-size:1.3rem;font-weight:700}@media (max-width:600px){.workout-tracker{border-radius:12px}.timer-time{font-size:2.5rem}.counter-display{font-size:3rem}.counter-btn{font-size:1.5rem;height:54px;min-height:54px;min-width:54px;width:54px}.exercise-header{align-items:flex-start;flex-direction:column}.btn-exercise-demo{padding:.7rem 1rem;width:100%}.exercise-details{grid-template-columns:1fr}.exercise-navigation{flex-direction:column}.exercise-list{width:100%}.btn{flex:1 1}.tracker-summary{flex-direction:column}}@media (max-width:400px){.timer-time{font-size:2rem}.timer-controls{flex-direction:column}.timer-controls .btn{width:100%}.counter-display{font-size:2.5rem}.counter-btn{font-size:1.2rem;height:50px;min-height:50px;min-width:50px;width:50px}.reps-counter{gap:1rem}}@media (max-width:360px){.timer-time{font-size:1.8rem}.counter-btn{font-size:1.1rem;height:48px;min-height:48px;min-width:48px;width:48px}.counter-display{font-size:2.2rem}.current-exercise{padding:1rem}.exercise-details{gap:.5rem}.detail-box{font-size:.85rem;padding:.5rem}}@media (max-width:320px){.timer-time{font-size:1.5rem}.counter-btn{font-size:1rem;height:48px;min-height:48px;min-width:48px;width:48px}.counter-display{font-size:2rem}.reps-counter-section h4{font-size:1rem}.tracker-summary{gap:.75rem}.summary-stat{padding:.75rem}}.exercise-demo-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:2000}.exercise-demo-modal{background:#fff;border-radius:1rem;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow-y:auto;width:100%;z-index:2001}.exercise-demo-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;gap:1rem;justify-content:space-between;padding:1.5rem}.exercise-demo-title{align-items:center;display:flex;flex:1 1;gap:.75rem;min-width:0}.exercise-demo-title h2{color:#333;font-size:1.5rem;margin:0;word-break:break-word}.exercise-demo-muscle{background:#4caf50;border-radius:.5rem;color:#fff;font-size:.85rem;font-weight:600;padding:.4rem .8rem;white-space:nowrap}.exercise-demo-close{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;flex-shrink:0;font-size:1.5rem;justify-content:center;min-height:44px;min-width:44px;padding:0;transition:color .2s}.exercise-demo-close:hover{color:#333}.exercise-demo-content{display:flex;flex:1 1;gap:1.5rem;min-height:300px;padding:1.5rem}.exercise-demo-image-container{align-items:center;background:#f5f5f5;border-radius:.5rem;display:flex;flex:1 1;justify-content:center;min-width:0;overflow:hidden}.exercise-demo-image{height:100%;max-height:100%;max-width:100%;object-fit:contain;width:100%}.exercise-demo-no-image{color:#999;font-size:1rem;text-align:center}.exercise-demo-info{display:flex;flex:1 1;flex-direction:column;gap:1rem;justify-content:flex-start;min-width:200px}.exercise-demo-detail{display:flex;flex-direction:column;gap:.25rem}.exercise-demo-label{color:#666;font-size:.9rem;font-weight:600}.exercise-demo-value{color:#333;font-size:1rem;text-transform:capitalize}.exercise-demo-controls{border-bottom:1px solid #e0e0e0;border-top:1px solid #e0e0e0;display:flex;gap:.75rem;padding:1rem 1.5rem}.exercise-demo-view-btn{background:#f0f0f0;border:2px solid #ddd;border-radius:.5rem;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;min-height:44px;padding:.7rem 1rem;transition:all .2s}.exercise-demo-view-btn:hover{background:#e8e8e8;border-color:#999}.exercise-demo-view-btn.active{background:#4caf50;border-color:#4caf50;color:#fff}.exercise-demo-footer{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.exercise-demo-source{color:#999;font-size:.85rem;margin:0}.exercise-demo-source a{color:#4caf50;font-weight:600;text-decoration:none}.exercise-demo-source a:hover{text-decoration:underline}.exercise-demo-close-btn{background:#4caf50;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;min-height:44px;padding:.7rem 1.5rem;transition:background .2s}.exercise-demo-close-btn:hover{background:#45a049}@media (max-width:768px){.exercise-demo-modal{max-height:95vh;max-width:95%}.exercise-demo-header{padding:1rem}.exercise-demo-title h2{font-size:1.25rem}.exercise-demo-content{flex-direction:column;gap:1rem;min-height:auto;padding:1rem}.exercise-demo-image-container{min-height:250px;width:100%}.exercise-demo-info{min-width:auto}.exercise-demo-controls{flex-wrap:nowrap}.exercise-demo-footer{flex-direction:column-reverse;justify-content:center;text-align:center}.exercise-demo-source{text-align:center;width:100%}}@media (max-width:480px){.exercise-demo-overlay{padding:.5rem}.exercise-demo-modal{border-radius:.75rem}.exercise-demo-header{align-items:flex-start;flex-direction:column;padding:.75rem}.exercise-demo-title{width:100%}.exercise-demo-close{position:absolute;right:.5rem;top:.5rem}.exercise-demo-content{padding:.75rem}.exercise-demo-title h2{font-size:1.1rem}.exercise-demo-muscle{font-size:.75rem;padding:.3rem .6rem}.exercise-demo-image-container{min-height:200px}.exercise-demo-detail{gap:.2rem}.exercise-demo-label{font-size:.8rem}.exercise-demo-value{font-size:.9rem}.exercise-demo-view-btn{font-size:.85rem;min-height:40px;padding:.6rem .75rem}.exercise-demo-close-btn{font-size:.85rem;min-height:40px;padding:.6rem 1rem;width:100%}}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0f172abf;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:900}.modal-content{animation:slideUp .3s cubic-bezier(.16,1,.3,1);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;position:relative;width:100%;z-index:901}.modal-content,.modal-header{background-color:var(--bg-surface);display:flex}.modal-header{align-items:center;border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;padding:1.25rem 1.5rem;z-index:10}.modal-header h2{color:var(--primary);font-size:1.5rem;margin:0}.modal-close{align-items:center;background:#0000;border:none;border-radius:50%;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;padding:.5rem;transition:var(--transition-fast);width:40px}.modal-close:hover{background-color:var(--bg-surface-alt);color:var(--text-main)}.modal-body{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto}.modal-footer{background-color:var(--bg-surface-alt);border-top:1px solid var(--border);display:flex;flex-shrink:0;gap:1rem;justify-content:flex-end;padding:1.25rem 1.5rem}.add-exercise-form{border-bottom:1px solid var(--border);margin-bottom:2rem;padding-bottom:1.5rem}.add-exercise-form h3{color:var(--text-main);font-size:1.1rem;margin-bottom:1rem}.form-row{grid-gap:.75rem;align-items:center;gap:.75rem;grid-template-columns:2fr 1fr 1fr 1fr auto}.form-control{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);font-size:.95rem;padding:.75rem;transition:var(--transition-fast);width:100%}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.exercises-in-workout h3{color:var(--text-main);font-size:1.1rem;margin-bottom:1rem}.exercises-table{display:flex;flex-direction:column;gap:.75rem}.exercise-row{grid-gap:1rem;align-items:center;background:var(--bg-surface-alt);border-left:4px solid var(--primary);border-radius:var(--radius-md);display:grid;gap:1rem;grid-template-columns:auto 1fr auto auto auto;padding:1rem;transition:var(--transition-fast)}.exercise-order-buttons{display:flex;flex-direction:column;gap:.25rem}.btn-move{background:var(--primary);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;min-width:35px;padding:.35rem .5rem;transition:var(--transition-fast)}.btn-move:hover:not(:disabled){background:var(--primary-hover);transform:scale(1.05)}.btn-move:disabled{background:var(--border);color:var(--text-tertiary);cursor:not-allowed;opacity:.5}.exercise-details strong{color:var(--text-main);display:block;margin-bottom:.25rem}.exercise-values{align-items:center;color:var(--text-secondary);display:flex;font-size:.9rem;gap:.5rem}.input-small{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;padding:.4rem;text-align:center;width:60px}.checkbox{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;-webkit-user-select:none;user-select:none;white-space:nowrap}.checkbox input{accent-color:var(--success);cursor:pointer;height:18px;width:18px}.workout-duration-section{background:linear-gradient(to right,var(--bg-surface-alt),var(--bg-surface));border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1.5rem;padding:1rem}.duration-display h3{color:var(--text-tertiary);font-size:.9rem;letter-spacing:.05em;margin:0 0 .75rem;text-transform:uppercase}.duration-info{align-items:center;display:flex;justify-content:space-between}.duration-value{color:var(--primary);font-size:1.25rem;font-weight:700}.start-workout-section{background:linear-gradient(135deg,#22c55e14,#0ea5e914);border-bottom:2px solid #22c55e;border-radius:8px;margin-bottom:1rem;padding:1.5rem}.btn-lg-full{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease;width:100%}.btn-lg-full:hover{box-shadow:0 6px 20px #22c55e4d;transform:translateY(-2px)}.suggestion-alert{align-items:center;background:#fffbeb;border:1px solid #fcd34d;border-radius:var(--radius-md);display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding:.75rem}.suggestion-content{align-items:center;color:#92400e;display:flex;font-size:.9rem;gap:.75rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-bottom-left-radius:0;border-bottom-right-radius:0;max-height:95vh;max-width:100%;width:100%}.form-row{grid-template-columns:1fr 1fr}.form-row select{grid-column:1/-1}.form-row button{grid-column:1/-1;margin-top:.5rem}.exercise-row{gap:.5rem;grid-template-columns:auto 1fr auto auto;padding:.75rem}.exercise-order-buttons{display:flex;flex-direction:row;gap:.25rem}.btn-move{font-size:.75rem;min-width:28px;padding:.3rem .4rem}.exercise-details{grid-column:auto;margin-bottom:0}.exercise-row button,.exercise-values{grid-column:auto}.checkbox{display:none;display:flex;grid-column:2/3;grid-row:1}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}@media (max-width:480px){.form-row{grid-template-columns:1fr}.form-row button,.form-row select{grid-column:auto}.btn-move{font-size:.7rem;min-height:44px;min-width:24px;padding:.25rem .3rem}.form-control{font-size:16px;padding:.6rem}}.exercise-list{padding:0}.exercise-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.exercise-header h2{color:var(--text-main);margin:0}.exercise-form{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:1.5rem}.exercise-form h3{color:var(--primary);margin-bottom:1.5rem}.form-group input,.form-group select,.form-group textarea{transition:var(--transition-fast)}.exercise-filters{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:1fr auto auto;margin-bottom:2rem}.filter-select,.search-input{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);font-size:.95rem;padding:.75rem;transition:var(--transition-fast)}.filter-select:focus,.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.result-count{color:var(--text-tertiary);font-size:.9rem;white-space:nowrap}.exercises-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.exercise-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem;transition:var(--transition-normal)}.exercise-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{align-items:flex-start;border-bottom:1px solid var(--border);display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.card-header h3{color:var(--text-main);flex-grow:1;font-size:1.25rem;margin:0}.exercise-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:1rem}.exercise-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.exercise-actions{display:flex;gap:.75rem;margin-top:auto}.empty-state{background-color:var(--bg-surface-alt);border:1px dashed var(--border);border-radius:var(--radius-lg)}@media (max-width:768px){.exercise-header{align-items:stretch;flex-direction:column}.exercise-filters,.exercises-grid{grid-template-columns:1fr}.exercise-actions,.form-buttons{flex-direction:column}}.photo-carousel-container{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:2rem;overflow:hidden;transition:var(--transition-normal)}.carousel-header{align-items:center;background:var(--bg-surface-alt);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem}.carousel-title{align-items:center;color:var(--text-main);display:flex;font-size:1.1rem;font-weight:600;gap:1rem;margin:0}.exercise-count{background:var(--secondary)}.exercise-count,.workout-duration{border-radius:var(--radius-full);color:#fff;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.workout-duration{background:var(--accent)}.photo-counter{background:var(--primary-soft);border-radius:var(--radius-full);color:var(--primary);font-size:.95rem;font-weight:600;padding:.5rem 1rem}.carousel-main,.carousel-wrapper{position:relative}.carousel-main{aspect-ratio:4/5;background:var(--bg-surface-alt);overflow:hidden;width:100%}.carousel-image{display:block;height:100%;object-fit:cover;width:100%}.carousel-placeholder{background:var(--bg-surface-alt);color:var(--text-tertiary);height:100%;width:100%}.carousel-btn,.carousel-placeholder{align-items:center;display:flex;justify-content:center}.carousel-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.5rem;height:48px;position:absolute;top:50%;transform:translateY(-50%);transition:var(--transition-fast);width:48px;z-index:10}.carousel-btn:hover{background:#000000b3;transform:translateY(-50%) scale(1.05)}.carousel-btn-prev{left:1rem}.carousel-btn-next{right:1rem}.carousel-thumbnails{background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;gap:.75rem;overflow-x:auto;padding:1rem;scroll-behavior:smooth}.carousel-thumbnail{background:var(--bg-surface-alt);border:2px solid #0000;border-radius:var(--radius-md);cursor:pointer;flex:0 0 80px;height:80px;overflow:hidden;padding:0;transition:var(--transition-fast);width:80px}.carousel-thumbnail img{display:block;height:100%;object-fit:cover;width:100%}.carousel-thumbnail:hover{border-color:var(--secondary);transform:scale(1.05)}.carousel-thumbnail.active{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-soft)}.carousel-info{align-items:flex-start;background:var(--bg-surface);display:flex;gap:1rem;justify-content:space-between;padding:1.5rem}.photo-details{flex:1 1}.photo-details h4{color:var(--text-main);font-size:1.1rem;font-weight:600;margin:0 0 .75rem}.photo-meta{flex-wrap:wrap;margin-bottom:.75rem}.photo-meta .date,.photo-meta .weight{align-items:center;display:flex}.photo-meta .weight{background:var(--primary-soft);border-radius:var(--radius-full);color:var(--primary-hover);font-size:.85rem;font-weight:600;padding:.25rem .75rem}.notes{font-style:italic}@media (max-width:768px){.carousel-header{flex-direction:column;gap:1rem;padding:1rem}.carousel-title{flex-direction:column;font-size:1rem;gap:.5rem}.exercise-count{width:-webkit-fit-content;width:fit-content}.carousel-btn{font-size:1.25rem;height:40px;width:40px}.carousel-btn-prev{left:.5rem}.carousel-btn-next{right:.5rem}.carousel-thumbnail{flex:0 0 70px;height:70px;width:70px}.carousel-info{flex-direction:column;padding:1rem}.photo-meta{font-size:.85rem}}@media (max-width:480px){.carousel-main{aspect-ratio:1/1.2}.carousel-btn{font-size:1.1rem;height:44px;min-height:44px;min-width:44px;width:44px}.carousel-header{padding:.75rem}.carousel-title{font-size:.9rem}.photo-counter{font-size:.85rem;padding:.35rem .75rem}.carousel-thumbnails{gap:.5rem;padding:.75rem}.carousel-thumbnail{flex:0 0 65px;height:65px;width:65px}.carousel-info{padding:.75rem}.photo-details h4{font-size:1rem}.notes{font-size:.85rem}}.progress-photos{padding:0}.photos-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.photos-header h2{color:var(--text-main);margin:0}.photo-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:1.5rem}.photo-form h3{color:var(--primary)}.photo-form h3,.photo-upload-area{margin-bottom:1.5rem}.upload-label{background-color:var(--bg-surface-alt);border:2px dashed var(--primary-light);border-radius:var(--radius-md);cursor:pointer;display:block;overflow:hidden;transition:var(--transition-fast)}.upload-label:hover{background-color:var(--primary-soft);border-color:var(--primary)}.upload-placeholder{padding:3rem 2rem;text-align:center}.upload-icon{color:var(--primary);font-size:3rem;margin-bottom:1rem}.upload-placeholder p{color:var(--text-main);font-weight:500;margin-bottom:.5rem}.upload-placeholder small{color:var(--text-tertiary);font-size:.9rem}.photo-previews-grid{grid-gap:1rem;background:var(--bg-surface-alt);border-radius:var(--radius-md);display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));margin-bottom:1.5rem;padding:1rem}.preview-item{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;position:relative;transition:var(--transition-normal)}.preview-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.preview-thumbnail{display:block;height:120px;object-fit:cover;width:100%}.preview-item .remove-btn{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;opacity:0;padding:0;position:absolute;right:.5rem;top:.5rem;transition:opacity .2s ease;width:28px}.preview-item:hover .remove-btn{opacity:1}.preview-size{background:#000000b3;border-radius:4px;bottom:.5rem;color:#fff;font-size:.75rem;font-weight:600;left:.5rem;padding:.25rem .5rem;position:absolute}.upload-progress{background:var(--bg-surface-alt);border-left:3px solid var(--primary);border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1rem}.progress-bar{background:var(--border);border-radius:4px;height:8px;margin-bottom:.5rem}.progress-fill{transition:width .3s ease}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-main);display:block;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);font-family:inherit;font-size:.95rem;padding:.75rem;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.form-buttons{display:flex;gap:1rem;justify-content:flex-end}.photos-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.photo-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition-normal)}.photo-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-4px)}.photo-image-container{background:var(--bg-surface-alt);height:300px;overflow:hidden;position:relative;width:100%}.photo-image{height:100%;object-fit:cover;width:100%}.photo-placeholder{align-items:center;background:var(--bg-surface-alt);color:var(--text-tertiary);display:flex;height:100%;justify-content:center;width:100%}.emoji-big{font-size:3rem}.photo-info{background:var(--bg-surface);padding:1.5rem}.photo-info h4{color:var(--text-main);font-size:1.1rem;font-weight:600;margin:0 0 .75rem}.photo-meta{color:var(--text-secondary);display:flex;font-size:.9rem;gap:1rem;margin-bottom:1rem}.date,.weight{align-items:center;display:flex}.weight{background:var(--primary-soft);border-radius:var(--radius-full);color:var(--primary-hover);font-weight:600;padding:.25rem .75rem}.workout-info-badge{background:var(--bg-surface-alt);border-left:3px solid var(--primary);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;padding:.75rem}.workout-info-badge small{color:var(--text-main);display:block;font-size:.85rem;font-weight:600}.notes{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.photo-actions{background:var(--bg-surface-alt);border-top:1px solid var(--border);display:flex;gap:.75rem;padding:1rem}.empty-state{padding:2rem 1rem}.empty-state p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:.5rem}.photos-section{display:flex;flex-direction:column;gap:3rem}.carousel-section,.unassigned-section{display:flex;flex-direction:column;gap:1.5rem}.section-title{border-bottom:2px solid var(--primary);color:var(--text-main);font-size:1.25rem;font-weight:700;margin:0;padding-bottom:1rem}.section-header .section-title{flex:1 1;margin-bottom:0}.pagination-info{background:var(--primary-soft);border-radius:var(--radius-full);color:var(--primary-hover);font-size:.9rem;font-weight:600;padding:.5rem 1rem;white-space:nowrap}.pagination-controls{align-items:center;border-top:1px solid var(--border);display:flex;gap:1rem;justify-content:center;margin-top:2rem;padding-top:1.5rem}.page-indicator{align-items:center;display:flex;gap:.5rem}.page-number{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;height:36px;min-width:36px;padding:0 .5rem;transition:var(--transition-fast)}.page-number:hover{border-color:var(--primary);color:var(--primary)}.page-number.active{background:var(--primary);border-color:var(--primary);color:#fff}.page-number:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.photos-header{align-items:stretch;flex-direction:column}.form-row,.photos-grid{grid-template-columns:1fr}.form-buttons,.photo-actions,.section-header{flex-direction:column}.section-header{align-items:flex-start}.pagination-controls{flex-wrap:wrap;gap:.75rem}}.measurements-container{padding:0}.measurements-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.measurements-header h2{color:var(--text-main);margin:0}.btn-add-measure{background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:var(--transition-fast)}.btn-add-measure:hover{background:var(--primary-dark);transform:translateY(-2px)}.measurements-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:2rem}.summary-card{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;padding:1.25rem;text-align:center}.summary-card.highlight{background:var(--bg-surface-alt);border-color:var(--primary)}.summary-label{color:var(--text-secondary);font-size:.85rem;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.summary-value{color:var(--text-main);font-size:1.5rem;font-weight:700}.summary-value small{color:var(--text-tertiary);font-size:.9rem;font-weight:400;margin-left:.25rem}.chart-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:1.5rem}.chart-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.chart-controls h3{color:var(--text-main);font-size:1.1rem;margin:0}.metric-selector{background:var(--bg-surface-alt);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);font-size:.9rem;padding:.5rem}.chart-wrapper{height:300px;width:100%}.no-data-chart{align-items:center;color:var(--text-tertiary);display:flex;font-style:italic;height:100%;justify-content:center}.history-table-wrapper{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow-x:auto}.history-table{border-collapse:collapse;width:100%}.history-table td,.history-table th{border-bottom:1px solid var(--border);padding:1rem;text-align:left}.history-table th{background:var(--bg-surface-alt);color:var(--text-secondary);font-size:.9rem;font-weight:600}.history-table td{color:var(--text-main);font-size:.95rem}.history-table tr:last-child td{border-bottom:none}.btn-delete-mini{background:none;border:none;cursor:pointer;font-size:1rem;opacity:.6;transition:opacity .2s}.btn-delete-mini:hover{opacity:1}.measure-form{display:flex;flex-direction:column;gap:1.5rem}.form-section-title{border-bottom:1px solid var(--border);color:var(--primary);font-size:.9rem;font-weight:700;letter-spacing:.05em;margin-top:.5rem;padding-bottom:.5rem;text-transform:uppercase}.form-row.three-cols{grid-template-columns:repeat(3,1fr)}@media (max-width:768px){.form-row.three-cols{grid-template-columns:1fr}.measurements-header{align-items:stretch;flex-direction:column}.btn-add-measure{width:100%}.history-table{min-width:100%}.history-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:600px){.history-table{font-size:.85rem}.history-table td,.history-table th{padding:.75rem}}@media (max-width:480px){.history-table{border-collapse:initial;border-spacing:0;display:block;width:100%}.history-table thead{display:none}.history-table tbody,.history-table td,.history-table tr{display:block;width:100%}.history-table tr{border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1rem;overflow:hidden}.history-table td{border-bottom:none;padding:.5rem 1rem .5rem 50%;position:relative;text-align:right}.history-table td:before{color:var(--primary);content:attr(data-label);font-size:.85rem;font-weight:600;left:0;padding:.5rem 1rem;position:absolute;text-align:left;width:50%}}.progress-chart-container{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);height:300px;padding:1rem;width:100%}.chart-empty-state{align-items:center;background:var(--bg-surface-alt);border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-tertiary);display:flex;flex-direction:column;height:300px;justify-content:center;padding:2rem;text-align:center}.chart-empty-state p{color:var(--text-secondary);font-weight:500;margin-bottom:.5rem}.chart-empty-state small{font-size:.85rem}.statistics{padding:0}.statistics h2{color:var(--text-main);margin-bottom:2rem}.stats-grid{grid-gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card,.stats-grid{display:grid;gap:1.5rem}.stat-card{grid-gap:1.5rem;align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);grid-template-columns:80px 1fr;padding:2rem;transition:var(--transition-normal)}.stat-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-4px)}.stat-icon{font-size:3rem;line-height:1;text-align:center}.stat-content h3{color:var(--text-secondary);font-size:.95rem;font-weight:600;letter-spacing:.05em;margin:0 0 .5rem;text-transform:uppercase}.stat-value{color:var(--primary);font-size:2.5rem;font-weight:700;line-height:1;margin-bottom:.5rem}.stat-label{color:var(--text-tertiary);font-size:.9rem;margin:0}.personal-records{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:2rem}.personal-records h3{color:var(--text-main);margin-bottom:1.5rem}.prs-list{display:flex;flex-direction:column;gap:1rem}.pr-item{grid-gap:1.5rem;align-items:center;background:var(--bg-surface-alt);border-left:4px solid var(--primary);border-radius:var(--radius-md);display:grid;gap:1.5rem;grid-template-columns:50px 1fr 120px;padding:1.5rem;transition:var(--transition-fast)}.pr-item:hover{background:var(--bg-surface);box-shadow:var(--shadow-sm)}.pr-rank{color:var(--primary);font-size:1.5rem;font-weight:700;text-align:center}.pr-details h4{color:var(--text-main);font-size:1.1rem;margin:0 0 .5rem}.pr-reps{background:var(--secondary);border-radius:var(--radius-full);color:#fff;display:inline-block;font-size:.8rem;font-weight:600;padding:.3rem .8rem}.pr-weight{align-items:flex-end;display:flex;flex-direction:column;text-align:right}.weight-value{color:var(--primary);font-size:2rem;font-weight:700;line-height:1}.weight-unit{color:var(--text-tertiary);font-size:.9rem;margin-top:.25rem}.stats-info{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:2rem}.stats-info h3{color:var(--text-main);margin-bottom:1.5rem}.tips-list{display:flex;flex-direction:column;gap:1rem;list-style:none;margin:0;padding:0}.tips-list li{background:var(--bg-surface-alt);border-left:4px solid var(--success);border-radius:var(--radius-md);color:var(--text-secondary);line-height:1.6;padding:1rem}.empty-state{color:var(--text-tertiary);font-size:1.1rem;padding:3rem 1rem;text-align:center}@media (max-width:768px){.pr-item,.stats-grid{grid-template-columns:1fr}.pr-item{gap:1rem}.pr-rank,.pr-weight{text-align:left}.pr-weight{align-items:baseline;flex-direction:row;gap:.5rem}}.progression-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:2rem}.section-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.section-header h3{color:var(--text-main);margin:0}.exercise-selector{min-width:250px}.exercise-selector select{background-color:var(--bg-surface-alt);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);cursor:pointer;font-family:Inter,sans-serif;font-size:.95rem;padding:.75rem 1rem;transition:var(--transition-fast);width:100%}.exercise-selector select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.loading-chart{align-items:center;background:var(--bg-surface-alt);border-radius:var(--radius-lg);color:var(--text-tertiary);display:flex;height:300px;justify-content:center}@media (max-width:768px){.section-header{align-items:stretch;flex-direction:column}.exercise-selector{width:100%}}.progression-analysis{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem}.analysis-card{background:var(--bg-surface-alt);border:1px solid #0000;border-radius:var(--radius-md);display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:150px;padding:1rem}.analysis-card.positive{background:#10b9811a;border-color:#10b98133}.analysis-card.positive .analysis-value{color:var(--success)}.analysis-card.negative{background:#ef44441a;border-color:#ef444433}.analysis-card.negative .analysis-value{color:var(--danger)}.analysis-card.warning{background:#f59e0b1a;border-color:#f59e0b33;flex:2 1}.analysis-label{color:var(--text-secondary);font-size:.85rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.analysis-value{color:var(--text-main);font-size:1.5rem;font-weight:700}.analysis-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.4}.comparison-section{border-top:1px dashed var(--border);margin-top:2rem;padding-top:1.5rem}.comparison-section h4{color:var(--text-secondary);font-size:1rem;margin:0 0 1rem}.comparison-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.comparison-card{align-items:center;background:var(--bg-surface-alt);border:1px solid #0000;border-radius:var(--radius-md);display:flex;flex-direction:column;padding:1rem;text-align:center}.comparison-card.highlight{background:#4f46e50d;border-color:#4f46e533}.comp-label{color:var(--text-tertiary);font-size:.85rem;margin-bottom:.25rem;text-transform:uppercase}.comp-value{color:var(--text-main);font-size:1.4rem;font-weight:700}.comp-sub{color:var(--text-secondary);font-size:.8rem;margin-top:.25rem}.volume-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;padding:2rem}.volume-chart-container{height:300px;width:100%}.nutrition-container{padding:0}.nutrition-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.nutrition-header h2{color:var(--text-main);margin:0}.header-actions{display:flex;gap:.75rem}.date-selector{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);display:flex;gap:1rem;padding:.5rem 1rem}.date-nav-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;transition:var(--transition-fast)}.date-nav-btn:hover{color:var(--primary);transform:scale(1.1)}.current-date{min-width:150px;text-align:center;text-transform:capitalize}.btn-goals,.current-date{color:var(--text-main);font-weight:600}.btn-goals{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:.5rem;padding:.5rem 1rem;transition:var(--transition-fast)}.btn-goals:hover{background:var(--bg-surface-alt);transform:translateY(-2px)}.btn-goals.active{background:var(--primary);border-color:var(--primary);color:#fff}.macros-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.macro-card{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;padding:1.5rem;text-align:center}.macro-value{color:var(--text-main);font-size:1.75rem;font-weight:700;line-height:1.2}.macro-label{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.macro-target{color:var(--text-tertiary);font-size:.8rem;margin-bottom:1rem}.progress-bar{background:var(--bg-surface-alt);height:6px;margin-top:auto;overflow:hidden;width:100%}.progress-bar,.progress-fill{border-radius:var(--radius-full)}.progress-fill{background:var(--primary);height:100%;transition:width .5s ease-in-out}.macro-card.calories .progress-fill{background:#ef4444}.macro-card.protein .progress-fill{background:#3b82f6}.macro-card.carbs .progress-fill{background:#f59e0b}.macro-card.fats .progress-fill{background:#10b981}.meals-section{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.meal-group{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.meal-group-header{align-items:center;background:var(--bg-surface-alt);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1rem 1.5rem}.meal-group-header h3{align-items:center;color:var(--text-main);display:flex;font-size:1.1rem;gap:.5rem;margin:0}.meal-group-total{color:var(--text-secondary);font-size:.9rem;font-weight:600}.meal-list{list-style:none;margin:0;padding:0}.meal-item{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1rem 1.5rem;transition:var(--transition-fast)}.meal-item:last-child{border-bottom:none}.meal-item:hover{background:var(--bg-surface-alt)}.meal-info h4{color:var(--text-main);font-size:1rem;margin:0 0 .25rem}.meal-macros{color:var(--text-secondary);display:flex;font-size:.85rem;gap:.75rem}.meal-macros span{align-items:center;display:flex;gap:.25rem}.meal-actions{display:flex;gap:.5rem}.btn-icon{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:1.1rem;padding:.25rem;transition:var(--transition-fast)}.btn-icon:hover{color:var(--danger);transform:scale(1.1)}.add-meal-btn{align-items:center;background:none;border:none;color:var(--primary);cursor:pointer;display:flex;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem;transition:var(--transition-fast);width:100%}.add-meal-btn:hover{background:var(--primary-soft)}.modal-body{padding:1.5rem}.form-actions-top{display:flex;gap:.75rem;margin-bottom:1rem}.btn-search-food{align-items:center;background:var(--primary-soft);border:1px solid var(--primary);border-radius:var(--radius-md);color:var(--primary);cursor:pointer;display:flex;flex:1 1;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:var(--transition-fast)}.btn-search-food:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.add-meal-form{display:flex;flex-direction:column;gap:1rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.macro-input-group{position:relative}.macro-input-group input{font-size:16px;padding-right:2rem;width:100%}.macro-suffix{color:var(--text-tertiary);font-size:.85rem;pointer-events:none;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.goals-form{display:flex;flex-direction:column;gap:1.5rem}@media (max-width:768px){.nutrition-header{align-items:stretch;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.nutrition-header h2{font-size:1.5rem}.date-selector{justify-content:space-between}.date-nav-btn{min-height:44px;min-width:44px;padding:.5rem}.header-actions{flex-wrap:wrap;justify-content:center}.btn-goals{font-size:.95rem;min-height:44px;padding:.65rem 1rem}.macros-summary{gap:.75rem;grid-template-columns:repeat(2,1fr)}.macro-card{padding:1.25rem 1rem}.macro-value{font-size:1.5rem}.meals-section{gap:1rem;grid-template-columns:1fr}.meal-group{border-radius:var(--radius-md)}.add-meal-btn{font-size:.95rem;min-height:44px;padding:.75rem}.form-row{grid-template-columns:1fr}.meal-item{align-items:flex-start;flex-direction:column;gap:.75rem}.meal-actions{justify-content:flex-end;width:100%}.form-control{font-size:16px;min-height:44px;padding:.85rem}.btn,.btn-search-food{font-size:.95rem;min-height:44px}.btn{padding:.75rem 1rem}}@media (max-width:480px){.nutrition-header{gap:.5rem;margin-bottom:1rem}.nutrition-header h2{font-size:1.3rem}.current-date{font-size:.85rem;min-width:auto}.date-selector{gap:.5rem;padding:.4rem .75rem}.macros-summary{gap:.5rem;grid-template-columns:1fr}.macro-card{padding:1rem .85rem}.macro-value{font-size:1.3rem}.macro-label{font-size:.8rem}.meal-group-header{padding:.75rem 1rem}.meal-group-header h3{font-size:.95rem}.meal-item{padding:.75rem 1rem}.form-row{grid-template-columns:1fr}.form-control,select{border-radius:var(--radius-md);font-size:16px;padding:.8rem .9rem}.macro-input-group{width:100%}.macro-suffix{right:.65rem}.btn-search-food{flex-direction:column;font-size:.9rem;padding:.7rem .9rem}.btn{font-size:.9rem;padding:.7rem 1rem;width:100%}.modal-footer{flex-direction:column;gap:.5rem}.modal-footer .btn{width:100%}.add-meal-form{gap:.75rem}.goals-form{gap:1rem}}.fasting-container{padding:0}.fasting-header{margin-bottom:2rem}.fasting-header h2{color:var(--text-main);margin:0}.timer-card{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:2rem}.timer-display{height:200px;position:relative;width:200px}.progress-ring{transform:rotate(-90deg);transform-origin:50% 50%}.progress-ring-circle-bg{stroke:var(--bg-surface-alt)}.progress-ring-circle{stroke-linecap:round}.timer-text{display:flex;flex-direction:column;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.elapsed-time{font-feature-settings:"tnum";color:var(--text-main);font-size:2.5rem;font-variant-numeric:tabular-nums;font-weight:700;line-height:1}.timer-label{color:var(--text-secondary);font-size:.9rem;margin-top:.5rem;text-transform:uppercase}.timer-status p{color:var(--primary);font-size:1.1rem;font-weight:600;margin:0}.timer-controls{flex-direction:column;width:100%}.protocol-selector,.timer-controls{align-items:center;display:flex;gap:1rem}.protocol-selector{margin-bottom:.5rem}.protocol-selector label{color:var(--text-secondary)}.protocol-selector select{background:var(--bg-surface-alt);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);padding:.5rem}.btn-end-fast,.btn-start-fast{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;gap:.5rem;justify-content:center;max-width:300px;padding:1rem;transition:var(--transition-fast);width:100%}.btn-start-fast{background:var(--primary);color:#fff}.btn-start-fast:hover{background:var(--primary-dark);transform:translateY(-2px)}.btn-end-fast{background:var(--bg-surface-alt);border:1px solid var(--border);color:var(--text-main)}.btn-end-fast:hover{background:var(--danger);border-color:var(--danger);color:#fff}.fasting-history h3{color:var(--text-main);margin-bottom:1rem}.history-item{justify-content:space-between}.history-item.success{border-left:4px solid var(--success)}.history-date{color:var(--text-secondary);font-weight:600;width:80px}.history-details{display:flex;flex:1 1;flex-direction:column}.history-duration{color:var(--text-main);font-size:1.1rem;font-weight:700}.history-target{color:var(--text-tertiary);font-size:.85rem}.history-status{font-size:1.2rem}.no-history{color:var(--text-tertiary);font-style:italic;padding:2rem;text-align:center}.food-search-container{display:flex;flex-direction:column;gap:1rem}.search-mode-tabs{border-bottom:2px solid var(--border);display:flex;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem}.mode-tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;flex:1 1;font-weight:600;margin-bottom:-.5rem;padding:.75rem;transition:all var(--transition-fast)}.mode-tab:hover{color:var(--text-main)}.mode-tab.active{border-bottom-color:var(--primary);color:var(--primary)}.food-search-input-wrapper{align-items:center;display:flex;position:relative}.food-search-input{background-color:var(--bg-surface);border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);font-size:1rem;padding:.75rem 1rem;transition:all var(--transition-fast);width:100%}.food-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.search-spinner{animation:spin 1s linear infinite;position:absolute;right:1rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.food-suggestions{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:0 0 var(--radius-md) var(--radius-md);border-top:none;box-shadow:var(--shadow-lg);left:0;margin-top:-.5rem;max-height:400px;overflow-y:auto;padding-top:.5rem;position:absolute;right:0;top:100%;z-index:100}.food-suggestion-item{border-bottom:1px solid var(--border);cursor:pointer;padding:.75rem 1rem;transition:background-color var(--transition-fast)}.food-suggestion-item:last-child{border-bottom:none}.food-suggestion-item:hover{background-color:var(--bg-surface-alt)}.barcode-input-wrapper{align-items:center;display:flex;gap:.5rem}.barcode-input{background-color:var(--bg-surface);border:2px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);flex:1 1;font-family:Courier New,monospace;font-size:1rem;letter-spacing:.1em;padding:.75rem 1rem;transition:all var(--transition-fast)}.barcode-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.btn-search-barcode{background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:600;min-width:45px;padding:.75rem 1rem;transition:all var(--transition-fast)}.btn-search-barcode:hover:not(:disabled){background:var(--primary-hover);transform:scale(1.05)}.btn-search-barcode:disabled{background:var(--border);color:var(--text-tertiary);cursor:not-allowed;opacity:.5}.barcode-error{background-color:#fee2e2;border:1px solid #fecaca;border-radius:var(--radius-md);color:#991b1b;font-size:.9rem;padding:.75rem}.btn-camera-scan{align-items:center;background:var(--primary-soft);border:2px solid var(--primary);border-radius:var(--radius-md);color:var(--primary);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all var(--transition-fast);width:100%}.btn-camera-scan:hover{background:var(--primary);box-shadow:var(--shadow-md);color:#fff;transform:translateY(-2px)}.btn-camera-scan:active{transform:translateY(0)}.suggestion-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.suggestion-name{color:var(--text-main);font-weight:600}.suggestion-source{background-color:var(--primary-soft);border-radius:var(--radius-sm);color:var(--primary);display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase}.suggestion-macros{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.macro-badge{border-radius:var(--radius-sm);color:#fff;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .5rem}.macro-badge.calories{background-color:#f97316}.macro-badge.protein{background-color:#ef4444}.macro-badge.carbs{background-color:#f59e0b}.macro-badge.fats{background-color:#8b5cf6}.suggestion-serving{color:var(--text-tertiary);font-size:.75rem;font-style:italic}.food-no-results{color:var(--text-secondary);font-style:italic;padding:1rem;text-align:center}.food-search-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;padding-top:.5rem}.food-search-actions .btn{flex:0 0 auto}@media (max-width:768px){.food-search-container{gap:.75rem}.food-suggestions{border-radius:var(--radius-lg);max-height:350px}.food-suggestion-item{padding:.85rem 1rem}.suggestion-name{font-size:.95rem}.suggestion-macros{font-size:.75rem;gap:.4rem}.macro-badge{font-size:.75rem;padding:.3rem .5rem}.search-mode-tabs{gap:.5rem;margin-bottom:.75rem;padding-bottom:.75rem}.mode-tab{align-items:center;display:flex;font-size:.9rem;justify-content:center;min-height:44px;padding:.65rem .85rem}.food-search-input{font-size:16px;min-height:44px;padding:.9rem 1rem}.barcode-input-wrapper{gap:.5rem}.barcode-input{font-size:16px;min-height:44px;padding:.9rem 1rem}.btn-search-barcode{font-size:1.2rem;min-height:44px;min-width:44px;padding:.9rem}.btn-camera-scan{font-size:1rem;min-height:44px;padding:.85rem 1rem}.suggestion-header{align-items:center;flex-direction:row;gap:.5rem}.suggestion-source{font-size:.8rem;padding:.2rem .4rem}.suggestion-serving{font-size:.75rem;margin-top:.3rem}}@media (max-width:480px){.food-search-input-wrapper{padding:0}.food-search-input{border-radius:var(--radius-md);font-size:16px}.search-mode-tabs{gap:.25rem}.mode-tab{font-size:.85rem;font-weight:500;padding:.6rem .7rem}.food-suggestions{margin-top:.5rem;max-height:280px}.food-suggestion-item{padding:.75rem .85rem}.barcode-input-wrapper{gap:.35rem}.barcode-input{padding:.85rem .9rem}.btn-search-barcode{padding:.85rem .75rem}.btn-camera-scan{font-size:.95rem;padding:.8rem .9rem}.search-spinner{right:.75rem}}.barcode-scanner-wrapper,.scanner-controls{display:flex;flex-direction:column;gap:1rem}.scanner-controls{align-items:center;background:var(--bg-surface-alt);border:2px dashed var(--border);border-radius:var(--radius-md);padding:1.5rem}.btn-start-scanner{align-items:center;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.85rem 1.5rem;transition:all var(--transition-fast)}.btn-start-scanner:hover{background:var(--primary-hover);box-shadow:var(--shadow-md);transform:scale(1.05)}.scanner-help{color:var(--text-secondary);font-size:.9rem;margin:0;max-width:300px;text-align:center}.scanner-active{display:flex;flex-direction:column;gap:1rem}.scanner-container{align-items:center;background:#000;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;height:auto;justify-content:center;min-height:400px;overflow:hidden;position:relative;width:100%}.scanner-container video{-webkit-appearance:none;display:block;height:100%;object-fit:cover;-webkit-user-select:none;width:100%}#barcode-scanner video{height:auto!important;max-width:100%;width:100%!important}#barcode-scanner canvas{width:100%!important}#barcode-scanner{transform:translateZ(0);width:100%}#barcode-scanner>div:first-child{height:100%;width:100%}#barcode-scanner canvas,#barcode-scanner video{-webkit-appearance:none;-webkit-user-select:none;user-select:none}#barcode-scanner canvas,#barcode-scanner>div{border-radius:var(--radius-md)}#barcode-scanner canvas{max-width:100%}#html5qr-button-camera-permission{background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1rem}#html5qr-button-camera-permission:hover{background:var(--primary-hover)}.scanner-error{background-color:#fee2e2;border:1px solid #fecaca;border-radius:var(--radius-md);color:#991b1b}.scanner-error,.scanner-info{font-size:.9rem;padding:.75rem}.scanner-info{background-color:var(--primary-soft);border-radius:var(--radius-md);color:var(--primary);font-weight:500;text-align:center}.btn-stop-scanner{align-items:center;background:#ef4444;background:var(--danger,#ef4444);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all var(--transition-fast)}.btn-stop-scanner:hover:not(:disabled){background:#dc2626;transform:scale(1.02)}.btn-stop-scanner:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.barcode-scanner-wrapper{gap:.75rem}.scanner-controls{gap:.75rem;padding:1.25rem}.btn-start-scanner{font-size:1rem;min-height:44px;padding:.9rem 1.25rem;width:100%}.scanner-help{font-size:.9rem;line-height:1.4}.scanner-active{gap:.75rem}.scanner-info{font-size:.9rem;padding:.85rem}.btn-stop-scanner{font-size:.95rem;min-height:44px;padding:.85rem 1rem;width:100%}#barcode-scanner{border-radius:var(--radius-lg);height:450px}.scanner-container{height:450px;min-height:450px}}@media (max-width:480px){.barcode-scanner-wrapper{gap:.5rem}.scanner-controls{gap:.5rem;padding:1rem}.btn-start-scanner{font-size:.95rem;font-weight:600;padding:.8rem 1rem}.scanner-help,.scanner-info{font-size:.8rem}.scanner-info{padding:.75rem}.btn-stop-scanner{font-size:.9rem;padding:.75rem .9rem}#barcode-scanner{height:350px}.scanner-container{height:350px;min-height:350px}#html5qr-button-fs,#html5qr-button-torch{font-size:.8rem;margin:.4rem;padding:.4rem .75rem}}#html5qr-button-torch{background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:600;margin:.5rem;padding:.5rem 1rem;transition:all var(--transition-fast)}#html5qr-button-torch:hover{background:var(--primary-hover)}#html5qr-button-fs{background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:600;margin:.5rem;padding:.5rem 1rem;transition:all var(--transition-fast)}#html5qr-button-fs:hover{background:var(--primary-hover)}#barcode-scanner .qr-shaded-region{box-shadow:0 0 0 9999px #00000080}#barcode-scanner .qr-shaded-region svg{stroke:var(--primary);stroke-width:3}.recovery-container{padding:0}.recovery-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.recovery-header h2{color:var(--text-main);margin:0}.btn-checkin{background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:var(--transition-fast)}.btn-checkin:hover{background:var(--primary-dark);transform:translateY(-2px)}.daily-score-card{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:2rem;margin-bottom:2rem;padding:2rem}.score-circle{align-items:center;border:8px solid var(--primary);border-radius:50%;display:flex;flex-direction:column;flex-shrink:0;height:120px;justify-content:center;width:120px}.score-number{font-size:2rem;font-weight:800;line-height:1}.score-label{color:var(--text-secondary);font-size:.7rem;margin-top:.25rem;text-transform:uppercase}.score-details h3{color:var(--text-main);font-size:1.5rem;margin:0 0 1rem}.metrics-grid-mini{grid-gap:.5rem 2rem;display:grid;gap:.5rem 2rem;grid-template-columns:1fr 1fr}.metric-mini{color:var(--text-secondary);font-size:.95rem}.metric-mini strong{color:var(--text-main);margin-left:.5rem}.no-score-card{background:var(--bg-surface-alt);border:2px dashed var(--border);border-radius:var(--radius-lg);cursor:pointer;margin-bottom:2rem;padding:2rem;text-align:center;transition:var(--transition-fast)}.no-score-card:hover{background:var(--bg-surface);border-color:var(--primary)}.no-score-card .icon{display:block;font-size:3rem;margin-bottom:1rem}.no-score-card p{color:var(--text-secondary);font-size:1.1rem;margin:0}.history-section h3{color:var(--text-main);margin-bottom:1rem}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;gap:1rem;padding:1rem}.history-item .date{color:var(--text-secondary);font-weight:600;width:80px}.mini-bar-container{background:var(--bg-surface-alt);flex:1 1;height:8px;overflow:hidden}.mini-bar,.mini-bar-container{border-radius:var(--radius-full)}.mini-bar{height:100%}.score-val{color:var(--text-main);font-weight:700;text-align:right;width:40px}.recovery-form{display:flex;flex-direction:column;gap:1.5rem}.star-rating{align-items:center;display:flex;gap:.25rem}.star{color:var(--border);cursor:pointer;font-size:1.5rem;transition:color .2s}.star.filled{color:#fbbf24}.star:hover{transform:scale(1.2)}.rating-value{color:var(--text-main);font-weight:600;margin-left:1rem}@media (max-width:768px){.daily-score-card{flex-direction:column;gap:1.5rem;text-align:center}.metrics-grid-mini{gap:.5rem;grid-template-columns:1fr}.star{font-size:1.25rem}.score-circle{border-width:6px;height:100px;width:100px}.score-number{font-size:1.7rem}}@media (max-width:480px){.score-circle{border-width:5px;height:80px;width:80px}.score-number{font-size:1.5rem}.score-label{font-size:.65rem}}.goals-container{padding:0}.goals-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.goals-header h2{color:var(--text-main);margin:0}.month-selector{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);display:flex;gap:1rem;padding:.5rem 1rem}.month-selector button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;transition:color .2s}.month-selector button:hover{color:var(--primary)}.month-selector span{color:var(--text-main);font-weight:600;min-width:120px;text-align:center;text-transform:capitalize}.btn-add-goal{background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:var(--transition-fast)}.btn-add-goal:hover{background:var(--primary-dark);transform:translateY(-2px)}.goals-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.goal-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;padding:1.5rem;transition:var(--transition-fast)}.goal-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.goal-card.completed{background:#10b9810d;border-color:var(--success)}.goal-header{align-items:flex-start;display:flex;justify-content:space-between}.goal-category{border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;padding:.25rem .5rem;text-transform:uppercase}.goal-category.strength{background:#3b82f61a;color:#3b82f6}.goal-category.physique{background:#ec48991a;color:#ec4899}.goal-category.habit{background:#10b9811a;color:#10b981}.goal-card h3{color:var(--text-main);font-size:1.2rem;margin:0}.goal-progress-section{display:flex;flex-direction:column;gap:.5rem}.progress-labels{color:var(--text-secondary);display:flex;font-size:.9rem;justify-content:space-between}.progress-bar-bg{background:var(--bg-surface-alt);border-radius:var(--radius-full);height:8px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);height:100%;transition:width .5s ease-out}.goal-update-input{display:flex;flex-direction:column;gap:.25rem;margin-top:auto}.goal-update-input input{background:var(--bg-surface-alt);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-main);font-size:.9rem;padding:.5rem;width:100%}.goal-update-input small{color:var(--text-tertiary);font-size:.75rem;text-align:right}.no-goals{background:var(--bg-surface);border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-secondary);grid-column:1/-1;padding:3rem;text-align:center}.goal-form{display:flex;flex-direction:column;gap:1.5rem}@media (max-width:768px){.goals-header{align-items:stretch;flex-direction:column}.month-selector{justify-content:space-between}}.error-boundary{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:1rem}.error-boundary-content{background:#fff;border-radius:1rem;box-shadow:0 20px 60px #0000004d;max-width:600px;padding:2rem;text-align:center;width:100%}.error-icon{font-size:4rem;margin-bottom:1rem}.error-boundary-content h2{color:#333;font-size:1.8rem;margin:0 0 .5rem}.error-boundary-content p{color:#666;font-size:1rem;margin:.5rem 0}.error-warning{background:#fff3cd;border:1px solid #ffc107;color:#856404;margin:1rem 0}.error-details,.error-warning{border-radius:.5rem;padding:1rem}.error-details{background:#f5f5f5;color:#333;font-family:Courier New,monospace;font-size:.85rem;margin-top:.5rem;overflow-x:auto;text-align:left}.error-details p{line-height:1.5;margin:.5rem 0}.error-details strong{color:#d9534f}.error-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2rem}.btn-home,.btn-reset{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;min-height:44px;padding:.75rem 1.5rem;transition:all .3s ease}.btn-reset{background:#667eea;color:#fff}.btn-reset:hover{background:#5568d3;box-shadow:0 10px 20px #667eea4d;transform:translateY(-2px)}.btn-home{background:#6c757d;color:#fff}.btn-home:hover{background:#5a6268;box-shadow:0 10px 20px #6c757d4d;transform:translateY(-2px)}@media (max-width:480px){.error-boundary-content{padding:1.5rem}.error-icon{font-size:3rem}.error-boundary-content h2{font-size:1.5rem}.error-actions{flex-direction:column}.btn-home,.btn-reset{width:100%}}
/*# sourceMappingURL=main.50de5c11.css.map*/