@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: #e0e7ff;--secondary: #ec4899;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--white: #ffffff;--bg-app: #f8fafc;--bg-card: #ffffff;--bg-input: #f1f5f9;--border-color: #e2e8f0;--text-primary: #0f172a;--text-secondary: #64748b;--text-tertiary: #94a3b8;--text-inverse: #ffffff;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px 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);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--bg-app);color:var(--text-primary);font-family:var(--font-family)}img,svg{display:block;max-width:100%}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;padding:2rem;border-radius:12px;width:90%;max-width:450px;position:relative;box-shadow:0 10px 25px #0000001a;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.close-btn{position:absolute;top:1rem;right:1.5rem;background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer}.modal-content h2{margin-bottom:1.5rem;color:#1a202c;font-size:1.5rem;font-weight:600}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#4a5568;font-weight:500;font-size:.95rem}.form-group input{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.divider{border:none;border-top:1px solid #e2e8f0;margin:1.5rem 0 1rem}.hint{font-size:.85rem;color:#718096;margin-bottom:1rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.btn-cancel{padding:.75rem 1.5rem;background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#edf2f7}.btn-save{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;box-shadow:0 4px 6px #667eea4d;transition:all .2s}.btn-save:hover{transform:translateY(-1px);box-shadow:0 6px 8px #667eea66}.btn-save:disabled{opacity:.7;cursor:not-allowed;transform:none}.alert-success{background:#c6f6d5;color:#276749;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.alert-error{background:#fed7d7;color:#9b2c2c;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.home-container{background-color:var(--bg-app)}.welcome-section{margin-bottom:2.5rem}.welcome-section h1{font-size:2.25rem;font-weight:800;color:var(--text-primary);margin:0 0 .5rem;letter-spacing:-.5px}.welcome-section .highlight{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-section p{color:var(--text-secondary);font-size:1.1rem;margin:0}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.staff-dashboard{grid-column:1 / -1;display:flex;flex-direction:column;gap:2rem}.stats-grid{grid-column:span 2;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--white);padding:1.5rem;border-radius:16px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);display:flex;align-items:flex-start;gap:1rem;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.stat-icon svg{width:24px;height:24px;color:#fff}.stat-content{display:flex;flex-direction:column}.stat-content h3{margin:0;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em;margin-bottom:.25rem}.stat-number{margin:0;font-size:1.5rem;font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:.25rem}.stat-detail{margin:0;font-size:.75rem;color:var(--text-tertiary)}.user-list-card{grid-column:span 2;background:var(--white);border-radius:24px;border:1px solid var(--border-color);box-shadow:var(--shadow-md);overflow:hidden;margin-top:1rem}.user-list-card .header-info{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.5rem;border-bottom:1px solid var(--border-color);background:#fff}.search-actions{display:flex;align-items:center;gap:1.5rem}.search-box{display:flex;align-items:center;background:var(--bg-app);border:1px solid transparent;border-radius:12px;padding:.75rem 1rem;gap:.75rem;transition:all .2s ease;width:300px}.search-box svg{color:var(--text-tertiary);flex-shrink:0}.search-box input{border:none;outline:none;background:transparent;font-size:.85rem;color:var(--text-secondary);width:100%}.user-list-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);background:var(--bg-app)}.user-list-header h3{color:var(--text-primary);font-size:1.125rem;font-weight:700;margin:0}.user-count-badge{background:var(--primary-light);color:var(--primary);padding:.375rem .875rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:700}.user-list-table{overflow-x:auto}.user-list-table table{width:100%;border-collapse:collapse}.user-list-table th{text-align:left;padding:1rem 1.5rem;color:var(--text-secondary);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:var(--bg-app);border-bottom:1px solid var(--border-color)}.user-list-table td{padding:1rem 1.5rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.9375rem}.user-list-table tbody tr{transition:background .2s}.user-list-table tbody tr:hover{background:var(--bg-app)}.assign-btn{padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all .2s;background:var(--primary-light);color:var(--primary)}.assign-btn:hover{background:var(--primary);color:#fff}.header-info h3{margin:0;font-size:1.25rem;font-weight:800;color:var(--text-primary)}.header-info .subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--text-secondary)}.user-pill{display:flex;align-items:center;gap:1rem}.user-pill .avatar{width:36px;height:36px;background:var(--primary-light);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;border:2px solid white;box-shadow:0 2px 4px #0000000d}.user-pill .info{display:flex;flex-direction:column}.user-pill .username{font-weight:700;color:var(--text-primary);font-size:.95rem}.user-pill .email{font-size:.75rem;color:var(--text-tertiary);margin-bottom:.25rem}.user-exercises-summary{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.ex-brief{font-size:.65rem;background:var(--bg-app);color:var(--text-secondary);padding:1px 6px;border-radius:4px;border:1px solid var(--border-color);max-width:80px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ex-more{font-size:.65rem;color:var(--primary);font-weight:700}.ex-none{font-size:.65rem;color:var(--text-tertiary);font-style:italic}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#10b9811a;color:#10b981}.status-badge.inactive{background:#6b72801a;color:#6b7280}.days-indicator{display:flex;gap:4px}.day-dot{width:24px;height:24px;border-radius:6px;background:var(--bg-app);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;transition:all .2s;border:1px solid var(--border-color)}.day-dot.active{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-action-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-md);border:1px solid var(--primary-light);background:#fff;color:var(--primary);font-weight:700;font-size:.85rem;cursor:pointer;transition:all .2s}.btn-action-primary:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.empty-table-state{padding:4rem 2rem;text-align:center;color:var(--text-tertiary);display:flex;flex-direction:column;align-items:center;gap:1rem}.empty-table-state p{margin:0;font-size:1rem}.attendance-card{grid-column:span 2;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:2rem;border-radius:var(--radius-lg);position:relative;overflow:hidden}.attendance-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;position:relative;z-index:2}.attendance-card h2{font-size:1.5rem;font-weight:800;margin:0}.history-count{background:#fff3;padding:.5rem 1rem;border-radius:var(--radius-full);font-size:.9rem;font-weight:600}.check-in-btn{width:100%;padding:1.25rem;border:none;border-radius:var(--radius-md);background:#fff;color:var(--primary);font-weight:800;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px #0000001a;position:relative;z-index:2}.check-in-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 15px #0003}.check-in-btn:disabled{cursor:default;opacity:1}.check-in-btn.checked{background:#ffffffe6;color:var(--success)}.day-selector-container{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem;margin-bottom:1rem;scrollbar-width:none;-ms-overflow-style:none}.day-selector-container::-webkit-scrollbar{display:none}.day-pill{padding:.6rem 1.25rem;border-radius:9999px;background:var(--white);color:var(--text-secondary);font-weight:600;font-size:.9rem;border:1px solid var(--border-color);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;position:relative;display:flex;align-items:center;gap:.5rem;-webkit-user-select:none;user-select:none}.day-pill:hover{background:var(--bg-app);border-color:var(--primary-light);color:var(--primary);transform:translateY(-1px)}.day-pill.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 12px #2563eb40;transform:translateY(-1px)}.day-pill.has-routine:not(.active){border-color:var(--primary-light);color:var(--primary);background:#2563eb0a}.today-dot{width:6px;height:6px;background-color:#ef4444;border-radius:50%;box-shadow:0 0 4px #ef444466}.day-pill.active .today-dot{background-color:#fff;box-shadow:none}.routine-display-header{margin-left:.5rem}.full-routine-card{grid-column:span 2;background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);overflow:hidden}.full-routine-card .card-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:var(--bg-app)}.header-text h2{margin:0;font-size:1.25rem;font-weight:800;color:var(--text-primary)}.routine-name{display:block;font-size:.9rem;color:var(--primary);font-weight:600;margin-top:.25rem}.exercise-list{display:flex;flex-direction:column}.exercise-item{display:flex;gap:1.25rem;padding:1.5rem;border-bottom:1px solid var(--border-color);transition:background .2s}.exercise-item:last-child{border-bottom:none}.exercise-item:hover{background:var(--bg-app)}.exercise-number{width:40px;height:40px;background:var(--primary-light);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}.exercise-details{flex:1}.exercise-details h3{margin:0 0 .75rem;font-size:1.1rem;color:var(--text-primary);font-weight:700}.exercise-meta{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.meta-tag{background:var(--bg-app);color:var(--text-secondary);padding:.25rem .75rem;border-radius:6px;font-size:.85rem;border:1px solid var(--border-color)}.meta-tag strong{color:var(--text-primary)}.exercise-notes{margin:.75rem 0 0;font-size:.9rem;color:var(--text-tertiary);font-style:italic;background:#fffbeb;padding:.5rem;border-radius:6px;display:inline-block}.no-routine-state{padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.no-routine-state .illustration{font-size:4rem;margin-bottom:1rem}.no-routine-state h3{margin:0 0 .5rem;color:var(--text-primary)}.mini-status-card{grid-column:span 2;background:var(--white);padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);cursor:pointer;transition:all .2s}.mini-status-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.status-row{display:flex;justify-content:space-around;align-items:center}.status-info{text-align:center}.status-info h3{font-size:.8rem;text-transform:uppercase;color:var(--text-secondary);margin:0 0 .25rem}.status-info p{font-size:1.1rem;font-weight:800;margin:0;color:var(--text-primary)}.text-success{color:var(--success)!important}.text-danger{color:var(--danger)!important}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}.attendance-card,.full-routine-card,.mini-status-card{grid-column:span 1}.exercise-item{padding:1.25rem;gap:1rem}.exercise-number{width:32px;height:32px;font-size:.9rem}.check-in-btn{padding:1rem;font-size:1.1rem}}.exercise-checkbox{width:24px;height:24px;cursor:pointer;accent-color:var(--primary);flex-shrink:0;margin-right:.5rem}.exercise-checkbox:disabled{cursor:not-allowed;opacity:.5}.exercise-item.completed{opacity:.7}@media(max-width:768px){.stats-grid,.user-list-card,.attendance-card,.full-routine-card,.mini-status-card{grid-column:1 / -1!important}.user-list-card .header-info{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.25rem}.search-actions{width:100%;flex-direction:column;align-items:stretch;gap:.75rem}.search-box{width:100%;max-width:none}.user-count-badge{align-self:flex-start}.user-list-table thead{display:none}.user-list-table tbody tr{display:block;background:#fff;border:1px solid var(--border-color);border-radius:12px;margin-bottom:1rem;padding:1rem;box-shadow:var(--shadow-sm)}.user-list-table td{display:block;padding:.5rem 0;border:none;text-align:left}.user-list-table td:first-child{border-bottom:1px solid var(--border-color);padding-bottom:.75rem;margin-bottom:.5rem}.user-list-table td:last-child{display:flex;justify-content:flex-end;gap:1rem;margin-top:.5rem;border-top:1px solid var(--border-color);padding-top:.75rem}.days-indicator{justify-content:flex-start;margin-top:.5rem}}.exercise-item.completed .exercise-details h3{text-decoration:line-through;color:var(--text-tertiary)}.progress-indicator{background:var(--bg-app)}.progress-indicator span{color:var(--text-primary)}.superadmin-dashboard{grid-column:span 2;animation:fadeIn .5s ease-out}.gym-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:1rem}.gym-summary-card{background:#fff;border-radius:16px;border:1px solid var(--border-color);overflow:hidden;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.gym-summary-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.gym-accent{height:6px;width:100%}.gym-body{padding:1.5rem;display:flex;flex-direction:column;gap:.5rem}.gym-body h3{margin:0;font-size:1.125rem;font-weight:800;color:var(--text-primary)}.gym-body .slug{font-size:.8rem;color:var(--text-tertiary);font-family:var(--font-mono);margin:0}.gym-footer{margin-top:1rem;display:flex;justify-content:space-between;align-items:center}.status-pill-small{font-size:.7rem;font-weight:800;text-transform:uppercase;padding:.25rem .6rem;border-radius:6px}.status-pill-small.active{background:#ecfdf5;color:#10b981}.status-pill-small.inactive{background:#fef2f2;color:#ef4444}.btn-detail{font-size:.75rem;font-weight:700;color:var(--primary);background:transparent;border:none;padding:0;cursor:pointer;transition:color .2s}.gym-summary-card:hover .btn-detail{color:var(--primary-dark)}.mt-8{margin-top:2rem}.animate-in{animation-duration:.2s;animation-fill-mode:forwards}.fade-in{animation-name:fadeIn}.zoom-in{animation-name:zoomIn}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.duration-200{animation-duration:.2s}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{background:#fff;border-radius:1.5rem;width:100%;max-width:42rem;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;max-height:90vh;display:flex;flex-direction:column}.modal-form-label{display:block;font-size:.7rem;font-weight:800;color:#9ca3af;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}.modal-input-container{position:relative;width:100%}.modal-input{width:100%;padding:.875rem 1rem;border-radius:.75rem;border:1px solid #e5e7eb;background-color:#f9fafb;color:#1f2937;font-weight:500;font-size:.95rem;outline:none;transition:all .2s;box-sizing:border-box}.modal-input:focus{background-color:#fff;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.modal-input-prefix-wrapper{display:flex;align-items:center;padding:.875rem 1rem;border-radius:.75rem;border:1px solid #e5e7eb;background-color:#f9fafb;gap:.5rem;transition:all .2s}.modal-input-prefix-wrapper:focus-within{background-color:#fff;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.modal-input-transparent{background:transparent;border:none;outline:none;width:100%;color:var(--primary);font-weight:600}.color-picker-container{display:flex;align-items:center;gap:.75rem;padding:.5rem;border:1px solid #f3f4f6;border-radius:.75rem;background-color:#f9fafb}.color-preview-box{position:relative;width:2.5rem;height:2.5rem;border-radius:.5rem;overflow:hidden;box-shadow:0 1px 2px #0000000d}.color-input-hidden{position:absolute;top:-50%;left:-50%;width:200%;height:200%;cursor:pointer;border:none;padding:0;margin:0}.modal-actions{display:flex;gap:1rem;padding-top:1.5rem;margin-top:1.5rem;border-top:1px solid #f3f4f6}.btn-cancel{padding:0 1rem;color:#9ca3af;font-weight:700;font-size:.875rem;background:transparent;border:none;cursor:pointer;transition:color .2s}.btn-cancel:hover{color:#4b5563}.btn-save{flex:1;background-color:var(--primary);color:#fff;padding:.875rem;border-radius:1rem;font-weight:700;border:none;cursor:pointer;box-shadow:0 4px 6px -1px #6366f11a,0 2px 4px -1px #6366f10f;transition:all .2s}.btn-save:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 10px 15px -3px #6366f133}.currency-input-wrapper{position:relative;width:100%}.currency-symbol{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;font-weight:700;pointer-events:none}.modal-header{padding:1.5rem;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;align-items:center;background-color:#f9fafb80}.modal-content-scroll{padding:2rem;overflow-y:auto;flex:1}.modal-footer{padding:1.5rem;background-color:#f9fafb;border-top:1px solid #f3f4f6;display:flex;gap:1rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.stat-pill{padding:1rem;background:#f9fafb;border-radius:.75rem;border:1px solid #f3f4f6}.staff-member-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border:1px solid #f3f4f6;border-radius:.75rem;transition:border-color .2s}.config-box{padding:1.5rem;background:#eff6ff80;border-radius:1rem;border:1px solid #dbeafe}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.font-bold{font-weight:700}.font-black{font-weight:900}.uppercase{text-transform:uppercase}.mt-4{margin-top:1.25rem}.mb-1{margin-bottom:.25rem}.mb-3{margin-bottom:.75rem}.space-y-8>*+*{margin-top:2rem}.payment-modal-container{max-width:450px;width:100%;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.payment-modal-header{padding:24px;background-color:#f9fafb;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;align-items:flex-start}.payment-modal-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0}.payment-modal-subtitle{font-size:.875rem;color:#6b7280;margin-top:4px;margin-bottom:0}.payment-modal-close{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;transition:color .2s}.payment-modal-close:hover{color:#4b5563}.payment-modal-form{padding:32px;display:flex;flex-direction:column;gap:24px}.payment-input-group{display:flex;flex-direction:column;gap:8px}.payment-input-group label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:0}.payment-input-wrapper{position:relative;display:flex;align-items:center}.payment-currency-symbol{position:absolute;left:16px;color:#9ca3af;font-weight:500;pointer-events:none;z-index:10}.payment-input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:12px;font-size:1rem;color:#111827;background-color:#fff;transition:all .2s;outline:none;height:48px}.payment-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.payment-input.has-currency{padding-left:32px}.payment-select-wrapper{position:relative;width:100%}.payment-select{appearance:none;-webkit-appearance:none;cursor:pointer;width:100%}.payment-select-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);pointer-events:none;color:#6b7280;display:flex;align-items:center;justify-content:center;width:20px;height:20px}.payment-textarea{min-height:120px;resize:none;height:auto;font-family:inherit}.payment-actions{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding-top:24px;border-top:1px solid #f9fafb;margin-top:8px}.btn-payment-cancel{padding:12px;border-radius:12px;border:1px solid #e5e7eb;background-color:transparent;color:#4b5563;font-weight:600;text-transform:uppercase;font-size:.875rem;cursor:pointer;transition:background-color .2s;text-align:center}.btn-payment-cancel:hover{background-color:#f9fafb}.btn-payment-submit{padding:12px;border-radius:12px;border:none;background-color:#6366f1;color:#fff;font-weight:600;text-transform:uppercase;font-size:.875rem;cursor:pointer;box-shadow:0 4px 6px -1px #6366f14d;transition:background-color .2s,transform .1s;text-align:center}.btn-payment-submit:hover{background-color:#4f46e5}.btn-payment-submit:active{transform:scale(.98)}.btn-action-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);transition:all .2s;cursor:pointer}.btn-action-icon:hover{background:var(--bg-app);color:var(--primary);border-color:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.history-row-actions{display:flex;gap:.5rem;justify-content:center}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:var(--space-lg)}.login-card{width:100%;max-width:440px;background:var(--white);border-radius:var(--radius-lg);padding:3rem 2.5rem;box-shadow:var(--shadow-xl)}.login-header{text-align:center;margin-bottom:2.5rem}.logo{width:64px;height:64px;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:#fff}.logo svg{width:32px;height:32px}.login-header h1{font-size:1.875rem;font-weight:800;color:var(--text-primary);margin:0 0 .5rem;letter-spacing:-.5px}.login-header p{color:var(--text-secondary);font-size:.95rem;margin:0}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);padding:.875rem 1rem;display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;color:#dc2626;font-size:.9rem}.error-message svg{width:20px;height:20px;flex-shrink:0}.login-form{display:flex;flex-direction:column;gap:1.25rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-weight:600;color:var(--text-primary);font-size:.9rem}.input-wrapper{position:relative;width:100%}.input-wrapper>svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-tertiary);pointer-events:none;transition:color .2s;z-index:10}.input-wrapper input{width:100%;padding:.875rem 3rem;border:1.5px solid var(--border-color);border-radius:var(--radius-md);font-size:.95rem;transition:all .2s;background:var(--white);color:var(--text-primary);box-sizing:border-box}.input-wrapper input::placeholder{color:var(--text-tertiary)}.input-wrapper input:hover{border-color:var(--text-tertiary)}.input-wrapper input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.input-wrapper input:focus+svg,.input-wrapper:focus-within>svg{color:var(--primary)}.input-wrapper input:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-input)}.toggle-password-btn{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:color .2s}.toggle-password-btn:hover{color:var(--primary)}.submit-btn{width:100%;margin-top:.5rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 12px #6366f14d}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6366f166}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn svg{width:20px;height:20px}.spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.admin-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem;margin:0}.admin-hint svg{width:16px;height:16px;flex-shrink:0}@media(max-width:480px){.login-card{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}}.confirm-modal-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:confirm-fadeIn .3s ease-out}.confirm-modal-container{background:#fff;width:90%;max-width:440px;border-radius:28px;padding:2.5rem;box-shadow:0 25px 50px -12px #00000040,0 10px 10px -5px #0000001a;animation:confirm-zoomIn .4s cubic-bezier(.16,1,.3,1);border:1px solid rgba(255,255,255,.2)}.confirm-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.confirm-modal-header h2{margin:0;font-size:1.6rem;font-weight:800;color:#0f172a;letter-spacing:-.02em}.confirm-close-btn{background:#f1f5f9;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;transition:all .2s cubic-bezier(.4,0,.2,1)}.confirm-close-btn:hover{background:#e2e8f0;color:#0f172a;transform:rotate(90deg)}.confirm-modal-content p{color:#475569;line-height:1.6;margin:0 0 2.5rem;font-size:1.15rem;font-weight:500}.confirm-modal-footer{display:flex;gap:1.2rem}.confirm-btn-base{flex:1;padding:1rem 1.5rem;border-radius:16px;font-weight:700;font-size:1.1rem;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;border:none}.confirm-btn-base:active{transform:scale(.96) translateY(1px)}.confirm-btn-confirm.danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 10px 15px -3px #ef44444d}.confirm-btn-confirm.danger:hover{box-shadow:0 15px 25px -5px #ef444466;transform:translateY(-2px)}.confirm-btn-confirm.primary{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 10px 15px -3px #6366f14d}.confirm-btn-confirm.primary:hover{box-shadow:0 15px 25px -5px #6366f166;transform:translateY(-2px)}.confirm-btn-cancel{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}.confirm-btn-cancel:hover{background:#f1f5f9;color:#334155;border-color:#cbd5e1}@keyframes confirm-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes confirm-zoomIn{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.page-container{max-width:1400px;margin:0 auto;width:100%;display:flex;flex-direction:column;flex:1}.admin-card-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);width:100%;flex-wrap:wrap;gap:1.5rem}.header-title-container{flex:1;min-width:200px}.search-box{display:flex;align-items:center;background:#f1f5f9;border:1px solid transparent;border-radius:9999px;padding:.625rem 1.25rem;gap:.75rem;transition:all .2s ease;width:320px;max-width:100%}.search-box:focus-within{background:#fff;border-color:var(--primary);box-shadow:0 0 0 4px #6366f126}.search-box svg{color:var(--text-tertiary);flex-shrink:0;width:20px;height:20px}.search-box input{border:none;outline:none;background:transparent;font-size:.95rem;color:var(--text-primary);width:100%;font-weight:500}.search-box input::placeholder{color:#94a3b8;font-weight:400}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.page-title{color:var(--text-primary);font-size:2rem;font-weight:800;margin:0 0 .5rem;letter-spacing:-.5px}.page-subtitle{color:var(--text-secondary);font-size:1rem;margin:0}.header-left{display:flex;flex-direction:column;gap:.5rem}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s;width:fit-content;font-weight:600}.back-btn:hover{background:var(--bg-app);color:var(--text-primary)}.create-btn{display:flex;align-items:center;gap:.625rem;padding:.875rem 1.5rem;background:var(--primary);border-radius:var(--radius-md);color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;border:none}.create-btn svg{width:20px;height:20px}.create-btn:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.create-form-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:2rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.create-form-card h2{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0 0 1.5rem}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-bottom:1.5rem}.form-group label{color:var(--text-primary);font-size:.9rem;font-weight:600}.form-group input,.form-group select{padding:.75rem 1rem;background:var(--white);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;transition:all .2s}.form-group input::placeholder{color:var(--text-tertiary)}.form-group input:hover,.form-group select:hover{border-color:var(--text-tertiary)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-actions{display:flex;justify-content:flex-end;gap:.75rem}.cancel-btn{padding:.75rem 1.5rem;background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.submit-btn{padding:.75rem 1.75rem;background:var(--primary);border-radius:var(--radius-md);color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;min-width:140px;display:flex;align-items:center;justify-content:center;border:none}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d;background:var(--primary-hover)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem}.loading-state p{color:var(--text-secondary);font-size:.95rem}.spinner-large{width:40px;height:40px;border:4px solid var(--primary-light);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.table-responsive{overflow-x:auto;width:100%}.table{width:100%;border-collapse:collapse}.table thead{background:var(--bg-app)}.table th{text-align:left;padding:1rem 1.5rem;color:var(--text-secondary);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.table th:first-child{width:140px}.table td{padding:1.125rem 1.5rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.95rem;vertical-align:middle}.table tbody tr:hover td{background:var(--bg-app)}.text-gray{color:var(--text-secondary)!important}.font-medium{font-weight:600}.flex-center{display:flex;align-items:center}.user-avatar-small{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.email-cell{color:var(--text-secondary)!important}.role-select{padding:.5rem 1rem;border-radius:var(--radius-full);border:1.5px solid var(--border-color);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;background:var(--white);color:var(--text-primary)}.role-select:focus{outline:none;box-shadow:0 0 0 3px var(--primary-light);border-color:var(--primary)}.role-select:disabled{opacity:.6;cursor:not-allowed}.actions-cell{text-align:center}.delete-btn{padding:.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--danger);cursor:pointer;transition:all .2s}.delete-btn svg{width:18px;height:18px}.delete-btn:hover{background:#ef444433;border-color:#ef444466}.you-badge{background:var(--primary-light);color:var(--primary);padding:.5rem 1rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:700}.alert{padding:1rem;border-radius:var(--radius-md);background:var(--white);border:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.alert-error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.alert-success{background:#ecfdf5;border-color:#d1fae5;color:#047857}.alert button{background:none;border:none;color:inherit;font-size:1.25rem;cursor:pointer;opacity:.7;transition:opacity .2s}.alert button:hover{opacity:1}.status-badge{padding:.375rem .875rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-admin{background:#fef2f2;color:var(--danger)}.status-staff{background:#fffbeb;color:var(--warning)}.status-usuario,.status-active{background:#ecfdf5;color:var(--success)}.status-inactive{background:#f3f4f6;color:var(--text-tertiary);border:1px solid var(--border-color)}@media(max-width:768px){.admin-content{padding:1.5rem 1rem}.admin-header{flex-direction:column;gap:1.25rem}.create-btn{width:100%;justify-content:center}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}.admin-header h1{font-size:1.625rem}.users-table th:nth-child(1),.users-table td:nth-child(1){display:none}}.page-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}.page-nav h1{font-size:2rem;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.5px}.page-nav p{color:var(--text-secondary);font-size:1rem;margin:.25rem 0 0}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s;font-weight:600;font-size:.9rem}.back-btn svg{width:18px;height:18px}.back-btn:hover{background:var(--bg-app);color:var(--text-primary);border-color:var(--text-tertiary)}.add-btn{padding:.75rem 1.5rem;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-weight:700;cursor:pointer;transition:all .2s;font-size:.95rem}.add-btn:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.filters-container{overflow-x:auto;padding-bottom:.5rem;margin-bottom:1.5rem}.filter-scroll{display:flex;gap:.5rem;min-width:min-content}.filter-pill{padding:.625rem 1.125rem;border-radius:var(--radius-full);background:var(--white);border:1.5px solid var(--border-color);color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.filter-pill:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.filter-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.exercises-catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.exercise-card{display:flex;flex-direction:column;justify-content:space-between;background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);transition:all .2s;min-height:480px}.exercise-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.exercise-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.muscle-icon-wrapper{width:40px;height:40px;background:var(--bg-app);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.muscle-group-badge{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--primary);letter-spacing:.5px}.exercise-card h3{color:var(--text-primary);margin:0 0 .75rem;font-size:1.125rem;font-weight:700}.exercise-card .description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0 0 1rem;display:-webkit-box;display:box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.exercise-card .exercise-stats{margin-top:auto;display:flex;gap:.5rem;background:var(--bg-app);padding:1rem;border-radius:var(--radius-md);margin-bottom:1rem}.exercise-card .stat-pill{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;flex:1;background:#fff;padding:.75rem .5rem;border-radius:var(--radius-md);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.exercise-card .stat-label{font-size:.65rem;text-transform:uppercase;color:var(--text-secondary);font-weight:700;letter-spacing:.5px}.exercise-card .stat-value{font-size:1rem;font-weight:800;color:var(--text-primary);line-height:1.2;text-align:center}.exercise-actions{display:flex;gap:.5rem}.exercise-actions button{flex:1;padding:.625rem;border-radius:var(--radius-md);border:none;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.edit-btn{background:#3b82f61a;color:var(--info)}.edit-btn:hover{background:#3b82f633}.delete-btn{background:#ef44441a;color:var(--danger)}.delete-btn:hover{background:#ef444433}.empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;background:var(--white);border-radius:var(--radius-lg);border:2px dashed var(--border-color);color:var(--text-secondary)}.empty-state span{font-size:4rem;display:block;margin-bottom:1rem;opacity:.5}.form-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:2rem;margin-bottom:2rem;box-shadow:var(--shadow-sm)}.form-card h2{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.25rem;font-weight:700}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;color:var(--text-primary);margin-bottom:.5rem;font-size:.9rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;background:var(--white);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;transition:all .2s}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--text-tertiary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group select option{background:var(--white);color:var(--text-primary)}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.cancel-btn{padding:.75rem 1.5rem;background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s;font-weight:600}.cancel-btn:hover{background:var(--bg-app);color:var(--text-primary)}.submit-btn{padding:.75rem 1.5rem;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-weight:700;cursor:pointer;transition:all .2s}.submit-btn:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.message{padding:1rem 1.25rem;border-radius:var(--radius-md);margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;font-size:.95rem}.message.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#15803d}.message.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#b91c1c}.message button{background:none;border:none;color:inherit;font-size:1.25rem;cursor:pointer;opacity:.7;transition:opacity .2s}.message button:hover{opacity:1}.loading{text-align:center;color:var(--text-secondary);padding:4rem;font-size:1.125rem}@media(max-width:768px){.page-nav{flex-direction:column;gap:1rem;align-items:stretch}.form-row,.exercises-grid{grid-template-columns:1fr}}.routines-layout{display:grid;grid-template-columns:320px 1fr;gap:1.5rem;flex:1;min-height:0}.users-panel{display:flex;flex-direction:column;overflow:hidden;background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.users-panel .card-header{padding:1.5rem;border-bottom:1px solid var(--border-color);margin:0;font-size:1.125rem;font-weight:700;color:var(--text-primary)}.users-list{flex:1;overflow-y:auto;padding:1rem}.user-item{display:flex;align-items:center;gap:.875rem;padding:.875rem;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;border:1.5px solid transparent}.user-item:hover{background:var(--bg-app)}.user-item.active{background:var(--primary-light);border-color:var(--primary)}.user-avatar{width:40px;height:40px;background:var(--primary-light);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--primary);font-weight:700;font-size:1rem;flex-shrink:0}.user-item.active .user-avatar{background:var(--primary);color:#fff}.user-info{flex:1;display:flex;flex-direction:column;gap:.25rem;overflow:hidden}.user-info .name{color:var(--text-primary);font-weight:600;font-size:.95rem}.user-info .email{color:var(--text-secondary);font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-item svg{width:16px;height:16px;color:var(--text-tertiary)}.editor-panel{display:flex;flex-direction:column;overflow:hidden;background:var(--white);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm)}.days-selector{display:flex;gap:.5rem;margin-bottom:1.5rem}.day-btn{flex:1;min-width:0;padding:.75rem .5rem;background:var(--white);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;position:relative}.day-btn:hover{background:var(--bg-app);border-color:var(--text-tertiary)}.day-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.day-btn .dot{position:absolute;top:6px;right:6px;width:6px;height:6px;background:var(--success);border-radius:50%}.day-btn.active .dot{background:#fff}.routine-editor{flex:1;overflow-y:auto;display:flex;flex-direction:column}.exercises-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;padding:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-app);max-height:300px;overflow-y:auto}.exercises-grid-mini{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.exercise-chip{display:flex;gap:.75rem;padding:.875rem;background:var(--bg-app);border:1.5px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;align-items:flex-start}.exercise-chip:hover{border-color:var(--primary);background:var(--primary-light)}.exercise-chip.selected{background:var(--primary-light);border-color:var(--primary)}.check-circle{width:20px;height:20px;border:2px solid var(--border-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;flex-shrink:0;transition:all .2s}.exercise-chip.selected .check-circle{background:var(--primary);border-color:var(--primary)}.chip-info{display:flex;flex-direction:column;gap:.25rem}.chip-name{font-weight:600;font-size:.9rem;color:var(--text-primary)}.chip-meta{font-size:.75rem;color:var(--text-secondary)}.muscle-group-chips{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;margin-bottom:1rem}.muscle-group-btn{padding:.5rem 1rem;border-radius:20px;border:1px solid var(--border-color);background:#fff;font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.muscle-group-btn:hover{border-color:var(--primary);color:var(--primary)}.muscle-group-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.templates-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.templates-list{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem}@media(max-width:900px){.routines-layout{grid-template-columns:1fr;height:auto}.users-panel{max-height:300px}.days-selector{overflow-x:auto}}.accounts-page{background:var(--bg-app);height:100%;display:flex;flex-direction:column}.accounts-grid{display:grid;grid-template-columns:1fr 420px;gap:1.5rem;flex:1;min-height:0}.accounts-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));align-content:start;gap:1.25rem;overflow-y:auto;padding-right:.5rem}.account-card{background:var(--white);border-radius:var(--radius-lg);border:2px solid var(--border-color);padding:1.5rem;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.account-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.account-card.selected{border-color:var(--primary);background:var(--primary-light)}.account-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1.25rem}.user-info h3{color:var(--text-primary);margin:0 0 .375rem;font-size:1.0625rem;font-weight:700}.user-info .email{color:var(--text-secondary);font-size:.8125rem}.status-badge{padding:.375rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-active{background:#22c55e26;color:#15803d}.status-expired{background:#ef444426;color:#b91c1c}.status-pending{background:#eab30826;color:#a16207}.account-details{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-color)}.detail-item{display:flex;flex-direction:column;gap:.375rem}.detail-item .label{color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.detail-item .value{color:var(--text-primary);font-size:.9375rem;font-weight:700}.value.debt{color:var(--danger)}.value.ok{color:var(--success)}.details-panel{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-md)}.account-actions-card{padding:1.5rem;height:100%;display:flex;flex-direction:column;gap:2rem}.account-actions-card h2{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0;padding-bottom:1.25rem;border-bottom:1px solid var(--border-color)}.action-group h3{color:var(--text-secondary);font-size:.875rem;margin:0 0 .875rem;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.875rem}.group-header h3{margin:0}.membership-selector{display:flex;gap:.625rem}.type-btn{flex:1;padding:.75rem;background:var(--bg-app);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:600}.type-btn:hover{background:var(--white);border-color:var(--text-tertiary)}.type-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.add-payment-btn{padding:.5rem 1rem;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:.8125rem;font-weight:700;cursor:pointer;transition:all .2s}.add-payment-btn:hover{background:var(--primary-hover)}.payment-form{background:var(--bg-app);padding:1rem;border-radius:var(--radius-md);margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem;border:1px solid var(--border-color)}.payment-form input{width:100%;padding:.75rem;background:var(--white);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem}.amount-row{display:flex;gap:.625rem}.amount-row button{padding:0 1.25rem;background:var(--secondary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:700;transition:all .2s}.amount-row button:hover{opacity:.9}.payments-list{display:flex;flex-direction:column;gap:.75rem;max-height:320px;overflow-y:auto}.payment-item{display:flex;justify-content:space-between;align-items:center;padding:.875rem;background:var(--bg-app);border-radius:var(--radius-md);border:1px solid var(--border-color)}.payment-info{display:flex;flex-direction:column;gap:.25rem}.payment-info .concept{color:var(--text-primary);font-size:.9375rem;font-weight:600}.payment-info .date{color:var(--text-secondary);font-size:.75rem}.payment-item .amount{color:var(--success);font-weight:700;font-size:1rem}.no-data{color:var(--text-secondary);text-align:center;font-size:.9rem;font-style:italic;margin:1.25rem 0}@media(max-width:1000px){.accounts-grid{grid-template-columns:1fr;height:auto}.accounts-list{max-height:400px}}.fee-config{margin-left:auto;margin-right:1rem}.fee-display{background:var(--white);padding:.5rem 1rem;border-radius:var(--radius-full);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s}.fee-display:hover{border-color:var(--primary);transform:translateY(-1px)}.fee-display strong{color:var(--primary);font-size:1.1rem}.edit-icon{font-size:.8rem;color:var(--text-secondary)}.fee-edit-form{background:var(--white);padding:.25rem .5rem;border-radius:var(--radius-full);border:1px solid var(--primary);display:flex;align-items:center;gap:.5rem}.fee-input{width:80px;padding:.25rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem}.page-nav{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 2rem;background:#fff;border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100}.search-box{display:flex;align-items:center;background:#f8fafc;border:1px solid var(--border-color);border-radius:8px;padding:.5rem 1rem;gap:.75rem;transition:all .2s ease;width:350px;margin-right:auto}.search-box:focus-within{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-box svg{color:var(--text-light);flex-shrink:0}.search-box input{border:none;outline:none;background:transparent;font-size:.875rem;color:var(--text-main);width:100%}.save-fee-btn,.cancel-fee-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;padding:.25rem;display:flex;align-items:center}.save-fee-btn{color:var(--success)}.cancel-fee-btn{color:var(--danger)}.membership-actions{background:var(--bg-app);padding:1rem;border-radius:var(--radius-md);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:1rem}.current-plan{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-secondary)}.no-search-results{padding:3rem;text-align:center;color:var(--text-light);grid-column:1 / -1;background:#00000005;border-radius:var(--radius-lg);border:2px dashed var(--border-color)}.current-plan strong{color:var(--text-primary)}.renew-btn{width:100%;padding:.875rem;background:var(--primary);color:#fff!important;border:none;border-radius:var(--radius-md);font-weight:700;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;gap:8px}.renew-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.renew-btn svg{stroke:#fff}.currency-input{position:relative;flex:1}.currency-input span{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-secondary);font-weight:600}.currency-input input{padding-left:24px}.my-routine-page{background:var(--bg-app);padding-bottom:2rem}.week-selector{display:flex;gap:.75rem;margin-bottom:2rem;overflow-x:auto;padding:.25rem;justify-content:center}.day-card{flex:1;min-width:70px;max-width:90px;height:90px;background:var(--white);border:2px solid var(--border-color);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.day-card:hover{background:var(--bg-app);transform:translateY(-2px);box-shadow:var(--shadow-md)}.day-card.active{background:var(--primary);border-color:var(--primary);box-shadow:0 8px 16px #6366f14d}.day-card.active .day-name{color:#fff;font-weight:700}.day-name{color:var(--text-secondary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.day-indicator{width:6px;height:6px;border-radius:50%;background:transparent}.day-card.has-routine .day-indicator{background:var(--success)}.day-card.active .day-indicator{background:#fff}.routine-container{max-width:900px;margin:0 auto}.rest-day{text-align:center;padding:4rem 2rem;background:var(--white);border-radius:var(--radius-lg);border:2px dashed var(--border-color)}.rest-day span{font-size:4rem;display:block;margin-bottom:1.25rem;opacity:.5}.rest-day h2{color:var(--text-primary);margin:0 0 .75rem;font-size:1.5rem;font-weight:700}.rest-day p{color:var(--text-secondary);margin:0;font-size:1rem}.routine-content{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow-sm)}.routine-header{padding:2rem;border-bottom:1px solid var(--border-color);background:linear-gradient(to right,var(--primary-light),transparent)}.routine-header h2{color:var(--text-primary);margin:0 0 1rem;font-size:1.5rem;font-weight:800}.routine-notes{background:#eff6ff;padding:1.25rem;border-radius:var(--radius-md);font-size:.95rem;line-height:1.6;border:1px solid #bfdbfe;border-left:4px solid var(--primary);margin-top:1rem;box-shadow:var(--shadow-sm)}.routine-notes strong{color:var(--primary);display:block;margin-bottom:.5rem;font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.5px}.routine-notes p{color:var(--text-primary);margin:0}.exercises-list{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.exercise-item{display:flex;gap:1.25rem;padding:1.25rem;background:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s}.exercise-item:hover{background:var(--white);transform:translate(4px);box-shadow:var(--shadow-sm)}.exercise-number{width:44px;height:44px;background:var(--primary-light);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--primary);font-weight:800;font-size:1.125rem;flex-shrink:0}.exercise-info{flex:1}.ex-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.ex-header h3{color:var(--text-primary);margin:0;font-size:1.125rem;font-weight:700}.muscle-tag{background:var(--bg-app);color:var(--text-secondary);padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;text-transform:uppercase;border:1px solid var(--border-color)}.ex-desc{color:var(--text-secondary);font-size:.9rem;margin:0 0 1rem;line-height:1.5}.ex-meta{display:flex;gap:1.25rem}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-item .label{color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.meta-item .value{color:var(--text-primary);font-weight:700;font-size:1rem}.exercise-check{display:flex;align-items:center;padding-left:1.25rem;border-left:1px solid var(--border-color)}.custom-checkbox{width:24px;height:24px;accent-color:var(--primary);cursor:pointer}@media(max-width:600px){.week-selector{justify-content:flex-start}.exercise-item{flex-direction:column;gap:1rem}.exercise-check{border-left:none;padding-left:0;padding-top:1rem;border-top:1px solid var(--border-color);justify-content:flex-end}}.logs-page-container{padding-bottom:2rem}.logs-header{margin-bottom:2rem}.logs-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0;background:linear-gradient(to right,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;background-clip:text}.logs-subtitle{color:var(--text-secondary);margin-top:.5rem}.logs-filters{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow-sm)}.filters-grid{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-end}.filter-item{flex:1;min-width:200px}.filter-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.filter-input-wrapper{position:relative;display:flex;align-items:center}.filter-icon{position:absolute;left:1rem;color:var(--text-tertiary);pointer-events:none;width:1rem;height:1rem}.filter-select{width:100%;padding:.75rem 1rem .75rem 2.5rem;background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;outline:none;transition:all .2s;appearance:none}.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.logs-table-container{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.table-wrapper{overflow-x:auto}.logs-table{width:100%;border-collapse:collapse}.logs-table th{text-align:left;padding:1rem 1.5rem;background-color:var(--bg-app);color:var(--text-secondary);font-size:.875rem;font-weight:600;border-bottom:1px solid var(--border-color)}.logs-table td{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);vertical-align:top}.logs-table tr:last-child td{border-bottom:none}.logs-table tr:hover td{background-color:var(--bg-app)}.log-source{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem}.time-text{font-size:.85rem;color:var(--text-tertiary);margin-left:.25rem}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;border:1px solid transparent}.badge.success{background-color:#22c55e1a;color:var(--success);border-color:#22c55e33}.badge.danger{background-color:#ef44441a;color:var(--danger);border-color:#ef444433}.badge.warning{background-color:#f59e0b1a;color:var(--warning);border-color:#f59e0b33}.badge.info{background-color:#3b82f61a;color:var(--info);border-color:#3b82f633}.badge.purple{background-color:#6366f11a;color:var(--primary);border-color:#6366f133}.badge.gray{background-color:var(--bg-input);color:var(--text-secondary);border-color:var(--border-color)}.badge.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.user-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.user-role{font-size:.75rem;color:var(--text-secondary)}.log-details{font-size:.85rem;color:var(--text-secondary);max-width:400px}.detail-row{margin-bottom:.25rem}.detail-key{font-weight:600;color:var(--text-primary);margin-right:.25rem}.stack-trace-box{margin-bottom:.5rem;padding:.75rem;background-color:#fef2f2;border:1px solid #fee2e2;border-radius:var(--radius-md);overflow-x:auto}.stack-title{display:block;color:var(--danger);font-weight:700;margin-bottom:.25rem;font-size:.75rem}.stack-content{font-family:monospace;font-size:.75rem;color:#b91c1c;white-space:pre-wrap;word-break:break-all}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background-color:var(--bg-app)}.pagination-controls{display:flex;gap:.5rem}.page-btn{padding:.5rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.page-btn:hover:not(:disabled){background-color:var(--bg-input);color:var(--text-primary)}.page-btn:disabled{opacity:.5;cursor:not-allowed}.loading-row td,.empty-row td{text-align:center;padding:3rem;color:var(--text-secondary)}.loading-dots{display:flex;justify-content:center;gap:.5rem}.dot{width:8px;height:8px;background-color:var(--primary);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.dot:nth-child(1){animation-delay:-.32s}.dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.my-account-page{background:var(--bg-app);min-height:100vh;padding-bottom:2rem}.page-nav{position:sticky;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.05);box-shadow:0 4px 6px -1px #0000000d}.page-nav h1{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin:0}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.back-btn:hover{background:var(--gray-50);color:var(--text-primary);transform:translate(-2px)}.back-btn svg{width:16px;height:16px}.account-dashboard{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;padding:2rem 1rem}.main-card{background:linear-gradient(135deg,#6366f1,#a855f7);border:none;border-radius:1.5rem;padding:2.5rem;box-shadow:0 20px 25px -5px #6366f140,0 8px 10px -6px #6366f133;color:#fff;position:relative;overflow:hidden}.main-card:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%23ffffff' fill-opacity='0.1' fill-rule='evenodd'/%3E%3C/svg%3E");opacity:.6}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;position:relative;z-index:1}.status-header span:first-child{color:#ffffffe6;font-size:.875rem;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.status-badge{padding:.35rem 1rem;border-radius:9999px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 4px #0000001a}.status-active{background:#fffffff2;color:#059669}.status-pending{background:#fffffff2;color:#d97706}.status-expired{background:#fffffff2;color:#dc2626}.days-remaining{text-align:center;margin-bottom:2rem;position:relative;z-index:1}.days-remaining .number{display:block;font-size:5rem;font-weight:800;line-height:1;color:#fff;text-shadow:0 4px 10px rgba(0,0,0,.1);letter-spacing:-.02em}.days-remaining .label{color:#ffffffe6;font-size:1.125rem;margin-top:.5rem;font-weight:500}.progress-bar{height:8px;background:#0003;border-radius:9999px;overflow:hidden;margin-bottom:1rem;position:relative;z-index:1}.progress-fill{height:100%;background:#fff;border-radius:9999px;box-shadow:0 0 10px #ffffff80;transition:width 1s ease-out}.expiration-text{text-align:center;color:#fffc;font-size:.875rem;margin:0;font-weight:500;position:relative;z-index:1}.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.info-card{background:#fff;padding:1.5rem;border-radius:1.25rem;border:1px solid #f3f4f6;box-shadow:0 4px 6px -1px #0000000d;transition:transform .2s}.info-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000000d}.info-card h3{color:#6b7280;font-size:.75rem;margin:0 0 .5rem;text-transform:uppercase;font-weight:800;letter-spacing:.05em}.large-text{color:#111827;font-size:2rem;font-weight:800;margin:0 0 .25rem;letter-spacing:-.02em}.large-text.debt{color:#ef4444}.large-text.ok{color:#10b981}.sub-text{color:#6b7280;font-size:.875rem;font-weight:500;margin:0}.sub-text.alert{color:#dc2626;font-weight:600}.sub-text.ok{color:#059669;font-weight:600}.history-section{background:#fff;border-radius:1.25rem;padding:2rem;border:1px solid #f3f4f6;box-shadow:0 4px 6px -1px #0000000d}.history-section h3{color:#111827;margin:0 0 1.5rem;font-size:1.25rem;font-weight:800}.payments-list{display:flex;flex-direction:column;gap:.75rem}.payment-row{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f9fafb;border-radius:1rem;border:1px solid #f3f4f6;transition:background-color .2s}.payment-row:hover{background-color:#f3f4f6}.payment-main{display:flex;flex-direction:column;gap:.25rem}.payment-main .concept{color:#374151;font-size:.9375rem;font-weight:700}.payment-main .date{color:#9ca3af;font-size:.8125rem}.payment-row .amount{color:#10b981;font-weight:700;font-size:1.125rem;font-family:monospace}.support-note{text-align:center;color:#9ca3af;font-size:.875rem;margin-top:2rem}.no-history{color:#9ca3af;font-style:italic;text-align:center;padding:2rem;font-size:.9375rem;background:#f9fafb;border-radius:1rem}@media(max-width:600px){.details-grid{grid-template-columns:1fr}.main-card{padding:2rem 1.5rem}.days-remaining .number{font-size:4rem}}.history-page{padding:2.5rem;max-width:1000px;margin:0 auto;animation:fadeIn .5s ease-out}.history-header{margin-bottom:3rem;text-align:center}.history-header h1{font-size:2.5rem;font-weight:800;color:var(--text-primary);margin-bottom:.5rem;background:linear-gradient(to right,var(--primary-color),#4f46e5);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.history-header p{color:var(--text-secondary);font-size:1.1rem}.history-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.history-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease}.history-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid #f1f5f9}.date-box{display:flex;flex-direction:column}.day-name{font-size:1.1rem;font-weight:700;color:var(--text-primary);text-transform:capitalize}.full-date{font-size:.9rem;color:var(--text-secondary)}.status-badge{display:flex;align-items:center;gap:.5rem;background:#ecfdf5;color:#059669;padding:.5rem 1rem;border-radius:9999px;font-size:.85rem;font-weight:700}.completed-exercises h4{font-size:.9rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.exercise-chips{display:flex;flex-wrap:wrap;gap:.75rem}.exercise-chip{display:flex;align-items:center;gap:.5rem;background:var(--bg-app);color:var(--text-primary);padding:.4rem .8rem;border-radius:12px;font-size:.9rem;border:1px solid var(--border-color)}.exercise-chip svg{color:var(--primary-color)}.no-details{color:var(--text-tertiary);font-style:italic;font-size:.9rem}.empty-history{text-align:center;padding:5rem 2rem;background:#fff;border-radius:20px;border:2px dashed var(--border-color)}.empty-icon{font-size:4rem;margin-bottom:1.5rem}.loading-container{display:flex;justify-content:center;align-items:center;height:400px;font-size:1.2rem;color:var(--text-secondary)}@media(max-width:640px){.history-container{grid-template-columns:1fr}}.tickets-filter-group{display:flex;gap:.5rem;background:#fff;padding:4px;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.filter-btn{padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;transition:all .2s;background:transparent;border:none;color:var(--text-secondary);cursor:pointer}.filter-btn:hover{background-color:var(--bg-input);color:var(--text-primary)}.filter-btn.active{background-color:var(--primary-light);color:var(--primary)}.tickets-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:1.5rem;align-items:start}@media(min-width:1024px){.tickets-grid{grid-template-columns:350px 1fr;height:calc(100vh - 120px);overflow:hidden}}.tickets-list{display:flex;flex-direction:column;gap:1rem;overflow-y:auto;padding-right:.5rem;max-height:100%}.ticket-item{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:1rem;cursor:pointer;transition:all .2s;border-left:4px solid transparent}.ticket-item:hover{border-color:var(--primary-light);background-color:var(--bg-app)}.ticket-item.active{border-color:var(--primary);border-left-color:var(--primary);background-color:#fff;box-shadow:var(--shadow-md)}.ticket-item-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.ticket-item-subject{font-weight:600;font-size:.9rem;color:var(--text-primary);margin-bottom:.25rem}.ticket-item-gym{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.chat-container{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-color);display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background-color:#fff}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;background-color:#f0f2f5;background-image:radial-gradient(#dee2e6 1px,transparent 1px);background-size:20px 20px}.message-bubble{max-width:75%;padding:12px 16px;border-radius:20px;position:relative;box-shadow:0 1px 2px #0000001a;font-size:.9375rem;line-height:1.4;margin-bottom:2px}.message-bubble.sent{align-self:flex-end;background-color:var(--primary);color:#fff;border-bottom-right-radius:4px;margin-left:50px}.message-bubble.sent:after{display:none}.message-bubble.received{align-self:flex-start;background-color:#fff;color:var(--text-primary);border-bottom-left-radius:4px;margin-right:50px}.message-bubble.received:before{display:none}.message-info{font-size:.75rem;margin-bottom:.25rem;opacity:.8}.chat-input-area{padding:1rem;background:#fff;border-top:1px solid var(--border-color);display:flex;gap:1rem}.chat-input{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);resize:none;font-family:inherit;outline:none}.chat-input:focus{border-color:var(--primary)}.btn-send{padding:0 1.5rem;background-color:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:background .2s}.btn-send:hover{background-color:var(--primary-hover)}.btn-send:disabled{opacity:.5;cursor:not-allowed}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);text-align:center;padding:2rem}.btn-logs{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;margin-left:.5rem;text-decoration:none}.btn-logs:hover{border-color:var(--primary);color:var(--primary);background-color:var(--primary-light)}.subs-container{max-width:1280px;margin:0 auto;padding:2rem}.subs-header{display:flex;flex-direction:column;justify-content:space-between;gap:1rem;margin-bottom:2.5rem}@media(min-width:768px){.subs-header{flex-direction:row;align-items:center}}.subs-title-group h1{font-size:1.875rem;font-weight:900;color:#111827;display:flex;align-items:center;gap:.75rem;letter-spacing:-.025em;margin:0}.subs-icon-wrapper{background:linear-gradient(135deg,#6366f1,#9333ea);color:#fff;padding:.5rem;border-radius:.75rem;box-shadow:0 4px 6px -1px #6366f166;display:flex;align-items:center;justify-content:center}.subs-subtitle{color:#6b7280;margin-top:.5rem;font-size:1.125rem}.subs-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:1280px){.subs-grid{grid-template-columns:1fr 2fr}}.subs-card{background:#fff;border-radius:1rem;box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -4px #00000006;border:1px solid #f3f4f6;overflow:hidden;transition:box-shadow .3s ease}.subs-card:hover{box-shadow:0 20px 25px -5px #0000000d,0 8px 10px -6px #00000006}.subs-card.sticky{position:sticky;top:2rem}.subs-card-header{padding:2rem 2rem 1.5rem;border-bottom:1px solid #f9fafb}.subs-card-title{font-size:1.25rem;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:.5rem;margin:0}.subs-dot{width:.5rem;height:.5rem;border-radius:50%}.subs-dot.blue{background-color:#6366f1}.subs-dot.amber{background-color:#f59e0b}.subs-form{padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:600;color:#374151;letter-spacing:.025em}.form-input{width:100%;padding:.75rem 1rem;border-radius:.75rem;background-color:#f9fafb;border:1px solid #e5e7eb;font-size:1rem;transition:all .2s}.form-input:focus{background-color:#fff;border-color:#6366f1;outline:none;box-shadow:0 0 0 4px #6366f11a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.input-wrapper-currency{position:relative}.currency-symbol{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;font-weight:700}.form-input.currency{padding-left:2rem}.helper-text{font-size:.75rem;color:#9ca3af;margin-top:.25rem}.form-textarea{resize:none}.form-actions{padding-top:1rem;display:flex;gap:.75rem}.btn{flex:1;padding:.875rem 1.5rem;border-radius:.75rem;font-weight:700;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.btn-primary{background:linear-gradient(to right,#4f46e5,#7c3aed);color:#fff;box-shadow:0 4px 6px -1px #4f46e533}.btn-primary:hover{transform:scale(1.02)}.btn-warning{background:linear-gradient(to right,#f59e0b,#f97316);color:#fff;box-shadow:0 4px 6px -1px #f59e0b33}.btn-secondary{background:#fff;border:2px solid #f3f4f6;color:#4b5563}.btn-secondary:hover{background:#f9fafb;border-color:#e5e7eb}.subs-table-header{padding:1.5rem;background-color:#f9fafb;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;align-items:center}.table-title{font-weight:700;color:#1f2937;font-size:1.125rem}.badge-count{font-size:.75rem;font-weight:700;text-transform:uppercase;color:#9ca3af;background:#f3f4f6;padding:.25rem .75rem;border-radius:9999px}.table-responsive{overflow-x:auto}.subs-table{width:100%;border-collapse:collapse}.subs-table th{background:#f9fafb80;color:#6b7280;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;padding:1.25rem;text-align:left}.subs-table td{padding:1.25rem;border-bottom:1px solid #f3f4f6;vertical-align:middle}.subs-table tr:hover{background-color:#6366f108}.plan-info{display:flex;align-items:center;gap:1rem}.plan-avatar{width:2.5rem;height:2.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.125rem;box-shadow:0 4px 6px -1px #0000001a}.avatar-violet{background:linear-gradient(135deg,#8b5cf6,#d946ef)}.avatar-amber{background:linear-gradient(135deg,#fbbf24,#f97316)}.avatar-blue{background:linear-gradient(135deg,#60a5fa,#06b6d4)}.plan-details-text{display:flex;flex-direction:column}.plan-name{font-weight:700;color:#111827}.plan-desc{font-size:.75rem;color:#6b7280;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700}.badge-purple{background:#f3e8ff;color:#7e22ce;border:1px solid #e9d5ff}.badge-gray{background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb}.badge-green{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.badge-red{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.status-dot{width:6px;height:6px;border-radius:50%}.status-dot.green{background-color:#22c55e}.status-dot.red{background-color:#ef4444}.price-text{font-family:monospace;font-weight:700;font-size:1rem;color:#1f2937}.period-text{font-size:.75rem;color:#9ca3af}.actions-cell{display:flex;gap:.5rem;justify-content:flex-end;opacity:0;transform:translate(10px);transition:all .2s}.subs-table tr:hover .actions-cell{opacity:1;transform:translate(0)}.action-btn{padding:.5rem;border-radius:.5rem;color:#9ca3af;background:transparent;border:none;cursor:pointer;transition:all .2s}.action-btn:hover{background-color:#eef2ff;color:#4f46e5}.action-btn.delete:hover{background-color:#fef2f2;color:#dc2626}.change-password-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-secondary);padding:2rem}.change-password-card{background:#fff;padding:2.5rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:450px;text-align:center}.change-password-card h2{color:var(--text-primary);margin-bottom:.5rem}.change-password-card p{color:var(--text-secondary);margin-bottom:2rem}.change-password-card form{display:flex;flex-direction:column;gap:1.5rem;text-align:left}.change-password-card .form-group{display:flex;flex-direction:column;gap:.5rem}.change-password-card label{font-weight:500;color:var(--text-primary)}.change-password-card input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-size:1rem;transition:all .2s}.change-password-card input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a;outline:none}.change-password-card button{margin-top:1rem;width:100%;padding:.75rem;font-size:1rem}.program-editor{max-width:1000px;margin:0 auto}.grid-editor-layout{display:grid;grid-template-columns:1fr 300px;gap:1rem;min-height:400px}.programs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.program-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .2s;overflow:hidden}.program-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.program-card .card-header{padding:1.25rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;background:transparent}.program-card .card-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);line-height:1.3;margin:0}.program-card .actions{display:flex;gap:.5rem;flex-shrink:0}.btn-icon-small{padding:.25rem;border-radius:4px;background:transparent;border:none;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;font-size:1rem}.btn-icon-small:hover{background:var(--bg-secondary)}.program-card .card-body{padding:1.25rem;display:flex;flex-direction:column;flex:1}.program-card .stats{margin-top:auto;display:flex;gap:.75rem}.stat-item{background:var(--bg-app);padding:.5rem .75rem;border-radius:8px;font-size:.85rem;color:var(--text-secondary);border:1px solid transparent}.program-card:hover .stat-item{border-color:var(--border-color);background:#fff}@media(max-width:768px){.grid-editor-layout{grid-template-columns:1fr}}.gym-profile-page{background:transparent;min-height:auto;padding-bottom:2rem;position:relative}.gym-page-nav{position:sticky;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.05);box-shadow:0 4px 6px -1px #0000000d;margin-bottom:2rem}.gym-page-nav h1{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.5rem}.gym-back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.gym-back-btn:hover{background:var(--bg-app);color:var(--text-primary);transform:translate(-2px)}.gym-content-container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.gym-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.gym-grid{grid-template-columns:2fr 1fr}}.gym-form-card{background:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -1px #00000005;border:1px solid rgba(0,0,0,.03);height:auto}.gym-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.gym-form-header h2{font-size:1.125rem;font-weight:800;color:var(--text-primary);margin:0}.gym-readonly-badge{font-size:.7rem;background:var(--bg-input);color:var(--text-secondary);padding:.25rem .75rem;border-radius:9999px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border-color)}.gym-input-group label{display:block;font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.gym-input-field{width:100%;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:.75rem 1rem;color:var(--text-primary);font-weight:500;transition:all .2s;outline:none}.gym-input-field:disabled{background:#f1f5f9;color:#64748b;cursor:not-allowed;opacity:.9}.gym-subscription-card{background:linear-gradient(135deg,#6366f1,#a855f7);border:none;border-radius:1.5rem;padding:2.5rem;box-shadow:0 20px 25px -5px #6366f140,0 8px 10px -6px #6366f133;color:#fff;position:relative;overflow:hidden}.gym-subscription-card:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%23ffffff' fill-opacity='0.1' fill-rule='evenodd'/%3E%3C/svg%3E");opacity:.6}.gym-status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;position:relative;z-index:1}.gym-status-header span:first-child{color:#ffffffe6;font-size:.875rem;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.gym-status-badge{padding:.35rem 1rem;border-radius:9999px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 4px #0000001a}.gym-status-active{background:#fffffff2;color:#059669}.gym-status-expired{background:#fffffff2;color:#dc2626}.gym-days-remaining{text-align:center;margin-bottom:2rem;position:relative;z-index:1}.gym-days-remaining .number{display:block;font-size:5rem;font-weight:800;line-height:1;color:#fff;text-shadow:0 4px 10px rgba(0,0,0,.1);letter-spacing:-.02em}.gym-days-remaining .label{color:#ffffffe6;font-size:1.125rem;margin-top:.5rem;font-weight:500}.gym-progress-bar{height:8px;background:#0003;border-radius:9999px;overflow:hidden;margin-bottom:1rem;position:relative;z-index:1}.gym-progress-fill{height:100%;background:#fff;border-radius:9999px;box-shadow:0 0 10px #ffffff80;transition:width 1s ease-out}.gym-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;position:relative;z-index:1}.gym-info-card{background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1.5rem;border-radius:1.25rem;border:1px solid rgba(255,255,255,.2);transition:transform .2s;text-align:center}.gym-info-card:hover{transform:translateY(-2px);background:#ffffff26}.gym-info-card h3{color:#fffc;font-size:.75rem;margin:0 0 .5rem;text-transform:uppercase;font-weight:800;letter-spacing:.05em}.gym-large-text{color:#fff;font-size:1.5rem;font-weight:800;margin:0;letter-spacing:-.02em}.gym-action-btn{width:100%;margin-top:2rem;background:#fff;color:var(--primary);border:none;border-radius:1rem;padding:1rem;font-weight:700;font-size:.9375rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px -1px #0000001a;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:.5rem}.gym-action-btn:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a;background:#f8fafc}.gym-support-note{text-align:center;color:#fff9;font-size:.75rem;margin-top:1rem;position:relative;z-index:1}.gym-qr-container{display:flex;flex-direction:column;gap:2rem}@media(min-width:768px){.gym-qr-container{flex-direction:row;align-items:center;text-align:left}}.gym-qr-info{flex:1}.gym-qr-info p{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:2rem}.gym-qr-actions{display:flex;gap:1rem;flex-direction:column}@media(min-width:480px){.gym-qr-actions{flex-direction:row}}.gym-qr-actions .gym-action-btn{margin:0;font-size:.875rem;padding:.75rem 1.25rem}.gym-action-btn.primary{background:var(--primary);color:#fff}.gym-action-btn.secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border-color)}.gym-qr-display{display:flex;flex-direction:column;align-items:center;gap:1rem;background:#f8fafc;padding:1.5rem;border-radius:1.5rem;border:1px dashed var(--border-color)}.gym-qr-box{background:#fff;padding:1rem;border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d}.gym-qr-slug{font-family:monospace;font-size:.875rem;color:var(--text-secondary);background:#fff;padding:.25rem .75rem;border-radius:9999px;border:1px solid var(--border-color)}.demo-page-container{min-height:100vh;background:radial-gradient(circle at top right,#f8fafc,#eef2f6);display:flex;flex-direction:column;font-family:Inter,system-ui,sans-serif;color:#1e293b;overflow-x:hidden}.demo-navbar{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 5%;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:fixed;top:0;left:0;right:0;z-index:100;border-bottom:1px solid rgba(226,232,240,.6)}.logo-text{font-size:1.5rem;font-weight:800;letter-spacing:-.5px;color:#0f172a}.logo-text .highlight{color:#3b82f6}.btn-login{background:transparent;border:1px solid #cbd5e1;padding:.5rem 1.2rem;border-radius:8px;font-weight:600;color:#475569;cursor:pointer;transition:all .2s}.btn-login:hover{background:#f1f5f9;color:#0f172a;border-color:#94a3b8}.demo-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:5rem 5% .5rem;max-width:1400px;margin:0 auto;width:100%}@media(min-width:1024px){.demo-content{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:2rem;padding-top:5rem}}.hero-section{flex:1;max-width:650px;animation:fadeIn .8s ease-out}.hero-title{font-size:2.25rem;line-height:1.1;font-weight:900;margin-bottom:1rem;letter-spacing:-1px}.gradient-text{background:linear-gradient(135deg,#2563eb,#9333ea);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-subtitle{font-size:1.125rem;color:#64748b;line-height:1.6;margin-bottom:1rem}.visual-showcase{margin:2rem 0 3rem;position:relative;border-radius:20px;box-shadow:0 20px 40px -10px #00000026;background:#000;overflow:hidden;animation:fadeIn 1s ease-out}.dashboard-img{width:100%;height:auto;display:block;border-radius:20px}.glow-effect{position:absolute;inset:0;box-shadow:inset 0 0 50px #0000001a;border-radius:20px;pointer-events:none}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.feature-item{background:#fff;padding:.85rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid #f1f5f9;transition:transform .2s}.feature-item:hover{transform:translateY(-5px)}.feature-icon{font-size:2rem;margin-bottom:1rem}.feature-item h3{font-weight:700;margin-bottom:.5rem;color:#0f172a}.feature-item p{font-size:.9rem;color:#64748b;line-height:1.5}.form-section{flex:1;max-width:500px;width:100%;margin-top:3rem}@media(min-width:1024px){.form-section{margin-top:0}}.form-card{background:#fff;padding:1.5rem;border-radius:24px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid #e2e8f0;animation:slideUp .8s ease-out}.form-header{margin-bottom:2rem;text-align:center}.form-header h2{font-size:1.8rem;font-weight:800;color:#0f172a;margin-bottom:.5rem}.form-header p{font-size:.95rem;color:#64748b}.demo-page-container .input-group{margin-bottom:1.25rem}.demo-page-container .input-group label{display:block;font-size:.85rem;font-weight:600;color:#334155;margin-bottom:.5rem}.demo-page-container .input-group input{width:100%;padding:.85rem 1rem;border:1px solid #cbd5e1;border-radius:10px;font-size:1rem;transition:all .2s;outline:none;box-sizing:border-box;background-color:#fff}.demo-page-container .input-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-submit{width:100%;padding:1rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .1s,box-shadow .2s;margin-top:1rem}.btn-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 15px -3px #2563eb4d}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.success-state{text-align:center;padding:2rem 0}.success-icon{font-size:4rem;margin-bottom:1.5rem}.success-state h2{font-size:1.8rem;font-weight:800;color:#0f172a;margin-bottom:1rem}.success-state p{color:#64748b;line-height:1.6;margin-bottom:2rem}.btn-secondary{background:#f1f5f9;color:#0f172a;border:none;padding:.8rem 2rem;border-radius:10px;font-weight:600;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#e2e8f0}.demo-footer{text-align:center;padding:.5rem;color:#94a3b8;font-size:.85rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.hero-title{font-size:2.2rem}.demo-content{padding-top:6rem}.form-card{padding:1.5rem}}.public-register-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)!important;padding:1.5rem;position:relative;overflow:hidden;font-family:Inter,sans-serif!important}.public-register-page .register-card{width:100%;max-width:480px;background-color:#fff!important;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;padding:2.5rem;position:relative;z-index:10;color:#0f172a!important}.public-register-page .register-header{text-align:center;margin-bottom:2rem}.public-register-page .register-title{font-size:1.875rem;font-weight:800;color:#1e293b!important;margin:0 0 .5rem;letter-spacing:-.5px}.public-register-page .register-subtitle{color:#64748b!important;font-size:.95rem;line-height:1.5}.public-register-page .gym-name-highlight{color:#6366f1!important;font-weight:700;font-size:1.1em}.public-register-page .register-form{display:flex;flex-direction:column;gap:1.25rem}.public-register-page .form-group{display:flex;flex-direction:column;gap:.5rem}.public-register-page .form-label{color:#334155!important;font-size:.9rem;font-weight:600;margin-left:.1rem}.public-register-page .form-input-container{position:relative}.public-register-page .form-input{width:100%;padding:.875rem 1rem;border:1.5px solid #e2e8f0;border-radius:.5rem;font-size:.95rem;transition:all .2s;background-color:#fff!important;color:#0f172a!important;outline:none}.public-register-page .form-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.public-register-page .form-input::placeholder{color:#94a3b8}.public-register-page .submit-btn{margin-top:1rem;background:linear-gradient(135deg,#6366f1,#ec4899);color:#fff!important;font-weight:700;padding:.875rem 1.5rem;border-radius:.5rem;border:none;cursor:pointer;font-size:1rem;transition:all .2s;box-shadow:0 4px 12px #6366f14d}.public-register-page .submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6366f166}.public-register-page .submit-btn:disabled{opacity:.7;cursor:not-allowed}.public-register-page .register-footer{margin-top:2rem;text-align:center;border-top:1px solid #e2e8f0;padding-top:1.5rem}.public-register-page .footer-text{color:#64748b;font-size:.875rem}.public-register-page .login-link{color:#6366f1;font-weight:600;text-decoration:none;background:none;border:none;padding:0;cursor:pointer;margin-left:.35rem;transition:color .2s}.public-register-page .login-link:hover{color:#4f46e5;text-decoration:underline}@media(max-width:640px){.public-register-page .register-card{padding:2rem 1.5rem}}.requests-page-container{padding:2rem;max-width:1200px;margin:0 auto}.requests-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.requests-title{font-size:1.8rem;font-weight:700;color:var(--text-primary, #111827);margin:0}.requests-subtitle{color:var(--text-secondary, #6b7280);margin-top:.5rem}.btn-refresh{background:none;border:none;color:var(--primary-color, #4f46e5);font-weight:600;cursor:pointer;padding:.5rem 1rem;border-radius:.5rem;transition:background-color .2s}.btn-refresh:hover{background-color:#eef2ff}.requests-card{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;overflow:hidden}.requests-table-wrapper{overflow-x:auto}.requests-table{width:100%;border-collapse:collapse;text-align:left}.requests-table thead{background-color:#f9fafb;border-bottom:1px solid #e5e7eb}.requests-table th{padding:1rem 1.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280;letter-spacing:.05em}.requests-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .2s}.requests-table tbody tr:hover{background-color:#f9fafb}.requests-table tbody tr:last-child{border-bottom:none}.requests-table td{padding:1rem 1.5rem;color:#374151;vertical-align:middle}.gym-name{font-weight:600;color:#111827}.owner-name{color:#4b5563}.contact-info div{line-height:1.4}.contact-email{color:#111827;font-weight:500}.contact-phone{color:#6b7280;font-size:.875rem}.status-badge{display:inline-flex;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.status-pending{background-color:#fef3c7;color:#92400e}.status-approved{background-color:#d1fae5;color:#065f46}.status-rejected{background-color:#fee2e2;color:#991b1b}.action-buttons{display:flex;justify-content:center;gap:.5rem}.btn-approve{background-color:#e0e7ff;color:#4f46e5;border:none;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-approve:hover{background-color:#c7d2fe;color:#4338ca}.btn-reject{background-color:#fee2e2;color:#dc2626;border:none;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-reject:hover{background-color:#fecaca;color:#b91c1c}.empty-state-row{text-align:center;padding:3rem!important;color:#9ca3af;font-style:italic}.monitor-page-container{padding:2rem;max-width:1600px;margin:0 auto;animation:fadeIn .5s ease-out}.monitor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.status-indicator-wrapper{position:relative;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.pulsing-dot{width:12px;height:12px;background-color:#10b981;border-radius:50%;position:relative}.pulsing-dot:after{content:"";position:absolute;width:100%;height:100%;top:0;left:0;background-color:#10b981;border-radius:50%;animation:ping 1.5s cubic-bezier(0,0,.2,1) infinite;opacity:.75}.dot.red{width:12px;height:12px;background-color:#ef4444;border-radius:50%}.monitor-header .status-badge{font-size:.75rem;font-weight:700;background-color:#f3f4f6;color:#374151;padding:.5rem 1rem;border-radius:999px;letter-spacing:.05em}.with-tooltip{position:relative;cursor:help;text-decoration:underline dotted #9ca3af;text-underline-offset:4px}.with-tooltip:hover .tooltip-content{visibility:visible;opacity:1;transform:translateY(0)}.tooltip-content{visibility:hidden;opacity:0;width:200px;background-color:#1f2937;color:#fff;text-align:center;border-radius:6px;padding:8px;position:absolute;z-index:10;bottom:125%;left:50%;transform:translate(-50%) translateY(5px);transition:opacity .2s,transform .2s;font-size:.75rem;font-weight:500;text-transform:none;letter-spacing:normal;box-shadow:0 4px 6px -1px #0000001a;pointer-events:none}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:#1f2937 transparent transparent transparent}.monitor-grid-advanced{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.monitor-card{background:#fff;border-radius:1.25rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid #f3f4f6;display:flex;flex-direction:column;transition:transform .2s}.monitor-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000000d}.span-2{grid-column:span 2}.span-3{grid-column:span 3}.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-label{font-size:.75rem;font-weight:800;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.big-counter{background:linear-gradient(145deg,#fff,#f9fafb);border-left:5px solid #3b82f6;height:250px;justify-content:space-between}.count-display{font-size:7rem;font-weight:900;color:#111827;line-height:1;letter-spacing:-.05em;margin:auto 0}.card-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:auto;font-size:.8rem;font-weight:600;color:#4b5563}.live-tag{display:flex;align-items:center;gap:6px;color:#dc2626}.dot-small{width:6px;height:6px;background-color:#dc2626;border-radius:50%}.peak-tag strong{color:#111827}.health-status{display:flex;flex-direction:column;gap:1rem;flex:1;justify-content:center}.health-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f9fafb;border-radius:.75rem}.health-item .label{font-size:.8rem;font-weight:600;color:#4b5563}.health-item .value{font-size:.9rem;font-weight:700;color:#111827}.health-item .value.safe{color:#059669}.business-card{border-left:5px solid #10b981}.business-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:.5rem}.stat-block{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.75rem;color:#6b7280;font-weight:600;text-transform:uppercase}.stat-value{font-size:2rem;font-weight:800;color:#1f2937;line-height:1}.stat-value.highlight{color:#059669}.stat-value.warning{color:#f59e0b}.ranking-list{display:flex;flex-direction:column;gap:.75rem}.ranking-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f9fafb;border-radius:.5rem;position:relative;overflow:hidden}.rank-num{font-weight:900;color:#d1d5db;font-size:1.25rem;width:30px}.gym-name{font-weight:700;color:#374151;flex:1;z-index:1}.gym-users{font-weight:600;color:#111827;z-index:1}.activity-bar-container{position:absolute;left:0;top:0;bottom:0;width:80%;pointer-events:none}.activity-bar{height:100%;background-color:#e0e7ff;opacity:.5;transition:width 1s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes ping{75%,to{transform:scale(2);opacity:0}}@media(max-width:1024px){.monitor-grid-advanced{grid-template-columns:1fr}.span-2,.span-3{grid-column:auto}.business-stats-row{grid-template-columns:repeat(2,1fr)}}.app-container{display:flex;height:100vh;overflow:hidden;background-color:var(--bg-app)}.main-content{flex:1;padding:var(--space-xl);max-width:1600px;margin:0 auto;overflow-y:auto;display:flex;flex-direction:column;width:100%}.sidebar{width:280px;background-color:var(--bg-card);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:var(--space-lg);height:100vh;position:sticky;top:0;z-index:1000}.sidebar-brand{font-size:1.5rem;font-weight:800;color:var(--primary);margin-bottom:2rem;display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:1rem var(--space-sm);letter-spacing:-.5px;text-align:center}.nav-links{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.nav-item{display:flex;align-items:center;padding:.875rem 1rem;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:600;font-size:.95rem;transition:all .2s ease;-webkit-user-select:none;user-select:none;cursor:pointer;text-decoration:none}.nav-item:hover{background-color:var(--bg-app);color:var(--text-primary)}.nav-item.active{background-color:var(--primary-light);color:var(--primary)}.nav-icon{margin-right:1rem;font-size:1.25rem;display:flex;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;font-size:.95rem;transition:all .2s ease;cursor:pointer;border:none;gap:.5rem}.btn:disabled{opacity:.7;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:var(--text-inverse);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:#fff;border:1px solid var(--border-color);color:var(--text-secondary);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){border-color:var(--text-primary);color:var(--text-primary);background-color:var(--bg-app)}.btn-soft-primary{background-color:var(--primary-light)!important;color:var(--primary)!important;border:1px solid transparent!important}.btn-soft-primary:hover:not(:disabled){background-color:var(--primary)!important;color:var(--text-inverse)!important;box-shadow:var(--shadow-sm)!important}.btn-danger{background-color:#ef44441a;color:var(--danger)}.btn-danger:hover:not(:disabled){background-color:#ef444433}.btn-block{width:100%}.card{background-color:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--space-xl);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.card-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary);font-size:.9rem}.form-input{width:100%;padding:.75rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--white);color:var(--text-primary);font-size:.95rem;transition:all .2s}.form-input:hover{border-color:var(--text-tertiary)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-input::placeholder{color:var(--text-tertiary)}.text-center{text-align:center}.mb-4{margin-bottom:1rem}.mt-4{margin-top:1rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.w-full{width:100%}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:1rem;background:#fff;border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:900}.mobile-menu-btn{background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text-primary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.mobile-menu-btn:hover{background-color:var(--bg-app)}.mobile-overlay{position:fixed;inset:0;background-color:#00000080;z-index:999;opacity:0;visibility:hidden;transition:all .3s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-overlay.visible{opacity:1;visibility:visible}@media(max-width:1024px){.app-container{flex-direction:column;height:auto;overflow:visible}.main-content{padding:var(--space-md);height:auto;overflow:visible}.mobile-header{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;height:100vh;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);border-right:1px solid var(--border-color);box-shadow:var(--shadow-xl);z-index:1000}.sidebar.open{transform:translate(0)}.sidebar-close-btn{display:flex!important}}.action-buttons-group{display:flex;gap:.5rem;align-items:center}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);border:1px solid transparent;background-color:var(--bg-app);color:var(--text-tertiary);transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer}.btn-icon svg{width:18px;height:18px;stroke-width:2px}.btn-icon:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-icon.detail:hover{background-color:var(--primary-light);color:var(--primary);border-color:var(--primary-light)}.btn-icon.edit:hover{background-color:#fff7ed;color:#ea580c;border-color:#ffedd5}.btn-icon.config:hover{background-color:#f3e8ff;color:#9333ea;border-color:#f3e8ff}.btn-icon.delete:hover{background-color:#fef2f2;color:#ef4444;border-color:#fee2e2}.modal-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.btn-save{flex:2;background-color:var(--primary);color:#fff;padding:.875rem;border-radius:var(--radius-md);font-weight:700;border:none;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.btn-save:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.btn-cancel{flex:1;background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:.875rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background-color:var(--bg-app);color:var(--text-primary);border-color:var(--text-tertiary)}.color-picker-container{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:#fff}.color-preview-box{width:100%;height:48px;border-radius:var(--radius-md);overflow:hidden;position:relative;cursor:pointer;box-shadow:inset 0 2px 4px #0000000d}.color-input-hidden{position:absolute;top:-10px;left:-10px;width:200%;height:200%;opacity:0;cursor:pointer}.currency-input-wrapper{position:relative;display:flex;align-items:center}background-color: rgba(0,0,0,.5); display: flex; justify-content: center; align-items: center; z-index: 1000; backdrop-filter: blur(4px); animation: fadeIn .2s ease-out; } .modal-content{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s ease-out;position:relative}.close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-tertiary);cursor:pointer;padding:.5rem;line-height:1;transition:color .2s}.close-btn:hover{color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
