*{margin:0;padding:0;box-sizing:border-box}:root{--primary-green: #22c55e;--primary-green-dark: #16a34a;--primary-green-light: #4ade80;--primary-green-lighter: #86efac;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-sidebar: #1f2937;--text-primary: #111827;--text-secondary: #6b7280;--border-color: #e5e7eb;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--primary-green);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-green-dark)}.layout{display:flex;min-height:100vh;background-color:var(--bg-secondary)}.sidebar{width:260px;background:linear-gradient(180deg,#1a1f2e,#151923);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:1000;box-shadow:4px 0 20px #00000026;transition:width .3s cubic-bezier(.4,0,.2,1);border-right:1px solid rgba(255,255,255,.08)}.sidebar.collapsed{width:80px}.sidebar-header{padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.1);position:relative;display:flex;align-items:center;justify-content:space-between;min-height:70px;gap:.75rem}.sidebar.collapsed .sidebar-header{padding:1rem .5rem;justify-content:center;flex-direction:column;gap:.75rem;min-height:60px}.collapse-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:#ffffff26;border:1px solid rgba(255,255,255,.2);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10;flex-shrink:0;box-shadow:0 2px 4px #0000001a}.collapse-toggle:hover{background:#ffffff40;border-color:#ffffff4d;transform:translateY(-50%) scale(1.05);box-shadow:0 4px 8px #00000026}.collapse-toggle:active{transform:translateY(-50%) scale(.95)}.sidebar.collapsed .collapse-toggle{position:relative;right:auto;top:auto;transform:none;margin:0;align-self:center}.sidebar.collapsed .collapse-toggle:hover{transform:scale(1.05)}.sidebar.collapsed .collapse-toggle:active{transform:scale(.95)}.logo{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0;justify-content:flex-start;position:relative;padding-right:2.5rem}.sidebar.collapsed .logo{justify-content:center;padding-right:0;flex:none;width:100%}.logo-image{width:auto;height:50px;max-width:100%;object-fit:contain;flex-shrink:0}.sidebar.collapsed .logo-image{height:40px}.sidebar-nav{flex:1;padding:.75rem;overflow-y:auto;overflow-x:hidden}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#fff3}.nav-item-wrapper{position:relative;margin-bottom:.5rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:12px;color:#ffffffbf;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;width:100%;justify-content:flex-start;font-size:.9375rem;font-weight:500}.nav-item-icon{width:20px;height:20px;flex-shrink:0;display:block}.nav-item.collapsed{justify-content:center;padding:.875rem}.nav-item.collapsed span{display:none}.nav-item:hover{background-color:#ffffff14;color:#fff;transform:translate(2px)}.nav-item.active{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;box-shadow:0 4px 16px #22c55e40;font-weight:600}.nav-item.active:hover{transform:translate(2px);box-shadow:0 4px 20px #22c55e59}.nav-indicator{position:absolute;left:0;top:0;bottom:0;width:4px;background:#fff;border-radius:0 4px 4px 0}.sidebar.collapsed .nav-indicator{width:3px}.nav-item.locked{cursor:not-allowed;opacity:.6;position:relative}.nav-item.locked:hover{background:#ffffff0d;transform:none}.coming-soon-badge{display:flex;align-items:center;gap:.25rem;margin-left:auto;padding:.25rem .5rem;background:#f59e0b33;border:1px solid rgba(245,158,11,.3);border-radius:12px;font-size:.625rem;font-weight:600;color:#fbbf24;text-transform:uppercase;letter-spacing:.5px}.tooltip-locked{color:#fbbf24;font-size:.75rem;margin-left:.25rem}.nav-tooltip{position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:#000000e6;color:#fff;padding:.5rem .75rem;border-radius:8px;font-size:.875rem;white-space:nowrap;pointer-events:none;opacity:0;z-index:2000;box-shadow:0 4px 12px #0000004d}.nav-tooltip:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:#000000e6}.nav-item-wrapper:hover .nav-tooltip{opacity:1;transition:opacity .2s ease .3s}.sidebar-footer{padding:1.25rem;border-top:1px solid rgba(255,255,255,.1);background:#0003;display:flex;flex-direction:column;gap:.75rem}.sidebar.collapsed .sidebar-footer{padding:1rem .5rem;align-items:center}.user-info{display:flex;align-items:center;gap:.75rem;width:100%;justify-content:center}.sidebar.collapsed .user-info{justify-content:center}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #22c55e4d}.user-details{flex:1}.user-name{font-weight:600;color:#fff;font-size:.875rem}.user-role{font-size:.75rem;color:#fff9}.logout-button{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:10px;color:#fca5a5;cursor:pointer;transition:all .3s ease;font-size:.875rem;font-weight:500;width:100%;justify-content:flex-start}.logout-button:hover:not(:disabled){background:#ef444433;border-color:#ef44444d;color:#f87171}.logout-button:disabled{opacity:.6;cursor:not-allowed}.sidebar.collapsed .logout-button{justify-content:center;padding:.75rem;width:auto}.logout-button svg{flex-shrink:0}.mobile-menu-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background:var(--primary-green);color:#fff;border:none;width:40px;height:40px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;box-shadow:var(--shadow-lg)}.mobile-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:999}.layout-main{flex:1;margin-left:260px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease}.layout-main.sidebar-collapsed{margin-left:80px}.header{background:var(--bg-primary);padding:1rem 2rem;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:1rem;position:sticky;top:0;z-index:100;min-height:60px}.header-search{flex:1;max-width:500px;position:relative}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-secondary)}.search-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.user-menu-wrapper{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.75rem;background:var(--bg-secondary);border:none;padding:.5rem .75rem;border-radius:12px;cursor:pointer;transition:all .3s ease;color:var(--text-primary)}.user-menu-trigger:hover{background:var(--primary-green);color:#fff}.user-avatar-small{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:#fff;flex-shrink:0}.user-info-small{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.user-name-small{font-size:.875rem;font-weight:600;color:inherit;line-height:1.2}.user-role-small{font-size:.75rem;color:#ffffffb3;line-height:1.2}.user-menu-trigger:hover .user-role-small{color:#ffffffe6}.chevron-icon{transition:transform .3s ease;flex-shrink:0;color:inherit}.chevron-icon.rotated{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #00000026;min-width:240px;z-index:1000;overflow:hidden}.user-menu-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-secondary)}.user-avatar-menu{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;color:#fff;flex-shrink:0}.user-info-menu{flex:1;display:flex;flex-direction:column;gap:.25rem}.user-name-menu{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.2}.user-email-menu{font-size:.8125rem;color:var(--text-secondary);margin:0;line-height:1.2}.user-menu-divider{height:1px;background:var(--border-color);margin:.5rem 0}.user-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;background:none;border:none;text-align:left;cursor:pointer;color:var(--text-primary);font-size:.875rem;transition:all .2s ease}.user-menu-item:hover:not(:disabled){background:var(--bg-secondary);color:var(--primary-green)}.user-menu-item:disabled{opacity:.6;cursor:not-allowed}.user-menu-item svg{flex-shrink:0;color:inherit}.header-btn{position:relative;background:var(--bg-secondary);border:none;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:all .3s ease}.header-btn:hover{background:var(--primary-green);color:#fff}.notification-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:.625rem;font-weight:600;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.layout-content{flex:1;padding:2rem}@media(max-width:768px){.mobile-menu-btn{display:flex}.mobile-overlay{display:block}.sidebar{transform:translate(-100%);transition:transform .3s ease}.sidebar.mobile-open{transform:translate(0)}.layout-main{margin-left:0}.header{padding:1rem}.header-search{max-width:none}.layout-content{padding:1rem}.sidebar{width:280px}}@media(max-width:480px){.header-search{display:none}.layout-content{padding:.75rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);padding:2rem;color:#fff}.login-background{position:absolute;inset:0;overflow:hidden;z-index:0}.bg-circle{position:absolute;border-radius:50%;background:linear-gradient(135deg,#22c55e1a,#22c55e0d);filter:blur(60px);animation:float 20s ease-in-out infinite}.circle-1{width:400px;height:400px;top:-100px;left:-100px;animation-delay:0s}.circle-2{width:500px;height:500px;bottom:-150px;right:-150px;animation-delay:5s}.circle-3{width:350px;height:350px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:10s}@keyframes float{0%,to{opacity:.4}50%{opacity:.6}}.fireflies{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none}.firefly{position:absolute;width:4px;height:4px;background:var(--primary-green);border-radius:50%;box-shadow:0 0 10px var(--primary-green),0 0 20px var(--primary-green);opacity:0;animation:firefly-float 15s infinite ease-in-out}.firefly:nth-child(1){left:10%;animation-delay:0s;animation-duration:12s}.firefly:nth-child(2){left:20%;animation-delay:1s;animation-duration:14s}.firefly:nth-child(3){left:30%;animation-delay:2s;animation-duration:13s}.firefly:nth-child(4){left:40%;animation-delay:3s;animation-duration:15s}.firefly:nth-child(5){left:50%;animation-delay:1.5s;animation-duration:16s}.firefly:nth-child(6){left:60%;animation-delay:2.5s;animation-duration:11s}.firefly:nth-child(7){left:70%;animation-delay:.5s;animation-duration:13s}.firefly:nth-child(8){left:80%;animation-delay:3.5s;animation-duration:14s}.firefly:nth-child(9){left:90%;animation-delay:1.2s;animation-duration:12s}.firefly:nth-child(10){left:15%;animation-delay:4s;animation-duration:15s}.firefly:nth-child(11){left:25%;animation-delay:2.8s;animation-duration:13s}.firefly:nth-child(12){left:45%;animation-delay:.8s;animation-duration:14s}.firefly:nth-child(13){left:65%;animation-delay:3.2s;animation-duration:12s}.firefly:nth-child(14){left:75%;animation-delay:1.8s;animation-duration:16s}.firefly:nth-child(15){left:85%;animation-delay:2.2s;animation-duration:11s}@keyframes firefly-float{0%{top:100%;opacity:0;transform:translate(0) scale(1)}10%{opacity:.8}20%{transform:translate(30px) scale(1.2)}40%{transform:translate(-30px) scale(.8)}60%{transform:translate(20px) scale(1.1)}80%{transform:translate(-20px) scale(.9);opacity:.8}90%{opacity:0}to{top:-10%;opacity:0;transform:translate(0) scale(1)}}.login-container{position:relative;z-index:1;width:100%;max-width:450px}.login-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:3rem;box-shadow:0 8px 32px #0000004d;border:1px solid rgba(255,255,255,.1)}.login-logo{text-align:center;margin-bottom:2.5rem}.logo-section{text-align:center;margin-bottom:1.5rem}.logo-image{width:300px;max-width:80%;height:auto;margin:0 auto;display:block}.login-title{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.5rem;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{font-size:.875rem;color:#fff9}.error-message{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#fca5a5;font-size:.875rem;margin-bottom:1.5rem;position:relative}.error-message svg:first-child{flex-shrink:0;color:#ef4444;margin-top:.125rem}.error-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.error-main{font-weight:600;color:#fca5a5}.error-details{margin:0;padding-left:1.25rem;list-style:disc;display:flex;flex-direction:column;gap:.25rem}.error-details li{color:#fca5a5e6;font-size:.8125rem;line-height:1.4}.error-close{background:none;border:none;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;border-radius:4px;transition:all .2s ease;flex-shrink:0}.error-close:hover{background:#ffffff1a;color:#fff}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.75rem}.login-page .form-group label,.login-card .form-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#22c55e!important}.form-group label svg{color:var(--primary-green)}.form-group input{width:100%;padding:.875rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:.875rem;transition:all .3s ease}.form-group input::placeholder{color:#fff6}.form-group input:focus{outline:none;border-color:var(--primary-green);background:#ffffff14;box-shadow:0 0 0 3px #22c55e33}.password-input-wrapper{position:relative}.password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .3s ease;padding:.25rem}.password-toggle:hover{color:var(--primary-green)}.form-options{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.remember-me{display:flex;align-items:center;gap:.5rem;color:#ffffffb3;cursor:pointer}.remember-me input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-green)}.forgot-password{color:var(--primary-green);text-decoration:none;font-weight:600;transition:all .3s ease}.forgot-password:hover{color:var(--primary-green-dark);text-decoration:underline}.login-button{width:100%;padding:1rem;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s ease;box-shadow:0 4px 16px #22c55e66;margin-top:.5rem}.login-button:hover:not(:disabled){box-shadow:0 6px 24px #22c55e80;transform:translateY(-2px)}.login-button:disabled{opacity:.7;cursor:not-allowed}.loading-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%}.login-footer{margin-top:2rem;text-align:center;font-size:.875rem;color:#fff9}.signup-link{color:var(--primary-green);text-decoration:none;font-weight:600;transition:all .3s ease}.signup-link:hover{color:var(--primary-green-dark);text-decoration:underline}@media(max-width:768px){.login-page{padding:1rem}.login-card{padding:2rem 1.5rem}.login-title{font-size:1.75rem}.logo-image{width:250px}.circle-1,.circle-2,.circle-3{width:300px;height:300px}}@media(max-width:480px){.login-card{padding:1.5rem 1rem}.login-title{font-size:1.5rem}.form-options{flex-direction:column;align-items:flex-start;gap:.75rem}}.dashboard{max-width:1400px;margin:0 auto}.page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow);display:flex;align-items:flex-start;gap:1rem;transition:all .3s ease;cursor:pointer}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-title{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.stat-change{font-size:.75rem;font-weight:600}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.dashboard-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow)}.card-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.checkins-list{display:flex;flex-direction:column;gap:.75rem}.checkin-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:10px;transition:all .3s ease;cursor:pointer}.checkin-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;flex-shrink:0;position:relative;overflow:visible;cursor:pointer}.checkin-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;transition:transform .3s ease}.checkin-avatar:hover img{transform:scale(1.1)}.checkin-avatar .avatar-zoom-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:150px;height:150px;border-radius:50%;box-shadow:0 8px 32px #0006;z-index:1000;pointer-events:none;border:4px solid white;opacity:0;transition:opacity .3s ease,transform .3s ease}.checkin-avatar:hover .avatar-zoom-overlay{opacity:1;transform:translate(-50%,-50%) scale(1)}.checkin-avatar .avatar-zoom-overlay img{width:100%;height:100%;border-radius:50%;object-fit:cover}.checkin-avatar span{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.checkin-info{flex:1;min-width:0}.checkin-member-name{font-weight:600;color:var(--text-primary);font-size:.875rem;margin-bottom:.25rem}.checkin-stats{display:flex;align-items:center;gap:.375rem;font-size:.75rem;flex-wrap:wrap}.checkin-stat{color:var(--text-secondary);font-weight:500}.checkin-separator{color:var(--text-secondary);opacity:.5;font-size:.625rem}.checkin-date-wrapper{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.checkin-icon{color:var(--primary-green);width:14px;height:14px}.checkin-date{font-size:.75rem;color:var(--text-secondary);font-weight:500}.pending-payments-list{display:flex;flex-direction:column;gap:1rem}.pending-payment-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:12px;background:var(--bg-secondary);transition:all .3s ease;cursor:pointer}.pending-payment-item:hover{background:var(--border-color);transform:translate(5px)}.payment-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;flex-shrink:0;position:relative;overflow:visible;cursor:pointer}.payment-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;transition:transform .3s ease}.payment-avatar:hover img{transform:scale(1.1)}.payment-avatar .avatar-zoom-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:150px;height:150px;border-radius:50%;box-shadow:0 8px 32px #0006;z-index:1000;pointer-events:none;border:4px solid white;opacity:0;transition:opacity .3s ease,transform .3s ease}.payment-avatar:hover .avatar-zoom-overlay{opacity:1;transform:translate(-50%,-50%) scale(1)}.payment-avatar .avatar-zoom-overlay img{width:100%;height:100%;border-radius:50%;object-fit:cover}.payment-avatar span{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.payment-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.payment-client-name{font-weight:600;color:var(--text-primary);font-size:.875rem;margin:0}.payment-details{display:flex;align-items:center;gap:.5rem;font-size:.8125rem}.payment-amount{color:var(--text-primary);font-weight:600}.payment-separator{color:var(--text-secondary)}.payment-overdue{color:#ef4444;font-weight:600}.payment-date-wrapper{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.payment-icon{color:var(--text-secondary)}.payment-date{color:var(--text-secondary);font-size:.8125rem;margin:0}@media(max-width:768px){.stats-grid,.dashboard-grid{grid-template-columns:1fr}.page-title{font-size:1.5rem}}.members-page{max-width:1400px;margin:0 auto}.members-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.btn-primary{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease}.members-table-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;overflow-x:auto}.members-table{width:100%;border-collapse:collapse}.members-table thead{background:var(--bg-secondary)}.members-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.members-table td{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem}.member-cell{display:flex;align-items:center;gap:.75rem}.member-cell.clickable:hover{color:var(--primary-green)}.member-avatar-small{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;flex-shrink:0;position:relative;overflow:visible;cursor:pointer}.member-avatar-small img{width:100%;height:100%;object-fit:cover;border-radius:50%;transition:transform .3s ease}.member-avatar-small:hover img{transform:scale(1.1)}.member-avatar-small .avatar-zoom-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:150px;height:150px;border-radius:50%;box-shadow:0 8px 32px #0006;z-index:1000;pointer-events:none;border:4px solid white;opacity:0;transition:opacity .3s ease,transform .3s ease}.member-avatar-small:hover .avatar-zoom-overlay{opacity:1;transform:translate(-50%,-50%) scale(1)}.member-avatar-small .avatar-zoom-overlay img{width:100%;height:100%;border-radius:50%;object-fit:cover}.member-avatar-small span{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.status-badge.active{background:#22c55e1a;color:var(--primary-green)}.status-badge.inactive{background:#ef44441a;color:#ef4444}.action-buttons{display:flex;gap:.5rem}.action-btn{width:32px;height:32px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.view-btn{background:#22c55e1a;color:var(--primary-green)}.view-btn:hover{background:var(--primary-green);color:#fff}.edit-btn{background:#3b82f61a;color:#3b82f6}.edit-btn:hover{background:#3b82f6;color:#fff}.delete-btn{background:#ef44441a;color:#ef4444}.delete-btn:hover{background:#ef4444;color:#fff}.gender-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;background:#3b82f61a;color:#3b82f6}.pt-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;background:#22c55e1a;color:var(--primary-green)}.no-pt-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;background:#9ca3af1a;color:#6b7280}@media(max-width:768px){.members-table{font-size:.75rem}.members-table th,.members-table td{padding:.75rem .5rem}.page-header,.members-filters{flex-direction:column}.search-box{min-width:100%}.form-row{grid-template-columns:1fr}.client-form-modal{max-width:95%;padding:1.5rem}}.member-detail-page{max-width:1400px;margin:0 auto}.member-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .3s ease;font-weight:600}.member-detail-content{display:grid;grid-template-columns:400px 1fr;gap:2rem}.member-info-panel{display:flex;flex-direction:column;gap:1.5rem}.member-info-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow)}.member-header-section{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.member-header-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.member-avatar-large{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;box-shadow:var(--shadow-lg);flex-shrink:0;position:relative;cursor:pointer}.member-avatar-large img{width:100%;height:100%;border-radius:50%;object-fit:cover;transition:transform .3s ease}.member-avatar-large:hover img{transform:scale(1.1)}.member-avatar-large .avatar-zoom-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;border-radius:50%;box-shadow:0 8px 32px #0006;z-index:1000;pointer-events:none;border:4px solid white;opacity:0;transition:opacity .3s ease,transform .3s ease;transform:translate(-50%,-50%) scale(.8)}.member-avatar-large:hover .avatar-zoom-overlay{opacity:1;transform:translate(-50%,-50%) scale(1)}.member-avatar-large .avatar-zoom-overlay img{width:100%;height:100%;border-radius:50%;object-fit:cover}.avatar-edit-btn{position:absolute;bottom:0;right:0;width:28px;height:28px;border-radius:50%;background:var(--primary-green);border:2px solid var(--bg-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .3s ease;z-index:10;box-shadow:0 2px 8px #0003}.avatar-edit-btn:hover{background:var(--primary-green-dark);transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.avatar-edit-btn:active{transform:scale(.95)}.avatar-edit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.avatar-edit-btn .spinner{animation:spin 1s linear infinite}.member-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.member-status-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;width:fit-content}.member-status-badge.active{background:#22c55e1a;color:var(--primary-green)}.member-status-badge.inactive{background:#ef44441a;color:#ef4444}.member-info-list{display:flex;flex-direction:column;gap:1rem}.info-section{display:flex;flex-direction:column;gap:.5rem}.info-section-title{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:700;margin-bottom:.25rem}.info-item-compact{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary)}.info-item-compact svg{flex-shrink:0;width:16px;height:16px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.info-mini-label{font-size:.625rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;font-weight:600}.info-mini-value{font-size:.875rem;color:var(--text-primary);font-weight:600}.info-item{display:flex;align-items:flex-start;gap:1rem}.info-icon{color:var(--primary-green);flex-shrink:0;margin-top:.125rem;width:16px;height:16px}.info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;font-weight:600}.info-value{font-size:.875rem;color:var(--text-primary);font-weight:500}.edit-member-btn{width:100%;padding:.75rem;border:none;border-radius:10px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s ease}.edit-member-btn:hover{box-shadow:0 4px 12px #22c55e66}.member-tabs-panel{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.member-tabs{display:flex;border-bottom:2px solid var(--border-color);background:var(--bg-secondary)}.member-tab{flex:1;padding:1rem 1.5rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s ease;border-bottom:2px solid transparent;margin-bottom:-2px}.member-tab:hover{color:var(--text-primary);background:var(--bg-primary)}.member-tab.active{color:var(--primary-green);border-bottom-color:var(--primary-green);background:var(--bg-primary)}.member-tab-content{padding:2rem;min-height:500px}.tab-header{margin-bottom:1.5rem}.tab-header h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.tab-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0}.overview-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;margin-bottom:2rem}.overview-chart-card{background:var(--bg-secondary);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);transition:all .3s ease}.overview-chart-card:hover{border-color:var(--primary-green);box-shadow:var(--shadow)}.chart-card-header{margin-bottom:1rem}.chart-card-header h4{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.chart-subtitle{font-size:.75rem;color:var(--text-secondary);margin:0}.overview-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.summary-card{background:var(--bg-secondary);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color);display:flex;align-items:center;gap:1rem;transition:all .3s ease}.summary-card:hover{border-color:var(--primary-green);box-shadow:var(--shadow);transform:translateY(-2px)}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-icon.weight-icon{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff}.summary-icon.bmi-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.summary-icon.workout-icon{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.summary-content{flex:1}.summary-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;font-weight:600}.summary-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.summary-value.positive{color:var(--primary-green)}.summary-period{font-size:.75rem;color:var(--text-secondary)}.table-container{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color)}.detail-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.detail-table thead{background:var(--bg-secondary)}.detail-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:2px solid var(--border-color)}.detail-table td{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem}.table-row{transition:all .3s ease}.table-row:hover{background:var(--bg-secondary)}.contract-type-cell{font-weight:600;color:var(--text-primary)}.price-cell,.paid-cell{font-weight:600;color:var(--primary-green)}.contract-status{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.contract-status.active{background:#22c55e1a;color:var(--primary-green)}.contract-status.expired{background:#ef44441a;color:#ef4444}.payment-status{display:inline-block;padding:.5rem 1rem;border-radius:8px;font-size:.75rem;font-weight:600}.payment-status.paid{background:#22c55e1a;color:var(--primary-green)}.payment-status.partial{background:#f59e0b1a;color:#f59e0b}.payment-status.unpaid,.payment-status.pending{background:#ef44441a;color:#ef4444}.view-contract-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:var(--bg-secondary);color:var(--primary-green);cursor:pointer;transition:all .3s ease}.view-contract-btn:hover{background:var(--primary-green);color:#fff;transform:scale(1.1)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem;color:var(--text-secondary)}.loading-container .loading-spinner{animation:spin 1s linear infinite;color:var(--primary-green)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-secondary);text-align:center}.empty-state svg{color:var(--text-secondary);opacity:.5}.empty-state p{font-size:1rem;font-weight:600;color:var(--text-primary)}.row-span-cell{vertical-align:middle;text-align:center;font-weight:700;color:var(--primary-green)}.date-cell,.exercise-name-cell{font-weight:600;color:var(--text-primary)}.exercise-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;background:#22c55e1a;color:var(--primary-green)}.exercise-detail-cell{color:var(--text-secondary)}.weight-cell,.height-cell{font-weight:600;color:var(--text-primary)}.bmi-cell{font-weight:700;color:var(--primary-green)}.images-badge{display:inline-block;padding:.375rem .75rem;background:#22c55e1a;color:var(--primary-green);border-radius:20px;font-size:.75rem;font-weight:600}.notes-cell{color:var(--text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workouts-collapse-container{display:flex;flex-direction:column;gap:1rem}.workout-collapse-item{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;transition:all .3s ease}.workout-collapse-item:hover{border-color:var(--primary-green);box-shadow:var(--shadow)}.workout-collapse-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;cursor:pointer;background:var(--bg-primary);transition:all .3s ease}.workout-collapse-header:hover{background:var(--bg-secondary)}.workout-header-left{display:flex;align-items:center;gap:1rem}.workout-number{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.calendar-icon{color:var(--primary-green);flex-shrink:0}.workout-date{font-weight:700;font-size:1rem;color:var(--text-primary)}.workout-exercises-count{font-size:.875rem;color:var(--text-secondary)}.workout-collapse-header svg:last-child{color:var(--text-secondary);flex-shrink:0}.workout-collapse-content{overflow:hidden}.workout-exercises-table-container{padding:1.5rem;background:var(--bg-secondary)}.workout-exercises-table{width:100%;border-collapse:collapse}.workout-exercises-table thead{background:var(--bg-primary)}.workout-exercises-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color)}.workout-exercises-table td{padding:.75rem 1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem}.exercise-table-row:hover{background:var(--bg-primary)}.program-section-item{margin-bottom:1rem;border:1px solid var(--border-color);border-radius:12px;overflow:hidden;background:var(--bg-secondary)}.program-section-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;cursor:pointer;transition:all .3s ease;background:var(--bg-primary)}.program-section-header:hover{background:#22c55e0d}.section-header-left{display:flex;align-items:center;gap:1rem;flex:1}.section-day{font-weight:700;color:var(--primary-green);min-width:80px}.section-name{font-weight:600;color:var(--text-primary);flex:1}.section-exercises-count{font-size:.875rem;color:var(--text-secondary)}.section-exercises-content{padding:1rem;background:var(--bg-primary)}.workout-description{font-size:.875rem;color:var(--text-secondary);font-style:italic}.exercise-note-cell{font-size:.8125rem;color:var(--text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-sections{padding:2rem;text-align:center;color:var(--text-secondary)}.client-form-modal{max-width:700px}.member-form{display:flex;flex-direction:column;gap:1.25rem}.form-group input,.form-group select{padding:.75rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;width:100%}.btn-primary{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d}@media(max-width:1024px){.member-detail-content,.overview-charts-grid,.overview-summary{grid-template-columns:1fr}.member-info-panel{order:2}.member-tabs-panel{order:1}}@media(max-width:768px){.member-tabs{flex-direction:column}.member-tab{width:100%;justify-content:flex-start}.member-tab-content{padding:1.5rem}.form-row{grid-template-columns:1fr}.client-form-modal{max-width:95%;padding:1.5rem}}.image-modal-header h2{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.image-modal-date{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary)}.stat-card{background:var(--bg-secondary);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.875rem;border:2px solid transparent;transition:all .3s ease}.stat-icon{width:48px;height:48px;border-radius:10px;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-green);box-shadow:var(--shadow)}.stat-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:.25rem;font-weight:600}.stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-unit{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.stat-category{font-size:.7rem;font-weight:600;margin-top:.25rem}.image-modal-notes h4{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:.625rem}.image-modal-notes p{color:var(--text-primary);font-size:.8rem;margin:0;line-height:1.5}.measurements-section{background:var(--bg-secondary);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color)}.measurements-section h4{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:.875rem}.measurements-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.measurement-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;background:var(--bg-primary);border-radius:8px}.measurement-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.measurement-value{font-size:.8rem;color:var(--text-primary);font-weight:600}@media(max-width:768px){.image-modal-body{grid-template-columns:1fr;gap:1.5rem}.checkin-image-modal-content{padding:1.5rem}.measurements-grid{grid-template-columns:1fr}}.view-detail-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary-green);color:#fff;border:none;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .3s ease}.view-detail-btn:hover{background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.meal-plan-actions{display:flex;gap:.5rem;align-items:center}.btn-send-email-meal{width:36px;height:36px;border:none;border-radius:8px;background:#3b82f61a;color:#3b82f6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.btn-send-email-meal:hover{background:#3b82f6;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f64d}.workout-header-actions{display:flex;align-items:center;gap:.5rem}.btn-send-email-workout{width:32px;height:32px;border:none;border-radius:8px;background:#3b82f61a;color:#3b82f6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.btn-send-email-workout:hover{background:#3b82f6;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f64d}.contracts-page{max-width:1400px;margin:0 auto}.contracts-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.contract-stat-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:1rem;transition:all .3s ease}.contract-stat-icon{width:48px;height:48px;border-radius:12px;background:#22c55e1a;color:var(--primary-green);display:flex;align-items:center;justify-content:center;flex-shrink:0}.contract-stat-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.contract-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.contracts-filters-section{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:center;flex-wrap:wrap}.contracts-search{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;flex:1;min-width:300px;transition:all .3s ease}.contracts-search:focus-within{border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.contracts-search svg{color:var(--text-secondary);flex-shrink:0}.search-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:.875rem;outline:none}.search-input::placeholder{color:var(--text-secondary)}.contracts-filters{display:flex;gap:.75rem;flex-wrap:wrap}.filter-btn{padding:.625rem 1.25rem;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-primary);color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.875rem}.filter-btn:hover{border-color:var(--primary-green);color:var(--primary-green)}.filter-btn.active{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border-color:transparent;box-shadow:0 4px 12px #22c55e4d}.contracts-table-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;overflow-x:auto}.contracts-table{width:100%;border-collapse:collapse}.contracts-table thead{background:var(--bg-secondary)}.contracts-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.contracts-table td{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem}.contract-table-row{transition:all .3s ease}.contract-table-row:hover{background:var(--bg-secondary)}.contract-member-cell{display:flex;align-items:center;gap:.75rem}.contract-avatar-small{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;flex-shrink:0;position:relative;overflow:visible;cursor:pointer}.contract-avatar-small img{width:100%;height:100%;object-fit:cover;border-radius:50%;transition:transform .3s ease}.contract-avatar-small:hover img{transform:scale(1.1)}.contract-avatar-small .avatar-zoom-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:150px;height:150px;border-radius:50%;box-shadow:0 8px 32px #0006;z-index:1000;pointer-events:none;border:4px solid white;opacity:0;transition:opacity .3s ease,transform .3s ease}.contract-avatar-small:hover .avatar-zoom-overlay{opacity:1;transform:translate(-50%,-50%) scale(1)}.contract-avatar-small .avatar-zoom-overlay img{width:100%;height:100%;border-radius:50%;object-fit:cover}.contract-avatar-small span{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.contract-member-name{font-weight:600;color:var(--text-primary)}.contract-type-text{color:var(--text-primary);font-weight:500}.contract-date-cell{display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.contract-date-cell svg{color:var(--text-secondary);flex-shrink:0}.contract-date-cell--end{flex-wrap:wrap;gap:.5rem}.contract-status-pill{display:inline-block;padding:.2rem .5rem;border-radius:10px;font-size:.6875rem;font-weight:600;white-space:nowrap}.contract-status-pill--active{background:#22c55e1f;color:var(--primary-green)}.contract-status-pill--expired{background:#ef44441a;color:#ef4444}.contract-price-cell{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.contract-price-cell svg{flex-shrink:0}.contract-price-cell--paid svg{color:var(--primary-green)}.contract-price-cell--partial svg{color:#f59e0b}.contract-price-cell--pending svg{color:#94a3b8}.contract-price{font-weight:600;color:var(--text-primary)}.contract-price-cell--paid .contract-price{color:var(--primary-green)}.contract-price-cell--partial .contract-price{color:#f59e0b}.contract-price-cell--pending .contract-price{color:#64748b}.contract-price-status-pill{display:inline-block;padding:.2rem .5rem;border-radius:10px;font-size:.6875rem;font-weight:600;white-space:nowrap}.contract-price-status-pill--status-paid{background:#22c55e1f;color:var(--primary-green)}.contract-price-status-pill--status-partial{background:#f59e0b1f;color:#f59e0b}.contract-price-status-pill--status-pending{background:#64748b26;color:#64748b}.contract-paid-cell{display:flex;flex-direction:column;gap:.5rem;min-width:180px}.contract-paid-amount{display:flex;align-items:center;gap:.5rem}.contract-paid-amount svg{color:var(--text-secondary);flex-shrink:0}.contract-paid-amount .paid-full{font-weight:600;color:var(--primary-green)}.contract-paid-amount .paid-partial{font-weight:600;color:#f59e0b}.contract-paid-amount .paid-unpaid{font-weight:600;color:#ef4444}.contract-paid-progress{display:flex;align-items:center;gap:.5rem}.contract-paid-progress-bar{flex:1;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.contract-paid-progress-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:3px;transition:width .3s ease}.contract-paid-percentage{font-size:.75rem;font-weight:600;color:#f59e0b;min-width:35px}.contract-paid-status-badge{display:inline-block;padding:.25rem .625rem;border-radius:12px;font-size:.625rem;font-weight:600;white-space:nowrap}.contract-paid-status-badge.paid{background:#22c55e1a;color:var(--primary-green)}.contract-paid-status-badge.partial{background:#f59e0b1a;color:#f59e0b}.contract-paid-status-badge.unpaid{background:#ef44441a;color:#ef4444}.contract-status-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.contract-status-badge.active{background:#22c55e1a;color:var(--primary-green)}.contract-status-badge.expired{background:#ef44441a;color:#ef4444}.contract-action-buttons{display:flex;gap:.5rem;align-items:center}.contracts-page .contract-action-btn{width:32px;height:32px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;background:transparent}.contracts-page .contract-action-btn.view-btn{color:var(--primary-green)}.contracts-page .contract-action-btn.view-btn:hover{background:#22c55e1a;color:var(--primary-green-dark)}.contracts-page .contract-action-btn.contract-row-edit-btn{background:#3b82f61f!important;color:#3b82f6!important}.contracts-page .contract-action-btn.contract-row-edit-btn svg{color:#3b82f6!important;stroke:#3b82f6!important}.contracts-page .contract-action-btn.contract-row-edit-btn:hover{background:#3b82f633!important;color:#2563eb!important}.contracts-page .contract-action-btn.contract-row-edit-btn:hover svg{color:#2563eb!important;stroke:#2563eb!important}.contracts-page .contract-action-btn.delete-btn{color:#ef4444}.contracts-page .contract-action-btn.delete-btn:hover{background:#ef44441a;color:#dc2626}.no-contracts{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-secondary);text-align:center}.no-contracts svg{color:var(--text-secondary);opacity:.5}.no-contracts p{font-size:1rem;font-weight:500;color:var(--text-primary)}.contract-paid-status-badge.status-paid{background:#22c55e1a;color:var(--primary-green)}.contract-paid-status-badge.status-partial{background:#f59e0b1a;color:#f59e0b}.contract-paid-status-badge.status-pending{background:#ef44441a;color:#ef4444}@media(max-width:768px){.contracts-stats{grid-template-columns:repeat(2,1fr)}.contracts-filters-section{flex-direction:column;align-items:stretch}.contracts-search{min-width:100%}.contracts-table{font-size:.75rem}.contracts-table th,.contracts-table td{padding:.75rem .5rem}.contract-action-buttons{flex-direction:column;gap:.25rem}.contracts-page .contract-action-btn{width:28px;height:28px}}.create-contract-modal{background:var(--bg-primary);border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.modal-header-left{display:flex;align-items:flex-start;gap:1rem;flex:1}.modal-icon{width:48px;height:48px;border-radius:12px;background:#22c55e1a;color:var(--primary-green);display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.modal-header p{color:var(--text-secondary);margin:0;font-size:.875rem}.modal-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.create-contract-form{display:flex;flex-direction:column;gap:1.5rem}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-primary);font-size:.875rem}.form-input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;width:100%}.form-input::placeholder{color:var(--text-secondary)}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color)}.btn-cancel{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--primary-green);color:var(--primary-green)}.btn-submit{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d;display:flex;align-items:center;gap:.5rem}.btn-submit:hover:not(:disabled){box-shadow:0 6px 16px #22c55e66;transform:translateY(-1px)}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}}.contract-detail-page{width:100%;margin:0;padding:0}.contract-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:1rem}.back-button{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.back-button:hover{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border-color:var(--primary-green);transform:translate(-2px)}.header-title-section{display:flex;align-items:center;gap:1rem}.header-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #22c55e4d}.page-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem;letter-spacing:-.5px}.page-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0;font-weight:500}.header-actions{display:flex;gap:.75rem}.btn-edit,.btn-delete{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;border:none}.btn-edit{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f633}.btn-edit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.btn-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef444433}.btn-delete:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ef444466}.contract-detail-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color);background:var(--bg-primary);padding:0 .5rem;border-radius:12px 12px 0 0}.contract-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.9375rem;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;position:relative;top:2px}.contract-tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.contract-tab.active{color:var(--primary-green);border-bottom-color:var(--primary-green);background:var(--bg-secondary)}.contract-tab svg{color:inherit}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 .375rem;background:var(--primary-green);color:#fff;border-radius:10px;font-size:.75rem;font-weight:700;margin-left:.25rem}.contract-tab.active .tab-badge{background:var(--primary-green-dark)}.contract-detail-content{display:flex;flex-direction:column;gap:2rem}.payments-tab-content{min-height:400px}.payment-progress-section{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color);margin-bottom:1.5rem}.payment-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.payment-progress-title{display:flex;align-items:center;gap:.75rem;font-size:1.125rem;font-weight:700;color:var(--text-primary)}.payment-progress-title svg{color:var(--primary-green)}.payment-progress-stats{display:flex;gap:2rem;flex-wrap:wrap}.payment-stat{display:flex;flex-direction:column;gap:.25rem}.payment-stat-label{font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.payment-stat-value{font-size:1.25rem;font-weight:700}.payment-stat-value.paid{color:var(--primary-green)}.payment-stat-value.partial{color:#f59e0b}.payment-stat-value.pending{color:#ef4444}.payment-stat-value.total{color:#3b82f6}.payment-progress-bar-large{width:100%;height:16px;background:var(--bg-secondary);border-radius:10px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a;margin-bottom:1rem}.payment-progress-fill-large{height:100%;border-radius:10px;transition:width .8s ease;box-shadow:0 2px 8px #0003}.payment-progress-fill-large.paid{background:linear-gradient(90deg,var(--primary-green),var(--primary-green-dark));box-shadow:0 2px 8px #22c55e66}.payment-progress-fill-large.partial{background:linear-gradient(90deg,#f59e0b,#fbbf24);box-shadow:0 2px 8px #f59e0b66}.payment-progress-fill-large.pending{background:linear-gradient(90deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef444466}.payment-progress-footer{display:flex;justify-content:space-between;align-items:center}.payment-status-badge-large{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:12px;font-size:.875rem;font-weight:700}.payment-status-badge-large.paid{background:#22c55e1a;color:var(--primary-green)}.payment-status-badge-large.partial{background:#f59e0b1a;color:#f59e0b}.payment-status-badge-large.pending{background:#ef44441a;color:#ef4444}.payment-percentage-large{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.contract-info-compact{display:flex;flex-direction:column;gap:1.5rem}.info-section-compact{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color)}.info-compact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.info-compact-column{display:flex;flex-direction:column;gap:1rem}.info-compact-title-with-status{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--border-color)}.info-compact-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.info-compact-title svg{color:var(--primary-green)}.status-badge-inline{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:8px;font-size:.8125rem;font-weight:600;border:1.5px solid}.status-badge-inline.contract-status.active{background:#22c55e1a;color:var(--primary-green);border-color:var(--primary-green)}.status-badge-inline.contract-status.expired{background:#ef44441a;color:#ef4444;border-color:#ef4444}.info-compact-items{display:flex;flex-direction:column;gap:.875rem}.info-compact-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px;transition:all .3s ease}.info-compact-item:hover{background:#22c55e0d}.info-compact-label{font-size:.8125rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;min-width:100px;flex-shrink:0}.info-compact-value{font-size:.9375rem;color:var(--text-primary);font-weight:600;text-align:right;flex:1}.info-compact-value.highlight{color:var(--primary-green);font-weight:700;font-size:1rem}.contract-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}.summary-card{display:flex;align-items:center;gap:1.25rem;padding:1.75rem;background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);border:2px solid var(--border-color);transition:all .3s ease;position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--border-color);transition:all .3s ease}.summary-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}.summary-card.contract-status.active:before{background:linear-gradient(90deg,var(--primary-green),var(--primary-green-dark))}.summary-card.contract-status.expired:before{background:linear-gradient(90deg,#ef4444,#dc2626)}.summary-card.payment-status.paid:before{background:linear-gradient(90deg,var(--primary-green),var(--primary-green-dark))}.summary-card.payment-status.partial:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.summary-card.payment-status.pending:before{background:linear-gradient(90deg,#ef4444,#dc2626)}.summary-card.total-amount:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.summary-card.paid-amount:before{background:linear-gradient(90deg,var(--primary-green),var(--primary-green-dark))}.summary-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s ease}.summary-card.contract-status.active .summary-card-icon{background:linear-gradient(135deg,#22c55e26,#22c55e40);color:var(--primary-green)}.summary-card.contract-status.expired .summary-card-icon{background:linear-gradient(135deg,#ef444426,#ef444440);color:#ef4444}.summary-card.payment-status.paid .summary-card-icon{background:linear-gradient(135deg,#22c55e26,#22c55e40);color:var(--primary-green)}.summary-card.payment-status.partial .summary-card-icon{background:linear-gradient(135deg,#f59e0b26,#f59e0b40);color:#f59e0b}.summary-card.payment-status.pending .summary-card-icon{background:linear-gradient(135deg,#ef444426,#ef444440);color:#ef4444}.summary-card.total-amount .summary-card-icon{background:linear-gradient(135deg,#3b82f626,#3b82f640);color:#3b82f6}.summary-card.paid-amount .summary-card-icon{background:linear-gradient(135deg,#22c55e26,#22c55e40);color:var(--primary-green)}.summary-card-content{flex:1}.summary-card-label{font-size:.8125rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.summary-card-value{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2}.summary-card-subtext{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem;font-weight:500}.contract-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.info-column{display:flex;flex-direction:column;gap:1.5rem}.info-section{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color);transition:all .3s ease}.info-section:hover{box-shadow:0 8px 24px #00000014}.section-title{display:flex;align-items:center;gap:.75rem;font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0 0 1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.section-title-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#22c55e1a,#22c55e33);display:flex;align-items:center;justify-content:center;color:var(--primary-green)}.info-items{display:flex;flex-direction:column;gap:1.25rem}.info-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--bg-secondary);border-radius:12px;transition:all .3s ease}.info-item:hover{background:#22c55e0d;transform:translate(4px)}.info-item-header{display:flex;align-items:center;gap:.5rem}.info-item-icon{color:var(--primary-green);flex-shrink:0}.info-label{font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1rem;color:var(--text-primary);font-weight:600;padding-left:1.75rem}.info-value.highlight{font-size:1.25rem;font-weight:700;color:var(--primary-green)}.info-value.highlight-package{font-size:1.125rem;font-weight:700;color:#3b82f6}.info-value.paid{color:var(--primary-green);font-weight:700}.info-value.partial{color:#f59e0b;font-weight:700}.info-value.pending{color:#ef4444;font-weight:700}.info-value.date-value{font-family:Monaco,Menlo,monospace;font-size:.9375rem}.info-value.description-text{font-weight:400;line-height:1.6;color:var(--text-primary)}.info-value.payment-method-value{font-weight:600;color:#3b82f6}.payment-summary-item{padding:0;background:transparent}.payment-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.payment-summary-card{padding:1.25rem;background:var(--bg-secondary);border-radius:12px;border:2px solid var(--border-color);transition:all .3s ease}.payment-summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.payment-summary-card.total{border-color:#3b82f6;background:#3b82f60d}.payment-summary-card.paid.paid{border-color:var(--primary-green);background:#22c55e0d}.payment-summary-card.paid.partial{border-color:#f59e0b;background:#f59e0b0d}.payment-summary-card.paid.pending{border-color:#ef4444;background:#ef44440d}.payment-summary-card.remaining{border-color:var(--border-color)}.payment-summary-label{font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.payment-summary-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.payment-summary-card.total .payment-summary-value{color:#3b82f6}.payment-summary-card.paid.paid .payment-summary-value{color:var(--primary-green)}.payment-summary-card.paid.partial .payment-summary-value{color:#f59e0b}.payment-summary-card.paid.pending .payment-summary-value{color:#ef4444}.progress-item{padding:1.25rem}.payment-progress-detail{display:flex;align-items:center;gap:1rem;margin-top:.75rem}.payment-progress-bar{flex:1;height:10px;background:var(--bg-secondary);border-radius:6px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.payment-progress-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:6px;transition:width .8s ease;box-shadow:0 2px 8px #f59e0b66}.payment-progress-text{font-size:.875rem;font-weight:700;color:#f59e0b;min-width:50px;text-align:right}.payments-section{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color)}.section-header-with-badge{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.section-badge{display:inline-flex;align-items:center;padding:.375rem .875rem;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border-radius:20px;font-size:.75rem;font-weight:700;box-shadow:0 2px 8px #22c55e4d}.payments-table-container{overflow-x:auto;margin-top:1rem;border-radius:12px;border:1px solid var(--border-color)}.payments-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.payments-table thead{background:linear-gradient(135deg,var(--bg-secondary),rgba(34,197,94,.05))}.payments-table th{padding:1rem 1.25rem;text-align:left;font-weight:700;color:var(--text-primary);font-size:.8125rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.payments-table td{padding:1.25rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.9375rem}.payment-row{transition:all .3s ease}.payment-row:hover{background:#22c55e0d;transform:translate(4px)}.payment-date-cell,.payment-amount{font-weight:600}.payment-date-wrapper,.payment-amount-wrapper{display:flex;align-items:center;gap:.5rem}.payment-date-wrapper svg,.payment-amount-wrapper svg{color:var(--primary-green);flex-shrink:0}.payment-amount{color:var(--primary-green);font-size:1rem}.payment-method-badge{display:inline-block;padding:.375rem .875rem;border-radius:12px;font-size:.8125rem;font-weight:600;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.payment-method-badge.cash{background:#22c55e1a;color:var(--primary-green);border-color:#22c55e4d}.payment-method-badge.card{background:#3b82f61a;color:#3b82f6;border-color:#3b82f64d}.payment-method-badge.bank_transfer{background:#8b5cf61a;color:#8b5cf6;border-color:#8b5cf64d}.payment-note-cell{color:var(--text-secondary)}.payment-note-cell .no-note{font-style:italic;opacity:.5}.payment-status-badge{display:inline-block;padding:.375rem .875rem;border-radius:12px;font-size:.8125rem;font-weight:600;white-space:nowrap}.payment-status-badge.pending{background:#f59e0b1a;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.payment-status-badge.completed{background:#22c55e1a;color:var(--primary-green);border:1px solid rgba(34,197,94,.3)}.payment-status-badge.cancelled{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.payment-status-cell{text-align:left}.payment-status-wrapper{display:flex;align-items:center;gap:.5rem}.btn-update-payment-status{width:28px;height:28px;border:none;border-radius:6px;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.btn-update-payment-status:hover{background:var(--primary-green);color:#fff;transform:translateY(-2px);box-shadow:0 2px 4px #22c55e4d}.image-preview{margin-top:.5rem;padding:.5rem;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color)}.image-preview-text{margin:0;font-size:.8125rem;color:var(--text-primary);font-weight:500}.payment-image-cell{text-align:center}.payment-image-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background:#22c55e1a;color:var(--primary-green);border:1px solid rgba(34,197,94,.3);border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .3s ease}.payment-image-btn:hover{background:var(--primary-green);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #22c55e4d}.payment-image-cell .no-image{color:var(--text-secondary);font-style:italic;opacity:.5}.image-modal-content{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;margin:auto}.image-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.image-modal-header h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.image-modal-body{padding:1.5rem;display:flex;align-items:center;justify-content:center;max-height:calc(90vh - 100px);overflow:auto;min-height:200px}.payment-image-preview{max-width:100%;max-height:calc(90vh - 150px);width:auto;height:auto;border-radius:12px;box-shadow:var(--shadow);object-fit:contain;display:block;margin:0 auto}.create-payment-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--primary-green);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.create-payment-btn:hover:not(:disabled){background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.create-payment-btn:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto}.payment-form-modal{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-close-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.modal-close-btn:disabled{opacity:.6;cursor:not-allowed}.payment-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.note-section{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color);border-left:4px solid var(--primary-green)}.note-content{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--bg-secondary);border-radius:12px;color:var(--text-primary);line-height:1.8;font-size:.9375rem;margin-top:1rem}.note-icon{color:var(--primary-green);flex-shrink:0;margin-top:.125rem}.note-content p{margin:0;flex:1}.creator-section{background:var(--bg-primary);border-radius:16px;padding:1.5rem 2rem;box-shadow:var(--shadow);border:1px solid var(--border-color)}.creator-info-wrapper{display:flex;align-items:center;gap:1rem}.creator-icon{width:40px;height:40px;padding:.75rem;background:linear-gradient(135deg,#22c55e1a,#22c55e33);border-radius:10px;color:var(--primary-green);flex-shrink:0}.creator-info{display:flex;flex-direction:column;gap:.25rem}.creator-label{font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.creator-name{font-size:1rem;color:var(--text-primary);font-weight:600}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6rem 2rem;gap:1.5rem;color:var(--text-secondary);text-align:center}.error-container svg{color:#ef4444;opacity:.5}.btn-back{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;margin-top:1rem;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d}.btn-back:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}.no-payments{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6rem 2rem;gap:1rem;background:var(--bg-primary);border-radius:16px;border:2px dashed var(--border-color);text-align:center}.no-payments svg{color:var(--text-secondary);opacity:.5}.no-payments p{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.no-payments-hint{font-size:.875rem;color:var(--text-secondary);font-weight:400;font-style:italic}@media(max-width:1024px){.contract-info-grid,.payment-summary-grid{grid-template-columns:1fr}}@media(max-width:768px){.contract-detail-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.25rem}.header-actions{width:100%;flex-direction:column}.btn-edit,.btn-delete{width:100%;justify-content:center}.contract-detail-tabs{padding:0 .25rem}.contract-tab{padding:.875rem 1rem;font-size:.875rem}.payment-progress-section{padding:1.5rem}.payment-progress-header{flex-direction:column;align-items:flex-start}.payment-progress-stats{width:100%;flex-direction:column;gap:1rem}.info-compact-grid{grid-template-columns:1fr;gap:1.5rem}.info-section-compact{padding:1.5rem}.info-compact-item{flex-direction:column;align-items:flex-start;gap:.5rem}.info-compact-label{min-width:auto}.info-compact-value{text-align:left}.payments-section{padding:1.5rem}.section-header-with-badge{flex-direction:column;align-items:flex-start;gap:.75rem}.payments-table{font-size:.8125rem}.payments-table th,.payments-table td{padding:.875rem .75rem}}.schedule-page{max-width:1400px;margin:0 auto}.session-types-filter{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);padding:1.5rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.filter-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.filter-type-btn{padding:.5rem 1rem;border:2px solid;border-radius:20px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.filter-type-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.week-view-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);padding:2rem;margin-bottom:2rem;overflow-x:auto}.week-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.week-grid{display:grid;grid-template-columns:80px repeat(7,1fr);grid-template-rows:auto repeat(17,60px);gap:1px;background:var(--border-color);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.week-grid-header-empty{background:var(--bg-secondary);border-bottom:2px solid var(--border-color)}.week-day-header{background:var(--bg-secondary);padding:1rem;text-align:center;border-bottom:2px solid var(--border-color);position:relative}.week-day-header.today{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border-bottom-color:var(--primary-green)}.week-day-name{font-weight:600;color:var(--text-primary);font-size:.875rem;margin-bottom:.25rem}.week-day-number{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.week-day-header.today .week-day-number{color:var(--primary-green)}.today-indicator{position:absolute;top:.5rem;right:.5rem;background:var(--primary-green);color:#fff;font-size:.625rem;font-weight:600;padding:.25rem .5rem;border-radius:12px}.week-time-label{background:var(--bg-secondary);padding:.5rem;text-align:center;font-weight:600;color:var(--text-secondary);font-size:.75rem;border-right:2px solid var(--border-color);display:flex;align-items:center;justify-content:center}.week-cell{background:var(--bg-primary);min-height:60px;padding:.25rem;position:relative;cursor:pointer;transition:all .2s ease;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);overflow:visible}.week-cell:hover{background:#22c55e08}.week-session-block{position:absolute;left:.25rem;right:.25rem;top:.25rem;border-radius:8px;padding:.5rem;color:#fff;font-size:.75rem;cursor:pointer;box-shadow:0 2px 8px #0003;z-index:2;display:flex;flex-direction:column;gap:.25rem;overflow:hidden;word-wrap:break-word}.session-block-student{font-weight:700;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-block-type{font-weight:600;font-size:.75rem;opacity:.9}.session-block-time{font-size:.625rem;opacity:.8;margin-top:auto}.calendar-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);padding:2rem;margin-bottom:2rem}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.375rem}.calendar-day{aspect-ratio:1;min-height:70px;background:var(--bg-secondary);border:2px solid transparent;border-radius:8px;padding:.5rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;position:relative;overflow:hidden}.calendar-day:hover{background:#22c55e0d;border-color:var(--primary-green);transform:translateY(-2px);box-shadow:var(--shadow)}.calendar-day.today{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border-color:var(--primary-green);font-weight:700}.calendar-day.today .calendar-day-number{color:var(--primary-green);font-weight:700}.calendar-day.selected{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));border-color:var(--primary-green);color:#fff}.calendar-day.selected .calendar-day-number{color:#fff;font-weight:700}.calendar-day.has-sessions{border-color:var(--primary-green)}.calendar-day.empty{cursor:default;background:transparent;border:none}.calendar-day.empty:hover{background:transparent;transform:none;box-shadow:none}.calendar-day-number{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.calendar-sessions-preview{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center;margin-top:auto}.session-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.session-more{font-size:.625rem;font-weight:600;color:var(--text-secondary);margin-left:.25rem}.calendar-day.selected .session-more{color:#fffc}.session-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.session-modal-content{background:var(--bg-primary);border-radius:16px;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.session-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.session-modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.session-modal-date{color:var(--text-secondary);font-size:.875rem}.session-modal-body{min-height:200px}.sessions-list{display:flex;flex-direction:column;gap:1rem}.session-item{background:var(--bg-secondary);border-left:4px solid;border-radius:12px;padding:1.25rem;transition:all .3s ease;cursor:pointer}.session-item:hover{background:#22c55e0d;box-shadow:var(--shadow)}.session-time{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;font-size:1rem}.session-time svg{color:var(--primary-green)}.session-duration{font-size:.875rem;color:var(--text-secondary);font-weight:400}.session-info{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.session-student{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);font-weight:500}.session-student svg{color:var(--text-secondary)}.session-type{font-weight:600;font-size:.875rem;padding:.375rem .75rem;border-radius:20px;background:#22c55e1a}.no-sessions{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--text-secondary)}.no-sessions svg{margin-bottom:1rem;opacity:.5}.no-sessions p{margin-bottom:1.5rem;font-size:1rem}@media(max-width:768px){.page-header-actions{flex-direction:column;width:100%}.view-mode-toggle{width:100%;justify-content:stretch}.view-mode-btn{flex:1}.session-types-filter{flex-direction:column;align-items:flex-start}.filter-buttons{width:100%}.filter-type-btn{flex:1}.calendar-container,.week-view-container{padding:1rem}.calendar-header,.week-header{flex-direction:column;align-items:stretch}.calendar-month-year,.week-range{justify-content:center;order:-1}.today-btn{margin-left:0;width:100%}.week-nav-btn{flex:1}.calendar-day{min-height:60px;padding:.375rem}.calendar-day-number{font-size:.75rem}.week-grid{grid-template-columns:60px repeat(7,1fr);grid-template-rows:auto repeat(17,50px)}.week-time-label{font-size:.625rem;padding:.25rem}.week-day-header{padding:.75rem .5rem}.week-day-name{font-size:.75rem}.week-day-number{font-size:1.25rem}.week-session-block{padding:.375rem;font-size:.625rem}.session-block-student{font-size:.75rem}.session-modal-content{padding:1.5rem}.session-item{padding:1rem}}@media(max-width:480px){.calendar-day{min-height:50px;padding:.25rem}.calendar-day-header{padding:.5rem .25rem;font-size:.625rem}.calendar-day-number{font-size:.625rem}.session-dot{width:6px;height:6px}.week-grid{grid-template-columns:50px repeat(7,1fr);grid-template-rows:auto repeat(17,40px)}.week-time-label{font-size:.5rem}.week-day-header{padding:.5rem .25rem}.week-day-name{font-size:.625rem}.week-day-number{font-size:1rem}.today-indicator{font-size:.5rem;padding:.125rem .25rem;top:.25rem;right:.25rem}.week-session-block{padding:.25rem;font-size:.5rem}.session-block-student{font-size:.625rem}.session-block-type,.session-block-time{font-size:.5rem}}.exercise-detail-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:3000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.exercise-detail-content{background:var(--bg-primary);border-radius:20px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.exercise-detail-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.exercise-detail-title-section{display:flex;align-items:center;gap:.75rem;flex:1}.exercise-detail-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.exercise-detail-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.exercise-detail-meta{display:flex;gap:.75rem;flex-wrap:wrap}.exercise-detail-category{padding:.375rem .75rem;background:#3b82f61a;color:#3b82f6;border-radius:20px;font-size:.875rem;font-weight:600}.exercise-detail-difficulty{padding:.375rem .75rem;background:#f59e0b1a;color:#f59e0b;border-radius:20px;font-size:.875rem;font-weight:600}.exercise-detail-actions{display:flex;align-items:center;gap:.75rem}.language-toggle{display:flex;background:var(--bg-primary);border-radius:8px;padding:.25rem;border:1px solid var(--border-color)}.lang-btn{padding:.5rem .75rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;border-radius:6px;transition:all .2s ease}.lang-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.lang-btn.active{background:var(--primary-green);color:#fff}.exercise-detail-close{width:40px;height:40px;border:none;border-radius:10px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.exercise-detail-close:hover{background:#ef4444;color:#fff}.exercise-detail-error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:.875rem}.exercise-detail-error-banner svg{flex-shrink:0;color:#ef4444}.language-indicator-detail{display:flex;align-items:center;gap:.5rem;padding:.75rem 2rem;background:var(--bg-secondary);color:var(--text-secondary);font-size:.875rem;border-bottom:1px solid var(--border-color)}.language-indicator-detail svg{color:var(--primary-green)}.language-indicator-detail strong{color:var(--primary-green);font-weight:600}.exercise-detail-body{padding:2rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.5rem}.detail-text-content{padding:.875rem 1rem;background:var(--bg-secondary);border-radius:10px;color:var(--text-secondary);line-height:1.6;font-size:.875rem;min-height:60px}.detail-badge-content{display:flex;align-items:center}.detail-category-badge{display:inline-block;padding:.5rem .75rem;background:#3b82f61a;color:#3b82f6;border-radius:20px;font-size:.875rem;font-weight:600}.detail-difficulty-badge{display:inline-block;padding:.5rem .75rem;background:#f59e0b1a;color:#f59e0b;border-radius:20px;font-size:.875rem;font-weight:600}.muscle-groups-detail-compact{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem;background:var(--bg-secondary);border-radius:10px;min-height:50px}.muscle-group-chip-detail{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;font-size:.875rem;color:var(--text-primary);font-weight:500}.muscle-group-chip-detail.primary{background:#22c55e1a;border-color:var(--primary-green);color:var(--primary-green);font-weight:600}.chip-primary-indicator{color:var(--primary-green);font-weight:700;font-size:1rem}.detail-media-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:10px;color:var(--primary-green);font-weight:600;font-size:.875rem;text-decoration:none;transition:all .3s ease;width:100%;justify-content:center}.detail-media-link:hover{background:var(--primary-green);color:#fff}.youtube-video-container{display:flex;flex-direction:column;gap:.75rem}.youtube-embed{width:100%;aspect-ratio:16 / 9;border-radius:10px;background:var(--bg-secondary)}.youtube-link-external{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-secondary);border-radius:8px;color:var(--primary-green);font-weight:600;font-size:.875rem;text-decoration:none;transition:all .3s ease;width:fit-content;align-self:flex-start}.youtube-link-external:hover{background:var(--primary-green);color:#fff}.detail-image-wrapper{width:100%;height:200px;background:var(--bg-secondary);border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}.detail-image{width:100%;height:100%;object-fit:cover}.detail-images-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:10px}.detail-image-item{display:flex;flex-direction:column;gap:.5rem}.detail-image-item .detail-image-wrapper{width:100%;height:200px;position:relative;cursor:pointer;transition:transform .3s ease}.detail-image-item .detail-image-wrapper:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000026}.detail-image-item .detail-image{border-radius:10px}.detail-image-order{position:absolute;top:.5rem;left:.5rem;background:#000000b3;color:#fff;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.detail-image-caption{padding:.5rem;background:var(--bg-primary);border-radius:6px;font-size:.8125rem;color:var(--text-secondary);text-align:center;line-height:1.4}.exercise-info-grid-compact{display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:10px}.info-item-compact{display:flex;align-items:center;gap:.5rem}.info-label-compact{font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-value-compact{font-size:.875rem;color:var(--text-primary);font-weight:500}.exercise-detail-loading,.exercise-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-secondary)}.loading-spinner{width:32px;height:32px;border:3px solid rgba(34,197,94,.2);border-top-color:var(--primary-green);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.no-data{color:var(--text-secondary);font-style:italic;margin:0}@media(max-width:768px){.exercise-detail-content{max-height:95vh}.exercise-detail-header{padding:1.25rem 1.5rem;flex-direction:column;align-items:flex-start;gap:1rem}.exercise-detail-header-actions{width:100%;justify-content:space-between}.exercise-detail-title{font-size:1.25rem}.exercise-detail-body{padding:1.5rem}.form-row{grid-template-columns:1fr}.exercise-info-grid-compact{flex-direction:column;gap:.75rem}}.exercise-form-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:3000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.exercise-form-content{background:var(--bg-primary);border-radius:20px;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.exercise-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.exercise-form-title-section{display:flex;align-items:center;gap:.75rem}.exercise-form-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff}.exercise-form-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.exercise-form-header-actions{display:flex;align-items:center;gap:.75rem}.language-toggle-form{display:flex;background:var(--bg-primary);border-radius:8px;padding:.25rem;border:1px solid var(--border-color)}.lang-btn-form{padding:.5rem .75rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;border-radius:6px;transition:all .2s ease}.lang-btn-form:hover{background:var(--bg-secondary);color:var(--text-primary)}.lang-btn-form.active{background:var(--primary-green);color:#fff}.exercise-form-close{width:40px;height:40px;border:none;border-radius:10px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.exercise-form-close:hover{background:#ef4444;color:#fff}.exercise-form-error{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:.875rem}.exercise-form-error svg{flex-shrink:0;color:#ef4444}.exercise-form{padding:2rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.5rem}.language-indicator{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:10px;color:var(--text-secondary);font-size:.875rem}.language-indicator svg{color:var(--primary-green)}.language-indicator strong{color:var(--primary-green);font-weight:600}.form-input,.form-textarea,.form-select{padding:.875rem 1rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;width:100%}.form-hint{font-size:.75rem;color:var(--text-secondary);font-style:italic;padding:.5rem;background:var(--bg-secondary);border-radius:6px;border-left:3px solid var(--primary-green)}.muscle-groups-selector{display:flex;flex-wrap:wrap;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);min-height:80px}.muscle-group-chip{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:2px solid var(--border-color);border-radius:20px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color);margin-top:.5rem}.btn-cancel,.btn-submit{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;border:none}@media(max-width:768px){.exercise-form-content{max-height:95vh}.exercise-form-header{padding:1.25rem 1.5rem;flex-direction:column;align-items:flex-start;gap:1rem}.exercise-form-header-actions{width:100%;justify-content:space-between}.exercise-form{padding:1.5rem}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%;justify-content:center}}.exercises-page{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-actions-exercises{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.btn-primary{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d;font-size:.875rem}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;font-size:.875rem}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--primary-green);color:var(--primary-green)}.exercises-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-primary)}.exercises-table-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;overflow-x:auto}.exercises-pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding:1rem 1.25rem;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.exercises-pagination .pagination-info{font-size:.875rem;color:var(--text-secondary)}.exercises-pagination .pagination-buttons{display:flex;align-items:center;gap:.5rem}.exercises-pagination .pagination-btn{display:flex;align-items:center;justify-content:center;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.exercises-pagination .pagination-btn:hover:not(:disabled){border-color:var(--primary-green);color:var(--primary-green);background:#22c55e14}.exercises-pagination .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.exercises-pagination .pagination-page{font-weight:600;min-width:2rem;text-align:center;font-size:.875rem;color:var(--text-primary)}.exercises-table{width:100%;border-collapse:collapse}.exercises-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.exercise-name-cell{display:flex;align-items:center;gap:.5rem}.exercise-name-cell svg{color:var(--primary-green);flex-shrink:0}.exercise-description{color:var(--text-secondary);max-width:300px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exercise-type-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.exercise-type-badge.strength{background:#3b82f61a;color:#3b82f6}.exercise-type-badge.cardio{background:#ef44441a;color:#ef4444}.exercise-type-badge.yoga{background:#22c55e1a;color:var(--primary-green)}.exercise-type-badge.pilates{background:#8b5cf61a;color:#8b5cf6}.exercise-type-badge.core{background:#f59e0b1a;color:#f59e0b}.exercise-type-badge.flexibility{background:#06b6d41a;color:#06b6d4}.exercise-difficulty-badge{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.exercise-difficulty-badge.dễ{background:#22c55e1a;color:var(--primary-green)}.exercise-difficulty-badge.trung-bình{background:#f59e0b1a;color:#f59e0b}.exercise-difficulty-badge.khó{background:#ef44441a;color:#ef4444}.exercise-muscle-groups{display:flex;flex-wrap:wrap;gap:.375rem}.muscle-group-tag{padding:.25rem .5rem;background:var(--bg-secondary);border-radius:12px;font-size:.75rem;color:var(--text-primary);font-weight:500}.video-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary-green);font-weight:600;text-decoration:none;transition:all .3s ease;font-size:.875rem}.video-link:hover{color:var(--primary-green-dark);text-decoration:underline}.no-video{color:var(--text-secondary);font-size:.875rem}.exercise-action-buttons{display:flex;gap:.5rem;align-items:center}.exercises-page .exercise-action-btn{width:32px;height:32px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;background:transparent}.exercises-page .exercise-action-btn.view-btn{color:var(--primary-green)}.exercises-page .exercise-action-btn.view-btn:hover{background:#22c55e1a;color:var(--primary-green-dark)}.exercises-page .exercise-action-btn.exercise-row-edit-btn{background:#3b82f61f!important;color:#3b82f6!important}.exercises-page .exercise-action-btn.exercise-row-edit-btn svg{color:#3b82f6!important;stroke:#3b82f6!important}.exercises-page .exercise-action-btn.exercise-row-edit-btn:hover{background:#3b82f633!important;color:#2563eb!important}.exercises-page .exercise-action-btn.exercise-row-edit-btn:hover svg{color:#2563eb!important;stroke:#2563eb!important}.exercises-page .exercise-action-btn.delete-btn{color:#ef4444}.exercises-page .exercise-action-btn.delete-btn:hover{background:#ef44441a;color:#dc2626}.no-exercises{text-align:center;padding:3rem;color:var(--text-secondary)}.no-muscle-groups{color:var(--text-secondary);font-style:italic;font-size:.875rem}.error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#fca5a5;margin-bottom:1.5rem;font-size:.875rem}.error-banner svg{flex-shrink:0;color:#ef4444}.error-banner span{flex:1}.error-close-btn{background:none;border:none;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;border-radius:4px;transition:all .2s ease;flex-shrink:0}.error-close-btn:hover{background:#ffffff1a;color:#fff}.exercise-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.exercise-dialog-content{background:var(--bg-primary);border-radius:16px;padding:2rem;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.dialog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.dialog-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.exercise-form{display:flex;flex-direction:column;gap:1.25rem}.form-group input,.form-group textarea,.form-group select{padding:.75rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:1rem;margin-top:.5rem;justify-content:flex-end}@media(max-width:768px){.exercises-filters{flex-direction:column}.search-box{min-width:100%}.exercises-table{font-size:.75rem}.exercises-table th,.exercises-table td{padding:.75rem .5rem}.exercise-description{max-width:200px}.form-row{grid-template-columns:1fr}.exercise-dialog-content{padding:1.5rem}.form-actions{flex-direction:column}.form-actions button{width:100%}}@media(max-width:480px){.exercise-action-buttons{flex-direction:column;gap:.25rem}.exercises-page .exercise-action-btn{width:28px;height:28px}.exercise-muscle-groups{flex-direction:column}}.edit-exercise-page{width:100%;margin:0;padding:0;margin-left:-2rem;margin-right:-2rem;padding-left:2rem;padding-right:2rem}.edit-exercise-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:.75rem}.back-button{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.back-button:hover{background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.header-title-section{display:flex;align-items:center;gap:.625rem}.header-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff}.page-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .125rem}.header-actions{display:flex;align-items:center;gap:1rem}.language-toggle-page{display:flex;background:var(--bg-secondary);border-radius:8px;padding:.25rem;border:1px solid var(--border-color)}.lang-btn-page{padding:.5rem .75rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;border-radius:6px;transition:all .2s ease}.lang-btn-page:hover{background:var(--bg-primary);color:var(--text-primary)}.lang-btn-page.active{background:var(--primary-green);color:#fff}.message-banner{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:6px;margin-bottom:.5rem;font-size:.875rem}.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.error-banner svg{color:#ef4444;flex-shrink:0}.success-banner{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#86efac}.success-banner svg{color:var(--primary-green);flex-shrink:0}.message-banner span{flex:1}.message-close{background:none;border:none;color:inherit;cursor:pointer;display:flex;align-items:center;padding:.25rem;border-radius:4px;transition:all .2s ease;opacity:.7}.message-close:hover{opacity:1;background:#ffffff1a}.edit-exercise-content{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow);padding:.5rem}.exercise-edit-form{display:flex;flex-direction:column;gap:.625rem}.language-indicator-page{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;background:var(--bg-secondary);border-radius:6px;color:var(--text-secondary);font-size:.8125rem;border-left:3px solid var(--primary-green)}.form-layout-grid{display:grid;grid-template-columns:1fr 1fr;gap:.625rem;align-items:start}.form-column-left,.form-column-right{display:flex;flex-direction:column;gap:.5rem}.language-indicator-page svg{color:var(--primary-green)}.language-indicator-page strong{color:var(--primary-green);font-weight:600}.form-section{display:flex;flex-direction:column;gap:.625rem;padding:.625rem;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color)}.section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem;padding-bottom:.375rem;border-bottom:1px solid var(--border-color)}.section-title svg{color:var(--primary-green)}.form-group{display:flex;flex-direction:column;gap:.25rem}.form-group label svg{color:var(--text-secondary)}.form-input,.form-textarea,.form-select{padding:.5rem .625rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;width:100%}.form-textarea{resize:vertical;min-height:100px}.form-select:disabled{opacity:.6;cursor:not-allowed}.form-hint{font-size:.75rem;color:var(--text-secondary);font-style:italic;padding:.25rem .375rem;background:var(--bg-primary);border-radius:4px;border-left:3px solid var(--primary-green)}.video-input-wrapper{position:relative;display:flex;align-items:center}.video-input-wrapper .form-input{padding-right:2.5rem}.input-success-icon{position:absolute;right:.75rem;color:var(--primary-green);display:flex;align-items:center;pointer-events:none}.input-error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-error-hint{font-size:.75rem;color:#ef4444;margin-top:.25rem}.form-success-hint{font-size:.75rem;color:var(--primary-green);margin-top:.25rem}.muscle-groups-selector{display:flex;flex-wrap:wrap;gap:.375rem;padding:.5rem;background:var(--bg-primary);border-radius:6px;border:1px solid var(--border-color);min-height:70px}.muscle-group-chip{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;border:2px solid var(--border-color);border-radius:14px;background:var(--bg-secondary);color:var(--text-primary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease}.muscle-group-chip:hover{border-color:var(--primary-green);background:#22c55e1a;color:var(--primary-green)}.muscle-group-chip.selected{border-color:var(--primary-green);background:var(--primary-green);color:#fff}.muscle-group-chip.primary{border-color:#f59e0b;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 8px #f59e0b4d}.chip-check{font-weight:700;font-size:1rem}.chip-primary-indicator{font-size:.875rem;margin-left:.25rem;color:#fbbf24}.form-actions-page{display:flex;gap:.625rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--border-color);margin-top:.125rem}.btn-cancel-page,.btn-submit-page{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;border-radius:6px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;border:none}.btn-cancel-page{background:var(--bg-secondary);color:var(--text-primary)}.btn-cancel-page:hover:not(:disabled){background:var(--text-secondary);color:#fff}.btn-submit-page{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;box-shadow:0 4px 12px #22c55e4d}.btn-submit-page:hover:not(:disabled){box-shadow:0 6px 20px #22c55e66;transform:translateY(-1px)}.btn-cancel-page:disabled,.btn-submit-page:disabled{opacity:.6;cursor:not-allowed;transform:none}.image-mode-selector{display:flex;gap:.5rem;flex-wrap:wrap}.image-mode-option{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);cursor:pointer;transition:all .3s ease;flex:1;min-width:120px;justify-content:center}.image-mode-option:hover{border-color:var(--primary-green);background:#22c55e0d}.image-mode-option input[type=radio]{margin:0;cursor:pointer;accent-color:var(--primary-green)}.image-mode-option input[type=radio]:checked+svg{color:var(--primary-green)}.image-mode-option:has(input[type=radio]:checked){border-color:var(--primary-green);background:#22c55e1a;color:var(--primary-green)}.image-mode-option svg{color:var(--text-secondary);transition:color .3s ease}.image-mode-option:has(input[type=radio]:checked) svg{color:var(--primary-green)}.image-mode-option span{font-weight:500;font-size:.875rem;color:var(--text-primary)}.image-mode-option:has(input[type=radio]:checked) span{color:var(--primary-green);font-weight:600}.file-upload-area{border:2px dashed var(--border-color);border-radius:8px;padding:1.5rem;text-align:center;background:var(--bg-primary);transition:all .3s ease}.file-upload-area:hover{border-color:var(--primary-green);background:#22c55e0d}.file-input-hidden{display:none}.file-upload-label{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-primary)}.file-upload-label svg{color:var(--primary-green);margin-bottom:.25rem}.file-upload-label span:first-of-type{font-weight:600;font-size:.875rem}.file-upload-hint{font-size:.75rem;color:var(--text-secondary);font-style:italic}.file-preview-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:1rem}.file-preview-item{display:flex;flex-direction:column;gap:.5rem}.file-preview-image{position:relative;width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid var(--border-color);background:var(--bg-secondary)}.file-preview-image img{width:100%;height:100%;object-fit:cover}.file-remove-btn{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;border-radius:50%;background:#ef4444e6;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #0003}.file-remove-btn:hover{background:#dc2626;transform:scale(1.1)}.file-caption-input{padding:.5rem;border:1px solid var(--border-color);border-radius:6px;font-size:.8125rem;background:var(--bg-primary);color:var(--text-primary);width:100%;transition:all .3s ease}.file-caption-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.file-preview-order{position:absolute;top:.5rem;left:.5rem;background:#22c55ee6;color:#fff;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1}.file-caption-display{padding:.5rem;background:var(--bg-secondary);border-radius:6px;font-size:.8125rem;color:var(--text-secondary);text-align:center;line-height:1.4;font-style:italic}.image-urls-list{display:flex;flex-direction:column;gap:.75rem}.image-url-item{display:flex;flex-direction:column;gap:.5rem}.image-url-inputs{display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem;align-items:start}.image-url-inputs .form-input{margin:0}.btn-remove-url{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid #ef4444;border-radius:6px;background:transparent;color:#ef4444;cursor:pointer;transition:all .3s ease;flex-shrink:0}.btn-remove-url:hover{background:#ef4444;color:#fff}.btn-add-url{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border:2px dashed var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-add-url:hover{border-color:var(--primary-green);background:#22c55e0d;color:var(--primary-green)}.btn-add-url svg{color:var(--primary-green)}.edit-exercise-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid var(--border-color);background:var(--bg-primary);padding:0 2rem}.edit-tab{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;position:relative;top:2px}.edit-tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.edit-tab.active{color:var(--primary-green);border-bottom-color:var(--primary-green);background:var(--bg-secondary)}.edit-tab svg{color:inherit}.images-management-section{display:flex;flex-direction:column;gap:1.5rem}.images-gallery-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.btn-delete-all{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:1px solid #ef4444;border-radius:8px;background:transparent;color:#ef4444;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-delete-all:hover{background:#ef4444;color:#fff}.no-images-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;background:var(--bg-secondary);border-radius:12px;border:2px dashed var(--border-color);color:var(--text-secondary);text-align:center}.no-images-message svg{color:var(--text-secondary);opacity:.5}.no-images-message .hint{font-size:.875rem;font-style:italic;opacity:.7}.add-images-section{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color)}.subsection-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.selected-files-preview{display:flex;flex-direction:column;gap:1rem}.btn-add-images{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;align-self:flex-start}.btn-add-images:hover:not(:disabled){box-shadow:0 4px 12px #22c55e4d;transform:translateY(-1px)}.btn-add-images:disabled{opacity:.6;cursor:not-allowed}.confirm-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:4000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-modal-content{background:var(--bg-primary);border-radius:16px;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;overflow:hidden}.confirm-modal-header{display:flex;align-items:center;gap:.75rem;padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.confirm-icon{color:#f59e0b;flex-shrink:0}.confirm-modal-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.confirm-modal-body{padding:1.5rem}.confirm-modal-body p{margin:0;color:var(--text-primary);line-height:1.6;font-size:.9375rem}.confirm-modal-actions{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);justify-content:flex-end;background:var(--bg-secondary)}.btn-cancel-confirm,.btn-confirm{padding:.625rem 1.25rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;border:none}.btn-cancel-confirm{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-cancel-confirm:hover{background:var(--text-secondary);color:#fff}.btn-confirm{background:#ef4444;color:#fff}.btn-confirm:hover{background:#dc2626;box-shadow:0 4px 12px #ef44444d}@media(max-width:1024px){.form-layout-grid{grid-template-columns:1fr;gap:1rem}.image-url-inputs{grid-template-columns:1fr}.btn-remove-url{width:100%}.edit-exercise-tabs{padding:0 1rem}.images-gallery-header{flex-direction:column;align-items:flex-start;gap:1rem}}@media(max-width:768px){.edit-exercise-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-left{flex-direction:column;align-items:flex-start;width:100%}.header-title-section{width:100%}.page-title{font-size:1.5rem}.edit-exercise-content{padding:1rem}.form-section{padding:.875rem}.form-layout-grid{grid-template-columns:1fr}.form-actions-page{flex-direction:column}.btn-cancel-page,.btn-submit-page{width:100%;justify-content:center}}.manage-categories-muscle-groups-page{width:100%;margin:0;padding:0;margin-left:-2rem;margin-right:-2rem;padding-left:2rem;padding-right:2rem}.page-header-manage{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.header-left-manage{display:flex;align-items:center;gap:.75rem}.back-button-manage{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.back-button-manage:hover{background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.header-title-section-manage{display:flex;align-items:center;gap:.625rem}.header-icon-manage{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff}.page-title-manage{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .125rem}.page-subtitle-manage{font-size:.875rem;color:var(--text-secondary);margin:0}.header-actions-manage{display:flex;align-items:center;gap:1rem}.language-toggle-manage{display:flex;background:var(--bg-secondary);border-radius:8px;padding:.25rem;border:1px solid var(--border-color)}.lang-btn-manage{padding:.5rem .75rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;border-radius:6px;transition:all .2s ease}.lang-btn-manage:hover{background:var(--bg-primary);color:var(--text-primary)}.lang-btn-manage.active{background:var(--primary-green);color:#fff}.tabs-container{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow);padding:.5rem;margin-top:.5rem}.tabs-header-wrapper{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:.5rem;gap:1rem;flex-wrap:wrap}.tabs-header{display:flex;gap:.5rem}.tab-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;border-radius:6px 6px 0 0;transition:all .2s ease;position:relative}.tab-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.tab-button.active{color:var(--primary-green);background:var(--bg-secondary)}.tab-button.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--primary-green)}.btn-create-tab{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border:none;border-radius:6px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #22c55e4d}.btn-create-tab:hover{box-shadow:0 4px 12px #22c55e66}.tab-content{min-height:400px}.tab-panel{width:100%}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-secondary)}.table-container{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow);overflow:hidden;overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-secondary)}.data-table th{padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);white-space:nowrap}.data-table tbody tr{border-bottom:1px solid var(--border-color);transition:all .2s ease}.data-table tbody tr:hover{background:var(--bg-secondary)}.data-table td{padding:.875rem 1rem;font-size:.875rem;color:var(--text-primary)}.table-row{cursor:default}.table-cell-name{display:flex;align-items:center;gap:.75rem}.table-icon{width:32px;height:32px;border-radius:6px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.table-icon img{width:100%;height:100%;object-fit:cover}.code-badge{font-family:Courier New,monospace;font-size:.875rem;font-weight:600;color:var(--text-primary)}.icon-preview{width:40px;height:40px;border-radius:6px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden}.icon-preview img{width:100%;height:100%;object-fit:cover}.no-icon{color:var(--text-secondary);font-style:italic}.action-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;background:transparent}.edit-btn{color:var(--primary-green)}.edit-btn:hover{background:#22c55e1a;color:var(--primary-green-dark)}@media(max-width:768px){.page-header-manage{flex-direction:column;align-items:flex-start;gap:1rem}.header-left-manage{flex-direction:column;align-items:flex-start;width:100%}.tabs-header{flex-direction:column;gap:.25rem}.tab-button{border-radius:6px}.tab-button.active:after{display:none}.table-container{overflow-x:auto}.data-table{min-width:600px}.tabs-header-wrapper{flex-direction:column;align-items:stretch}.btn-create-tab{width:100%;justify-content:center}}.create-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.create-dialog-content{background:var(--bg-primary);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.create-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.create-dialog-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.form-input-dialog{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;width:100%}.form-input-dialog:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.form-hint-dialog{font-size:.75rem;color:var(--text-secondary);font-style:italic;padding:.5rem;background:var(--bg-secondary);border-radius:6px;border-left:3px solid var(--primary-green)}.packages-page{max-width:1400px;margin:0 auto}.packages-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.packages-table-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;overflow-x:auto}.packages-table{width:100%;border-collapse:collapse}.packages-table thead{background:var(--bg-secondary)}.packages-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);white-space:nowrap}.packages-table tbody tr{border-bottom:1px solid var(--border-color);transition:all .3s ease}.packages-table tbody tr:hover{background:var(--bg-secondary)}.packages-table td{padding:1rem;font-size:.875rem;color:var(--text-primary)}.package-table-row{cursor:default}.package-name-cell{display:flex;align-items:center;gap:.75rem}.package-name-cell svg{color:var(--primary-green);flex-shrink:0}.package-name{font-weight:600;color:var(--text-primary)}.package-duration-cell,.package-price-cell,.package-description-cell{display:flex;align-items:center;gap:.5rem}.package-duration-cell svg,.package-price-cell svg,.package-description-cell svg{color:var(--text-secondary);flex-shrink:0}.package-price{font-weight:600;color:var(--primary-green);font-size:.9375rem}.package-description{color:var(--text-secondary);max-width:300px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.package-actions{display:flex;align-items:center;gap:.5rem}.packages-page .action-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;background:transparent}.packages-page .action-btn.view-btn{color:var(--primary-green)}.packages-page .action-btn.view-btn:hover{background:#22c55e1a;color:var(--primary-green-dark)}.packages-page .action-btn.package-row-edit-btn{background:#3b82f61f!important;color:#3b82f6!important}.packages-page .action-btn.package-row-edit-btn svg{color:#3b82f6!important;stroke:#3b82f6!important}.packages-page .action-btn.package-row-edit-btn:hover{background:#3b82f633!important;color:#2563eb!important}.packages-page .action-btn.package-row-edit-btn:hover svg{color:#2563eb!important;stroke:#2563eb!important}.package-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.package-dialog-content{background:var(--bg-primary);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.package-detail-content{max-width:700px}.package-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.dialog-title-section h2{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.package-dialog-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.form-group-dialog{display:flex;flex-direction:column;gap:.5rem}.form-group-dialog label{font-weight:600;font-size:.875rem;color:var(--text-primary)}.form-input-dialog,.form-textarea-dialog{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;width:100%}.form-input-dialog:focus,.form-textarea-dialog:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.form-textarea-dialog{resize:vertical;min-height:100px}.form-row-dialog{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-cancel-dialog,.btn-submit-dialog{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;border:none}.btn-cancel-dialog{background:var(--bg-secondary);color:var(--text-primary)}.btn-cancel-dialog:hover:not(:disabled){background:var(--text-secondary);color:#fff}.btn-submit-dialog{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;box-shadow:0 4px 12px #22c55e4d}.btn-submit-dialog:hover:not(:disabled){box-shadow:0 6px 20px #22c55e66;transform:translateY(-1px)}.btn-cancel-dialog:disabled,.btn-submit-dialog:disabled{opacity:.6;cursor:not-allowed;transform:none}.package-detail-body{padding:1.5rem}.detail-info-group{display:flex;flex-direction:column;gap:1.25rem}.detail-info-item{display:flex;flex-direction:column;gap:.5rem}.detail-info-item.full-width{grid-column:1 / -1}.detail-info-item label{font-weight:600;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.detail-info-item span{font-size:.9375rem;color:var(--text-primary);padding:.75rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.detail-value-duration,.detail-value-price{display:flex;align-items:center;gap:.5rem;font-weight:600}.detail-value-price{color:var(--primary-green);font-size:1.125rem}.detail-value-description{line-height:1.6;white-space:pre-wrap}@media(max-width:768px){.packages-table-container{overflow-x:auto}.packages-table{min-width:800px}.package-description{max-width:200px}.form-row-dialog{grid-template-columns:1fr}.package-dialog-content{max-width:95%}}.training-templates-page{max-width:1400px;margin:0 auto}.templates-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-box{flex:1;min-width:300px;position:relative}.search-box .search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.search-box .search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary)}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.template-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border-color);transition:all .3s ease;display:flex;flex-direction:column;gap:1rem}.template-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-green);transform:translateY(-2px)}.template-card-header{display:flex;align-items:flex-start;gap:1rem}.template-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.template-header-info{flex:1}.template-name{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.template-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.template-week{font-size:.875rem;color:var(--text-secondary);font-weight:600}.template-status{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.template-status.active{background:#22c55e1a;color:var(--primary-green)}.template-description{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin:0}.template-stats{display:flex;gap:1.5rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px}.stat-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary);font-weight:600}.stat-item svg{color:var(--primary-green)}.template-sections-preview{padding-top:.75rem;border-top:1px solid var(--border-color)}.sections-header{margin-bottom:.75rem}.sections-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.sections-list{display:flex;flex-direction:column;gap:.5rem}.section-preview-item{display:flex;align-items:center;gap:.75rem;font-size:.875rem;padding:.5rem;background:var(--bg-secondary);border-radius:6px}.section-day{font-weight:700;color:var(--primary-green);min-width:60px}.section-name{flex:1;color:var(--text-primary);font-weight:500}.section-exercises{font-size:.75rem;color:var(--text-secondary)}.section-preview-more{font-size:.875rem;color:var(--text-secondary);font-style:italic;padding:.5rem;text-align:center}.template-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-secondary)}.template-creator{display:flex;align-items:center;gap:.5rem}.template-creator svg{color:var(--text-secondary)}.template-actions{margin-top:auto;padding-top:.75rem}.view-template-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:1px solid var(--primary-green);border-radius:8px;background:transparent;color:var(--primary-green);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.view-template-btn:hover{background:var(--primary-green);color:#fff}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-secondary);grid-column:1 / -1}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.modal-content{background:var(--bg-primary);border-radius:16px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.template-create-modal{max-width:600px}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.modal-subtitle{color:var(--text-secondary);margin:0}.modal-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.template-create-form{display:flex;flex-direction:column;gap:1.25rem}.form-input,.form-textarea,.form-select{padding:.75rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;width:100%}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.form-select{cursor:pointer}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:1rem;margin-top:.5rem}.form-actions button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary:hover:not(:disabled){box-shadow:0 6px 16px #22c55e66}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--primary-green);color:var(--primary-green)}.spinner{animation:spin 1s linear infinite}@media(max-width:768px){.templates-grid{grid-template-columns:1fr}.template-card{padding:1.25rem}.form-row{grid-template-columns:1fr}.template-create-modal{max-width:95%;padding:1.5rem}}.template-detail-page{max-width:1400px;margin:0 auto}.template-detail-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem}.template-info-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow);margin-bottom:2rem}.template-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-icon.exercises-icon{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.info-icon.creator-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.info-icon.status-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.info-icon.date-icon{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 .25rem;font-weight:600;line-height:1;text-align:center!important;width:100%;display:block}.info-value{font-size:1rem;color:var(--text-primary);font-weight:700;margin:0;line-height:1.2;text-align:center!important;width:100%;display:block}.info-value.status-active{color:var(--primary-green)}.sections-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color);gap:1rem}.sections-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.sections-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0}.btn-add-section{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:1px solid var(--primary-green);border-radius:8px;background:transparent;color:var(--primary-green);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;white-space:nowrap;flex-shrink:0}.sections-list{display:flex;flex-direction:column;gap:1rem}.section-collapse-item{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;transition:all .3s ease}.section-collapse-item:hover{border-color:var(--primary-green);box-shadow:var(--shadow)}.section-collapse-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;cursor:pointer;background:var(--bg-primary);transition:all .3s ease}.section-collapse-header:hover{background:var(--bg-secondary)}.section-header-left{display:flex;align-items:center;gap:1rem;flex:1;cursor:pointer}.section-header-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.btn-edit-section{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .3s ease}.btn-edit-section:hover{background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.section-header-info{flex:1}.section-day-name{font-size:.875rem;color:var(--text-secondary);font-weight:600;margin-bottom:.25rem}.section-name{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.section-exercises-badge{padding:.5rem 1rem;background:#22c55e1a;color:var(--primary-green);border-radius:20px;font-size:.875rem;font-weight:600;white-space:nowrap}.section-chevron{color:var(--text-secondary);flex-shrink:0}.section-collapse-content{overflow:hidden}.exercises-table-container{padding:1.5rem;background:var(--bg-secondary);overflow-x:auto}.exercises-table{width:100%;border-collapse:collapse;background:var(--bg-primary);border-radius:8px;overflow:hidden}.exercises-table thead{background:var(--bg-secondary)}.exercises-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color);white-space:nowrap}.exercises-table td{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem}.exercise-table-row{transition:all .3s ease}.exercise-table-row:hover{background:var(--bg-secondary)}.exercise-order{font-weight:700;color:var(--primary-green);text-align:center;width:50px}.exercise-name-cell{font-weight:600;color:var(--text-primary);min-width:200px}.exercise-name-wrapper{display:flex;align-items:center;gap:.5rem}.exercise-icon{color:var(--primary-green);flex-shrink:0}.exercise-sets,.exercise-reps,.exercise-rpe,.exercise-rir,.exercise-tempo{text-align:center;font-weight:600;color:var(--text-primary)}.exercise-rest{text-align:center}.rest-time{display:flex;align-items:center;justify-content:center;gap:.25rem;font-size:.875rem;color:var(--text-secondary)}.rest-time svg{color:var(--text-secondary)}.exercise-note{text-align:center}.note-badge{display:inline-block;padding:.25rem .75rem;background:#3b82f61a;color:#3b82f6;border-radius:12px;font-size:.75rem;font-weight:600}@media(max-width:1024px){.template-info-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}@media(max-width:768px){.template-detail-header{flex-direction:column}.template-info-grid{grid-template-columns:1fr}.sections-header{flex-direction:column;align-items:stretch}.btn-add-section{width:100%;justify-content:center}.section-header-left{flex-wrap:wrap}.exercises-table-container{overflow-x:auto}.exercises-table{min-width:800px}}.edit-section-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.edit-section-modal-content{background:var(--bg-primary);border-radius:16px;width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.edit-section-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color)}.edit-section-modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .3s ease}.modal-close-btn:hover{background:var(--border-color)}.edit-section-modal-body{flex:1;overflow-y:auto;padding:2rem}.edit-section-form{display:flex;flex-direction:column;gap:1.5rem}.form-group-section{display:flex;flex-direction:column;gap:.5rem}.form-group-section label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.form-group-section input,.form-group-section select{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;transition:all .3s ease}.form-group-section input:focus,.form-group-section select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.section-items-header{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.btn-add-exercise-edit{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--primary-green);border-radius:8px;background:transparent;color:var(--primary-green);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-add-exercise-edit:hover{background:var(--primary-green);color:#fff}.empty-items{padding:2rem;text-align:center;color:var(--text-secondary);background:var(--bg-secondary);border-radius:8px}.items-table-container-edit{overflow-x:auto;border:1px solid var(--border-color);border-radius:8px}.items-table-edit{width:100%;border-collapse:collapse;background:var(--bg-primary)}.items-table-edit thead{background:var(--bg-secondary)}.items-table-edit th{padding:.75rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color);white-space:nowrap}.items-table-edit td{padding:.75rem;border-top:1px solid var(--border-color)}.items-table-edit input,.items-table-edit select{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;transition:all .3s ease}.items-table-edit input:focus,.items-table-edit select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 2px #22c55e1a}.btn-remove-item{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:#ef4444;cursor:pointer;transition:all .3s ease}.btn-remove-item:hover{background:#ef4444;color:#fff;border-color:#ef4444}.edit-section-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid var(--border-color)}.btn-cancel-edit{padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-cancel-edit:hover{background:var(--border-color)}.btn-cancel-edit:disabled{opacity:.5;cursor:not-allowed}.btn-submit-edit{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;background:var(--primary-green);color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-submit-edit:hover:not(:disabled){background:var(--primary-green-dark)}.btn-submit-edit:disabled{opacity:.5;cursor:not-allowed}.btn-submit-edit .spinner{animation:spin 1s linear infinite}@media(max-width:768px){.edit-section-modal-content{max-width:100%;max-height:95vh}.edit-section-modal-header,.edit-section-modal-body,.edit-section-modal-footer{padding:1rem}.items-table-container-edit{overflow-x:auto}.items-table-edit{min-width:900px}}.create-template-page{max-width:1400px;margin:0 auto}.create-template-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem}.sections-container{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow)}.sections-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.created-sections-container{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow);margin-bottom:2rem}.created-sections-list{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid var(--border-color)}.created-sections-list:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.created-sections-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.created-section-card{background:var(--bg-secondary);border-radius:12px;padding:1rem 1.5rem;margin-bottom:.75rem;border:1px solid var(--border-color);transition:all .3s ease}.created-section-card:hover{border-color:var(--primary-green);box-shadow:var(--shadow)}.created-section-header{display:flex;justify-content:space-between;align-items:center}.created-section-info{display:flex;align-items:center;gap:1rem;flex:1}.created-section-number{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.created-section-day{font-size:.875rem;color:var(--text-secondary);font-weight:600;margin-bottom:.25rem}.created-section-name{font-size:1rem;font-weight:700;color:var(--text-primary)}.created-section-badge{padding:.5rem 1rem;background:#22c55e1a;color:var(--primary-green);border-radius:20px;font-size:.875rem;font-weight:600;margin-left:auto}.sections-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.btn-add-section{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:1px solid var(--primary-green);border-radius:8px;background:transparent;color:var(--primary-green);font-weight:600;cursor:pointer;transition:all .3s ease}.btn-add-section:hover{background:var(--primary-green);color:#fff}.empty-sections{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem;color:var(--text-secondary)}.sections-list{display:flex;flex-direction:column;gap:1.5rem}.section-form-card{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;transition:all .3s ease}.section-form-card:hover{border-color:var(--primary-green);box-shadow:var(--shadow)}.section-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:var(--bg-primary);border-bottom:1px solid var(--border-color)}.section-form-header-left{display:flex;align-items:center;gap:1rem;flex:1}.section-number{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.section-form-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.section-name-input{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:600;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;width:100%}.section-name-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.section-form-meta{display:flex;align-items:center;gap:1rem}.section-day-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-weight:600;cursor:pointer}.section-order{font-size:.875rem;color:var(--text-secondary)}.section-form-actions{display:flex;align-items:center;gap:.5rem}.section-toggle-btn,.section-remove-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.section-toggle-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.section-remove-btn:hover{background:#ef44441a;color:#ef4444}.section-form-content{padding:1.5rem;overflow:hidden}.section-items-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-items-header h3{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0}.btn-add-exercise{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--primary-green);border-radius:6px;background:transparent;color:var(--primary-green);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-add-exercise:hover{background:var(--primary-green);color:#fff}.empty-items{padding:2rem;text-align:center;color:var(--text-secondary)}.items-table-container{overflow-x:auto;margin-bottom:1.5rem}.items-table{width:100%;border-collapse:collapse;background:var(--bg-primary);border-radius:8px;overflow:hidden}.items-table thead{background:var(--bg-secondary)}.items-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color);white-space:nowrap}.items-table td{padding:.75rem;border-top:1px solid var(--border-color)}.item-table-row{transition:all .3s ease}.item-table-row:hover{background:var(--bg-secondary)}.item-order{font-weight:700;color:var(--primary-green);text-align:center;width:50px}.item-exercise{min-width:200px}.exercise-select{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;cursor:pointer}.exercise-select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.item-input{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-family:inherit}.item-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.item-sets,.item-reps,.item-rpe,.item-rir,.item-tempo,.item-rest{min-width:80px}.item-note{min-width:120px}.item-actions{width:60px;text-align:center}.item-remove-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.item-remove-btn:hover{background:#ef44441a}.section-submit{padding-top:1rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.btn-submit-section{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d}.btn-submit-section:hover:not(:disabled){box-shadow:0 6px 16px #22c55e66}.btn-submit-section:disabled{opacity:.6;cursor:not-allowed}.finish-section{margin-top:2rem;padding-top:2rem;border-top:2px solid var(--border-color);display:flex;justify-content:center}.btn-finish{padding:1rem 2rem;border:none;border-radius:10px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d}.btn-finish:hover{box-shadow:0 6px 20px #22c55e66}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem;color:var(--text-secondary);min-height:60vh}.error-container p{font-size:1.125rem;color:var(--text-primary)}.btn-primary{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d;display:flex;align-items:center;gap:.5rem}.btn-primary:hover{box-shadow:0 6px 16px #22c55e66}@media(max-width:1024px){.items-table-container{overflow-x:auto}.items-table{min-width:1000px}}@media(max-width:768px){.create-template-header{flex-direction:column}.section-form-header{flex-wrap:wrap}.section-form-header-left{width:100%;margin-bottom:.5rem}.section-form-meta{flex-wrap:wrap}}.add-exercise-btn{padding:.75rem 1.5rem;border:2px dashed var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;font-size:.875rem}.add-exercise-btn:hover{border-color:var(--primary-green);background:#22c55e0d;color:var(--primary-green)}.exercise-form-container{background:var(--bg-secondary);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.exercise-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.875rem}.form-group input,.form-group select{padding:.625rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary);color:var(--text-primary);font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.disabled-input{background:var(--bg-secondary)!important;color:var(--text-secondary)!important;cursor:not-allowed}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.btn-cancel,.btn-submit{padding:.625rem 1.25rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.btn-cancel{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-cancel:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-submit{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff}.btn-submit:hover{box-shadow:0 4px 12px #22c55e4d}.exercise-form-preview{background:var(--bg-secondary);border-left:4px solid var(--primary-green);border-radius:12px;padding:1.25rem;transition:all .3s ease}.preview-content{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.preview-info{flex:1}.preview-info h4{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.preview-details{display:flex;gap:1rem;flex-wrap:wrap}.preview-details span{font-size:.875rem;color:var(--text-secondary);padding:.25rem .75rem;background:var(--bg-primary);border-radius:12px}.preview-actions{display:flex;gap:.5rem}.preview-btn{width:32px;height:32px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.preview-btn.edit-btn{background:#3b82f61a;color:#3b82f6}.preview-btn.edit-btn:hover{background:#3b82f6;color:#fff}.preview-btn.delete-btn{background:#ef44441a;color:#ef4444}.preview-btn.delete-btn:hover{background:#ef4444;color:#fff}@media(max-width:768px){.form-row{grid-template-columns:1fr}.preview-content{flex-direction:column;align-items:flex-start}.preview-actions{width:100%;justify-content:flex-end}}.workout-day-card{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.workout-card-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.workout-member-info{display:flex;align-items:center;gap:1rem}.workout-member-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.workout-member-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.workout-date-info{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.workout-date-info svg{flex-shrink:0}.workout-card-actions{display:flex;gap:.5rem}.workout-action-btn{width:40px;height:40px;border:none;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.workout-action-btn.edit-btn{background:#3b82f61a;color:#3b82f6}.workout-action-btn.edit-btn:hover{background:#3b82f6;color:#fff}.workout-action-btn.delete-btn{background:#ef44441a;color:#ef4444}.workout-action-btn.delete-btn:hover{background:#ef4444;color:#fff}.workout-exercises{padding:1.5rem}.exercises-header{margin-bottom:1.5rem}.exercises-header h4{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.exercises-list{display:flex;flex-direction:column;gap:1rem}.workout-table-container{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color)}.workout-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.workout-table thead{background:var(--bg-secondary)}.workout-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:2px solid var(--border-color)}.workout-table td{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem}.workout-table-row{transition:all .3s ease}.workout-table-row:hover{background:var(--bg-secondary)}.table-cell-number{font-weight:700;color:var(--primary-green);text-align:center;width:50px}.table-cell-exercise{display:flex;align-items:center;gap:.5rem}.table-cell-exercise svg{color:var(--primary-green);flex-shrink:0}.exercise-name{font-weight:600;color:var(--text-primary)}.exercise-type-cell{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#22c55e1a;border-radius:20px;font-weight:600;font-size:.875rem;color:var(--primary-green)}.exercise-type-cell.to-failure{background:#f59e0b1a;color:#f59e0b}.exercise-type-cell svg{flex-shrink:0}.table-cell-value{font-weight:600;color:var(--text-primary)}@media(max-width:768px){.workout-card-header{flex-direction:column;align-items:flex-start;gap:1rem}.workout-card-actions{width:100%;justify-content:flex-end}}.workout-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.workout-dialog-content{background:var(--bg-primary);border-radius:16px;padding:2rem;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.dialog-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.dialog-header-actions{display:flex;gap:.5rem;align-items:center}.dialog-action-btn{padding:.5rem 1rem;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease}.dialog-action-btn.edit-btn{background:#3b82f61a;color:#3b82f6}.dialog-action-btn.edit-btn:hover{background:#3b82f6;color:#fff}.workout-dialog-content.view-mode{max-width:900px}.workout-view-content{max-height:70vh;overflow-y:auto}.workout-dialog-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color)}.workout-tab{padding:.75rem 1.5rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;border-bottom:2px solid transparent;margin-bottom:-2px;position:relative}.workout-tab:hover{color:var(--text-primary)}.workout-tab.active{color:var(--primary-green);border-bottom-color:var(--primary-green)}.workout-tab-content{min-height:300px}.workout-records-container{display:flex;flex-direction:column;gap:1.5rem}.records-header{margin-bottom:1rem}.records-header h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.records-subtitle{font-size:.875rem;color:var(--text-secondary)}.workout-records-table-container{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color)}.workout-records-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.workout-records-table thead{background:var(--bg-secondary)}.workout-records-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:2px solid var(--border-color)}.workout-records-table td{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem;vertical-align:top}.workout-record-row{transition:all .3s ease}.workout-record-row:hover{background:var(--bg-secondary)}.record-exercise-name{font-weight:600}.exercise-name-bold{font-weight:700;color:var(--text-primary)}.record-planned{color:var(--text-secondary);font-size:.875rem}.record-actual{display:flex;flex-direction:column;gap:.5rem}.actual-reps,.actual-time{display:flex;flex-direction:column;gap:.25rem}.rep-badge,.time-badge{display:inline-block;padding:.25rem .5rem;background:#22c55e1a;color:var(--primary-green);border-radius:8px;font-size:.75rem;font-weight:600;width:fit-content}.incomplete-badge{display:inline-block;padding:.25rem .5rem;background:#f59e0b1a;color:#f59e0b;border-radius:8px;font-size:.75rem;font-weight:600;width:fit-content}.record-notes{color:var(--text-secondary);font-size:.875rem;max-width:200px;display:block}.record-time{color:var(--text-secondary);font-size:.75rem;white-space:nowrap}.record-status{display:inline-block;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.record-status.completed{background:#22c55e1a;color:var(--primary-green)}.record-status.incomplete{background:#ef44441a;color:#ef4444}.no-records-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.no-records-message svg{margin-bottom:1rem;opacity:.5;color:var(--text-secondary)}.no-records-message p{font-size:1rem;margin-bottom:.5rem;color:var(--text-primary);font-weight:600}.no-records-subtitle{font-size:.875rem;color:var(--text-secondary);font-weight:400}@media(max-width:768px){.workout-dialog-tabs{flex-direction:column}.workout-tab{width:100%;justify-content:center}.workout-records-table{font-size:.75rem}.workout-records-table th,.workout-records-table td{padding:.75rem .5rem}.record-notes{max-width:150px;font-size:.75rem}}.dialog-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.dialog-date{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.dialog-date svg{flex-shrink:0}.dialog-close-btn{width:36px;height:36px;border:none;border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.dialog-close-btn:hover{background:#ef4444;color:#fff}.workout-form{display:flex;flex-direction:column;gap:2rem}.form-section{display:flex;flex-direction:column;gap:1rem}.section-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.875rem;display:flex;align-items:center;gap:.5rem}.form-group label svg{flex-shrink:0}.form-group input{padding:.75rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit}.form-group input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.exercises-form-list{display:flex;flex-direction:column;gap:1rem}.add-exercise-wrapper{margin-bottom:1rem}.no-exercises-message{padding:2rem;text-align:center;background:var(--bg-secondary);border-radius:12px;color:var(--text-secondary)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color)}.form-actions button{padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.875rem}@media(max-width:768px){.workout-dialog-content{padding:1.5rem}.section-header{flex-direction:column;align-items:stretch}.form-actions{flex-direction:column}.form-actions button{width:100%}}.workout-plan-page{max-width:1400px;margin:0 auto}.workout-plan-tabs{display:flex;gap:.5rem;margin-bottom:2rem;background:var(--bg-secondary);padding:.5rem;border-radius:12px}.workout-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.workout-tab:hover{color:var(--text-primary);background:var(--bg-primary)}.workout-tab.active{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;box-shadow:0 2px 8px #22c55e4d}.page-header-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.view-mode-toggle{display:flex;gap:.5rem;background:var(--bg-secondary);padding:.25rem;border-radius:10px}.view-mode-btn{padding:.5rem 1rem;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;font-size:.875rem}.view-mode-btn:hover{color:var(--text-primary);background:var(--bg-primary)}.view-mode-btn.active{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;box-shadow:0 2px 8px #22c55e4d}.workout-calendar-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);padding:2rem;margin-bottom:2rem}.workout-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.calendar-month-year{display:flex;align-items:center;gap:.75rem;flex:1;justify-content:center}.calendar-month-year h2{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.calendar-nav-btn{width:40px;height:40px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.calendar-nav-btn:hover{background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.today-btn{margin-left:auto}.workout-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.375rem}.calendar-day-header{padding:.75rem .5rem;text-align:center;font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.workout-calendar-day{aspect-ratio:1;min-height:100px;background:var(--bg-secondary);border:2px solid transparent;border-radius:8px;padding:.5rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;position:relative;overflow:hidden}.workout-calendar-day:hover{background:#22c55e0d;border-color:var(--primary-green);transform:translateY(-2px);box-shadow:var(--shadow)}.workout-calendar-day.today{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border-color:var(--primary-green);font-weight:700}.workout-calendar-day.today .workout-day-number{color:var(--primary-green);font-weight:700}.workout-calendar-day.has-workouts{border-color:var(--primary-green)}.workout-calendar-day.empty{cursor:default;background:transparent;border:none}.workout-calendar-day.empty:hover{background:transparent;transform:none;box-shadow:none}.workout-day-number{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.workout-chips-container{display:flex;flex-direction:column;gap:.375rem;margin-top:auto;max-height:60px;overflow-y:auto}.workout-member-chip{display:flex;align-items:center;gap:.375rem;padding:.375rem .5rem;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #22c55e33}.workout-member-chip:hover{box-shadow:0 4px 8px #22c55e66;transform:translateY(-1px)}.workout-member-chip svg{flex-shrink:0}.workout-member-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.workout-more-chip{padding:.25rem .5rem;background:#22c55e33;color:var(--primary-green);border-radius:12px;font-size:.625rem;font-weight:700;text-align:center}.workout-week-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);padding:2rem;margin-bottom:2rem}.workout-week-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.week-range{display:flex;align-items:center;gap:.75rem;flex:1;justify-content:center}.week-range h2{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.week-nav-btn{padding:.625rem 1rem;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;font-weight:600;font-size:.875rem}.week-nav-btn:hover{background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.workout-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1rem}.workout-week-day{background:var(--bg-secondary);border-radius:12px;padding:1rem;min-height:200px;border:2px solid transparent;transition:all .3s ease}.workout-week-day.today{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border-color:var(--primary-green)}.workout-week-day-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);position:relative}.workout-week-day-name{font-weight:600;color:var(--text-primary);font-size:.875rem;margin-bottom:.25rem}.workout-week-day-number{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.workout-week-day.today .workout-week-day-number{color:var(--primary-green)}.today-badge{position:absolute;top:0;right:0;background:var(--primary-green);color:#fff;font-size:.625rem;font-weight:600;padding:.25rem .5rem;border-radius:12px}.workout-week-chips{display:flex;flex-direction:column;gap:.5rem;min-height:120px}.workout-member-chip.week-chip{padding:.625rem .75rem;font-size:.875rem;justify-content:space-between}.chip-exercises-count{font-size:.75rem;opacity:.9;background:#fff3;padding:.125rem .5rem;border-radius:10px}.no-workouts-week{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem .5rem;text-align:center;color:var(--text-secondary);min-height:120px}.no-workouts-week svg{margin-bottom:.5rem;opacity:.5}.no-workouts-week p{font-size:.75rem;margin-bottom:.75rem}.btn-primary.small{padding:.5rem 1rem;font-size:.75rem}.training-programs-list-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);padding:2rem;margin-bottom:2rem}.training-programs-filters{background:var(--bg-secondary);border-radius:8px;padding:.75rem;margin-bottom:1rem;border:1px solid var(--border-color)}.filters-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.filter-item{flex:1;min-width:150px}.filter-input-wrapper{position:relative;display:flex;align-items:center}.filter-input-icon{position:absolute;left:.625rem;color:var(--text-secondary);pointer-events:none;z-index:1}.filter-input,.filter-select{width:100%;padding:.5rem .75rem .5rem 2rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;transition:all .3s ease}.filter-select{padding-left:.75rem}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 2px #22c55e1a}.filter-input::placeholder{color:var(--text-secondary);font-size:.8rem}.btn-reset-filters{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .3s ease;flex-shrink:0}.btn-reset-filters:hover{background:var(--border-color);color:var(--text-primary);border-color:var(--primary-green)}.loading-container-full{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-secondary);min-height:60vh}.loading-container-full .loading-spinner{animation:spin 1s linear infinite;color:var(--primary-green)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary);min-height:60vh}.empty-state h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:.5rem 0}.empty-state p{font-size:1rem;margin:0}.training-programs-table-container{overflow-x:auto;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-primary)}.training-programs-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.training-programs-table thead{background:var(--bg-secondary)}.training-programs-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color);white-space:nowrap}.training-programs-table td{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem}.training-program-row{transition:all .3s ease}.training-program-row:hover{background:var(--bg-secondary)}.program-client-cell{display:flex;align-items:center;gap:.75rem}.client-icon{color:var(--primary-green);flex-shrink:0}.client-name{font-weight:600;color:var(--text-primary)}.week-badge{display:inline-block;padding:.375rem .75rem;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border-radius:20px;font-size:.875rem;font-weight:600;white-space:nowrap}.program-description-text{color:var(--text-secondary);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block}.program-stat-cell{display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.program-stat-cell svg{color:var(--primary-green);flex-shrink:0}.creator-name{color:var(--text-secondary)}.program-actions-cell{display:flex;align-items:center;gap:.5rem}.btn-view-program-table,.btn-send-email-table{display:flex;align-items:center;justify-content:center;padding:.5rem;border:1px solid var(--primary-green);border-radius:8px;background:transparent;color:var(--primary-green);cursor:pointer;transition:all .3s ease;width:36px;height:36px}.btn-view-program-table:hover,.btn-send-email-table:hover{background:var(--primary-green);color:#fff}.btn-send-email-table{border-color:#3b82f6;color:#3b82f6}.btn-send-email-table:hover{background:#3b82f6;color:#fff}.create-program-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.create-program-modal-content{background:var(--bg-primary);border-radius:16px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.create-program-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color)}.create-program-modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.create-program-modal-body{flex:1;overflow-y:auto;padding:2rem}.create-mode-selection{text-align:center}.mode-selection-title{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem}.mode-options{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.mode-option{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1.5rem;border:2px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .3s ease}.mode-option:hover{border-color:var(--primary-green);background:#22c55e0d;transform:translateY(-2px)}.mode-option svg{color:var(--primary-green)}.mode-option h3{font-size:1.125rem;font-weight:700;margin:0}.mode-option p{font-size:.875rem;color:var(--text-secondary);margin:0}.create-program-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.form-input,.form-select,.form-textarea{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;transition:all .3s ease;font-family:inherit}.form-textarea{resize:vertical;min-height:80px}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.loading-options{display:flex;align-items:center;gap:.5rem;padding:.75rem;color:var(--text-secondary);font-size:.875rem}.loading-options .spinner{animation:spin 1s linear infinite}.create-program-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid var(--border-color)}.btn-cancel{padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-cancel:hover{background:var(--border-color)}.btn-submit{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;background:var(--primary-green);color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-submit:hover:not(:disabled){background:var(--primary-green-dark)}.btn-submit:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.mode-options{grid-template-columns:1fr}.create-program-modal-content{max-width:100%;max-height:95vh}.create-program-modal-header,.create-program-modal-body,.create-program-modal-footer{padding:1rem}}@media(max-width:768px){.workout-plan-tabs{flex-direction:column}.workout-tab{width:100%;justify-content:center}.training-programs-table-container{overflow-x:auto}.training-programs-table{min-width:1000px}.training-programs-table th,.training-programs-table td{padding:.75rem .5rem;font-size:.8rem}.program-description-text{max-width:200px}.filters-row{flex-direction:column}.filter-item{width:100%;min-width:100%}.btn-reset-filters{width:100%;height:36px}.page-header-actions{flex-direction:column;width:100%}.view-mode-toggle{width:100%;justify-content:stretch}.view-mode-btn{flex:1}.workout-calendar-container,.workout-week-container{padding:1rem}.workout-calendar-header,.workout-week-header{flex-direction:column;align-items:stretch}.calendar-month-year,.week-range{justify-content:center;order:-1}.today-btn{margin-left:0;width:100%}.workout-calendar-day{min-height:80px;padding:.375rem}.workout-week-grid{grid-template-columns:1fr}.workout-week-day{min-height:150px}}@media(max-width:480px){.workout-calendar-day{min-height:60px;padding:.25rem}.workout-day-number{font-size:.75rem}.workout-member-chip{font-size:.625rem;padding:.25rem .375rem}.workout-member-chip svg{width:10px;height:10px}}.send-email-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.send-email-modal-content{background:var(--bg-primary);border-radius:16px;width:100%;max-width:500px;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.send-email-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color)}.send-email-modal-body{flex:1;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.send-email-info{padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.send-email-info .info-text{margin:0;font-size:.875rem;color:var(--text-secondary)}.send-email-info .info-text strong{color:var(--text-primary);font-weight:600}.send-email-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid var(--border-color)}.btn-cancel{padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:8px;background:transparent;color:var(--text-secondary);font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-submit{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #22c55e4d}.btn-submit:hover:not(:disabled){box-shadow:0 6px 16px #22c55e66}@media(max-width:768px){.send-email-modal-content{max-width:100%;max-height:95vh}.send-email-modal-header,.send-email-modal-body,.send-email-modal-footer{padding:1rem}.program-actions-cell{flex-direction:column;gap:.25rem}.btn-view-program-table,.btn-send-email-table{width:100%;justify-content:center}}.checkin-page{max-width:1400px;margin:0 auto}.checkin-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.filter-group{display:flex;align-items:center;gap:.5rem;padding:0 1rem;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-primary);height:44px;box-sizing:border-box}.filter-select{border:none;background:transparent;color:var(--text-primary);font-weight:600;font-size:.875rem;cursor:pointer;outline:none}.checkin-table-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;overflow-x:auto}.checkin-table{width:100%;border-collapse:collapse}.checkin-table thead{background:var(--bg-secondary)}.checkin-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.checkin-table td{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem}.checkin-table-row{transition:all .3s ease;cursor:pointer}.checkin-table-row:hover{background:var(--bg-secondary)}.checkin-member-cell{display:flex;align-items:center;gap:.75rem}.checkin-member-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;flex-shrink:0;position:relative;overflow:visible;cursor:pointer}.checkin-member-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;transition:transform .3s ease}.checkin-member-avatar:hover img{transform:scale(1.1)}.checkin-member-avatar .avatar-zoom-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:150px;height:150px;border-radius:50%;box-shadow:0 8px 32px #0006;z-index:1000;pointer-events:none;border:4px solid white;opacity:0;transition:opacity .3s ease,transform .3s ease}.checkin-member-avatar:hover .avatar-zoom-overlay{opacity:1;transform:translate(-50%,-50%) scale(1)}.checkin-member-avatar .avatar-zoom-overlay img{width:100%;height:100%;border-radius:50%;object-fit:cover}.checkin-member-avatar span{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.checkin-member-name{font-weight:600;color:var(--text-primary)}.checkin-date-cell{display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.checkin-date-cell svg{color:var(--text-secondary);flex-shrink:0}.checkin-weight-cell,.checkin-height-cell{display:flex;align-items:center;gap:.5rem}.checkin-weight-cell svg{color:var(--primary-green);flex-shrink:0}.checkin-height-cell svg{color:#3b82f6;flex-shrink:0}.weight-value,.height-value{font-weight:600;color:var(--text-primary)}.checkin-bmi-cell{display:flex;flex-direction:column;gap:.25rem}.bmi-value{font-weight:700;color:var(--text-primary);font-size:1rem}.bmi-category{font-size:.75rem;font-weight:600}.checkin-images-count{display:flex;align-items:center;gap:.5rem;color:var(--primary-green);font-weight:600}.checkin-images-count svg{flex-shrink:0}.checkin-notes{color:var(--text-secondary);max-width:200px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-checkins{text-align:center;padding:3rem;color:var(--text-secondary)}.checkin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary)}.checkin-loading .spinner{animation:spin 1s linear infinite;color:var(--primary-green);margin-bottom:1rem}.checkin-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);text-align:center}.checkin-error p{margin-bottom:1rem;color:#ef4444}.no-images-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);text-align:center}.no-images-message svg{margin-bottom:1rem;opacity:.5}.checkin-image-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:3000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.checkin-image-modal-content{background:var(--bg-primary);border-radius:16px;padding:2rem;max-width:1000px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.image-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.image-modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.image-modal-date{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.image-modal-date svg{flex-shrink:0}.image-modal-body{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.5rem}.image-modal-left{display:flex;flex-direction:column;gap:1rem}.image-modal-right{display:flex;flex-direction:column;gap:1.5rem}.image-modal-stats{display:flex;flex-direction:column;gap:1rem}.stat-card{background:var(--bg-secondary);border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;border:2px solid transparent;transition:all .3s ease}.stat-card:hover{border-color:var(--primary-green);transform:translateY(-2px);box-shadow:var(--shadow)}.stat-card.weight-card{background:linear-gradient(135deg,#22c55e1a,#22c55e0d)}.stat-card.height-card{background:linear-gradient(135deg,#3b82f61a,#3b82f60d)}.stat-card.bmi-card{background:linear-gradient(135deg,#f59e0b1a,#f59e0b0d)}.stat-icon{width:56px;height:56px;border-radius:12px;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-green);box-shadow:var(--shadow)}.stat-card.weight-card .stat-icon{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff}.stat-card.height-card .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.bmi-icon-text{font-weight:700;font-size:.875rem}.stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;font-weight:600}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-unit{font-size:1rem;font-weight:600;color:var(--text-secondary)}.stat-category{font-size:.75rem;font-weight:600;margin-top:.25rem}.image-modal-notes{background:var(--bg-secondary);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color)}.image-modal-notes h4{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.image-modal-notes p{color:var(--text-primary);font-size:.875rem;margin:0;line-height:1.6}.image-modal-main{position:relative;width:100%;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg);background:var(--bg-secondary);aspect-ratio:1}.main-image{width:100%;height:100%;object-fit:contain;display:block;background:var(--bg-secondary)}.main-image-number{position:absolute;bottom:1rem;right:1rem;background:#000000b3;color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.875rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-thumbnail-gallery{display:flex;gap:.75rem;overflow-x:auto;padding:.5rem 0;scrollbar-width:thin;scrollbar-color:var(--primary-green) var(--bg-secondary)}.image-thumbnail-gallery::-webkit-scrollbar{height:6px}.image-thumbnail-gallery::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:10px}.image-thumbnail-gallery::-webkit-scrollbar-thumb{background:var(--primary-green);border-radius:10px}.thumbnail-item{position:relative;width:100px;height:100px;border-radius:12px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .3s ease;flex-shrink:0;box-shadow:var(--shadow)}.thumbnail-item:hover{transform:scale(1.1);box-shadow:var(--shadow-lg)}.thumbnail-item.active{border-color:var(--primary-green);box-shadow:0 0 0 2px #22c55e26}.thumbnail-item img{width:100%;height:100%;object-fit:cover;display:block}.modal-close-btn{width:36px;height:36px;border:none;border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.modal-close-btn:hover{background:#ef4444;color:#fff}@media(max-width:768px){.checkin-filters{flex-direction:column}.search-box{min-width:100%}.checkin-table{font-size:.75rem}.checkin-table th,.checkin-table td{padding:.75rem .5rem}.checkin-notes{max-width:150px}.checkin-image-modal-content{padding:1.5rem}.image-modal-body{grid-template-columns:1fr;gap:1.5rem}.image-modal-stats{flex-direction:column}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.image-modal-main{aspect-ratio:1}.thumbnail-item{width:80px;height:80px}}@media(max-width:480px){.image-modal-gallery{grid-template-columns:1fr}.image-modal-info{flex-direction:column;align-items:flex-start;gap:.5rem}.image-modal-info span:not(:last-child):after{content:""}}.create-checkin-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-green);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.create-checkin-btn:hover{background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.checkin-form-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.checkin-form-dialog-content{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:700px;max-height:90vh;overflow-y:auto}.checkin-form-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.checkin-form-dialog-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.checkin-form-dialog-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.form-group-checkin{display:flex;flex-direction:column;gap:.5rem}.form-group-checkin label{font-weight:600;font-size:.875rem;color:var(--text-primary)}.form-input-checkin{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;width:100%}.form-input-checkin:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.form-input-checkin:disabled{opacity:.6;cursor:not-allowed}.form-row-checkin{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.image-upload-section{display:flex;flex-direction:column;gap:1rem}.image-upload-input{display:none}.image-upload-label{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:2px dashed var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .3s ease;font-weight:600;font-size:.875rem;justify-content:center}.image-upload-label:hover{border-color:var(--primary-green);background:#22c55e0d;color:var(--primary-green)}.image-preview-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;margin-top:.5rem}.image-preview-item{position:relative;width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid var(--border-color)}.image-preview{width:100%;height:100%;object-fit:cover}.image-remove-btn{position:absolute;top:.25rem;right:.25rem;background:#ef4444e6;color:#fff;border:none;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease}.image-remove-btn:hover{background:#ef4444;transform:scale(1.1)}.checkin-form-dialog-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color);margin-top:.5rem}.btn-cancel,.btn-submit{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;border:none}.btn-cancel:hover:not(:disabled){background:var(--bg-secondary);opacity:.8}.btn-submit{background:var(--primary-green);color:#fff}.btn-cancel:disabled,.btn-submit:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.page-header{flex-direction:column;gap:1rem}.form-row-checkin{grid-template-columns:1fr}.checkin-form-dialog-content{max-width:100%;margin:.5rem}.image-preview-list{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}.meal-plans-page{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.create-meal-plan-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-green);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.create-meal-plan-btn:hover{background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.meal-plans-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:300px;position:relative;display:flex;align-items:center}.search-box .search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-secondary);z-index:1}.search-box .search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary);height:44px;box-sizing:border-box}.search-box .search-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.meal-plans-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);padding:1.5rem}.meal-plans-loading,.meal-plans-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);text-align:center}.meal-plans-loading .spinner{animation:spin 1s linear infinite;color:var(--primary-green);margin-bottom:1rem}.meal-plans-error p{margin-bottom:1rem;color:#ef4444}.retry-button{padding:.75rem 1.5rem;background:var(--primary-green);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-button:hover{background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.empty-state{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state svg{margin-bottom:1rem;opacity:.5}.meal-plans-table-container{overflow-x:auto}.meal-plans-table{width:100%;border-collapse:collapse}.meal-plans-table thead{background:var(--bg-secondary)}.meal-plans-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color);white-space:nowrap}.meal-plans-table td{padding:1rem;border-bottom:1px solid var(--border-color);font-size:.875rem;color:var(--text-primary)}.meal-plan-row{transition:all .3s ease;cursor:pointer}.meal-plan-row:hover{background:#22c55e0d;transform:translate(2px)}.client-cell{display:flex;align-items:center;gap:.75rem}.client-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;flex-shrink:0;position:relative;overflow:visible;cursor:pointer}.client-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;transition:transform .3s ease}.client-avatar:hover img{transform:scale(1.1)}.client-avatar .avatar-zoom-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:150px;height:150px;border-radius:50%;box-shadow:0 8px 32px #0006;z-index:1000;pointer-events:none;border:4px solid white;opacity:0;transition:opacity .3s ease,transform .3s ease}.client-avatar:hover .avatar-zoom-overlay{opacity:1;transform:translate(-50%,-50%) scale(1)}.client-avatar .avatar-zoom-overlay img{width:100%;height:100%;border-radius:50%;object-fit:cover}.client-avatar span{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.week-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;background:#22c55e1a;color:var(--primary-green);border-radius:12px;font-size:.8125rem;font-weight:600}.stat-cell{display:flex;align-items:center;gap:.5rem;font-weight:600}.stat-cell svg{color:var(--primary-green);flex-shrink:0}.meal-plan-form-modal{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.meal-plan-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-input textarea{resize:vertical;min-height:100px}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--border-color)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-primary:hover:not(:disabled){background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary .spinner{animation:spin 1s linear infinite}@media(max-width:768px){.page-header{flex-direction:column;gap:1rem}.search-box{min-width:100%}.meal-plans-table-container{overflow-x:scroll}.meal-plans-table{min-width:1000px}.meal-plan-form-modal{max-width:95%}}.meal-plan-actions-cell{text-align:center}.meal-plan-actions{display:flex;gap:.5rem;justify-content:center;align-items:center}.btn-view-meal-plan-table,.btn-send-email-table{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-primary)}.btn-view-meal-plan-table{color:var(--primary-green)}.btn-view-meal-plan-table:hover{background:var(--primary-green);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #22c55e4d}.btn-send-email-table{color:#3b82f6}.btn-send-email-table:hover{background:#3b82f6;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f64d}.send-email-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.send-email-modal-content{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.send-email-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.send-email-modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.send-email-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.send-email-info{background:var(--bg-secondary);border-radius:12px;padding:1rem;border:1px solid var(--border-color)}.send-email-info .info-text{margin:0;color:var(--text-primary);font-size:.875rem;line-height:1.6}.send-email-info .info-text strong{color:var(--primary-green);font-weight:600}.send-email-modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid var(--border-color)}.btn-cancel{padding:.75rem 1.5rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-cancel:hover:not(:disabled){background:var(--border-color)}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.btn-submit{padding:.75rem 1.5rem;background:var(--primary-green);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.btn-submit:hover:not(:disabled){background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-submit .spinner{animation:spin 1s linear infinite}@media(max-width:768px){.btn-send-email-table,.btn-view-meal-plan-table{width:32px;height:32px}.send-email-modal-content{max-width:95vw}.send-email-modal-header,.send-email-modal-body,.send-email-modal-footer{padding:1rem}}.meal-plan-detail-page{max-width:1400px;margin:0 auto}.meal-plan-detail-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .3s ease;font-weight:600;flex-shrink:0}.back-btn:hover{background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.header-content{flex:1}.page-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.page-subtitle{font-size:1rem;color:var(--text-secondary);margin:0}.edit-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-green);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;flex-shrink:0}.edit-btn:hover{background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.edit-actions{display:flex;gap:.75rem;flex-shrink:0}.cancel-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.cancel-btn:hover:not(:disabled){background:var(--border-color)}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.save-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-green);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.save-btn:hover:not(:disabled){background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.save-btn:disabled{opacity:.6;cursor:not-allowed}.save-btn .spinner{animation:spin 1s linear infinite}.meals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.add-item-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--primary-green);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.meal-actions{display:flex;gap:.5rem;align-items:center}.action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);cursor:pointer;transition:all .3s ease}.edit-action-btn{color:var(--primary-green)}.edit-action-btn:hover{background:#22c55e1a;border-color:var(--primary-green)}.delete-action-btn{color:#ef4444}.delete-action-btn:hover{background:#ef44441a;border-color:#ef4444}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-input textarea{resize:vertical;min-height:80px}.btn-secondary{padding:.75rem 1.5rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:var(--border-color)}.btn-primary{padding:.75rem 1.5rem;background:var(--primary-green);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.btn-primary:hover{background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.meal-plan-info-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow);margin-bottom:2rem}.meal-plan-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.info-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.info-icon svg{width:20px;height:20px}.info-icon.week-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.info-icon.days-icon{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff}.info-icon.meals-icon{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.info-icon.calories-icon{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.info-icon.protein-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.info-icon.creator-icon{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.info-content{display:flex;flex-direction:column;align-items:center;gap:.25rem;width:100%}.info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 .25rem;font-weight:600;line-height:1;text-align:center;width:100%}.info-value{font-size:1rem;color:var(--text-primary);font-weight:700;margin:0;line-height:1.2;text-align:center;width:100%}.meals-container{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow)}.meals-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.meals-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.day-section{margin-bottom:2.5rem}.day-section:last-child{margin-bottom:0}.day-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--border-color)}.meals-table-container{overflow-x:auto;margin-top:1rem}.meals-table{width:100%;border-collapse:collapse;background:var(--bg-primary);border-radius:12px;overflow:hidden}.meals-table thead{background:var(--bg-secondary)}.meals-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color);white-space:nowrap}.meals-table td{padding:1rem;border-bottom:1px solid var(--border-color);font-size:.875rem;color:var(--text-primary)}.meal-row{transition:all .3s ease}.meal-row:hover{background:#22c55e05}.meal-type-badge{display:inline-block;padding:.375rem .875rem;background:var(--primary-green);color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.meal-time-cell{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary);font-weight:500}.meal-time-cell svg{color:var(--text-secondary);flex-shrink:0}.no-time{color:var(--text-secondary);font-style:italic}.serving-cell{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--text-primary);font-weight:500}.no-serving{color:var(--text-secondary);font-style:italic}.meal-name-cell{font-weight:600;color:var(--text-primary)}.calories-cell{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-primary)}.calories-cell svg{color:#ef4444;flex-shrink:0}.macros-cell{display:flex;gap:.75rem;flex-wrap:wrap}.macro-item-inline{font-size:.8125rem;font-weight:600;padding:.25rem .5rem;background:var(--bg-secondary);border-radius:6px}.macro-item-inline.protein{color:#3b82f6}.macro-item-inline.carbs{color:#f59e0b}.macro-item-inline.fat{color:#ef4444}.macro-item-inline.sodium{color:#8b5cf6}.meal-note-cell{font-size:.8125rem;color:var(--text-secondary);font-style:italic;max-width:300px}.empty-meals{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-meals svg{margin-bottom:1rem;opacity:.5}.loading-container-full,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:var(--text-secondary)}.loading-spinner{animation:spin 1s linear infinite;color:var(--primary-green);margin-bottom:1rem}.error-container p{margin-bottom:1rem;color:#ef4444}.meal-item-card.active{border-color:var(--primary-green);box-shadow:0 0 0 2px #22c55e33}@media(max-width:768px){.meal-plan-detail-header{flex-direction:column}.meal-plan-info-grid{grid-template-columns:repeat(2,1fr)}.meals-table-container{overflow-x:scroll}.meals-table{min-width:800px}.form-card,.items-card{padding:1.5rem}.form-grid{grid-template-columns:1fr}}.add-meal-items-page{min-height:100vh;background:var(--bg-secondary);padding:2rem}.add-meal-items-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.header-content{flex:1;min-width:200px}.page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.page-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.back-btn:hover{background:var(--bg-secondary);border-color:var(--primary-green)}.submit-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-green);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.submit-btn:hover:not(:disabled){background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.submit-btn .spinner{animation:spin 1s linear infinite}.add-meal-items-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.form-section{position:sticky;top:2rem}.form-card{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color)}.form-title{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 1.5rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{grid-column:1 / -1}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.875rem;color:var(--text-primary)}.form-group label svg{color:var(--primary-green);flex-shrink:0}.form-input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;width:100%}.form-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.form-input textarea{resize:vertical;min-height:60px}.add-item-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:var(--primary-green);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.add-item-btn:hover{background:var(--primary-green-dark);transform:translateY(-2px);box-shadow:var(--shadow)}.items-section{max-height:calc(100vh - 200px);overflow-y:auto}.items-card{background:var(--bg-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color)}.items-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.items-title{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.clear-all-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;color:var(--text-danger);border:1px solid var(--text-danger);border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease}.clear-all-btn:hover{background:#ef44441a}.empty-items{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.empty-items svg{margin-bottom:1rem;opacity:.5}.empty-items p{font-size:1.125rem;font-weight:600;margin:.5rem 0;color:var(--text-primary)}.empty-items span{font-size:.875rem}.items-list{display:flex;flex-direction:column;gap:2rem}.day-group{border-bottom:2px solid var(--border-color);padding-bottom:1.5rem}.day-group:last-child{border-bottom:none;padding-bottom:0}.day-group-title{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.meal-type-group{margin-bottom:1.5rem}.meal-type-group:last-child{margin-bottom:0}.meal-type-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.meal-type-icon{font-size:1.25rem}.meal-count{margin-left:auto;font-size:.875rem;color:var(--text-secondary);font-weight:400}.meal-items{display:flex;flex-direction:column;gap:.75rem}.meal-item-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;padding:1rem;transition:all .3s ease}.meal-item-card.clickable{cursor:pointer}.meal-item-card.clickable:hover{border-color:var(--primary-green);box-shadow:0 2px 8px #22c55e1a;transform:translateY(-2px)}.meal-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.meal-item-name{display:flex;flex-direction:column;gap:.25rem;flex:1}.meal-item-name strong{font-size:.9375rem;color:var(--text-primary)}.meal-item-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.meal-item-time,.meal-item-serving{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-secondary)}.remove-item-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .3s ease;flex-shrink:0}.remove-item-btn:hover{background:var(--text-danger);border-color:var(--text-danger);color:#fff}.meal-item-macros{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.macro-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:600}.macro-badge.calories{background:#ef44441a;color:#ef4444}.macro-badge.protein{background:#3b82f61a;color:#3b82f6}.macro-badge.carbs{background:#fbbf241a;color:#fbbf24}.macro-badge.fat{background:#a855f71a;color:#a855f7}.macro-badge.sodium{background:#22c55e1a;color:var(--primary-green)}.meal-item-note{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.meal-item-note small{color:var(--text-secondary);font-size:.8125rem}.loading-container-full{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.loading-spinner{animation:spin 1s linear infinite;color:var(--primary-green)}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}@media(max-width:1200px){.add-meal-items-content{grid-template-columns:1fr}.form-section{position:static}.items-section{max-height:none}}@media(max-width:768px){.add-meal-items-page{padding:1rem}.form-card,.items-card{padding:1.5rem}.form-grid{grid-template-columns:1fr}.add-meal-items-header{flex-direction:column;align-items:stretch}.submit-btn{width:100%;justify-content:center}}.meal-item-edit-modal{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:700px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.modal-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;transition:all .3s ease}.modal-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid var(--border-color)}.revenue-page{max-width:1400px;margin:0 auto}.revenue-filters{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.5rem;background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);margin-bottom:2rem;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:1rem}.filter-group svg{color:var(--text-secondary)}.filter-label{font-weight:600;color:var(--text-primary);font-size:.875rem}.time-filter-buttons{display:flex;gap:.5rem;background:var(--bg-secondary);padding:.25rem;border-radius:10px}.time-filter-btn{padding:.5rem 1rem;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease}.time-filter-btn:hover{color:var(--text-primary);background:var(--bg-primary)}.time-filter-btn.active{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;box-shadow:0 2px 8px #22c55e4d}.date-range-picker{display:flex;align-items:center;gap:.75rem}.date-range-picker svg{color:var(--text-secondary)}.date-input{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .3s ease}.date-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.revenue-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.revenue-stat-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:1rem;border:2px solid transparent;transition:all .3s ease}.revenue-stat-card:hover{border-color:var(--primary-green);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow)}.stat-icon.revenue-icon{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff}.stat-icon.contracts-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.stat-icon.avg-icon{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stat-icon.growth-icon{background:var(--bg-secondary)}.stat-icon.growth-icon.positive{color:var(--primary-green)}.stat-icon.growth-icon.negative{color:#ef4444}.stat-content{flex:1}.stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-weight:600}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;line-height:1.2}.stat-value.positive{color:var(--primary-green)}.stat-value.negative{color:#ef4444}.revenue-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:1.5rem;margin-bottom:2rem}.top-customers-table{margin-top:1.5rem;overflow-x:auto}.customers-table{width:100%;border-collapse:collapse;font-size:.875rem}.customers-table thead{background:var(--bg-secondary)}.customers-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.customers-table td{padding:.75rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.customers-table tbody tr:hover{background:var(--bg-secondary)}.customer-name{font-weight:600;color:var(--text-primary)}.revenue-cell{font-weight:700;color:var(--primary-green)}.avg-cell{color:var(--text-secondary);font-size:.8125rem}.chart-card{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow)}.chart-header{margin-bottom:1.5rem}.chart-header h3{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.chart-header p{font-size:.875rem;color:var(--text-secondary)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border-color);opacity:.3}.recharts-text{fill:var(--text-secondary);font-size:.75rem}.recharts-legend-wrapper{padding-top:1rem}.recharts-legend-item-text{color:var(--text-primary);font-size:.875rem}.recharts-tooltip-wrapper{outline:none}.recharts-default-tooltip{background:var(--bg-primary)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;box-shadow:var(--shadow)!important}.recharts-tooltip-label{color:var(--text-primary)!important;font-weight:600!important}.recharts-tooltip-item{color:var(--text-primary)!important}@media(max-width:1024px){.revenue-charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.revenue-filters,.filter-group{flex-direction:column;align-items:stretch}.time-filter-buttons{width:100%;justify-content:stretch}.time-filter-btn{flex:1}.date-range-picker{flex-direction:column;align-items:stretch}.date-input{width:100%}.revenue-stats-grid{grid-template-columns:1fr}.stat-value{font-size:1.25rem}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{color:var(--primary-green)}@media(max-width:480px){.chart-card{padding:1rem}.chart-header h3{font-size:1rem}}.bank-accounts-page{max-width:1400px;margin:0 auto}.bank-accounts-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.bank-accounts-filters .search-box{flex:1;min-width:300px;position:relative}.bank-accounts-filters .search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.bank-accounts-filters .search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-color);border-radius:10px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary)}.bank-accounts-filters .search-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.bank-accounts-table-container{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;overflow-x:auto}.bank-accounts-table{width:100%;border-collapse:collapse}.bank-accounts-table thead{background:var(--bg-secondary)}.bank-accounts-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);white-space:nowrap}.bank-accounts-table tbody tr{border-bottom:1px solid var(--border-color);transition:all .3s ease}.bank-accounts-table tbody tr:hover{background:var(--bg-secondary)}.bank-accounts-table td{padding:1rem;font-size:.875rem;color:var(--text-primary)}.cell-bank{display:flex;align-items:center;gap:.75rem}.cell-bank svg{color:var(--primary-green);flex-shrink:0}.bank-name{font-weight:600;color:var(--text-primary)}.cell-code{font-weight:500}.cell-bin{color:var(--text-secondary);font-size:.8125rem}.cell-owner{display:flex;align-items:center;gap:.5rem}.cell-owner svg{color:var(--text-secondary);flex-shrink:0}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.badge-active{background:#22c55e26;color:var(--primary-green)}.badge-inactive{background:var(--bg-secondary);color:var(--text-secondary)}.bank-accounts-actions{display:flex;align-items:center;gap:.5rem}.bank-accounts-page .action-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;background:transparent}.bank-accounts-page .action-btn.view-btn{color:var(--primary-green)}.bank-accounts-page .action-btn.view-btn:hover{background:#22c55e1a}.bank-accounts-page .action-btn.edit-btn{background:#3b82f61f;color:#3b82f6}.bank-accounts-page .action-btn.edit-btn:hover{background:#3b82f633;color:#2563eb}.bank-accounts-page .action-btn.delete-btn{background:#ef44441f;color:#ef4444}.bank-accounts-page .action-btn.delete-btn:hover{background:#ef444433;color:#dc2626}.bank-accounts-page .action-btn.qr-btn{background:#8b5cf61f;color:#8b5cf6}.bank-accounts-page .action-btn.qr-btn:hover{background:#8b5cf633;color:#7c3aed}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-secondary)}.loading-spinner{animation:bank-spin 1s linear infinite;color:var(--primary-green)}@keyframes bank-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--text-secondary)}.empty-state svg{opacity:.5}.bank-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.bank-dialog-content{background:var(--bg-primary);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:560px;max-height:90vh;overflow-y:auto}.bank-detail-content{max-width:640px}.bank-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.bank-dialog-header h2{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.dialog-header-actions{display:flex;align-items:center;gap:.5rem}.dialog-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.dialog-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.bank-dialog-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.bank-dialog-form .form-group{display:flex;flex-direction:column;gap:.5rem}.bank-dialog-form .form-group label{font-weight:600;font-size:.875rem;color:var(--text-primary)}.bank-dialog-form .form-input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;transition:all .3s ease;background:var(--bg-primary);color:var(--text-primary);width:100%}.bank-dialog-form .form-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.bank-dialog-form .form-select{cursor:pointer;appearance:auto}.bank-dialog-form .form-hint{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-secondary);margin-top:.25rem}.bank-dialog-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.bank-dialog-form .checkbox-group label{display:flex;align-items:center;gap:.5rem;font-weight:500;cursor:pointer}.bank-dialog-form .checkbox-group input[type=checkbox]{width:1rem;height:1rem}.dialog-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color);margin-top:.5rem}.btn-cancel,.btn-submit,.btn-delete{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;border:none}.btn-cancel{background:var(--bg-secondary);color:var(--text-primary)}.btn-cancel:hover:not(:disabled){background:var(--text-secondary);color:#fff}.btn-submit{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;box-shadow:0 4px 12px #22c55e4d}.btn-submit:hover:not(:disabled){box-shadow:0 6px 20px #22c55e66;transform:translateY(-1px)}.btn-delete{background:#ef4444e6;color:#fff}.btn-delete:hover{background:#dc2626}.btn-cancel:disabled,.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner{animation:bank-spin 1s linear infinite}.loading-state-dialog{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem;color:var(--text-secondary)}.bank-detail-body{padding:1.5rem}.bank-detail-body .detail-row{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.bank-detail-body .detail-row label{font-weight:600;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.bank-detail-body .detail-row span{font-size:.9375rem;color:var(--text-primary);padding:.75rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem}.detail-value-name{font-weight:700;font-size:1.125rem;color:var(--primary-green)}.delete-confirm-content{max-width:420px}.delete-confirm-body{padding:1.5rem}.delete-confirm-body p{margin:0 0 1.25rem;color:var(--text-primary);line-height:1.5}.delete-confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.qr-dialog-content{max-width:420px}.qr-dialog-body{padding:1.5rem}.qr-dialog-hint{font-size:.8125rem;color:var(--text-secondary);margin-bottom:1rem;line-height:1.5}.qr-dialog-hint a{color:var(--primary-green);text-decoration:none}.qr-dialog-hint a:hover{text-decoration:underline}.qr-form-row{margin-bottom:1rem}.qr-form-row .form-group label{font-weight:600;font-size:.875rem;color:var(--text-primary)}.qr-readonly{display:block;padding:.5rem 0;font-size:.9375rem;color:var(--text-primary)}.qr-form-row .form-input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);width:100%}.qr-image-wrap{display:flex;justify-content:center;padding:1.25rem 0;background:var(--bg-secondary);border-radius:12px;margin:1rem 0}.qr-image{width:200px;height:200px;object-fit:contain}.qr-dialog-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color);margin-top:.5rem}.qr-copy-btn,.bank-accounts-page .btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.qr-copy-btn:hover,.bank-accounts-page .btn-secondary:hover{border-color:var(--primary-green);color:var(--primary-green);background:#22c55e14}@media(max-width:768px){.bank-accounts-table-container{overflow-x:auto}.bank-accounts-table{min-width:700px}.bank-dialog-form .form-row{grid-template-columns:1fr}.bank-dialog-content{max-width:95%}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.75rem;pointer-events:none;max-width:400px}.toast{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border-radius:10px;box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;background:var(--bg-primary);border:1px solid var(--border-color);pointer-events:auto;min-width:300px;max-width:400px;position:relative;overflow:hidden}.toast:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:currentColor}.toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%}.toast-content{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.toast-title{font-weight:600;font-size:.875rem;color:var(--text-primary);line-height:1.4}.toast-message{font-size:.8125rem;color:var(--text-secondary);line-height:1.4;word-wrap:break-word}.toast-close{flex-shrink:0;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:.6}.toast-close:hover{opacity:1;background:#0000000d}.toast-success{background:#f0fdf4;border-color:#86efac;color:#16a34a}.toast-success .toast-icon{background:#22c55e1a;color:#22c55e}.toast-success:before{background:#22c55e}.toast-error{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.toast-error .toast-icon{background:#ef44441a;color:#ef4444}.toast-error:before{background:#ef4444}.toast-warning{background:#fffbeb;border-color:#fde68a;color:#d97706}.toast-warning .toast-icon{background:#f59e0b1a;color:#f59e0b}.toast-warning:before{background:#f59e0b}.toast-info{background:#eff6ff;border-color:#93c5fd;color:#2563eb}.toast-info .toast-icon{background:#3b82f61a;color:#3b82f6}.toast-info:before{background:#3b82f6}@media(max-width:768px){.toast-container{top:.5rem;right:.5rem;left:.5rem;max-width:none}.toast{min-width:auto;max-width:none}}
