@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;600;800&display=swap";.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}.loading-text{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.loading-fullscreen{position:fixed;inset:0;background:#fffffff2;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.spinner-large{border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite}.loading-message{color:var(--text-primary);font-size:var(--text-lg);font-weight:500;margin:0}.header{position:sticky;top:0;left:0;right:0;background:var(--bg-primary);border-bottom:1px solid var(--border-color);z-index:var(--z-sticky);transition:all var(--transition-fast)}.header-scrolled{box-shadow:var(--shadow-md)}.header-container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg);height:70px;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xl)}.header-logo{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;font-weight:700;font-size:var(--text-xl);color:var(--primary-color);transition:color var(--transition-fast)}.header-logo:hover{color:var(--primary-dark)}.logo-text{white-space:nowrap}.desktop-nav{display:flex;gap:var(--spacing-xl);flex:1;justify-content:center}.nav-link{color:var(--text-primary);text-decoration:none;font-weight:500;font-size:var(--text-base);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative}.nav-link:hover,.nav-link.active{color:var(--primary-color);background:var(--bg-tertiary)}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.header-icon-btn{position:relative;background:transparent;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--spacing-sm)}.header-icon-btn:hover{background:var(--bg-tertiary);color:var(--primary-color)}.cart-btn{position:relative}.cart-badge{position:absolute;top:0;right:0;background:var(--error-color);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);padding:0 4px}.user-menu{position:relative}.user-btn{gap:var(--spacing-sm)}.user-name{font-size:var(--text-sm);font-weight:500;display:none}.user-menu-backdrop{position:fixed;inset:0;z-index:var(--z-dropdown)}.user-menu-dropdown{position:absolute;top:calc(100% + var(--spacing-sm));right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:260px;z-index:var(--z-dropdown);animation:slideDown .2s ease-out}.user-menu-header{padding:var(--spacing-lg);display:flex;gap:var(--spacing-md);align-items:center}.user-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:600;flex-shrink:0}.user-info{flex:1;min-width:0}.user-fullname{font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--text-sm)}.user-email{color:var(--text-secondary);margin:0;font-size:var(--text-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-divider{height:1px;background:var(--border-color);margin:var(--spacing-xs) 0}.user-menu-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);color:var(--text-primary);text-decoration:none;font-size:var(--text-sm);transition:all var(--transition-fast);cursor:pointer;border:none;background:transparent;width:100%;text-align:left}.user-menu-item:hover{background:var(--bg-tertiary);color:var(--primary-color)}.logout-item{color:var(--error-color)}.logout-item:hover{background:#fee2e2;color:var(--error-color)}.mobile-menu-btn{display:none}.mobile-menu-backdrop{display:none;position:fixed;inset:70px 0 0;background:#00000080;z-index:calc(var(--z-dropdown) - 1)}.mobile-nav{display:none;position:fixed;top:70px;left:0;right:0;background:var(--bg-primary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-lg);max-height:calc(100vh - 70px);overflow-y:auto;z-index:var(--z-dropdown);animation:slideDown .2s ease-out}.mobile-nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);color:var(--text-primary);text-decoration:none;font-size:var(--text-base);font-weight:500;border-bottom:1px solid var(--border-light);transition:all var(--transition-fast);background:transparent;border-left:none;border-right:none;border-top:none;width:100%;text-align:left;cursor:pointer}.mobile-nav-link:hover,.mobile-nav-link.active{background:var(--bg-tertiary);color:var(--primary-color)}.logout-link{color:var(--error-color)}.logout-link:hover{background:#fee2e2}.mobile-nav-divider{height:8px;background:var(--bg-tertiary)}@media(min-width:769px){.user-name{display:inline}}@media(max-width:768px){.desktop-nav{display:none}.mobile-menu-btn{display:flex}.mobile-menu-backdrop,.mobile-nav{display:block}.header-container{padding:0 var(--spacing-md)}.user-name{display:none}}.user-avatar-small{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#d946ef,#a855f7);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.75rem;letter-spacing:.5px}.footer{background:var(--text-primary);color:#e5e7eb;margin-top:auto}.footer-container{max-width:1400px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-lg);display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-2xl)}.footer-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.footer-title{font-size:var(--text-2xl);font-weight:700;color:#fff;margin:0 0 var(--spacing-sm) 0}.footer-subtitle{font-size:var(--text-lg);font-weight:600;color:#fff;margin:0 0 var(--spacing-md) 0}.footer-description{color:#d1d5db;line-height:1.6;margin:0;font-size:var(--text-sm)}.footer-social{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffff1a;color:#fff;border-radius:var(--radius-md);font-size:1.25rem;transition:all var(--transition-fast)}.social-link:hover{background:var(--primary-color);transform:translateY(-2px)}.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.footer-links li a{color:#d1d5db;text-decoration:none;font-size:var(--text-sm);transition:color var(--transition-fast);display:inline-block}.footer-links li a:hover{color:var(--primary-light);padding-left:var(--spacing-sm)}.footer-contact{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.footer-contact li{display:flex;align-items:flex-start;gap:var(--spacing-md);color:#d1d5db;font-size:var(--text-sm)}.footer-contact li svg{color:var(--primary-light);font-size:1.25rem;flex-shrink:0;margin-top:2px}.footer-contact li a{color:#d1d5db;text-decoration:none;transition:color var(--transition-fast)}.footer-contact li a:hover{color:var(--primary-light)}.footer-divider{height:1px;background:#ffffff1a;max-width:1400px;margin:0 auto}.footer-bottom{padding:var(--spacing-lg)}.footer-bottom .footer-container{display:flex;justify-content:space-between;align-items:center;padding:0 var(--spacing-lg);gap:var(--spacing-lg)}.footer-copyright{color:#9ca3af;font-size:var(--text-sm);margin:0}.footer-payments{display:flex;align-items:center;gap:var(--spacing-md)}.payment-text{color:#9ca3af;font-size:var(--text-sm)}.payment-icons{display:flex;gap:var(--spacing-sm)}.payment-icon{font-size:1.5rem;opacity:.8;transition:opacity var(--transition-fast)}.payment-icon:hover{opacity:1}@media(max-width:768px){.footer-container{grid-template-columns:1fr;padding:var(--spacing-xl) var(--spacing-md)}.footer-bottom .footer-container{flex-direction:column;text-align:center;gap:var(--spacing-md)}.footer-payments{flex-direction:column;gap:var(--spacing-sm)}}.main-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;width:100%}.admin-layout{display:flex;min-height:100vh;background:var(--bg-secondary)}.admin-sidebar{width:280px;background:var(--bg-primary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:var(--z-fixed);transition:transform var(--transition-base)}.sidebar-header{padding:var(--spacing-xl) var(--spacing-lg);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.sidebar-title{font-size:var(--text-xl);font-weight:700;color:var(--primary-color);margin:0}.sidebar-close{display:none;background:transparent;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs)}.sidebar-nav{flex:1;padding:var(--spacing-lg) 0;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);color:var(--text-secondary);text-decoration:none;font-size:var(--text-base);font-weight:500;transition:all var(--transition-fast);border-left:3px solid transparent}.sidebar-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-link.active{background:var(--bg-tertiary);color:var(--primary-color);border-left-color:var(--primary-color)}.sidebar-link svg{font-size:1.25rem;flex-shrink:0}.sidebar-footer{padding:var(--spacing-lg);border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-link.logout{color:var(--error-color)}.sidebar-link.logout:hover{background:#fee2e2;color:var(--error-color)}.admin-main{flex:1;margin-left:280px;display:flex;flex-direction:column;min-height:100vh}.admin-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:var(--spacing-lg) var(--spacing-xl);position:sticky;top:0;z-index:var(--z-sticky)}.menu-toggle{display:none;background:transparent;border:none;font-size:1.5rem;color:var(--text-primary);cursor:pointer;padding:var(--spacing-sm)}.admin-header-content{display:flex;align-items:center;justify-content:space-between}.page-title{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin:0}.admin-user{display:flex;align-items:center;gap:var(--spacing-md)}.admin-user-info{display:flex;flex-direction:column;align-items:flex-end}.admin-user-name{font-weight:600;color:var(--text-primary);font-size:var(--text-sm)}.admin-user-role{font-size:var(--text-xs);color:var(--text-secondary)}.admin-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-lg)}.admin-content{flex:1;padding:var(--spacing-xl)}.sidebar-overlay{display:none}@media(max-width:1024px){.admin-sidebar{transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.sidebar-close{display:block}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-fixed) - 1)}.admin-main{margin-left:0}.menu-toggle{display:block}.admin-header{padding:var(--spacing-md) var(--spacing-lg)}.admin-header-content{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.admin-content{padding:var(--spacing-lg)}}@media(max-width:640px){.admin-user-info{display:none}.page-title{font-size:var(--text-xl)}}.spa-home{background:linear-gradient(to bottom,#fef7ff,#fff5f7,#fff)}.spa-hero{position:relative;background:linear-gradient(135deg,#ffc2e2,#d4a5ff,#a5b4fc);padding:8rem 0 6rem;overflow:hidden}.hero-decoration-top,.hero-decoration-bottom{position:absolute;width:100%;height:100%;pointer-events:none;z-index:1}.hero-decoration-top:before,.hero-decoration-top:after,.hero-decoration-bottom:before,.hero-decoration-bottom:after{content:"";position:absolute;border-radius:50%;background:#ffffff26;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.hero-decoration-top:before{width:300px;height:300px;top:-100px;left:-50px;animation:float1 20s ease-in-out infinite}.hero-decoration-top:after{width:200px;height:200px;top:100px;right:10%;animation:float2 15s ease-in-out infinite}.hero-decoration-bottom:before{width:250px;height:250px;bottom:-80px;right:-80px;animation:float3 18s ease-in-out infinite}.hero-decoration-bottom:after{width:180px;height:180px;bottom:50px;left:15%;animation:float4 22s ease-in-out infinite}.spa-hero:before,.spa-hero:after{content:"";position:absolute;border-radius:50%;background:#ffffff1a;z-index:1}.spa-hero:before{width:150px;height:150px;top:30%;left:5%;animation:float5 16s ease-in-out infinite}.spa-hero:after{width:120px;height:120px;top:60%;right:8%;animation:float6 14s ease-in-out infinite}@keyframes float1{0%,to{transform:translate(0) scale(1);opacity:.15}25%{transform:translate(30px,-30px) scale(1.1);opacity:.2}50%{transform:translate(60px,-50px) scale(1);opacity:.15}75%{transform:translate(30px,-30px) scale(.9);opacity:.1}}@keyframes float2{0%,to{transform:translate(0) scale(1);opacity:.2}33%{transform:translate(-40px,40px) scale(1.15);opacity:.15}66%{transform:translate(-20px,70px) scale(.95);opacity:.25}}@keyframes float3{0%,to{transform:translate(0) rotate(0);opacity:.15}25%{transform:translate(-50px,30px) rotate(90deg);opacity:.2}50%{transform:translate(-80px,60px) rotate(180deg);opacity:.1}75%{transform:translate(-40px,40px) rotate(270deg);opacity:.15}}@keyframes float4{0%,to{transform:translate(0) scale(1);opacity:.18}50%{transform:translate(50px,-50px) scale(1.2);opacity:.12}}@keyframes float5{0%,to{transform:translateY(0) rotate(0);opacity:.1}50%{transform:translateY(-40px) rotate(180deg);opacity:.15}}@keyframes float6{0%,to{transform:translate(0) scale(1);opacity:.12}33%{transform:translate(25px,25px) scale(1.1);opacity:.18}66%{transform:translate(50px,-25px) scale(.9);opacity:.15}}.spa-hero .hero-content:before{content:"";position:absolute;top:20%;left:50%;width:4px;height:4px;background:#fff;border-radius:50%;box-shadow:-200px -150px 0 1px #ffffff4d,200px -100px 0 2px #fff6,-150px 100px 0 1px #fff3,150px 150px 0 1px #ffffff59,-100px -200px 0 2px #ffffff40,100px 200px 0 1px #ffffff4d,-250px 50px 0 1px #fff3,250px -50px 0 2px #ffffff4d,0 -180px 0 1px #fff6,0 180px 0 1px #ffffff40;animation:sparkle 3s ease-in-out infinite;pointer-events:none;z-index:1}@keyframes sparkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.hero-content{position:relative;text-align:center;max-width:900px;margin:0 auto;z-index:2}.hero-badge-wrapper{animation:fadeInDown .8s ease-out}.hero-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:#d946ef;margin-bottom:var(--spacing-xl);box-shadow:0 4px 20px #d946ef33}.hero-badge svg{color:#fbbf24;font-size:1rem}.hero-title{font-size:clamp(2.5rem,6vw,5rem);font-weight:800;margin-bottom:var(--spacing-lg);line-height:1.1;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.1);animation:fadeInUp .8s ease-out .2s both}.hero-title-accent{background:linear-gradient(135deg,#fbbf24,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}.hero-subtitle{font-size:clamp(1rem,2vw,1.25rem);margin-bottom:var(--spacing-2xl);color:#fffffff2;line-height:1.6;max-width:700px;margin-left:auto;margin-right:auto;animation:fadeInUp .8s ease-out .4s both}.hero-actions{display:flex;gap:var(--spacing-lg);justify-content:center;flex-wrap:wrap;margin-bottom:var(--spacing-2xl);animation:fadeInUp .8s ease-out .6s both}.btn-glow{box-shadow:0 4px 20px #d946ef66;position:relative;overflow:hidden}.btn-glow:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-glow:hover:before{width:300px;height:300px}.btn-outline-white{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:2px solid rgba(255,255,255,.5)}.btn-outline-white:hover{background:#ffffff4d;border-color:#fffc;transform:translateY(-2px)}.trust-badges{display:flex;justify-content:center;gap:var(--spacing-2xl);flex-wrap:wrap;animation:fadeInUp .8s ease-out .8s both}.trust-badge{display:flex;align-items:center;gap:var(--spacing-md);background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:0 4px 20px #0000001a;transition:all var(--transition-base)}.trust-badge:hover{transform:translateY(-4px);box-shadow:0 8px 30px #d946ef33}.trust-badge-icon{width:50px;height:50px;background:linear-gradient(135deg,#d946ef,#a855f7);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.trust-badge-icon svg{font-size:1.5rem;color:#fff}.trust-badge-info{display:flex;flex-direction:column;text-align:left}.trust-badge-info strong{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);line-height:1}.trust-badge-info span{font-size:var(--text-sm);color:var(--text-secondary)}.benefits-section{padding:var(--spacing-2xl) 0;background:#fff;margin-top:-50px;position:relative;z-index:3}.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl)}.benefit-card{background:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-2xl);text-align:center;box-shadow:0 10px 30px #d946ef14;transition:all var(--transition-base);border:1px solid rgba(217,70,239,.1);position:relative;overflow:hidden}.benefit-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#d946ef,#a855f7);transform:scaleX(0);transition:transform var(--transition-base)}.benefit-card:hover:before{transform:scaleX(1)}.benefit-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #d946ef26}.benefit-icon-wrapper{margin-bottom:var(--spacing-lg)}.benefit-icon{width:80px;height:80px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto;transition:all var(--transition-base);box-shadow:0 10px 25px #d946ef33}.benefit-card:hover .benefit-icon{transform:scale(1.1) rotate(-5deg)}.benefit-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.benefit-description{color:var(--text-secondary);font-size:var(--text-base);margin:0;line-height:1.6}.featured-services-section{padding:var(--spacing-2xl) 0;background:linear-gradient(to bottom,#fff,#fef7ff)}.section-header{text-align:center;margin-bottom:var(--spacing-2xl)}.section-header.centered{max-width:700px;margin-left:auto;margin-right:auto}.section-badge{display:inline-block;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;padding:var(--spacing-xs) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;margin-bottom:var(--spacing-md);box-shadow:0 4px 15px #d946ef33}.section-title{font-size:var(--text-4xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.section-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0}.services-showcase{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-2xl);margin-bottom:var(--spacing-2xl)}.service-showcase-card{background:#fff;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:0 10px 30px #00000014;transition:all var(--transition-base);animation:fadeInUp .6s ease-out both}.service-showcase-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #d946ef26}.service-showcase-image{position:relative;height:280px;overflow:hidden;display:flex;align-items:center;justify-content:center}.service-image-overlay{position:absolute;inset:0;transition:opacity var(--transition-base)}.service-image-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:center}.service-icon-large{width:100px;height:100px;background:#fffffff2;border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px #00000026;transition:all var(--transition-base)}.service-icon-large svg{font-size:3rem;color:#d946ef}.service-showcase-card:hover .service-icon-large{transform:scale(1.1) rotate(-5deg)}.service-overlay{position:absolute;inset:0;background:#d946efe6;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-base);z-index:3}.service-showcase-card:hover .service-overlay{opacity:1}.btn-white{background:#fff;color:#d946ef;font-weight:600;display:inline-flex;align-items:center;gap:var(--spacing-sm)}.btn-white:hover{background:#fef7ff;transform:translateY(-2px);box-shadow:0 4px 15px #0003}.service-showcase-content{padding:var(--spacing-xl)}.service-showcase-name{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.service-showcase-description{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--spacing-lg);line-height:1.6}.service-showcase-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.service-showcase-duration{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary);font-size:var(--text-sm)}.service-showcase-price{font-size:var(--text-2xl);font-weight:700;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-cta{text-align:center}.booking-cta-section{padding:var(--spacing-2xl) 0;background:#fff}.booking-cta-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2xl);align-items:center}.cta-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;padding:var(--spacing-xs) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;margin-bottom:var(--spacing-lg);box-shadow:0 4px 15px #d946ef33}.cta-title{font-size:var(--text-4xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md);line-height:1.2}.cta-title-highlight{background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cta-description{color:var(--text-secondary);font-size:var(--text-lg);line-height:1.6;margin-bottom:var(--spacing-xl)}.cta-features{list-style:none;padding:0;margin:0 0 var(--spacing-2xl) 0;display:flex;flex-direction:column;gap:var(--spacing-md)}.cta-features li{display:flex;align-items:center;gap:var(--spacing-md);color:var(--text-primary);font-size:var(--text-base)}.feature-check{width:30px;height:30px;background:linear-gradient(135deg,#10b981,#059669);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-check svg{color:#fff;font-size:1rem}.booking-cta-visual{display:flex;flex-direction:column;gap:var(--spacing-lg)}.visual-card{background:linear-gradient(135deg,#fef7ff,#fff5f7);padding:var(--spacing-2xl);border-radius:var(--radius-2xl);box-shadow:0 10px 30px #d946ef1a;border:1px solid rgba(217,70,239,.1)}.visual-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.visual-icon{width:50px;height:50px;background:linear-gradient(135deg,#d946ef,#a855f7);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.visual-icon svg{font-size:1.5rem;color:#fff}.visual-card h3{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0}.schedule-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.schedule-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:#fff;border-radius:var(--radius-lg);font-size:var(--text-sm);box-shadow:0 2px 10px #0000000d}.schedule-item span{color:var(--text-secondary)}.schedule-item strong{color:var(--text-primary);font-weight:600}.visual-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.stat-mini{background:#fff;padding:var(--spacing-lg);border-radius:var(--radius-xl);display:flex;align-items:center;gap:var(--spacing-md);box-shadow:0 4px 15px #d946ef1a;transition:all var(--transition-base)}.stat-mini:hover{transform:translateY(-4px);box-shadow:0 8px 25px #d946ef26}.stat-mini-icon{width:45px;height:45px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-mini-icon svg{font-size:1.25rem;color:#fff}.stat-mini-info{display:flex;flex-direction:column}.stat-mini-info strong{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);line-height:1}.stat-mini-info span{font-size:var(--text-xs);color:var(--text-secondary)}.spa-testimonials{padding:var(--spacing-2xl) 0;background:linear-gradient(135deg,#fef7ff,#fff5f7)}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-xl)}.testimonial-card-spa{background:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-2xl);box-shadow:0 10px 30px #d946ef14;transition:all var(--transition-base);animation:fadeInUp .6s ease-out both;position:relative;text-align:center}.testimonial-card-spa:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#d946ef,#a855f7);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.testimonial-card-spa:hover{transform:translateY(-8px);box-shadow:0 20px 40px #d946ef26}.testimonial-header{margin-bottom:var(--spacing-xl);display:flex;justify-content:center}.testimonial-avatar-large{width:90px;height:90px;border-radius:var(--radius-full);background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-2xl);box-shadow:0 8px 25px #d946ef4d;border:4px solid white;position:relative}.testimonial-avatar-large:after{content:"✓";position:absolute;bottom:-5px;right:-5px;width:30px;height:30px;background:#10b981;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.875rem;border:3px solid white}.testimonial-rating{display:flex;gap:var(--spacing-xs);justify-content:center;margin-bottom:var(--spacing-lg)}.star-filled{color:#fbbf24;font-size:1.25rem}.testimonial-comment{color:var(--text-secondary);font-size:var(--text-base);line-height:1.7;margin-bottom:var(--spacing-xl);font-style:italic;position:relative;padding:0 var(--spacing-md)}.testimonial-comment:before{content:'"';position:absolute;top:-20px;left:0;font-size:4rem;color:#d946ef1a;font-family:Georgia,serif;line-height:1}.testimonial-author-info{padding-top:var(--spacing-lg);border-top:1px solid var(--border-light)}.testimonial-name{font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);font-size:var(--text-lg)}.testimonial-service{font-size:var(--text-sm);color:#d946ef;font-weight:500}.why-choose-section{padding:var(--spacing-2xl) 0;background:#fff}.why-choose-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2xl);align-items:center}.why-choose-image{position:relative}.image-frame{width:100%;aspect-ratio:1;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:0 20px 40px #d946ef33}.image-gradient{width:100%;height:100%;background:linear-gradient(135deg,#ffc2e2,#d4a5ff,#a5b4fc);position:relative}.image-gradient:before{content:"";position:absolute;inset:20%;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%)}.image-badge{position:absolute;bottom:var(--spacing-xl);right:var(--spacing-xl);background:#fff;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-full);box-shadow:0 10px 30px #00000026;display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600;color:#d946ef}.image-badge svg{font-size:1.25rem}.why-choose-info .section-description{font-size:var(--text-lg);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--spacing-xl)}.why-features{display:flex;flex-direction:column;gap:var(--spacing-xl)}.why-feature{display:flex;gap:var(--spacing-lg)}.why-feature-icon{width:55px;height:55px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;box-shadow:0 4px 15px #d946ef33}.why-feature-content h4{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.why-feature-content p{color:var(--text-secondary);font-size:var(--text-sm);margin:0;line-height:1.6}.final-cta-section{padding:var(--spacing-2xl) 0;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;text-align:center;position:relative;overflow:hidden}.final-cta-section:before{content:"";position:absolute;width:200%;height:200%;top:-50%;left:-50%;background:radial-gradient(circle at 30% 40%,rgba(255,255,255,.15) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(255,255,255,.1) 0%,transparent 50%);animation:wave 15s linear infinite}.final-cta-section:after{content:"";position:absolute;width:100%;height:100%;top:0;left:0;background:radial-gradient(circle at 20% 80%,rgba(255,255,255,.08) 0%,transparent 40%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.12) 0%,transparent 40%);animation:wave 20s linear infinite reverse}@keyframes wave{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.final-cta-content:before,.final-cta-content:after{content:"";position:absolute;border-radius:50%;background:#ffffff1a;animation:floatBubble 12s ease-in-out infinite}.final-cta-content:before{width:100px;height:100px;top:10%;left:10%;animation-delay:0s}.final-cta-content:after{width:150px;height:150px;bottom:15%;right:15%;animation-delay:3s}@keyframes floatBubble{0%,to{transform:translateY(0) scale(1);opacity:.1}50%{transform:translateY(-30px) scale(1.1);opacity:.2}}.final-cta-content{position:relative;z-index:2;max-width:800px;margin:0 auto}.final-cta-icon{width:80px;height:80px;background:#fff3;border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:pulse 2s ease-in-out infinite}.final-cta-icon svg{font-size:2.5rem;color:#fff}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #fff6}50%{transform:scale(1.05);box-shadow:0 0 0 10px #fff0}}.final-cta-title{font-size:var(--text-4xl);font-weight:700;margin-bottom:var(--spacing-md)}.final-cta-subtitle{font-size:var(--text-xl);opacity:.95;margin-bottom:var(--spacing-2xl);line-height:1.6}.final-cta-actions{display:flex;gap:var(--spacing-lg);justify-content:center;flex-wrap:wrap}.btn-outline-primary{background:transparent;border:2px solid white;color:#fff}.btn-outline-primary:hover{background:#fff;color:#d946ef}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skeleton{pointer-events:none}.skeleton-image{width:100%;height:280px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite}.skeleton-content{padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-md)}.skeleton-text{height:20px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:var(--radius-md)}.skeleton-text.short{width:60%}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:1024px){.booking-cta-content,.why-choose-content{grid-template-columns:1fr}.why-choose-image{order:-1}}@media(max-width:768px){.spa-hero{padding:5rem 0 4rem}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1rem}.hero-actions,.final-cta-actions{flex-direction:column}.hero-actions .btn,.final-cta-actions .btn{width:100%}.trust-badges{flex-direction:column;gap:var(--spacing-md)}.trust-badge{width:100%;max-width:400px;margin:0 auto}.benefits-grid,.services-showcase,.testimonials-grid{grid-template-columns:1fr}.section-title,.cta-title,.final-cta-title{font-size:2rem}.visual-stats{grid-template-columns:1fr}}:root{--spa-primary: #d946ef;--spa-secondary: #a855f7;--spa-tertiary: #ec4899;--spa-gradient: linear-gradient(135deg, var(--spa-primary) 0%, var(--spa-secondary) 100%);--glass-bg: rgba(255, 255, 255, .9);--text-main: #1e293b}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden;background:linear-gradient(135deg,#fdf2f8,#fae8ff,#f3e8ff);font-family:Plus Jakarta Sans,sans-serif}.auth-container:before,.auth-container:after{content:"";position:absolute;width:200%;height:200%;top:-50%;left:-50%;z-index:1;background:radial-gradient(circle at 30% 40%,rgba(217,70,239,.12) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(168,85,247,.08) 0%,transparent 50%);animation:waveRotate 25s linear infinite}.auth-container:after{animation:waveRotate 35s linear infinite reverse;opacity:.5}@keyframes waveRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.particles-overlay{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;z-index:15;background-image:radial-gradient(circle,#ffffff 1.5px,transparent 1.5px);background-size:80px 80px;animation:particleSlide 40s linear infinite;opacity:.7}@keyframes particleSlide{0%{background-position:0 0}to{background-position:400px 400px}}.spa-logo-container{width:120px;height:120px;margin:0 auto 2rem;position:relative;display:flex;align-items:center;justify-content:center}.logo-outer-ring{position:absolute;width:100%;height:100%;border:3px solid var(--spa-primary);border-radius:50%;opacity:.3;animation:pulseRing 3s ease-in-out infinite}@keyframes pulseRing{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.15);opacity:.1}}.logo-lotus{width:80px;height:80px;position:relative;display:flex;align-items:center;justify-content:center}.logo-petal{position:absolute;width:32px;height:32px;background:linear-gradient(135deg,var(--spa-primary) 0%,var(--spa-secondary) 100%);border-radius:50% 0;opacity:.85;animation:petalFloat 4s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(217,70,239,.4))}.logo-petal:nth-child(1){transform:rotate(0) translateY(15px);animation-delay:0s}.logo-petal:nth-child(2){transform:rotate(45deg) translateY(15px);animation-delay:.1s}.logo-petal:nth-child(3){transform:rotate(90deg) translateY(15px);animation-delay:.2s}.logo-petal:nth-child(4){transform:rotate(135deg) translateY(15px);animation-delay:.3s}.logo-petal:nth-child(5){transform:rotate(180deg) translateY(15px);animation-delay:.4s}.logo-petal:nth-child(6){transform:rotate(225deg) translateY(15px);animation-delay:.5s}.logo-petal:nth-child(7){transform:rotate(270deg) translateY(15px);animation-delay:.6s}.logo-petal:nth-child(8){transform:rotate(315deg) translateY(15px);animation-delay:.7s}@keyframes petalFloat{0%,to{transform:rotate(var(--rotation, 0deg)) translateY(15px) scale(1);opacity:.85}50%{transform:rotate(var(--rotation, 0deg)) translateY(12px) scale(1.08);opacity:1}}.logo-center{position:absolute;width:20px;height:20px;background:radial-gradient(circle,#ffffff 0%,var(--spa-primary) 100%);border-radius:50%;box-shadow:0 0 20px #d946ef99,0 0 40px #d946ef4d,inset 0 0 10px #fffc;animation:centerGlow 2s ease-in-out infinite;z-index:10}@keyframes centerGlow{0%,to{box-shadow:0 0 20px #d946ef99,0 0 40px #d946ef4d,inset 0 0 10px #fffc}50%{box-shadow:0 0 30px #d946efcc,0 0 60px #d946ef80,inset 0 0 15px #fff}}.logo-particle{position:absolute;width:4px;height:4px;background:var(--spa-primary);border-radius:50%;opacity:0;animation:floatParticle 3s ease-in-out infinite}.logo-particle:nth-child(9){top:0;left:50%;animation-delay:0s}.logo-particle:nth-child(10){top:50%;right:0;animation-delay:.5s}.logo-particle:nth-child(11){bottom:0;left:50%;animation-delay:1s}.logo-particle:nth-child(12){top:50%;left:0;animation-delay:1.5s}@keyframes floatParticle{0%,to{transform:translateY(0) scale(0);opacity:0}50%{transform:translateY(-20px) scale(1);opacity:1}}.auth-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid rgba(255,255,255,.8);border-radius:40px;box-shadow:0 40px 100px -20px #a855f733,0 0 0 1px #ffffff80 inset;width:100%;max-width:440px;padding:3.5rem;position:relative;z-index:10;animation:cardEntrance .6s ease-out}@keyframes cardEntrance{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.input-container{position:relative;display:flex;align-items:center}.input-icon-left{position:absolute;left:1.25rem;color:var(--spa-primary);font-size:1.25rem;z-index:2;transition:all .3s ease}.auth-input{width:100%;padding:1.1rem 1rem 1.1rem 3.5rem!important;background:#fff9;border:2px solid #f1f5f9;border-radius:18px;font-size:1rem;color:var(--text-main);transition:all .3s ease;font-family:Plus Jakarta Sans,sans-serif}.auth-input:focus{outline:none;border-color:var(--spa-primary);background:#fff;box-shadow:0 4px 20px #d946ef26;transform:translateY(-2px)}.auth-input:focus+.input-icon-left{transform:scale(1.1)}.password-toggle{position:absolute;right:1rem;background:none;border:none;cursor:pointer;color:#94a3b8;font-size:1.2rem;transition:all .3s ease;padding:.5rem;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--spa-primary);transform:scale(1.1)}.btn-submit{width:100%;padding:1.2rem;background:var(--spa-gradient);color:#fff;border:none;border-radius:20px;font-weight:800;font-size:1.1rem;cursor:pointer;box-shadow:0 10px 25px #d946ef4d;margin-top:1rem;transition:all .3s ease;position:relative;overflow:hidden}.btn-submit:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.btn-submit:hover{transform:translateY(-3px);box-shadow:0 15px 35px #d946ef66}.btn-submit:hover:before{left:100%}.btn-submit:active{transform:translateY(-1px)}@media(max-width:500px){.auth-card{padding:2.5rem 1.5rem;border-radius:30px}.spa-logo-container{width:100px;height:100px}.logo-lotus{width:70px;height:70px}.logo-petal{width:28px;height:28px}}.dashboard-page{padding:0}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;gap:var(--spacing-lg)}.spinner-large{width:60px;height:60px;border:4px solid var(--border-light);border-top-color:#d946ef;border-radius:var(--radius-full);animation:spin 1s linear infinite}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);flex-wrap:wrap;gap:var(--spacing-lg)}.dashboard-title{font-size:var(--text-3xl);font-weight:700;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.dashboard-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.dashboard-actions{display:flex;gap:var(--spacing-md);align-items:center}.filter-select{padding:var(--spacing-sm) var(--spacing-lg);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;background:#fff;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.stat-card{background:#fff;border-radius:var(--radius-2xl);padding:var(--spacing-xl);box-shadow:0 4px 15px #0000000d;transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;transition:height var(--transition-base)}.stat-card:hover:before{height:100%;opacity:.05}.stat-card.stat-primary:before{background:linear-gradient(135deg,#d946ef,#a855f7)}.stat-card.stat-success:before{background:linear-gradient(135deg,#10b981,#059669)}.stat-card.stat-info:before{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-card.stat-warning:before{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card:hover{transform:translateY(-8px);box-shadow:0 12px 35px #0000001f}.stat-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.stat-icon{width:60px;height:60px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:1.75rem;transition:transform var(--transition-base)}.stat-primary .stat-icon{background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#d946ef;box-shadow:0 8px 20px #d946ef33}.stat-success .stat-icon{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#10b981;box-shadow:0 8px 20px #10b98133}.stat-info .stat-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#3b82f6;box-shadow:0 8px 20px #3b82f633}.stat-warning .stat-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#f59e0b;box-shadow:0 8px 20px #f59e0b33}.stat-trend{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:700}.stat-trend.up{background:#d1fae5;color:#10b981}.stat-trend.down{background:#fee2e2;color:#ef4444}.stat-body{position:relative;z-index:2}.stat-value{font-size:var(--text-3xl);font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.charts-row{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.chart-card{background:#fff;border-radius:var(--radius-2xl);box-shadow:0 4px 15px #0000000d;overflow:hidden;transition:all var(--transition-base)}.chart-card:hover{box-shadow:0 8px 25px #0000001a}.chart-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--border-light);background:linear-gradient(to bottom,#fef7ff,#fff)}.chart-title{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.chart-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.chart-body{padding:var(--spacing-xl)}.appointments-chart{margin-bottom:var(--spacing-2xl)}.custom-tooltip{background:#fff;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:0 8px 25px #00000026;border:1px solid var(--border-light)}.tooltip-label{font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs);font-size:var(--text-sm)}.tooltip-value{font-size:var(--text-sm);margin:var(--spacing-xs) 0;font-weight:600}.pie-legend{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);transition:background var(--transition-fast)}.legend-item:hover{background:var(--bg-tertiary)}.legend-color{width:16px;height:16px;border-radius:var(--radius-sm);flex-shrink:0}.legend-name{flex:1;font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.legend-value{font-size:var(--text-sm);font-weight:700;color:var(--text-primary)}.dashboard-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.dashboard-card{background:#fff;border-radius:var(--radius-2xl);box-shadow:0 4px 15px #0000000d;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--border-light);background:linear-gradient(to right,#fef7ff,#fff)}.card-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin:0}.card-action{color:#d946ef;font-size:var(--text-sm);font-weight:600;text-decoration:none;transition:color var(--transition-fast)}.card-action:hover{color:#a855f7}.card-body{padding:var(--spacing-xl)}.appointments-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.appointment-item{background:linear-gradient(135deg,#fef7ff,#fff);border:2px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--spacing-lg);transition:all var(--transition-base)}.appointment-item:hover{border-color:#d946ef;box-shadow:0 8px 20px #d946ef26;transform:translate(8px)}.appointment-main{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-md)}.appointment-client{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.client-avatar{width:50px;height:50px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-base);flex-shrink:0;box-shadow:0 6px 20px #d946ef4d}.client-name{font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);font-size:var(--text-base)}.client-service{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appointment-details{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs)}.appointment-datetime{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm);color:var(--text-secondary)}.appointment-datetime svg{font-size:1rem}.appointment-price{font-size:var(--text-lg);font-weight:700;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.appointment-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge svg{font-size:.875rem}.badge-warning{background:#fef3c7;color:#f59e0b}.badge-success{background:#d1fae5;color:#10b981}.badge-info{background:#dbeafe;color:#3b82f6}.badge-error{background:#fee2e2;color:#ef4444}.btn-icon-small{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon-small:hover{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-color:#d946ef;transform:scale(1.1)}.services-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.service-item-enhanced{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:linear-gradient(135deg,#fef7ff,#fff);border:2px solid var(--border-light);border-radius:var(--radius-xl);transition:all var(--transition-base)}.service-item-enhanced:hover{border-color:#d946ef;box-shadow:0 8px 20px #d946ef26;transform:translateY(-4px)}.service-rank{width:45px;height:45px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--text-xl);flex-shrink:0;box-shadow:0 6px 20px #d946ef4d}.service-info-enhanced{flex:1;min-width:0}.service-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.service-name{font-weight:600;color:var(--text-primary);font-size:var(--text-base)}.service-trend{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);font-size:.875rem}.service-trend.up{background:#d1fae5;color:#10b981}.service-trend.down{background:#fee2e2;color:#ef4444}.service-stats-enhanced{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.stat-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm);color:var(--text-secondary)}.stat-item svg{font-size:1rem}.stat-item.revenue{color:#10b981;font-weight:700}.service-progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#d946ef,#a855f7);border-radius:var(--radius-full);transition:width 1s ease;box-shadow:0 0 10px #d946ef66}@media(max-width:1200px){.dashboard-grid,.charts-row{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-header{flex-direction:column;align-items:flex-start}.dashboard-actions{width:100%;flex-direction:column}.dashboard-actions .btn,.filter-group{width:100%}.stats-grid,.charts-row,.dashboard-grid{grid-template-columns:1fr}.appointment-main{flex-direction:column;align-items:flex-start}.appointment-details{width:100%;flex-direction:row;justify-content:space-between;align-items:center}}.products-page{min-height:100vh}.products-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;gap:var(--spacing-lg)}.products-hero{position:relative;min-height:400px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff,#a5b4fc);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:4rem 2rem}.products-hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 50%)}.products-hero-content{position:relative;z-index:2;text-align:center;max-width:800px;animation:fadeInUp .8s ease}.products-hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:#fff;margin-bottom:var(--spacing-md);text-shadow:0 2px 20px rgba(0,0,0,.1)}.products-hero-subtitle{font-size:clamp(1rem,2vw,1.25rem);color:#fff;margin:0;text-shadow:0 2px 10px rgba(0,0,0,.1);line-height:1.6}.products-filters-section{padding:3rem 0 2rem;background:linear-gradient(to bottom,#fef7ff,#fff)}.products-container{max-width:1400px;margin:0 auto;padding:0 2rem}.filters-wrapper{background:#fff;padding:var(--spacing-xl);border-radius:var(--radius-2xl);box-shadow:0 4px 20px #00000014}.search-box-products{position:relative;margin-bottom:var(--spacing-lg)}.search-box-products svg{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:1.25rem}.search-box-products input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) calc(var(--spacing-md) * 3);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);transition:all var(--transition-fast)}.search-box-products input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 4px #d946ef1a}.filters-row-products{display:flex;gap:var(--spacing-md);flex-wrap:wrap;margin-bottom:var(--spacing-md)}.filter-group-products{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:200px}.filter-group-products svg{color:var(--text-secondary);font-size:1.125rem}.filter-group-products span{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.filter-select-products{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;background:#fff;cursor:pointer;transition:all var(--transition-fast)}.filter-select-products:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.results-count{font-size:var(--text-sm);color:var(--text-secondary)}.results-count strong{color:#d946ef;font-weight:700}.products-grid-section{padding:3rem 0;background:#fff}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-2xl)}.product-card{background:#fff;border-radius:var(--radius-2xl);border:2px solid var(--border-light);overflow:hidden;transition:all var(--transition-base);position:relative}.product-card:hover{border-color:#d946ef;box-shadow:0 12px 35px #d946ef26;transform:translateY(-8px)}.product-badge{position:absolute;top:var(--spacing-md);z-index:10;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:var(--spacing-xs);box-shadow:0 4px 15px #0000001a}.product-badge.new{left:var(--spacing-md);background:linear-gradient(135deg,#10b981,#059669);color:#fff}.product-badge.discount{right:var(--spacing-md);background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.product-badge svg{font-size:.875rem}.product-image{position:relative;width:100%;height:320px;background:linear-gradient(135deg,#fef7ff,#fff5f7);overflow:hidden}.product-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.product-card:hover .product-image img{transform:scale(1.1)}.product-overlay{position:absolute;inset:0;background:#d946efe6;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-base)}.product-card:hover .product-overlay{opacity:1}.btn-quick-view{padding:var(--spacing-md) var(--spacing-xl);background:#fff;color:#d946ef;border:none;border-radius:var(--radius-lg);font-weight:700;font-size:var(--text-base);display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 20px #0003}.btn-quick-view:hover{transform:scale(1.05);box-shadow:0 6px 25px #0000004d}.product-body{padding:var(--spacing-xl)}.product-brand{font-size:var(--text-xs);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-sm)}.product-name{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm);line-height:1.3;min-height:2.6em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-rating{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.stars{display:flex;gap:2px}.stars svg{font-size:1rem}.star-filled{color:#fbbf24;fill:#fbbf24}.star-empty{color:#e5e7eb}.rating-text{font-size:var(--text-xs);color:var(--text-secondary)}.product-footer{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-light);margin-bottom:var(--spacing-sm)}.product-price{display:flex;flex-direction:column;gap:var(--spacing-xs)}.price-original{font-size:var(--text-sm);color:var(--text-secondary);text-decoration:line-through}.price-current{font-size:var(--text-xl);font-weight:800;color:#d946ef}.btn-add-cart{padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:700;font-size:var(--text-sm);display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-add-cart:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d946ef66}.btn-add-cart:disabled{opacity:.5;cursor:not-allowed;background:#9ca3af}.product-stock{font-size:var(--text-xs);display:flex;align-items:center;gap:var(--spacing-xs)}.in-stock{color:#10b981;font-weight:600;display:flex;align-items:center;gap:var(--spacing-xs)}.out-stock{color:#ef4444;font-weight:600}.empty-state-products{text-align:center;padding:var(--spacing-2xl);grid-column:1 / -1}.empty-state-products h3{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.empty-state-products p{color:var(--text-secondary);margin:0}.features-section{padding:4rem 0;background:linear-gradient(135deg,#fef7ff,#fff5f7)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl)}.feature-card{background:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-xl);text-align:center;border:2px solid var(--border-light);transition:all var(--transition-base)}.feature-card:hover{border-color:#d946ef;box-shadow:0 8px 25px #d946ef26;transform:translateY(-4px)}.feature-icon{width:70px;height:70px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto var(--spacing-lg);box-shadow:0 8px 25px #d946ef33}.feature-card h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.feature-card p{color:var(--text-secondary);margin:0}@media(max-width:1200px){.products-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.products-hero{min-height:300px;padding:3rem 1rem}.products-hero-title{font-size:2rem}.products-hero-subtitle{font-size:1rem}.products-container{padding:0 1rem}.filters-wrapper{padding:var(--spacing-lg)}.filters-row-products{flex-direction:column}.filter-group-products{width:100%}.products-grid{grid-template-columns:1fr}.product-image{height:280px}.features-grid{grid-template-columns:1fr}}@media(max-width:480px){.hero-badge{font-size:var(--text-xs);padding:var(--spacing-xs) var(--spacing-md)}.products-hero-title{font-size:1.75rem}.product-footer{flex-direction:column;align-items:stretch}.btn-add-cart{width:100%;justify-content:center}}.not-found-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background:var(--bg-secondary)}.not-found-content{text-align:center;max-width:600px}.not-found-illustration{position:relative;margin-bottom:var(--spacing-2xl)}.error-code{font-size:10rem;font-weight:900;color:var(--primary-color);margin:0;line-height:1;opacity:.2;-webkit-user-select:none;user-select:none}.error-emoji{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:5rem;animation:float 3s ease-in-out infinite}.not-found-title{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.not-found-description{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--spacing-2xl);line-height:1.6}.not-found-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}@keyframes float{0%,to{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-20px)}}@media(max-width:640px){.error-code{font-size:6rem}.error-emoji{font-size:3rem}.not-found-title{font-size:var(--text-2xl)}.not-found-description{font-size:var(--text-base)}.not-found-actions{flex-direction:column}.not-found-actions .btn{width:100%}}.spa-booking-page{min-height:100vh;background:linear-gradient(to bottom,#fef7ff,#fff5f7,#fff)}.booking-hero{position:relative;background:linear-gradient(135deg,#ffc2e2,#d4a5ff,#a5b4fc);padding:5rem 0 4rem;overflow:hidden}.booking-hero-decoration{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none}.booking-hero-decoration:before,.booking-hero-decoration:after{content:"";position:absolute;border-radius:50%;background:#ffffff26;animation:floatBubble 15s ease-in-out infinite}.booking-hero-decoration:before{width:250px;height:250px;top:-50px;left:10%}.booking-hero-decoration:after{width:180px;height:180px;bottom:-40px;right:15%;animation-delay:3s}@keyframes floatBubble{0%,to{transform:translateY(0) scale(1);opacity:.15}50%{transform:translateY(-30px) scale(1.1);opacity:.25}}.booking-hero-content{position:relative;z-index:2;text-align:center;max-width:700px;margin:0 auto}.booking-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:#d946ef;margin-bottom:var(--spacing-lg);box-shadow:0 4px 20px #d946ef33;animation:fadeInDown .8s ease-out}.booking-badge svg{color:#f43f5e}.booking-hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:#fff;margin-bottom:var(--spacing-md);text-shadow:0 2px 20px rgba(0,0,0,.1);animation:fadeInUp .8s ease-out .2s both}.booking-hero-subtitle{font-size:clamp(1rem,2vw,1.25rem);color:#fffffff2;margin:0;animation:fadeInUp .8s ease-out .4s both}.booking-container{max-width:1100px;margin:0 auto;padding:var(--spacing-2xl) 0}.progress-steps-wrapper{position:relative;background:#fff;border-radius:var(--radius-2xl);padding:var(--spacing-2xl);margin-bottom:var(--spacing-2xl);box-shadow:0 10px 30px #d946ef14}.progress-line-bg{position:absolute;top:50%;left:10%;right:10%;height:3px;background:var(--border-light);transform:translateY(-50%);z-index:1}.progress-line-fill{position:absolute;top:50%;left:10%;height:3px;background:linear-gradient(90deg,#d946ef,#a855f7);transform:translateY(-50%);transition:width .6s ease;z-index:2}.progress-steps{display:flex;justify-content:space-between;position:relative;z-index:3}.progress-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.step-circle{width:60px;height:60px;border-radius:var(--radius-full);background:#fff;border:3px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:700;color:var(--text-secondary);transition:all var(--transition-base);box-shadow:0 4px 15px #0000000d}.progress-step.active .step-circle{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-color:#d946ef;transform:scale(1.15);box-shadow:0 8px 25px #d946ef4d}.progress-step.completed .step-circle{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981}.step-info{text-align:center}.step-label{font-size:var(--text-base);font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.progress-step.active .step-label{color:#d946ef}.step-description{font-size:var(--text-sm);color:var(--text-light)}.booking-step{background:#fff;border-radius:var(--radius-2xl);padding:var(--spacing-2xl);box-shadow:0 10px 30px #d946ef14;animation:fadeInUp .6s ease-out}.step-header{text-align:center;margin-bottom:var(--spacing-2xl)}.step-title{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.step-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0}.services-grid-booking{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.service-card-booking{background:linear-gradient(to bottom,#fef7ff,#fff);border:2px solid var(--border-light);border-radius:var(--radius-2xl);padding:var(--spacing-xl);cursor:pointer;transition:all var(--transition-base);position:relative;animation:fadeInUp .6s ease-out both}.service-card-booking:hover{transform:translateY(-8px);box-shadow:0 20px 40px #d946ef26;border-color:#d946ef}.service-card-booking.selected{border-color:#d946ef;background:linear-gradient(to bottom,#fef7ff,#fff);box-shadow:0 10px 30px #d946ef33}.service-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.service-icon-wrapper{width:80px;height:80px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;font-size:2.5rem;box-shadow:0 8px 20px #d946ef33;transition:transform var(--transition-base)}.service-card-booking:hover .service-icon-wrapper{transform:scale(1.1) rotate(-5deg)}.service-icon-booking{font-size:2.5rem}.service-check-badge{width:35px;height:35px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;animation:scaleIn .3s ease-out;box-shadow:0 4px 15px #10b9814d}.service-card-body{text-align:center}.service-card-name{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.service-card-description{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.6;margin-bottom:var(--spacing-lg)}.service-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.service-duration-badge{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary);font-size:var(--text-sm)}.service-price-badge{font-size:var(--text-xl);font-weight:700;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.therapist-selection-section{margin-bottom:var(--spacing-2xl)}.section-title-small{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.section-title-small svg{color:#d946ef}.therapists-grid-booking{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-lg)}.therapist-card-booking{background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--spacing-lg);text-align:center;cursor:pointer;transition:all var(--transition-base);position:relative}.therapist-card-booking:hover{transform:translateY(-4px);box-shadow:0 10px 25px #d946ef1a;border-color:#d946ef}.therapist-card-booking.selected{border-color:#d946ef;background:linear-gradient(to bottom,#fef7ff,#fff);box-shadow:0 8px 20px #d946ef26}.therapist-avatar-booking{width:70px;height:70px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;margin:0 auto var(--spacing-md);box-shadow:0 6px 20px #d946ef4d}.therapist-info-booking{margin-bottom:var(--spacing-sm)}.therapist-name-booking{font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);font-size:var(--text-base)}.therapist-specialty-booking{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.therapist-rating-booking{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.star-icon{color:#fbbf24}.therapist-check-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:28px;height:28px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.875rem;animation:scaleIn .3s ease-out}.calendar-section-booking{margin-bottom:var(--spacing-2xl)}.calendar-card{background:linear-gradient(135deg,#fef7ff,#fff5f7);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid rgba(217,70,239,.1)}.calendar-header-booking{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.calendar-title-booking{font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.calendar-nav-btn{width:45px;height:45px;background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.calendar-nav-btn:hover{background:#d946ef;color:#fff;border-color:#d946ef;transform:scale(1.05)}.calendar-days-header-booking{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.calendar-day-name-booking{text-align:center;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);padding:var(--spacing-sm)}.calendar-grid-booking{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-sm)}.calendar-day-booking{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);color:var(--text-primary)}.calendar-day-booking.empty{background:transparent;border:none;cursor:default}.calendar-day-booking.disabled{background:var(--bg-tertiary);color:var(--text-light);cursor:not-allowed;opacity:.4}.calendar-day-booking:not(.empty):not(.disabled):hover{background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-color:#d946ef;transform:scale(1.1)}.calendar-day-booking.selected{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-color:#d946ef;transform:scale(1.05);box-shadow:0 4px 15px #d946ef4d}.time-slots-section-booking{margin-bottom:var(--spacing-2xl)}.date-selected-text{text-align:center;font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--spacing-lg);font-weight:500;text-transform:capitalize}.loading-slots-booking{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md)}.spinner-booking{width:50px;height:50px;border:4px solid var(--border-light);border-top-color:#d946ef;border-radius:var(--radius-full);animation:spin 1s linear infinite}.time-slots-grid-booking{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-md)}.time-slot-booking{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-lg);background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-xl);color:var(--text-primary);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.time-slot-booking svg{font-size:1.25rem}.time-slot-booking:hover:not(.disabled){background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-color:#d946ef;transform:translateY(-4px);box-shadow:0 8px 20px #d946ef33}.time-slot-booking.selected{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-color:#d946ef;box-shadow:0 6px 20px #d946ef4d}.time-slot-booking.disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary)}.slot-badge{font-size:var(--text-xs);font-weight:400;opacity:.8}.booking-summary-card{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-2xl);margin-bottom:var(--spacing-2xl);box-shadow:0 10px 30px #d946ef4d}.summary-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.summary-icon{font-size:2rem}.summary-title{font-size:var(--text-2xl);font-weight:700;margin:0}.summary-body{display:flex;flex-direction:column;gap:var(--spacing-lg)}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:#ffffff26;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.summary-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm);opacity:.95}.label-icon{width:35px;height:35px;background:#fff3;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.summary-value{font-size:var(--text-base);font-weight:600;text-align:right}.summary-divider{height:2px;background:#fff3;margin:var(--spacing-sm) 0}.summary-total{background:#ffffff40;padding:var(--spacing-lg) var(--spacing-xl)}.summary-total .summary-value.price{font-size:var(--text-2xl);font-weight:800}.client-data-card{background:linear-gradient(to bottom,#fef7ff,#fff);padding:var(--spacing-2xl);border-radius:var(--radius-2xl);border:1px solid rgba(217,70,239,.1);margin-bottom:var(--spacing-2xl)}.card-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xl)}.card-title svg{color:#d946ef}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.input-wrapper{position:relative}.input-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:1.125rem}.form-input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) calc(var(--spacing-md) * 3);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);transition:all var(--transition-fast);background:#fff}.form-textarea{padding:var(--spacing-md);resize:vertical;min-height:120px}.step-actions{display:flex;gap:var(--spacing-md);justify-content:space-between;margin-top:var(--spacing-2xl);padding-top:var(--spacing-xl);border-top:2px solid var(--border-light)}.step-actions .btn{flex:1;max-width:250px}.step-actions .btn:first-child{margin-right:auto}.step-actions .btn:last-child{margin-left:auto}.spinner-inline{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:var(--radius-full);animation:spin 1s linear infinite;display:inline-block}.error-message{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#fee2e2;border:1px solid #fecaca;border-radius:var(--radius-lg);color:#dc2626;font-size:var(--text-sm);font-weight:500;margin-top:var(--spacing-md)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.booking-hero{padding:4rem 0 3rem}.booking-hero-title{font-size:2rem}.progress-steps-wrapper{padding:var(--spacing-lg)}.progress-steps{flex-direction:column;gap:var(--spacing-xl)}.progress-line-bg,.progress-line-fill{display:none}.step-circle{width:50px;height:50px}.booking-step{padding:var(--spacing-xl)}.services-grid-booking,.therapists-grid-booking{grid-template-columns:1fr}.calendar-grid-booking{gap:4px}.calendar-day-booking{font-size:var(--text-xs)}.time-slots-grid-booking{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.form-grid{grid-template-columns:1fr}.step-actions{flex-direction:column}.step-actions .btn{max-width:100%}}.contact-page{min-height:100vh}.contact-hero{position:relative;min-height:400px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff,#a5b4fc);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:4rem 2rem}.contact-hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 50%)}.floating-bubble{position:absolute;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff6,#ffffff1a);animation:floatBubble 15s ease-in-out infinite;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.bubble-1{width:100px;height:100px;top:10%;left:10%;animation-delay:0s}.bubble-2{width:150px;height:150px;top:60%;right:15%;animation-delay:2s}.bubble-3{width:80px;height:80px;bottom:20%;left:20%;animation-delay:4s}.bubble-4{width:120px;height:120px;top:30%;right:25%;animation-delay:1s}@keyframes floatBubble{0%,to{transform:translate(0) scale(1);opacity:.6}50%{transform:translate(30px,-30px) scale(1.1);opacity:.8}}.contact-hero-content{position:relative;z-index:2;text-align:center;max-width:800px;animation:fadeInUp .8s ease}.hero-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-full);color:#d946ef;font-weight:600;font-size:var(--text-sm);margin-bottom:var(--spacing-lg);box-shadow:0 4px 20px #d946ef33}.hero-badge svg{font-size:1.25rem}.contact-hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:#fff;margin-bottom:var(--spacing-md);text-shadow:0 2px 20px rgba(0,0,0,.1)}.contact-hero-subtitle{font-size:clamp(1rem,2vw,1.25rem);color:#fff;margin:0;text-shadow:0 2px 10px rgba(0,0,0,.1);line-height:1.6}.contact-content{padding:5rem 0;background:linear-gradient(to bottom,#fef7ff,#fff)}.contact-container{max-width:1200px;margin:0 auto;padding:0 2rem}.contact-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--spacing-2xl)}.contact-form-section{background:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-2xl);box-shadow:0 8px 30px #00000014}.form-header{margin-bottom:var(--spacing-2xl)}.form-header h2{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.form-header p{color:var(--text-secondary);margin:0}.contact-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.form-group-contact{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-label-contact{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.input-wrapper-contact{position:relative}.input-icon-contact{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:1.125rem;pointer-events:none}.form-input-contact{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) calc(var(--spacing-md) * 3);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);background:#fff;transition:all var(--transition-fast)}.form-input-contact:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 4px #d946ef1a}.form-input-contact.error{border-color:#ef4444}.form-textarea-contact{resize:vertical;min-height:150px;padding:var(--spacing-md);font-family:inherit;line-height:1.6}.form-error-contact{font-size:var(--text-sm);color:#ef4444;display:flex;align-items:center;gap:var(--spacing-xs)}.btn-submit-contact{padding:var(--spacing-lg) var(--spacing-2xl);background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--text-lg);font-weight:700;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 20px #d946ef4d}.btn-submit-contact:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 8px 30px #d946ef66}.btn-submit-contact:disabled{opacity:.6;cursor:not-allowed}.spinner-contact{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.contact-info-section{display:flex;flex-direction:column;gap:var(--spacing-lg)}.info-card{background:#fff;padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:0 4px 20px #0000000f;display:flex;gap:var(--spacing-lg);transition:all var(--transition-base);border:2px solid transparent}.info-card:hover{border-color:#d946ef;box-shadow:0 8px 30px #d946ef26;transform:translateY(-4px)}.info-card-icon{width:60px;height:60px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0;box-shadow:0 6px 20px #d946ef33}.info-card-content{flex:1}.info-card-content h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.info-card-content p{color:var(--text-secondary);margin:var(--spacing-xs) 0;line-height:1.6}.whatsapp-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:#10b981;font-weight:600;text-decoration:none;margin-top:var(--spacing-sm);transition:color var(--transition-fast)}.whatsapp-link:hover{color:#059669}.schedule-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.schedule-list p.closed{color:#ef4444;font-weight:600}.social-section{background:linear-gradient(135deg,#fef7ff,#fff5f7);padding:var(--spacing-xl);border-radius:var(--radius-xl);text-align:center;box-shadow:0 4px 20px #0000000f}.social-section h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.social-links{display:flex;justify-content:center;gap:var(--spacing-md)}.social-link{width:50px;height:50px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;text-decoration:none;transition:all var(--transition-base);box-shadow:0 4px 15px #0000001a}.social-link:hover{transform:translateY(-4px) scale(1.1);box-shadow:0 8px 25px #00000026}.social-link.facebook{background:linear-gradient(135deg,#1877f2,#0c63d4)}.social-link.instagram{background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af)}.social-link.twitter{background:linear-gradient(135deg,#1da1f2,#0d8bd9)}.map-section{position:relative;overflow:hidden}.map-container{position:relative;height:500px}.map-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;pointer-events:none}.map-info{background:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-2xl);box-shadow:0 10px 40px #00000026;text-align:center;max-width:400px;pointer-events:auto;border:2px solid #d946ef}.map-icon{width:70px;height:70px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto var(--spacing-lg);box-shadow:0 8px 25px #d946ef4d}.map-info h3{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.map-info p{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.map-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-lg);text-decoration:none;font-weight:600;transition:all var(--transition-base);box-shadow:0 4px 15px #d946ef4d}.map-button:hover{transform:translateY(-2px);box-shadow:0 6px 25px #d946ef66}.faq-section{padding:5rem 0;background:#fff}.faq-header{text-align:center;margin-bottom:var(--spacing-2xl)}.faq-header h2{font-size:var(--text-3xl);font-weight:800;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-sm)}.faq-header p{color:var(--text-secondary);font-size:var(--text-lg);margin:0}.faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-xl)}.faq-card{background:linear-gradient(135deg,#fef7ff,#fff);padding:var(--spacing-2xl);border-radius:var(--radius-xl);border:2px solid var(--border-light);transition:all var(--transition-base);text-align:center}.faq-card:hover{border-color:#d946ef;box-shadow:0 8px 30px #d946ef26;transform:translateY(-8px)}.faq-icon{font-size:3rem;margin-bottom:var(--spacing-lg)}.faq-card h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.faq-card p{color:var(--text-secondary);line-height:1.6;margin:0}@media(max-width:1024px){.contact-grid{grid-template-columns:1fr}.contact-info-section{grid-row:1}.contact-form-section{grid-row:2}}@media(max-width:768px){.contact-hero{min-height:300px;padding:3rem 1rem}.contact-hero-title{font-size:2rem}.contact-hero-subtitle{font-size:1rem}.contact-content{padding:3rem 0}.contact-container{padding:0 1rem}.contact-form-section{padding:var(--spacing-xl)}.form-row{grid-template-columns:1fr}.info-card{flex-direction:column;text-align:center}.info-card-icon{margin:0 auto}.map-container{height:400px}.map-info{padding:var(--spacing-xl);max-width:90%}.faq-section{padding:3rem 0}.faq-grid{grid-template-columns:1fr}}@media(max-width:480px){.hero-badge{font-size:var(--text-xs);padding:var(--spacing-xs) var(--spacing-md)}.contact-hero-title{font-size:1.75rem}.btn-submit-contact{font-size:var(--text-base);padding:var(--spacing-md) var(--spacing-xl)}.social-link{width:45px;height:45px;font-size:1.25rem}.map-icon{width:60px;height:60px;font-size:1.75rem}.faq-icon{font-size:2.5rem}}.services-page{min-height:100vh}.services-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;gap:var(--spacing-lg)}.services-hero{position:relative;min-height:500px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff,#a5b4fc);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:5rem 2rem}.services-hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 50%)}.services-hero-content{position:relative;z-index:2;text-align:center;max-width:900px;animation:fadeInUp .8s ease}.services-hero-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;color:#fff;margin-bottom:var(--spacing-md);text-shadow:0 2px 20px rgba(0,0,0,.1)}.services-hero-subtitle{font-size:clamp(1.125rem,2.5vw,1.5rem);color:#fff;margin-bottom:var(--spacing-2xl);text-shadow:0 2px 10px rgba(0,0,0,.1);line-height:1.6}.hero-cta-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-2xl);background:#fff;color:#d946ef;border-radius:var(--radius-full);font-weight:700;font-size:var(--text-lg);text-decoration:none;transition:all var(--transition-base);box-shadow:0 8px 30px #0003}.hero-cta-button:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 12px 40px #0000004d}.services-categories{padding:3rem 0;background:linear-gradient(to bottom,#fef7ff,#fff);position:sticky;top:0;z-index:100;box-shadow:0 4px 20px #0000000d}.services-container{max-width:1400px;margin:0 auto;padding:0 2rem}.categories-scroll{display:flex;gap:var(--spacing-md);overflow-x:auto;padding-bottom:var(--spacing-sm);scrollbar-width:thin}.categories-scroll::-webkit-scrollbar{height:6px}.categories-scroll::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:var(--radius-full)}.categories-scroll::-webkit-scrollbar-thumb{background:#d946ef;border-radius:var(--radius-full)}.category-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-full);font-weight:600;font-size:var(--text-base);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.category-button:hover{border-color:#d946ef;background:linear-gradient(135deg,#fef7ff,#fff)}.category-button.active{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:#d946ef;color:#fff;box-shadow:0 4px 20px #d946ef4d}.category-icon{font-size:1.5rem}.category-label{font-weight:700}.services-grid-section{padding:4rem 0;background:#fff}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-2xl)}.service-card{background:#fff;border-radius:var(--radius-2xl);border:2px solid var(--border-light);overflow:hidden;transition:all var(--transition-base);position:relative;display:flex;flex-direction:column}.service-card:hover{border-color:#d946ef;box-shadow:0 12px 40px #d946ef33;transform:translateY(-12px)}.service-badge{position:absolute;top:var(--spacing-lg);z-index:10;padding:var(--spacing-xs) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:var(--spacing-xs);box-shadow:0 4px 15px #0003}.service-badge.popular{left:var(--spacing-lg);background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.service-badge.featured{right:var(--spacing-lg);background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff}.service-badge svg{font-size:1rem}.service-image{position:relative;width:100%;height:280px;overflow:hidden}.service-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.service-card:hover .service-image img{transform:scale(1.15)}.service-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 0%,rgba(217,70,239,.95) 100%);display:flex;align-items:flex-end;justify-content:center;padding:var(--spacing-xl);opacity:0;transition:opacity var(--transition-base)}.service-card:hover .service-overlay{opacity:1}.btn-reserve{padding:var(--spacing-md) var(--spacing-2xl);background:#fff;color:#d946ef;border-radius:var(--radius-full);font-weight:700;font-size:var(--text-base);display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;transition:all var(--transition-fast);box-shadow:0 4px 20px #0003}.btn-reserve:hover{transform:scale(1.05);box-shadow:0 6px 25px #0000004d}.service-body{padding:var(--spacing-2xl);flex:1;display:flex;flex-direction:column}.service-name{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md);line-height:1.2}.service-description{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-lg)}.service-info{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);margin-bottom:var(--spacing-lg)}.info-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-base);color:var(--text-secondary);font-weight:600}.info-item svg{font-size:1.25rem}.info-item.price{font-size:var(--text-xl);color:#d946ef;font-weight:800}.service-benefits{margin-bottom:var(--spacing-xl);flex:1}.service-benefits h4{font-size:var(--text-base);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.service-benefits ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.service-benefits li{display:flex;align-items:flex-start;gap:var(--spacing-sm);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.service-benefits li svg{color:#10b981;font-size:1rem;flex-shrink:0;margin-top:2px}.btn-book-service{width:100%;padding:var(--spacing-md) var(--spacing-xl);background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:700;font-size:var(--text-base);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);text-decoration:none;cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 20px #d946ef4d}.btn-book-service:hover{transform:translateY(-4px);box-shadow:0 8px 30px #d946ef66}.why-choose-section{padding:5rem 0;background:linear-gradient(135deg,#fef7ff,#fff5f7)}.section-header-center{text-align:center;margin-bottom:var(--spacing-2xl)}.section-header-center h2{font-size:var(--text-3xl);font-weight:800;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-sm)}.section-header-center p{font-size:var(--text-lg);color:var(--text-secondary);margin:0}.why-choose-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-xl)}.why-card{background:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-2xl);text-align:center;border:2px solid var(--border-light);transition:all var(--transition-base)}.why-card:hover{border-color:#d946ef;box-shadow:0 12px 35px #d946ef26;transform:translateY(-8px)}.why-icon{width:80px;height:80px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto var(--spacing-lg);box-shadow:0 10px 30px #d946ef33;transition:transform var(--transition-base)}.why-card:hover .why-icon{transform:scale(1.1) rotate(-5deg)}.why-card h3{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.why-card p{color:var(--text-secondary);line-height:1.6;margin:0}.cta-section{padding:5rem 2rem;background:linear-gradient(135deg,#d946ef,#a855f7);position:relative;overflow:hidden}.cta-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(255,255,255,.1) 0%,transparent 50%)}.cta-content{position:relative;z-index:2;max-width:800px;margin:0 auto;text-align:center}.cta-content h2{font-size:clamp(2rem,5vw,3rem);font-weight:800;color:#fff;margin-bottom:var(--spacing-md)}.cta-content p{font-size:clamp(1.125rem,2vw,1.5rem);color:#fff;margin-bottom:var(--spacing-2xl);opacity:.95}.cta-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-2xl);background:#fff;color:#d946ef;border-radius:var(--radius-full);font-weight:700;font-size:var(--text-xl);text-decoration:none;transition:all var(--transition-base);box-shadow:0 10px 40px #0000004d}.cta-button:hover{transform:translateY(-6px) scale(1.05);box-shadow:0 15px 50px #0006}@media(max-width:1200px){.services-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media(max-width:768px){.services-hero{min-height:400px;padding:3rem 1rem}.services-hero-title{font-size:2rem}.services-hero-subtitle{font-size:1rem}.services-container{padding:0 1rem}.services-categories{padding:2rem 0}.categories-scroll{gap:var(--spacing-sm)}.category-button{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--text-sm)}.services-grid{grid-template-columns:1fr}.service-image{height:240px}.why-choose-grid{grid-template-columns:1fr}.cta-section{padding:3rem 1rem}}@media(max-width:480px){.hero-cta-button{font-size:var(--text-base);padding:var(--spacing-md) var(--spacing-xl)}.service-body{padding:var(--spacing-lg)}.service-name{font-size:var(--text-xl)}.service-info{flex-direction:column;gap:var(--spacing-sm);align-items:flex-start}.why-icon{width:70px;height:70px;font-size:2rem}.cta-button{font-size:var(--text-lg);padding:var(--spacing-md) var(--spacing-xl)}}.about-page{min-height:100vh}.about-hero{position:relative;min-height:500px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff,#a5b4fc);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:8rem 2rem 5rem}.about-hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 50%)}.about-hero-content{position:relative;z-index:2;text-align:center;max-width:900px;animation:fadeInUp .8s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.about-hero-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;color:#fff;margin-bottom:var(--spacing-md);text-shadow:0 2px 20px rgba(0,0,0,.1);line-height:1.1}.about-hero-subtitle{font-size:clamp(1.125rem,2.5vw,1.5rem);color:#fff;margin:0;text-shadow:0 2px 10px rgba(0,0,0,.1);line-height:1.6}.stats-section{padding:5rem 0;background:#fff;margin-top:-3rem;position:relative;z-index:10}.about-container{max-width:1400px;margin:0 auto;padding:0 2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-2xl)}.stat-card{background:linear-gradient(135deg,#fef7ff,#fff);padding:var(--spacing-2xl);border-radius:var(--radius-2xl);text-align:center;border:2px solid var(--border-light);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent-color, #d946ef);transform:scaleX(0);transition:transform var(--transition-base)}.stat-card:hover{transform:translateY(-8px);box-shadow:0 12px 35px #d946ef26;border-color:var(--accent-color, #d946ef)}.stat-card:hover:before{transform:scaleX(1)}.stat-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--accent-color, #d946ef) 0%,#a855f7 100%);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto var(--spacing-lg);box-shadow:0 10px 30px #d946ef4d;transition:transform var(--transition-base)}.stat-card:hover .stat-icon{transform:scale(1.1) rotate(-5deg)}.stat-value{font-size:var(--text-4xl);font-weight:800;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-sm)}.stat-label{font-size:var(--text-base);color:var(--text-secondary);font-weight:600}.story-section{padding:6rem 0;background:linear-gradient(to bottom,#fff,#fef7ff)}.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2xl);align-items:center}.story-image{position:relative;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:0 20px 60px #00000026}.story-image img{width:100%;height:600px;object-fit:cover;transition:transform var(--transition-base)}.story-image:hover img{transform:scale(1.05)}.image-decoration{position:absolute;top:-20px;right:-20px;width:200px;height:200px;background:linear-gradient(135deg,#d946ef,#a855f7);border-radius:var(--radius-2xl);opacity:.1;z-index:-1}.story-content{padding:var(--spacing-xl)}.section-title{font-size:var(--text-3xl);font-weight:800;color:var(--text-primary);margin-bottom:var(--spacing-md);line-height:1.2}.section-title.centered{text-align:center;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--spacing-2xl)}.section-subtitle.centered{text-align:center}.story-text{font-size:var(--text-base);color:var(--text-secondary);line-height:1.8;margin-bottom:var(--spacing-lg)}.values-section{padding:6rem 0;background:#fff}.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-2xl)}.value-card{background:linear-gradient(135deg,#fef7ff,#fff);padding:var(--spacing-2xl);border-radius:var(--radius-2xl);border:2px solid var(--border-light);transition:all var(--transition-base);text-align:center}.value-card:hover{transform:translateY(-8px);border-color:#d946ef;box-shadow:0 12px 35px #d946ef26}.value-icon{width:70px;height:70px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto var(--spacing-lg);box-shadow:0 8px 25px #d946ef33;transition:transform var(--transition-base)}.value-card:hover .value-icon{transform:scale(1.1) rotate(-5deg)}.value-title{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.value-description{font-size:var(--text-base);color:var(--text-secondary);line-height:1.7;margin:0}.timeline-section{padding:6rem 0;background:linear-gradient(to bottom,#fff,#fef7ff)}.timeline{max-width:900px;margin:0 auto;position:relative}.timeline:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#d946ef,#a855f7,#06b6d4);transform:translate(-50%)}.timeline-item{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--spacing-2xl);margin-bottom:var(--spacing-2xl);position:relative}.timeline-item:nth-child(2n) .timeline-content{grid-column:1;text-align:right}.timeline-item:nth-child(2n) .timeline-marker{grid-column:2}.timeline-marker{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.timeline-dot{width:20px;height:20px;background:linear-gradient(135deg,#d946ef,#a855f7);border-radius:50%;border:4px solid white;box-shadow:0 0 0 4px #d946ef33;z-index:2}.timeline-year{padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-full);font-weight:700;font-size:var(--text-sm);box-shadow:0 4px 15px #d946ef4d}.timeline-content{background:#fff;padding:var(--spacing-xl);border-radius:var(--radius-xl);border:2px solid var(--border-light);box-shadow:0 4px 20px #0000000d;transition:all var(--transition-base)}.timeline-content:hover{transform:translateY(-4px);box-shadow:0 8px 30px #d946ef26;border-color:#d946ef}.timeline-title{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.timeline-description{font-size:var(--text-base);color:var(--text-secondary);line-height:1.7;margin:0}.team-section{padding:6rem 0;background:#fff}.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-2xl)}.team-card{background:#fff;border-radius:var(--radius-2xl);overflow:hidden;border:2px solid var(--border-light);transition:all var(--transition-base)}.team-card:hover{transform:translateY(-8px);box-shadow:0 12px 35px #d946ef26;border-color:#d946ef}.team-image{position:relative;overflow:hidden;height:350px}.team-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.team-card:hover .team-image img{transform:scale(1.1)}.team-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(217,70,239,.95),transparent);padding:var(--spacing-xl);transform:translateY(100%);transition:transform var(--transition-base)}.team-card:hover .team-overlay{transform:translateY(0)}.team-specialty{color:#fff;font-size:var(--text-base);font-weight:600;text-align:center}.team-info{padding:var(--spacing-xl);text-align:center}.team-name{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.team-role{font-size:var(--text-base);color:#d946ef;font-weight:600;margin-bottom:var(--spacing-sm)}.team-experience{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.about-cta-section{padding:6rem 2rem;background:linear-gradient(135deg,#d946ef,#a855f7);position:relative;overflow:hidden}.about-cta-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(255,255,255,.1) 0%,transparent 50%)}.about-cta-content{position:relative;z-index:2;max-width:900px;margin:0 auto;text-align:center}.cta-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:#fff;margin-bottom:var(--spacing-lg);line-height:1.2}.cta-subtitle{font-size:clamp(1.125rem,2vw,1.5rem);color:#fff;margin-bottom:var(--spacing-2xl);line-height:1.6;opacity:.95}.cta-buttons{display:flex;gap:var(--spacing-lg);justify-content:center;flex-wrap:wrap}.cta-button{padding:var(--spacing-lg) var(--spacing-2xl);border-radius:var(--radius-full);font-weight:700;font-size:var(--text-lg);text-decoration:none;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:var(--spacing-sm)}.cta-button.primary{background:#fff;color:#d946ef;box-shadow:0 10px 40px #0003}.cta-button.primary:hover{transform:translateY(-4px);box-shadow:0 15px 50px #0000004d}.cta-button.secondary{background:#ffffff1a;color:#fff;border:2px solid white;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cta-button.secondary:hover{background:#fff;color:#d946ef;transform:translateY(-4px)}.contact-info-section{padding:5rem 0;background:linear-gradient(to bottom,#fef7ff,#fff)}.contact-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl)}.contact-info-card{background:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-xl);border:2px solid var(--border-light);text-align:center;transition:all var(--transition-base)}.contact-info-card:hover{transform:translateY(-8px);box-shadow:0 12px 35px #d946ef26;border-color:#d946ef}.contact-icon{width:60px;height:60px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin:0 auto var(--spacing-lg);box-shadow:0 8px 25px #d946ef33}.contact-info-card h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.contact-info-card p{font-size:var(--text-base);color:var(--text-secondary);margin:var(--spacing-xs) 0}@media(max-width:1024px){.story-grid{grid-template-columns:1fr}.story-image{max-width:600px;margin:0 auto}.timeline:before{left:30px}.timeline-item{grid-template-columns:auto 1fr;gap:var(--spacing-lg)}.timeline-item:nth-child(2n) .timeline-content{grid-column:2;text-align:left}.timeline-marker{grid-column:1}.timeline-content{grid-column:2}}@media(max-width:768px){.about-hero{min-height:400px;padding:6rem 1rem 4rem}.about-hero-title{font-size:2rem}.about-hero-subtitle{font-size:1rem}.stats-section{padding:3rem 0}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.story-section,.values-section,.timeline-section,.team-section{padding:4rem 0}.values-grid{grid-template-columns:1fr}.team-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.about-cta-section{padding:4rem 1rem}.cta-buttons{flex-direction:column}.cta-button{width:100%;justify-content:center}.contact-info-grid{grid-template-columns:1fr}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.story-image img{height:400px}.timeline-year{font-size:var(--text-xs);padding:var(--spacing-xs) var(--spacing-md)}.team-image{height:300px}}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-lg);animation:fadeIn .2s ease-out}.modal-container{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;width:100%;animation:slideUp .3s ease-out}.modal-small{max-width:400px}.modal-medium{max-width:600px}.modal-large{max-width:900px}.modal-full{max-width:95vw;max-height:95vh}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin:0}.modal-close{background:transparent;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-sm);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-footer{padding:var(--spacing-lg);border-top:1px solid var(--border-color);display:flex;gap:var(--spacing-md);justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.modal-backdrop{padding:0}.modal-container{max-height:100vh;border-radius:0}.modal-small,.modal-medium,.modal-large{max-width:100%}}.confirm-dialog-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg) 0;text-align:center}.confirm-icon{font-size:3rem}.confirm-danger .confirm-icon{color:var(--error-color)}.confirm-warning .confirm-icon{color:var(--warning-color)}.confirm-info .confirm-icon{color:var(--info-color)}.confirm-message{font-size:var(--text-base);color:var(--text-secondary);margin:0;max-width:400px}.admin-products-page{padding:0}.admin-products-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;gap:var(--spacing-lg)}.products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);flex-wrap:wrap;gap:var(--spacing-lg)}.products-title{font-size:var(--text-3xl);font-weight:700;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.products-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.products-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-box{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-lg);box-shadow:0 4px 15px #0000000d;transition:all var(--transition-base)}.stat-box:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001a}.stat-icon.total{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#3b82f6}.stat-icon.active{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#10b981}.stat-icon.inactive{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#ef4444}.stat-icon.revenue{background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#d946ef}.stat-value{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:600}.products-filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl);flex-wrap:wrap}.search-box{flex:1;min-width:250px;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:var(--spacing-md);color:var(--text-secondary);font-size:1.25rem;pointer-events:none}.search-box input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) calc(var(--spacing-md) * 3);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);background:#fff;transition:all var(--transition-fast)}.filter-group{display:flex;align-items:center;gap:var(--spacing-sm)}.filter-group svg{color:var(--text-secondary);font-size:1.25rem}.filter-select{padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;background:#fff;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);min-width:180px}.filter-select:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.service-card{background:#fff;border-radius:var(--radius-2xl);border:2px solid var(--border-light);overflow:hidden;transition:all var(--transition-base);display:flex;flex-direction:column}.service-card:hover{transform:translateY(-8px);box-shadow:0 12px 30px #d946ef26;border-color:#d946ef}.service-card.inactive:hover{opacity:1}.service-card-header{background:linear-gradient(135deg,#fef7ff,#fff5f7);padding:var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-light)}.service-category-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:#fff;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;box-shadow:0 2px 10px #0000000d}.category-icon{font-size:1.25rem}.category-label{color:var(--text-primary)}.service-status{display:flex;align-items:center}.status-badge{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge svg{font-size:.875rem}.status-badge.active{background:#d1fae5;color:#10b981}.status-badge.inactive{background:#fee2e2;color:#ef4444}.service-card-body{padding:var(--spacing-xl);flex:1;display:flex;flex-direction:column}.service-name{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm);line-height:1.3}.service-description{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.6;margin-bottom:var(--spacing-lg);flex:1}.service-details{display:flex;gap:var(--spacing-lg);padding:var(--spacing-md) 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);margin-bottom:var(--spacing-md)}.detail-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm);color:var(--text-secondary)}.detail-item svg{font-size:1.125rem}.detail-item.price{font-weight:700;font-size:var(--text-lg);color:#d946ef}.service-stats{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:linear-gradient(135deg,#fef7ff,#fff5f7);border-radius:var(--radius-lg);margin-top:auto}.service-stats .stat-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm);color:var(--text-secondary)}.service-stats .stat-item svg{font-size:1rem;color:#d946ef}.service-stats .stat-item.revenue{font-weight:700;color:#10b981}.service-card-footer{display:flex;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--bg-tertiary);border-top:1px solid var(--border-light)}.btn-icon{flex:1;height:42px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-light);border-radius:var(--radius-lg);background:#fff;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:1.125rem}.btn-icon:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0000001a}.btn-icon.primary:hover{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:#d946ef;color:#fff}.btn-icon.success:hover{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff}.btn-icon.warning:hover{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b;color:#fff}.btn-icon.danger:hover{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff}.empty-state{text-align:center;padding:var(--spacing-2xl);background:#fff;border-radius:var(--radius-2xl);border:2px dashed var(--border-light)}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg)}.empty-state h3{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.empty-state p{color:var(--text-secondary);margin:0}.service-form{padding:var(--spacing-md) 0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.form-input{padding:var(--spacing-md);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);background:#fff;transition:all var(--transition-fast)}.form-textarea{resize:vertical;min-height:100px;font-family:inherit}.form-error{font-size:var(--text-sm);color:var(--error-color);display:flex;align-items:center;gap:var(--spacing-xs)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;padding:var(--spacing-md);border-radius:var(--radius-lg);background:linear-gradient(135deg,#fef7ff,#fff);border:2px solid var(--border-light);transition:all var(--transition-fast)}.checkbox-label:hover{border-color:#d946ef;background:linear-gradient(135deg,#fef7ff,#fff5f7)}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#d946ef}.checkbox-label span{font-size:var(--text-base);color:var(--text-primary);font-weight:500}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-xl);border-top:2px solid var(--border-light)}.form-actions .btn{min-width:150px}@media(max-width:1200px){.services-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.products-header{flex-direction:column;align-items:flex-start}.products-header .btn{width:100%}.products-stats{grid-template-columns:1fr}.products-filters{flex-direction:column}.search-box,.filter-select{width:100%}.services-grid,.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.service-card-footer{flex-wrap:wrap}.btn-icon{min-width:calc(50% - var(--spacing-xs))}}@media(max-width:480px){.products-title{font-size:var(--text-2xl)}.stat-box{flex-direction:column;text-align:center}.service-details{flex-direction:column;gap:var(--spacing-sm)}.service-stats{flex-direction:column;gap:var(--spacing-sm);align-items:flex-start}}.admin-orders-page{padding:0}.admin-orders-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;gap:var(--spacing-lg)}.orders-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);flex-wrap:wrap;gap:var(--spacing-lg)}.orders-title{font-size:var(--text-3xl);font-weight:700;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.orders-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.orders-actions{display:flex;gap:var(--spacing-md)}.orders-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card-orders{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);box-shadow:0 4px 15px #0000000d;transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card-orders:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card-orders.stat-total:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.stat-card-orders.stat-pending:before{background:linear-gradient(90deg,#f59e0b,#d97706)}.stat-card-orders.stat-confirmed:before{background:linear-gradient(90deg,#10b981,#059669)}.stat-card-orders.stat-completed:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.stat-card-orders.stat-cancelled:before{background:linear-gradient(90deg,#ef4444,#dc2626)}.stat-card-orders.stat-revenue:before{background:linear-gradient(90deg,#d946ef,#a855f7)}.stat-card-orders:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001a}.stat-icon-orders{width:50px;height:50px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.stat-card-orders.stat-total .stat-icon-orders{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#3b82f6}.stat-card-orders.stat-pending .stat-icon-orders{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#f59e0b}.stat-card-orders.stat-confirmed .stat-icon-orders{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#10b981}.stat-card-orders.stat-completed .stat-icon-orders{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#3b82f6}.stat-card-orders.stat-cancelled .stat-icon-orders{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#ef4444}.stat-card-orders.stat-revenue .stat-icon-orders{background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#d946ef}.stat-content-orders{flex:1}.stat-value-orders{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label-orders{font-size:var(--text-xs);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.orders-filters{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg);box-shadow:0 4px 15px #0000000d}.search-box-orders{position:relative;margin-bottom:var(--spacing-lg)}.search-box-orders svg{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:1.25rem}.search-box-orders input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) calc(var(--spacing-md) * 3);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);transition:all var(--transition-fast)}.search-box-orders input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.filters-row{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.filter-group-orders{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:200px}.filter-group-orders svg{color:var(--text-secondary);font-size:1.125rem}.filter-group-orders span{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.filter-select-orders{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;background:#fff;cursor:pointer;transition:all var(--transition-fast)}.filter-select-orders:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.results-info{padding:var(--spacing-md) 0;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-md)}.results-info strong{color:#d946ef;font-weight:700}.orders-table-container{background:#fff;border-radius:var(--radius-xl);box-shadow:0 4px 15px #0000000d;overflow:hidden;margin-bottom:var(--spacing-xl)}.orders-table{width:100%;border-collapse:collapse}.orders-table thead{background:linear-gradient(135deg,#fef7ff,#fff5f7)}.orders-table th{padding:var(--spacing-lg);text-align:left;font-size:var(--text-sm);font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-light)}.orders-table tbody tr{transition:all var(--transition-fast);border-bottom:1px solid var(--border-light)}.orders-table tbody tr:hover{background:linear-gradient(135deg,#fef7ff,#fff)}.orders-table tbody tr.expanded{background:linear-gradient(135deg,#fef7ff,#fff5f7)}.orders-table td{padding:var(--spacing-lg);font-size:var(--text-sm);color:var(--text-primary)}.code-cell{display:flex;align-items:center}.code-text{font-family:Courier New,monospace;font-weight:700;color:#d946ef;background:linear-gradient(135deg,#fef7ff,#fff5f7);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md)}.client-cell{display:flex;align-items:center;gap:var(--spacing-md)}.client-avatar{width:45px;height:45px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-sm);flex-shrink:0;box-shadow:0 4px 15px #d946ef33}.client-info{flex:1;min-width:0}.client-name{font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.client-email{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.service-cell{display:flex;flex-direction:column;gap:var(--spacing-xs)}.duration-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-secondary);background:var(--bg-tertiary);padding:2px var(--spacing-sm);border-radius:var(--radius-md);width:fit-content}.datetime-cell{display:flex;flex-direction:column;gap:var(--spacing-xs)}.date-text,.time-text{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm)}.date-text svg,.time-text svg{font-size:1rem;color:var(--text-secondary)}.therapist-cell{display:flex;align-items:center;gap:var(--spacing-xs)}.therapist-cell svg{color:var(--text-secondary)}.price-cell{font-size:var(--text-lg);font-weight:700;color:#10b981}.status-badge-table{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge-table.warning{background:#fef3c7;color:#f59e0b}.status-badge-table.success{background:#d1fae5;color:#10b981}.status-badge-table.info{background:#dbeafe;color:#3b82f6}.status-badge-table.error{background:#fee2e2;color:#ef4444}.actions-cell{display:flex;gap:var(--spacing-xs);align-items:center}.btn-action{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-action:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.btn-action.view:hover{background:#3b82f6;color:#fff;border-color:#3b82f6}.btn-action.expand:hover{background:#d946ef;color:#fff;border-color:#d946ef}.btn-action.more:hover{background:var(--text-primary);color:#fff;border-color:var(--text-primary)}.dropdown-actions{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--spacing-xs);background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 25px #00000026;min-width:180px;z-index:100;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast)}.dropdown-actions:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-menu button{width:100%;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border:none;background:transparent;color:var(--text-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast);text-align:left}.dropdown-menu button:hover{background:var(--bg-tertiary)}.dropdown-menu button.danger{color:#ef4444}.dropdown-menu button.danger:hover{background:#fee2e2}.expanded-row td{padding:0!important;background:linear-gradient(135deg,#fef7ff,#fff)}.expanded-content{padding:var(--spacing-2xl);display:flex;flex-direction:column;gap:var(--spacing-xl);border-top:2px solid var(--border-light)}.expanded-section h4{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-md)}.expanded-section h4 svg{color:#d946ef}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.info-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-light)}.info-item svg{font-size:1.25rem;color:#d946ef;flex-shrink:0;margin-top:2px}.info-item>div{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.notes-text{padding:var(--spacing-lg);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-light);color:var(--text-secondary);font-size:var(--text-sm);line-height:1.6;margin:0}.pagination-orders{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background:#fff;border-radius:var(--radius-xl);box-shadow:0 4px 15px #0000000d}.pagination-btn{padding:var(--spacing-sm) var(--spacing-lg);border:2px solid var(--border-light);border-radius:var(--radius-lg);background:#fff;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:#d946ef;color:#fff;border-color:#d946ef}.pagination-pages{display:flex;gap:var(--spacing-xs)}.pagination-page{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-light);border-radius:var(--radius-md);background:#fff;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.pagination-page:hover{background:var(--bg-tertiary)}.pagination-page.active{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-color:#d946ef}.empty-state-orders{text-align:center;padding:var(--spacing-2xl)}.empty-icon-orders{font-size:4rem;margin-bottom:var(--spacing-lg)}.empty-state-orders h3{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.empty-state-orders p{color:var(--text-secondary);margin:0}.appointment-detail-modal{padding:var(--spacing-md) 0}.detail-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-xl);border-bottom:2px solid var(--border-light);margin-bottom:var(--spacing-xl)}.detail-code{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-xl);font-weight:700;color:#d946ef}.detail-code svg{font-size:1.5rem}.status-badge-modal{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:700;text-transform:uppercase}.status-badge-modal.warning{background:#fef3c7;color:#f59e0b}.status-badge-modal.success{background:#d1fae5;color:#10b981}.status-badge-modal.info{background:#dbeafe;color:#3b82f6}.status-badge-modal.error{background:#fee2e2;color:#ef4444}.detail-sections{display:flex;flex-direction:column;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.detail-section{background:linear-gradient(135deg,#fef7ff,#fff);padding:var(--spacing-xl);border-radius:var(--radius-xl);border:1px solid var(--border-light)}.detail-section h3{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.detail-section h3 svg{color:#d946ef}.detail-info{display:flex;flex-direction:column;gap:var(--spacing-md)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:#fff;border-radius:var(--radius-lg)}.detail-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:600}.detail-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.detail-value.price{font-size:var(--text-lg);font-weight:700;color:#10b981}.notes-box{padding:var(--spacing-lg);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-light);color:var(--text-secondary);line-height:1.6}.modal-actions{display:flex;justify-content:flex-end;padding-top:var(--spacing-xl);border-top:2px solid var(--border-light)}@media(max-width:1400px){.orders-table{font-size:var(--text-xs)}.orders-table th,.orders-table td{padding:var(--spacing-md)}}@media(max-width:1200px){.orders-stats{grid-template-columns:repeat(3,1fr)}.orders-table-container{overflow-x:auto}.orders-table{min-width:1000px}}@media(max-width:768px){.orders-header{flex-direction:column;align-items:flex-start}.orders-actions{width:100%}.orders-actions .btn{flex:1}.orders-stats{grid-template-columns:repeat(2,1fr)}.filters-row{flex-direction:column}.filter-group-orders{width:100%}.info-grid{grid-template-columns:1fr}}@media(max-width:480px){.orders-stats{grid-template-columns:1fr}.pagination-pages{flex-wrap:wrap}}.admin-users-page{padding:0}.admin-users-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;gap:var(--spacing-lg)}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);flex-wrap:wrap;gap:var(--spacing-lg)}.users-title{font-size:var(--text-3xl);font-weight:700;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.users-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.users-actions{display:flex;gap:var(--spacing-md)}.users-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card-users{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);box-shadow:0 4px 15px #0000000d;transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card-users:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card-users.stat-total:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.stat-card-users.stat-clients:before{background:linear-gradient(90deg,#d946ef,#a855f7)}.stat-card-users.stat-therapists:before{background:linear-gradient(90deg,#10b981,#059669)}.stat-card-users.stat-admins:before{background:linear-gradient(90deg,#f59e0b,#d97706)}.stat-card-users.stat-active:before{background:linear-gradient(90deg,#10b981,#059669)}.stat-card-users.stat-revenue:before{background:linear-gradient(90deg,#d946ef,#a855f7)}.stat-card-users:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001a}.stat-icon-users{width:50px;height:50px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.stat-card-users.stat-total .stat-icon-users{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#3b82f6}.stat-card-users.stat-clients .stat-icon-users{background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#d946ef}.stat-card-users.stat-therapists .stat-icon-users{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#10b981}.stat-card-users.stat-admins .stat-icon-users{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#f59e0b}.stat-card-users.stat-active .stat-icon-users{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#10b981}.stat-card-users.stat-revenue .stat-icon-users{background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#d946ef}.stat-content-users{flex:1}.stat-value-users{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label-users{font-size:var(--text-xs);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.users-filters{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg);box-shadow:0 4px 15px #0000000d}.search-box-users{position:relative;margin-bottom:var(--spacing-lg)}.search-box-users svg{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:1.25rem}.search-box-users input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) calc(var(--spacing-md) * 3);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);transition:all var(--transition-fast)}.search-box-users input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.filters-row-users{display:flex;gap:var(--spacing-md);flex-wrap:wrap;align-items:center}.filter-group-users{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:180px}.filter-group-users svg{color:var(--text-secondary);font-size:1.125rem}.filter-group-users span{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.filter-select-users{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;background:#fff;cursor:pointer;transition:all var(--transition-fast)}.filter-select-users:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.view-toggle{display:flex;gap:var(--spacing-xs);background:var(--bg-tertiary);padding:var(--spacing-xs);border-radius:var(--radius-lg)}.view-btn{padding:var(--spacing-sm);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.view-btn:hover{background:#fff}.view-btn.active{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff}.results-info-users{padding:var(--spacing-md) 0;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-md)}.results-info-users strong{color:#d946ef;font-weight:700}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.user-card{background:#fff;border-radius:var(--radius-2xl);border:2px solid var(--border-light);overflow:hidden;transition:all var(--transition-base);position:relative}.user-card:hover{transform:translateY(-8px);box-shadow:0 12px 30px #d946ef26;border-color:#d946ef}.user-card.inactive{opacity:.6}.user-card.inactive:hover{opacity:1}.user-card-header{background:linear-gradient(135deg,#fef7ff,#fff5f7);padding:var(--spacing-xl);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);border-bottom:1px solid var(--border-light);position:relative}.user-avatar-large{width:80px;height:80px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-2xl);box-shadow:0 8px 25px #d946ef4d;border:4px solid white}.role-badge{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.role-badge.primary{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#f59e0b}.role-badge.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#10b981}.role-badge.info{background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#d946ef}.role-badge svg{font-size:.875rem}.user-card-body{padding:var(--spacing-xl)}.user-name{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);text-align:center;margin-bottom:var(--spacing-lg)}.user-info-grid{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.info-item-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary)}.info-item-card svg{color:#d946ef;font-size:1rem;flex-shrink:0}.info-item-card span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-stats-card{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);padding:var(--spacing-md) 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);margin-bottom:var(--spacing-md)}.stat-item-card{display:flex;align-items:center;gap:var(--spacing-sm)}.stat-item-card svg{font-size:1.5rem;color:#d946ef}.stat-item-card>div{display:flex;flex-direction:column}.stat-value-card{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);line-height:1}.stat-label-card{font-size:var(--text-xs);color:var(--text-secondary)}.user-meta{display:flex;flex-direction:column;gap:var(--spacing-xs)}.meta-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-secondary)}.meta-item svg{font-size:.875rem}.user-card-footer{display:flex;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--bg-tertiary);border-top:1px solid var(--border-light)}.btn-icon-user{flex:1;height:42px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-light);border-radius:var(--radius-lg);background:#fff;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:1.125rem}.btn-icon-user:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0000001a}.btn-icon-user.primary:hover{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:#d946ef;color:#fff}.btn-icon-user.success:hover{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff}.btn-icon-user.warning:hover{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b;color:#fff}.btn-icon-user.info:hover{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#3b82f6;color:#fff}.btn-icon-user.danger:hover{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff}.inactive-overlay{position:absolute;inset:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);color:#fff;font-weight:700;opacity:0;transition:opacity var(--transition-base);pointer-events:none}.user-card.inactive:hover .inactive-overlay{opacity:1}.inactive-overlay svg{font-size:3rem}.users-table-container{background:#fff;border-radius:var(--radius-xl);box-shadow:0 4px 15px #0000000d;overflow:hidden;margin-bottom:var(--spacing-xl)}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:linear-gradient(135deg,#fef7ff,#fff5f7)}.users-table th{padding:var(--spacing-lg);text-align:left;font-size:var(--text-sm);font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-light)}.users-table tbody tr{transition:all var(--transition-fast);border-bottom:1px solid var(--border-light)}.users-table tbody tr:hover{background:linear-gradient(135deg,#fef7ff,#fff)}.users-table tbody tr.inactive-row{opacity:.6}.users-table tbody tr.inactive-row:hover{opacity:1}.users-table td{padding:var(--spacing-lg);font-size:var(--text-sm);color:var(--text-primary)}.user-cell{display:flex;align-items:center;gap:var(--spacing-md)}.user-avatar-table{width:45px;height:45px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-sm);flex-shrink:0;box-shadow:0 4px 15px #d946ef33}.user-info-table{flex:1;min-width:0}.user-name-table{font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.user-address-table{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-secondary)}.user-address-table svg{font-size:.875rem}.contact-cell{display:flex;flex-direction:column;gap:var(--spacing-xs)}.contact-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-sm)}.contact-item svg{font-size:1rem;color:var(--text-secondary)}.role-badge-table{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase}.role-badge-table.primary{background:#fef3c7;color:#f59e0b}.role-badge-table.success{background:#d1fae5;color:#10b981}.role-badge-table.info{background:#ffc2e2;color:#d946ef}.role-badge-table svg{font-size:.875rem}.stats-cell{display:flex;flex-direction:column;gap:var(--spacing-xs)}.stat-mini{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--text-xs);color:var(--text-secondary)}.stat-mini svg{font-size:.875rem}.stat-mini.revenue{color:#10b981;font-weight:600}.date-cell{font-size:var(--text-sm);color:var(--text-secondary)}.status-badge-table{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase}.status-badge-table.active{background:#d1fae5;color:#10b981}.status-badge-table.inactive{background:#fee2e2;color:#ef4444}.status-badge-table svg{font-size:.875rem}.actions-cell-table{display:flex;gap:var(--spacing-xs)}.btn-action-table{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-action-table:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.btn-action-table.view:hover{background:#3b82f6;color:#fff;border-color:#3b82f6}.btn-action-table.edit:hover{background:#d946ef;color:#fff;border-color:#d946ef}.btn-action-table.toggle:hover{background:#f59e0b;color:#fff;border-color:#f59e0b}.btn-action-table.delete:hover{background:#ef4444;color:#fff;border-color:#ef4444}.empty-state-users{text-align:center;padding:var(--spacing-2xl);background:#fff;border-radius:var(--radius-2xl);border:2px dashed var(--border-light)}.empty-icon-users{font-size:4rem;margin-bottom:var(--spacing-lg)}.empty-state-users h3{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.empty-state-users p{color:var(--text-secondary);margin:0}.user-form{padding:var(--spacing-md) 0}.form-grid-users{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.form-group-users{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group-users.form-full{grid-column:1 / -1}.form-label-users{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.input-wrapper-users{position:relative}.input-icon-users{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:1.125rem}.form-input-users{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) calc(var(--spacing-md) * 3);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);background:#fff;transition:all var(--transition-fast)}.form-input-users:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.form-input-users.error{border-color:var(--error-color)}.form-error-users{font-size:var(--text-sm);color:var(--error-color)}.checkbox-label-users{display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;padding:var(--spacing-md);border-radius:var(--radius-lg);background:linear-gradient(135deg,#fef7ff,#fff);border:2px solid var(--border-light);transition:all var(--transition-fast)}.checkbox-label-users:hover{border-color:#d946ef}.checkbox-label-users input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#d946ef}.checkbox-label-users span{font-size:var(--text-base);color:var(--text-primary);font-weight:500}.form-actions-users{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-xl);border-top:2px solid var(--border-light)}.form-actions-users .btn{min-width:150px}.user-detail-modal{padding:var(--spacing-md) 0}.detail-header-user{display:flex;align-items:center;gap:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:2px solid var(--border-light);margin-bottom:var(--spacing-xl)}.detail-avatar-large{width:100px;height:100px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-3xl);box-shadow:0 10px 30px #d946ef4d;border:5px solid white;flex-shrink:0}.detail-user-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.detail-user-name{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin:0}.role-badge-detail{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:700;text-transform:uppercase;width:fit-content}.role-badge-detail.primary{background:#fef3c7;color:#f59e0b}.role-badge-detail.success{background:#d1fae5;color:#10b981}.role-badge-detail.info{background:#ffc2e2;color:#d946ef}.status-badge-detail{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:700;width:fit-content}.status-badge-detail.active{background:#d1fae5;color:#10b981}.status-badge-detail.inactive{background:#fee2e2;color:#ef4444}.detail-sections-user{display:flex;flex-direction:column;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.detail-section-user{background:linear-gradient(135deg,#fef7ff,#fff);padding:var(--spacing-xl);border-radius:var(--radius-xl);border:1px solid var(--border-light)}.detail-section-user h3{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.detail-section-user h3 svg{color:#d946ef}.detail-info-user{display:flex;flex-direction:column;gap:var(--spacing-md)}.detail-row-user{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:#fff;border-radius:var(--radius-lg)}.detail-label-user{font-size:var(--text-sm);color:var(--text-secondary);font-weight:600}.detail-value-user{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.detail-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-lg)}.detail-stat-card{background:#fff;padding:var(--spacing-lg);border-radius:var(--radius-xl);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);text-align:center}.detail-stat-icon{width:50px;height:50px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff);color:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.detail-stat-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.detail-stat-value{font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.detail-stat-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:600}.modal-actions-user{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-xl);border-top:2px solid var(--border-light)}@media(max-width:1200px){.users-stats{grid-template-columns:repeat(3,1fr)}.users-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.users-header{flex-direction:column;align-items:flex-start}.users-actions{width:100%}.users-actions .btn{flex:1}.users-stats{grid-template-columns:repeat(2,1fr)}.filters-row-users{flex-direction:column}.filter-group-users{width:100%}.users-grid{grid-template-columns:1fr}.users-table-container{overflow-x:auto}.users-table{min-width:1000px}.form-grid-users{grid-template-columns:1fr}.form-actions-users{flex-direction:column}.form-actions-users .btn{width:100%}.detail-header-user{flex-direction:column;text-align:center}.detail-user-info{align-items:center}.detail-stats-grid{grid-template-columns:1fr}}@media(max-width:480px){.users-stats,.user-stats-card{grid-template-columns:1fr}}.search-bar{position:relative;display:flex;align-items:center;width:100%;max-width:500px}.search-icon{position:absolute;left:var(--spacing-md);color:var(--text-secondary);font-size:1.25rem;pointer-events:none}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-left:calc(var(--spacing-md) * 3);padding-right:calc(var(--spacing-md) * 3);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-base);background:var(--bg-primary);transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.search-clear{position:absolute;right:var(--spacing-md);background:transparent;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.search-clear:hover{background:var(--bg-tertiary);color:var(--text-primary)}@media(max-width:640px){.search-bar{max-width:100%}}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin:var(--spacing-xl) 0;flex-wrap:wrap}.pagination-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--primary-color);color:var(--primary-color)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-numbers{display:flex;align-items:center;gap:var(--spacing-xs)}.pagination-number{min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.pagination-number:hover{background:var(--bg-tertiary);border-color:var(--primary-color);color:var(--primary-color)}.pagination-number.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.pagination-ellipsis{padding:0 var(--spacing-sm);color:var(--text-secondary)}@media(max-width:640px){.pagination-text{display:none}.pagination-btn{padding:var(--spacing-sm)}.pagination-number{min-width:36px;height:36px;font-size:var(--text-xs)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center}.empty-state-icon{font-size:4rem;color:var(--text-light);margin-bottom:var(--spacing-lg)}.empty-state-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.empty-state-description{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--spacing-lg);max-width:400px}.empty-state-action{margin-top:var(--spacing-md)}.admin-appointments-page{padding:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:all var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:60px;height:60px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.stat-icon.total{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-icon.warning{background:#fef3c7;color:#f59e0b}.stat-icon.info{background:#dbeafe;color:#3b82f6}.stat-icon.success{background:#d1fae5;color:#10b981}.stat-value{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.page-header{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);flex-wrap:wrap;align-items:center}.page-header .search-bar{flex:1;min-width:300px}.header-actions{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary)}.filter-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.table-container{background:var(--bg-primary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);margin-bottom:var(--spacing-xl)}.appointments-table{width:100%;border-collapse:collapse}.appointments-table thead{background:var(--bg-tertiary)}.appointments-table th{padding:var(--spacing-lg);text-align:left;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color)}.appointments-table tbody tr{border-bottom:1px solid var(--border-light);transition:background var(--transition-fast)}.appointments-table tbody tr:hover{background:var(--bg-secondary)}.appointments-table td{padding:var(--spacing-lg);font-size:var(--text-sm);color:var(--text-primary)}.client-info{display:flex;align-items:center;gap:var(--spacing-sm)}.client-icon{color:var(--text-secondary)}.client-name{font-weight:600}.contact-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.contact-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-xs);color:var(--text-secondary)}.contact-item svg{font-size:.875rem}.datetime-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.datetime-info .date,.datetime-info .time{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-sm)}.datetime-info .date{font-weight:600;color:var(--text-primary)}.datetime-info .time{color:var(--text-secondary);font-size:var(--text-xs)}.service-tag{display:inline-block;padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);color:var(--text-primary);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;white-space:nowrap}.table-actions{display:flex;gap:var(--spacing-sm)}.btn-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:1rem}.btn-icon:hover{background:var(--bg-secondary);color:var(--text-primary);transform:translateY(-2px)}.btn-icon.success{color:var(--success-color)}.btn-icon.success:hover{background:#d1fae5;border-color:var(--success-color)}.btn-icon.danger{color:var(--error-color)}.btn-icon.danger:hover{background:#fee2e2;border-color:var(--error-color)}.appointment-details{display:flex;flex-direction:column;gap:var(--spacing-xl)}.detail-section{border-bottom:1px solid var(--border-light);padding-bottom:var(--spacing-lg)}.detail-section:last-child{border-bottom:none;padding-bottom:0}.detail-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.detail-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.detail-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.detail-value{font-size:var(--text-base);color:var(--text-primary);font-weight:600}.appointment-message{background:var(--bg-tertiary);padding:var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin:0;border-left:3px solid var(--primary-color)}@media(max-width:1200px){.appointments-table{display:block;overflow-x:auto}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:stretch}.page-header .search-bar{min-width:100%}.header-actions{flex-direction:column}.filter-group,.header-actions .btn,.filter-select{width:100%}.table-container{overflow:visible}.appointments-table,.appointments-table thead,.appointments-table tbody,.appointments-table tr,.appointments-table td{display:block}.appointments-table thead{display:none}.appointments-table tr{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);padding:var(--spacing-lg)}.appointments-table td{padding:var(--spacing-sm) 0;border:none}.appointments-table td:before{content:attr(data-label);font-weight:600;color:var(--text-secondary);font-size:var(--text-xs);text-transform:uppercase;display:block;margin-bottom:var(--spacing-xs)}.detail-grid{grid-template-columns:1fr}}.admin-settings-page{padding:0}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);flex-wrap:wrap;gap:var(--spacing-lg)}.settings-title{font-size:var(--text-3xl);font-weight:700;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.settings-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.spin{animation:spin 1s linear infinite}.settings-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);overflow-x:auto;padding-bottom:var(--spacing-sm);scrollbar-width:thin}.settings-tabs::-webkit-scrollbar{height:6px}.settings-tabs::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:var(--radius-full)}.settings-tabs::-webkit-scrollbar-thumb{background:#d946ef;border-radius:var(--radius-full)}.tab-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);border:2px solid var(--border-light);border-radius:var(--radius-lg);background:#fff;color:var(--text-secondary);font-weight:600;font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.tab-button:hover{background:var(--bg-tertiary);border-color:#d946ef}.tab-button.active{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-color:#d946ef;box-shadow:0 4px 15px #d946ef33}.tab-button svg{font-size:1.25rem}.settings-content{background:#fff;border-radius:var(--radius-2xl);padding:var(--spacing-2xl);box-shadow:0 4px 15px #0000000d}.settings-section{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.section-header-settings{padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-light)}.section-header-settings h2{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.section-header-settings h2 svg{color:#d946ef}.section-header-settings p{color:var(--text-secondary);font-size:var(--text-base);margin:0}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}.setting-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.setting-group.full{grid-column:1 / -1}.setting-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.setting-input{width:100%;padding:var(--spacing-md);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);background:#fff;transition:all var(--transition-fast)}.setting-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon svg{position:absolute;left:var(--spacing-md);color:var(--text-secondary);font-size:1.125rem}.input-with-icon .setting-input{padding-left:calc(var(--spacing-md) * 3)}.setting-help{font-size:var(--text-xs);color:var(--text-secondary);font-style:italic}.hours-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.hour-item{background:linear-gradient(135deg,#fef7ff,#fff);padding:var(--spacing-lg);border-radius:var(--radius-xl);border:2px solid var(--border-light);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);transition:all var(--transition-fast)}.hour-item:hover{border-color:#d946ef;box-shadow:0 4px 15px #d946ef1a}.hour-header{min-width:150px}.day-name{font-weight:600;font-size:var(--text-base)}.hour-inputs{display:flex;align-items:center;gap:var(--spacing-md)}.time-input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.time-input-group label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:600}.time-input{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.time-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.time-separator{font-size:var(--text-xl);color:var(--text-secondary);font-weight:700;margin-top:20px}.closed-label{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:#fee2e2;color:#ef4444;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600}.checkbox-label-settings{display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;padding:var(--spacing-md);border-radius:var(--radius-lg);transition:background var(--transition-fast)}.checkbox-label-settings:hover{background:var(--bg-tertiary)}.checkbox-label-settings input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#d946ef}.checkbox-label-settings span{font-size:var(--text-base);color:var(--text-primary);font-weight:500;display:flex;align-items:center;gap:var(--spacing-sm)}.checkbox-label-settings span svg{font-size:1.25rem;color:#d946ef}.notification-groups{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.notification-group{background:linear-gradient(135deg,#fef7ff,#fff);padding:var(--spacing-xl);border-radius:var(--radius-xl);border:2px solid var(--border-light)}.notification-group h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.notification-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.payment-methods{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.system-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-xl)}.system-card{background:linear-gradient(135deg,#fef7ff,#fff);padding:var(--spacing-xl);border-radius:var(--radius-2xl);border:2px solid var(--border-light);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);text-align:center;transition:all var(--transition-base)}.system-card:hover{border-color:#d946ef;box-shadow:0 8px 25px #d946ef26;transform:translateY(-4px)}.system-card-icon{width:80px;height:80px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff}.system-card-icon.backup{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 8px 25px #3b82f64d}.system-card-icon.restore{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 8px 25px #f59e0b4d}.system-card-icon.info{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 25px #10b9814d}.system-card-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md);width:100%}.system-card-content h3{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin:0}.system-card-content p{color:var(--text-secondary);font-size:var(--text-sm);margin:0;line-height:1.6}.system-card-content .btn{width:100%}.system-info{display:flex;flex-direction:column;gap:var(--spacing-md);text-align:left;margin-top:var(--spacing-md)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:#fff;border-radius:var(--radius-md);font-size:var(--text-sm)}.info-row span{color:var(--text-secondary)}.info-row strong{color:var(--text-primary);font-weight:600}@media(max-width:1200px){.settings-grid{grid-template-columns:1fr}.setting-group.full{grid-column:1}}@media(max-width:768px){.settings-header{flex-direction:column;align-items:flex-start}.settings-header .btn{width:100%}.settings-tabs{display:grid;grid-template-columns:repeat(2,1fr)}.tab-button{justify-content:center}.settings-content{padding:var(--spacing-xl)}.hour-item{flex-direction:column;align-items:flex-start}.hour-inputs{width:100%}.time-input-group{flex:1}.system-actions{grid-template-columns:1fr}}@media(max-width:480px){.settings-tabs{grid-template-columns:1fr}.settings-title{font-size:var(--text-2xl)}.section-header-settings h2{font-size:var(--text-xl)}.hour-inputs{flex-direction:column;gap:var(--spacing-md)}.time-separator{display:none}.system-card-icon{width:60px;height:60px;font-size:2rem}}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary:disabled:hover{transform:none}.admin-services-page{padding:2rem;max-width:1400px;margin:0 auto}.admin-services-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.services-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.services-title{font-size:1.875rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.services-subtitle{color:#64748b;margin:0}.services-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card.stat-success .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}.stat-card.stat-warning .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card.stat-info .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-value{font-size:2rem;font-weight:700;color:#1e293b;line-height:1;margin-bottom:.25rem}.services-filters{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.search-box input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.filter-select:focus{outline:none;border-color:#d946ef}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.service-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:all .3s;position:relative}.service-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001f}.service-card.inactive{opacity:.6}.service-badge{position:absolute;top:1rem;right:1rem;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.25rem;z-index:2}.service-badge.popular{background:#fef3c7;color:#d97706}.service-badge.featured{background:#ddd6fe;color:#7c3aed}.service-image{width:100%;height:200px;overflow:hidden;background:#f1f5f9}.service-image img{width:100%;height:100%;object-fit:cover}.service-image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8;font-size:3rem}.service-image-placeholder span{font-size:.875rem;margin-top:.5rem}.service-body{padding:1.5rem}.service-category{font-size:.75rem;font-weight:600;color:#d946ef;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.service-name{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 .5rem;line-height:1.3}.service-description{color:#64748b;font-size:.875rem;line-height:1.5;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.service-info{display:flex;gap:1.5rem;padding:1rem 0;border-top:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;margin-bottom:1rem}.info-item{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.875rem}.info-item svg{color:#d946ef}.info-item.price{color:#10b981;font-weight:600;font-size:1rem}.service-benefits{font-size:.875rem}.service-benefits strong{color:#1e293b;display:block;margin-bottom:.5rem}.service-benefits ul{list-style:none;padding:0;margin:0}.service-benefits li{color:#64748b;padding-left:1.25rem;position:relative;margin-bottom:.25rem}.service-benefits li:before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700}.service-actions{display:flex;gap:.5rem;padding:1rem 1.5rem;background:#f8fafc;border-top:1px solid #f1f5f9}.btn-icon{flex:1;padding:.75rem;border:none;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:1.125rem}.btn-icon.success:hover{background:#a7f3d0}.btn-icon.warning{background:#fef3c7;color:#92400e}.btn-icon.warning:hover{background:#fde68a}.btn-icon.primary:hover{background:#c4b5fd}.btn-icon.danger:hover{background:#fecaca}.inactive-overlay{position:absolute;inset:0;background:#0f172ab3;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-weight:600;gap:.5rem;font-size:1.125rem}.inactive-overlay svg{font-size:2rem}.service-form{padding:1rem 0}.form-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.beneficio-input-group{display:flex;gap:.5rem;margin-bottom:.75rem}.beneficio-input-group .form-input{flex:1}.btn-remove-beneficio{width:40px;height:40px;border:2px solid #fee2e2;background:#fff;color:#ef4444;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-remove-beneficio:hover{background:#fee2e2}.checkboxes-row{display:flex;gap:2rem;padding:1rem;background:#f8fafc;border-radius:8px}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem;color:#475569}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a}@media(max-width:768px){.admin-services-page{padding:1rem}.services-header{flex-direction:column;gap:1rem}.services-stats{grid-template-columns:repeat(2,1fr)}.services-grid,.form-grid{grid-template-columns:1fr}.checkboxes-row{flex-direction:column;gap:1rem}}.module-selector-page{min-height:100vh;background:linear-gradient(135deg,#fdf2f8,#fae8ff,#f3e8ff);position:relative;overflow:hidden}.module-selector-bg{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.animated-gradient{position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 15% 20%,rgba(236,72,153,.08) 0%,transparent 40%),radial-gradient(circle at 85% 30%,rgba(168,85,247,.08) 0%,transparent 40%),radial-gradient(circle at 50% 80%,rgba(217,70,239,.06) 0%,transparent 40%),radial-gradient(circle at 30% 60%,rgba(251,207,232,.1) 0%,transparent 30%);animation:gradientFloat 15s ease-in-out infinite}@keyframes gradientFloat{0%,to{opacity:1;transform:scale(1) rotate(0)}50%{opacity:.85;transform:scale(1.05) rotate(2deg)}}.floating-shapes{position:absolute;top:0;left:0;width:100%;height:100%}.shape{position:absolute;border-radius:50%;opacity:.4;filter:blur(40px);animation:floatBubble 25s ease-in-out infinite}.shape-1{width:350px;height:350px;top:5%;left:8%;background:radial-gradient(circle,rgba(236,72,153,.2) 0%,rgba(251,207,232,.1) 70%,transparent 100%);animation-delay:0s}.shape-2{width:280px;height:280px;top:50%;right:5%;background:radial-gradient(circle,rgba(168,85,247,.18) 0%,rgba(221,214,254,.08) 70%,transparent 100%);animation-delay:8s}.shape-3{width:320px;height:320px;bottom:10%;left:25%;background:radial-gradient(circle,rgba(217,70,239,.15) 0%,rgba(250,232,255,.1) 70%,transparent 100%);animation-delay:4s}.shape-4{width:400px;height:400px;top:35%;right:20%;background:radial-gradient(circle,rgba(244,114,182,.12) 0%,rgba(252,231,243,.08) 70%,transparent 100%);animation-delay:12s}@keyframes floatBubble{0%,to{transform:translate(0) scale(1);opacity:.4}25%{transform:translate(30px,-30px) scale(1.05);opacity:.5}50%{transform:translate(-20px,20px) scale(.95);opacity:.35}75%{transform:translate(25px,25px) scale(1.02);opacity:.45}}.module-selector-bg:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(2px 2px at 20% 30%,rgba(236,72,153,.3),transparent),radial-gradient(2px 2px at 60% 70%,rgba(168,85,247,.3),transparent),radial-gradient(3px 3px at 50% 50%,rgba(217,70,239,.25),transparent),radial-gradient(2px 2px at 80% 20%,rgba(244,114,182,.3),transparent),radial-gradient(2px 2px at 40% 80%,rgba(251,207,232,.4),transparent);background-size:200% 200%;animation:sparkle 20s linear infinite}@keyframes sparkle{0%{background-position:0% 0%}to{background-position:100% 100%}}.module-selector-header{position:relative;z-index:10;padding:1.5rem 2rem;background:#ffffffb3;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(236,72,153,.1);box-shadow:0 4px 30px #ec48990d}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo-section{display:flex;align-items:center;gap:1rem}.logo-icon{width:55px;height:55px;border-radius:16px;background:linear-gradient(135deg,#ec4899,#d946ef,#a855f7);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 40px #ec489940,0 0 0 4px #ec48991a;position:relative;animation:logoFloat 3s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.logo-icon:after{content:"";position:absolute;inset:-8px;border-radius:20px;background:linear-gradient(135deg,#ec489933,#a855f733);filter:blur(15px);z-index:-1;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}.logo-text{font-size:1.75rem;font-weight:900;background:linear-gradient(135deg,#ec4899,#d946ef);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.company-name{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;line-height:1}.company-tagline{font-size:.875rem;color:#94a3b8;margin:.25rem 0 0;font-weight:500}.btn-logout{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#ef44441a,#dc26261a);border:1.5px solid rgba(239,68,68,.2);border-radius:12px;color:#dc2626;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #ef44441a}.btn-logout:hover{background:linear-gradient(135deg,#ef444426,#dc262626);border-color:#ef444466;transform:translateY(-2px);box-shadow:0 8px 25px #ef444433}.module-selector-content{position:relative;z-index:5;padding:4rem 2rem;min-height:calc(100vh - 100px);display:flex;align-items:center;justify-content:center}.selector-container{max-width:1200px;width:100%;margin:0 auto}.selector-intro{text-align:center;margin-bottom:4rem;animation:fadeInUp .8s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.selector-title{font-size:3.5rem;font-weight:900;color:#1e293b;margin:0 0 1rem;line-height:1.1;letter-spacing:-.02em}.title-accent{display:block;background:linear-gradient(135deg,#ec4899,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.title-accent:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:120px;height:4px;background:linear-gradient(90deg,transparent,#ec4899,#d946ef,#a855f7,transparent);border-radius:2px}.selector-subtitle{font-size:1.25rem;color:#64748b;margin:0;font-weight:500}.modules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(480px,1fr));gap:2.5rem;margin-bottom:3rem;perspective:1000px}.module-card{position:relative;background:#ffffffd9;-webkit-backdrop-filter:blur(30px) saturate(150%);backdrop-filter:blur(30px) saturate(150%);border:2px solid rgba(236,72,153,.1);border-radius:32px;padding:3rem;cursor:pointer;transition:all .5s cubic-bezier(.23,1,.32,1);overflow:hidden;animation:fadeInUp .8s ease;animation-fill-mode:both;transform-style:preserve-3d;box-shadow:0 10px 40px #ec489914,0 0 0 1px #ffffff80 inset}.module-card:nth-child(1){animation-delay:.1s}.module-card:nth-child(2){animation-delay:.25s}.module-card.available:hover{transform:translateY(-12px) rotateX(2deg) scale(1.02);border-color:#ec48994d;box-shadow:0 25px 60px #ec489926,0 0 0 1px #ec48991a inset,0 0 80px #ec48991a}.module-card.unavailable{opacity:.65;cursor:not-allowed;filter:grayscale(.3)}.unavailable-badge{position:absolute;top:2rem;right:2rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#fbbf2426,#f59e0b26);border:1.5px solid rgba(251,191,36,.3);border-radius:30px;color:#d97706;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 15px #fbbf2433}.module-card-inner{position:relative;z-index:2}.module-icon-wrapper{position:relative;margin-bottom:2rem;perspective:500px}.module-icon{width:90px;height:90px;border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:2.75rem;color:#fff;box-shadow:0 15px 40px #00000026,0 0 0 4px #fff3;transition:all .5s cubic-bezier(.23,1,.32,1);position:relative;z-index:2;transform-style:preserve-3d}.module-card.available:hover .module-icon{transform:translateY(-10px) translateZ(20px) rotateY(-8deg);box-shadow:0 25px 60px #0003,0 0 0 6px #ffffff4d}.module-icon-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120px;height:120px;border-radius:50%;opacity:0;filter:blur(30px);transition:opacity .5s}.module-card.available:hover .module-icon-glow{opacity:.6;animation:iconGlowPulse 2s ease-in-out infinite}@keyframes iconGlowPulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.1)}}.module-content{margin-bottom:2rem}.module-title{font-size:2rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 1rem;letter-spacing:-.01em}.module-description{font-size:1rem;color:#64748b;line-height:1.7;margin:0 0 1.75rem;font-weight:500}.module-features{display:flex;flex-direction:column;gap:.875rem}.feature-item{display:flex;align-items:center;gap:.875rem;color:#475569;font-size:.9375rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);padding:.5rem;border-radius:8px}.module-card.available:hover .feature-item{color:#1e293b;transform:translate(8px);background:#ec489908}.feature-item svg{background:linear-gradient(135deg,#ec4899,#d946ef);color:#fff;padding:6px;border-radius:8px;font-size:1rem;box-shadow:0 4px 12px #ec489933}.module-action{margin-top:2rem}.btn-module-enter{width:100%;padding:1.125rem 1.75rem;background:linear-gradient(135deg,#ec4899,#d946ef,#a855f7);border:none;border-radius:16px;color:#fff;font-weight:700;font-size:1.0625rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.875rem;transition:all .4s cubic-bezier(.23,1,.32,1);box-shadow:0 10px 35px #ec489940,0 0 0 1px #fff3 inset;position:relative;overflow:hidden}.btn-module-enter:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s}.btn-module-enter:hover:before{left:100%}.btn-module-enter:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 18px 50px #ec489959,0 0 0 1px #ffffff4d inset}.btn-module-enter svg{transition:transform .4s cubic-bezier(.23,1,.32,1);font-size:1.25rem}.btn-module-enter:hover svg{transform:translate(6px)}.coming-soon-text{text-align:center;padding:1.125rem;background:linear-gradient(135deg,#fbbf2414,#f59e0b14);border:2px dashed rgba(251,191,36,.3);border-radius:16px;color:#d97706;font-weight:700;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.module-card-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:var(--module-gradient);opacity:0;filter:blur(100px);transition:opacity .5s;pointer-events:none;border-radius:50%}.module-card.available:hover .module-card-glow{opacity:.12;animation:glowRotate 8s linear infinite}@keyframes glowRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.selector-footer{text-align:center;padding:2rem;background:#fff9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;border:1px solid rgba(236,72,153,.1);animation:fadeInUp .8s ease .5s;animation-fill-mode:both;box-shadow:0 8px 30px #ec48990f}.footer-text{color:#64748b;font-size:.9375rem;font-weight:500;margin:0}@media(max-width:1024px){.modules-grid{grid-template-columns:1fr}}@media(max-width:768px){.module-selector-content{padding:2rem 1rem}.selector-title{font-size:2.25rem}.selector-subtitle{font-size:1rem}.module-card{padding:2rem}.header-content{flex-direction:column;gap:1rem}.btn-logout span{display:none}.logo-icon{width:48px;height:48px}}.snacks-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.welcome-banner{background:linear-gradient(135deg,#fef3c7,#fed7aa);border-radius:24px;padding:2.5rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 10px 40px #f59e0b26;border:2px solid #fbbf24;position:relative;overflow:hidden}.banner-content{display:flex;align-items:center;gap:2rem;z-index:1}.banner-icon{font-size:4rem;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.banner-text h1{font-size:2rem;font-weight:900;color:#78350f;margin:0 0 .5rem}.banner-text p{font-size:1.125rem;color:#92400e;margin:0}.banner-illustration{position:relative}.floating-emoji{font-size:8rem;opacity:.2;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(5deg)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;display:flex;gap:1.5rem;transition:all .3s;border:2px solid transparent}.stat-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px #0000001f}.stat-card.primary{border-color:#f59e0b33}.stat-card.primary:hover{border-color:#f59e0b}.stat-card.danger:hover{border-color:#ef4444}.stat-card.info:hover{border-color:#3b82f6}.stat-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;flex-shrink:0}.stat-card.primary .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card.danger .stat-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-label{font-size:.875rem;color:#64748b;font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2.25rem;font-weight:900;color:#1e293b;line-height:1;margin-bottom:.5rem}.stat-footer{font-size:.8125rem;color:#94a3b8;font-weight:600}.secondary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.secondary-stat{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;display:flex;align-items:center;gap:1rem}.secondary-icon{font-size:2.5rem}.secondary-label{font-size:.875rem;color:#64748b;font-weight:600;margin-bottom:.25rem}.secondary-value{font-size:1.5rem;font-weight:900;color:#f59e0b}.wallet-banner{background:linear-gradient(135deg,#ddd6fe,#c4b5fd);border-radius:20px;padding:2rem;margin-bottom:2rem;display:flex;align-items:center;gap:2rem;box-shadow:0 8px 30px #8b5cf633;border:2px solid #a78bfa}.wallet-icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff}.wallet-info{flex:1}.wallet-label{font-size:.875rem;color:#5b21b6;font-weight:700;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.wallet-value{font-size:2rem;font-weight:900;color:#5b21b6}.wallet-btn{padding:.875rem 2rem;background:#fff;color:#5b21b6;border:none;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #0000001a}.wallet-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.quick-actions{margin-bottom:2rem}.section-title{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.action-card{background:#fff;border-radius:16px;padding:1.75rem;display:flex;align-items:center;gap:1.25rem;box-shadow:0 4px 20px #0000000f;border:2px solid transparent;cursor:pointer;transition:all .3s;text-align:left;width:100%}.action-card:hover{transform:translate(8px);box-shadow:0 8px 30px #0000001f;border-color:#fbbf24}.action-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.action-icon.primary{background:linear-gradient(135deg,#f59e0b,#d97706)}.action-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.action-icon.warning{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.action-icon.info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.action-content{flex:1}.action-title{font-size:1.125rem;font-weight:700;color:#1e293b;margin-bottom:.25rem}.action-description{font-size:.875rem;color:#64748b}.action-arrow{font-size:1.5rem;color:#f59e0b;font-weight:700}.low-stock-section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f}.view-all-btn{padding:.625rem 1.25rem;background:#fef3c7;color:#78350f;border:2px solid #fbbf24;border-radius:12px;font-weight:700;font-size:.875rem;cursor:pointer;transition:all .2s}.view-all-btn:hover{background:#fde68a;transform:translateY(-2px)}.low-stock-list{display:flex;flex-direction:column;gap:1rem}.low-stock-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fef2f2;border-radius:12px;border:2px solid #fecaca}.product-icon{font-size:2rem}.product-info{flex:1}.product-name{font-weight:700;color:#1e293b;margin-bottom:.25rem}.product-stock{font-size:.875rem;color:#64748b}.product-stock strong{color:#dc2626;font-weight:900}.stock-badge{padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.75rem;text-transform:uppercase}.stock-badge.danger{background:#fee2e2;color:#991b1b}.empty-low-stock{text-align:center;padding:3rem 2rem}.success-icon{font-size:4rem;margin-bottom:1rem}.empty-low-stock p{color:#10b981;font-weight:600;font-size:1.125rem;margin:0}.spinner-large{width:48px;height:48px;border:4px solid #f1f5f9;border-top-color:#f59e0b;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:1024px){.stats-grid,.actions-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.snacks-dashboard{padding:1rem}.welcome-banner{flex-direction:column;text-align:center}.banner-content{flex-direction:column}.stats-grid,.actions-grid{grid-template-columns:1fr}.wallet-banner{flex-direction:column;text-align:center}}.alerts-widget{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;margin-bottom:2rem}.alerts-widget-minimized{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:2px solid #fbbf24;border-radius:16px;padding:1.25rem 1.75rem;margin-bottom:2rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 20px #fbbf2433}.alerts-widget-minimized:hover{transform:translateY(-4px);box-shadow:0 12px 30px #fbbf244d;border-color:#f59e0b}.minimized-content{display:flex;align-items:center;gap:1.5rem}.minimized-icon{width:56px;height:56px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.75rem;flex-shrink:0;animation:pulse-warning 2s infinite}@keyframes pulse-warning{0%,to{box-shadow:0 0 #f59e0bb3}50%{box-shadow:0 0 0 10px #f59e0b00}}.minimized-info{flex:1}.minimized-info h3{font-size:1.25rem;font-weight:800;color:#92400e;margin:0 0 .25rem}.minimized-info p{font-size:.9375rem;font-weight:600;color:#b45309;margin:0}.minimized-badges{display:flex;gap:.5rem;flex-wrap:wrap}.alert-mini-badge{min-width:32px;height:32px;padding:0 .625rem;border-radius:8px;color:#fff;font-weight:900;font-size:.875rem;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000026}.expand-button{width:40px;height:40px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#f59e0b;font-size:1.25rem;transition:all .3s;box-shadow:0 2px 8px #0000001a}.alerts-widget-minimized:hover .expand-button{transform:translate(4px);background:#f59e0b;color:#fff}.alerts-loading,.alerts-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:#64748b}.alerts-loading .spinner{width:40px;height:40px;border:4px solid #f1f5f9;border-top-color:#f59e0b;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.alerts-empty svg{font-size:4rem;color:#10b981;margin-bottom:1rem}.alerts-empty h3{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.alerts-empty p{margin:0;color:#64748b}.alerts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.alerts-header h2{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0;display:flex;align-items:center;gap:.75rem}.alerts-header h2 svg{color:#f59e0b;font-size:1.75rem}.alerts-header-actions{display:flex;align-items:center;gap:.75rem}.alerts-count{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-weight:900;font-size:1.125rem;padding:.5rem 1rem;border-radius:12px;min-width:40px;text-align:center}.btn-minimize{width:36px;height:36px;border:2px solid #e2e8f0;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b}.btn-minimize:hover{background:#f1f5f9;border-color:#f59e0b;color:#f59e0b;transform:scale(1.1)}.alerts-list{display:flex;flex-direction:column;gap:1rem}.alert-item{border-radius:16px;border:2px solid #f1f5f9;border-left-width:4px;overflow:hidden;transition:all .3s}.alert-item:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.alert-item.error{background:linear-gradient(135deg,#fef2f2,#fee2e2)}.alert-item.warning{background:linear-gradient(135deg,#fffbeb,#fef3c7)}.alert-item.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.alert-item.info{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.alert-header{display:flex;align-items:center;gap:1rem;padding:1.5rem;cursor:pointer}.alert-icon{width:48px;height:48px;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;box-shadow:0 4px 12px #0000001a}.alert-content{flex:1}.alert-content h3{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 .375rem}.alert-content p{font-size:.9375rem;color:#64748b;margin:0;font-weight:600}.alert-actions{display:flex;align-items:center;gap:.75rem}.alert-badge{background:#fff;color:#1e293b;font-weight:900;font-size:1rem;padding:.375rem .75rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.btn-collapse{width:36px;height:36px;border:none;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #0000001a}.btn-collapse:hover{background:#f8fafc;transform:scale(1.1)}.btn-collapse svg{transition:transform .3s}.btn-collapse svg.rotated{transform:rotate(90deg)}.alert-details{padding:0 1.5rem 1.5rem;animation:slideDown .3s ease-out}.stock-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.stock-item{background:#fff;padding:1rem;border-radius:12px;display:flex;justify-content:space-between;align-items:center;border:2px solid #f1f5f9}.stock-info{display:flex;flex-direction:column;gap:.25rem}.stock-code{font-family:Courier New,monospace;font-weight:700;color:#f59e0b;font-size:.875rem}.stock-name{font-weight:600;color:#1e293b}.stock-values{display:flex;gap:1rem;font-size:.875rem;font-weight:600}.stock-current{color:#64748b}.stock-min{color:#f59e0b}.stock-missing{color:#ef4444}.expired-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.expired-item{background:#fff;padding:1rem;border-radius:12px;display:flex;justify-content:space-between;align-items:center;border:2px solid #f1f5f9}.expired-info{display:flex;flex-direction:column;gap:.25rem}.expired-code{font-family:Courier New,monospace;font-weight:700;color:#ef4444;font-size:.875rem}.expired-name{font-weight:600;color:#1e293b}.expired-date{display:flex;align-items:center;gap:.5rem;font-weight:700;color:#f59e0b}.expired-date.critical,.expired-date span.critical{color:#ef4444;animation:pulse 1.5s infinite}.cash-info{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #f1f5f9;margin-bottom:1rem}.cash-item p{margin:.5rem 0;color:#475569;font-size:.9375rem}.cash-item p strong{color:#1e293b;font-weight:700}.sales-goal{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #f1f5f9;margin-bottom:1rem}.sales-progress{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.progress-bar{flex:1;height:12px;background:#f1f5f9;border-radius:6px;overflow:hidden}.progress-fill{height:100%;border-radius:6px;transition:width .5s ease-out}.progress-label{font-weight:900;font-size:1.125rem;color:#1e293b;min-width:60px;text-align:right}.sales-values{display:flex;justify-content:space-between;font-size:.9375rem;font-weight:600;color:#64748b}.sales-missing{color:#ef4444}.btn-action{width:100%;padding:.875rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;font-weight:700;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s}.btn-action:hover{background:#f8fafc;border-color:#3b82f6;color:#3b82f6;transform:translateY(-2px)}@media(max-width:768px){.alerts-widget{padding:1.5rem}.alert-header{padding:1rem}.alert-details{padding:0 1rem 1rem}.stock-item,.expired-item{flex-direction:column;align-items:flex-start;gap:.75rem}.stock-values,.sales-values{flex-direction:column;gap:.5rem}}.admin-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.dashboard-title{font-size:2rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.dashboard-subtitle{color:#64748b;margin:0}.dashboard-actions{display:flex;gap:1rem}.period-select{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:16px;padding:1.5rem;display:flex;gap:1rem;box-shadow:0 1px 3px #0000001a}.stat-icon{width:60px;height:60px;border-radius:12px;background:linear-gradient(135deg,#d946ef,#a855f7);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem}.stat-icon.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-label{font-size:.875rem;color:#64748b;margin-bottom:.25rem}.stat-value{font-size:2rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.stat-change{display:inline-flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:600}.stat-change.positive{color:#10b981}.stat-change.neutral{color:#64748b}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.quick-stat-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #0000001a}.dashboard-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border-radius:12px}.activity-icon{width:40px;height:40px;border-radius:8px;background:#ddd6fe;color:#7c3aed;display:flex;align-items:center;justify-content:center}.activity-content{flex:1}.activity-user{font-weight:600;color:#1e293b}.activity-details{font-size:.875rem;color:#64748b}.activity-time{font-size:.75rem;color:#94a3b8}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.quick-action-card{padding:1.5rem;background:#f8fafc;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-decoration:none;color:#1e293b;font-weight:600;transition:all .2s}.quick-action-card:hover{background:#d946ef;color:#fff;transform:translateY(-2px)}.quick-action-card svg{font-size:2rem}@media(max-width:768px){.admin-dashboard{padding:1rem}.dashboard-header{flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:1fr}}.snacks-products-page{padding:2rem;max-width:1600px;margin:0 auto}.snacks-products-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.products-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.products-title{font-size:2rem;font-weight:700;color:#1e293b;margin:0 0 .5rem;display:flex;align-items:center;gap:.75rem}.products-title svg{color:#f59e0b}.products-subtitle{color:#64748b;margin:0}.products-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #0000001a;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.stat-icon{width:60px;height:60px;border-radius:12px;background:linear-gradient(135deg,#f59e0b,#d97706);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem}.stat-card.warning .stat-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-card.info .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-value{font-size:1.875rem;font-weight:700;color:#1e293b;line-height:1;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:#64748b}.products-filters{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.search-box{position:relative;margin-bottom:1rem}.search-box input{width:100%;padding:.75rem 1rem .75rem 3rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9375rem;transition:all .2s}.filters-row{display:flex;gap:1rem;flex-wrap:wrap}.filter-select{flex:1;min-width:200px;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9375rem;background:#fff;cursor:pointer;transition:all .2s}.filter-select:focus{outline:none;border-color:#f59e0b}.results-info{color:#64748b;margin-bottom:1rem;font-size:.875rem}.results-info strong{color:#1e293b;font-weight:600}.products-table-container{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000014}.products-table{width:100%;border-collapse:collapse}.products-table thead{background:linear-gradient(135deg,#fef3c7,#fed7aa)}.products-table th{padding:1rem 1.5rem;text-align:left;font-weight:700;color:#92400e;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #fbbf24}.products-table td{padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;font-size:.9375rem}.products-table tbody tr{transition:background .2s}.products-table tbody tr:hover{background:#fef3c7}.products-table tbody tr.inactive-row{opacity:.5}.product-code{font-family:Courier New,monospace;font-weight:600;color:#f59e0b;background:#fef3c7;padding:.25rem .5rem;border-radius:4px;font-size:.8125rem}.product-info{display:flex;align-items:center;gap:1rem}.product-thumb{width:50px;height:50px;object-fit:cover;border-radius:8px}.product-thumb-placeholder{width:50px;height:50px;background:#f1f5f9;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:1.5rem}.product-name{font-weight:600;color:#1e293b;margin-bottom:.125rem}.product-description{font-size:.8125rem;color:#64748b;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:20px;font-size:.8125rem;font-weight:600}.text-muted{color:#64748b}.text-price{color:#10b981;font-weight:700;font-size:1rem}.stock-cell{display:flex;align-items:center;gap:.5rem}.stock-badge{padding:.375rem .75rem;border-radius:20px;font-weight:700;font-size:.875rem}.stock-badge.normal{background:#d1fae5;color:#065f46}.stock-badge.low{background:#fee2e2;color:#991b1b;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.btn-replenish{width:32px;height:32px;border:none;background:#fbbf24;color:#fff;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-replenish:hover{background:#f59e0b;transform:scale(1.1)}.status-toggle{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:none;border-radius:20px;font-weight:600;font-size:.8125rem;cursor:pointer;transition:all .2s}.status-toggle.active{background:#d1fae5;color:#065f46}.status-toggle.active:hover{background:#a7f3d0}.status-toggle.inactive{background:#fee2e2;color:#991b1b}.status-toggle.inactive:hover{background:#fecaca}.action-buttons{display:flex;gap:.5rem}.btn-icon{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:1rem}.btn-icon.primary{background:#ddd6fe;color:#5b21b6}.btn-icon.primary:hover{background:#c4b5fd;transform:scale(1.1)}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#1e293b;margin:0 0 .5rem}.empty-state p{color:#64748b;margin:0}.product-form{padding:1rem 0}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.form-group{display:flex;flex-direction:column}.form-group.form-full{grid-column:1 / -1}.form-label{font-weight:600;color:#475569;margin-bottom:.5rem;font-size:.875rem}.form-label .text-muted{font-weight:400;font-size:.8125rem}.form-input{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9375rem;transition:all .2s}.form-error{color:#ef4444;font-size:.75rem;margin-top:.25rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem;color:#475569;padding:1rem;background:#f8fafc;border-radius:8px}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.replenish-form{padding:1rem 0}.product-replenish-info{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fef3c7;border-radius:12px;margin-bottom:1.5rem}.product-replenish-info svg{font-size:2rem;color:#f59e0b}.replenish-product-name{font-weight:700;color:#1e293b;margin-bottom:.25rem}.replenish-current-stock{font-size:.875rem;color:#64748b}.new-stock-preview{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#d1fae5;color:#065f46;border-radius:12px;margin-top:1.5rem;font-weight:600}.new-stock-preview svg{font-size:1.25rem}@media(max-width:1024px){.products-table-container{overflow-x:auto}.products-table{min-width:900px}}@media(max-width:768px){.snacks-products-page{padding:1rem}.products-header{flex-direction:column;gap:1rem}.products-stats{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}}.snacks-layout{display:flex;min-height:100vh;background:#f8fafc}.snacks-sidebar{width:280px;background:linear-gradient(180deg,#fff,#fef3c7);border-right:2px solid rgba(245,158,11,.1);display:flex;flex-direction:column;position:fixed;left:0;top:0;height:100vh;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000;box-shadow:4px 0 20px #0000000d}.snacks-sidebar.closed{width:80px}.sidebar-header{padding:1.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid rgba(245,158,11,.1)}.sidebar-logo{display:flex;align-items:center;gap:1rem}.logo-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#f59e0b,#d97706);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;box-shadow:0 8px 20px #f59e0b4d;flex-shrink:0}.logo-text h2{font-size:1.5rem;font-weight:800;margin:0;background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-text span{font-size:.75rem;color:#92400e;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.sidebar-toggle{width:36px;height:36px;border:none;background:#f59e0b1a;color:#f59e0b;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all .2s}.sidebar-toggle:hover{background:#f59e0b33;transform:scale(1.05)}.snacks-sidebar.closed .sidebar-toggle{margin:0 auto}.sidebar-nav{flex:1;padding:1rem;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;margin-bottom:.5rem;border-radius:12px;text-decoration:none;color:#64748b;font-weight:600;font-size:.9375rem;transition:all .2s;position:relative}.nav-item:hover:not(.disabled){background:#f59e0b14;color:#f59e0b;transform:translate(4px)}.nav-item.active{background:linear-gradient(135deg,#fef3c7,#fed7aa);color:#f59e0b;box-shadow:0 4px 12px #f59e0b26}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:60%;background:linear-gradient(180deg,#f59e0b,#d97706);border-radius:0 4px 4px 0}.nav-item.disabled{opacity:.5;cursor:not-allowed}.nav-icon{font-size:1.25rem;flex-shrink:0}.nav-label{white-space:nowrap}.soon-badge{margin-left:auto;font-size:.625rem;padding:.25rem .5rem;background:#fbbf24;color:#fff;border-radius:8px;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.snacks-sidebar.closed .nav-item{justify-content:center;padding:.875rem}.snacks-sidebar.closed .nav-label,.snacks-sidebar.closed .soon-badge{display:none}.sidebar-footer{padding:1rem;border-top:2px solid rgba(245,158,11,.1);display:flex;flex-direction:column;gap:.5rem}.footer-button{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border:none;background:#f59e0b0d;color:#64748b;border-radius:12px;font-weight:600;font-size:.9375rem;cursor:pointer;text-decoration:none;transition:all .2s}.footer-button:hover{background:#f59e0b1a;color:#f59e0b}.footer-button.logout{background:#ef44440d;color:#ef4444}.footer-button.logout:hover{background:#ef44441a}.footer-button svg{font-size:1.25rem;flex-shrink:0}.snacks-sidebar.closed .footer-button{justify-content:center;padding:.875rem}.snacks-sidebar.closed .footer-button span{display:none}.snacks-main{flex:1;margin-left:280px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);min-height:100vh;background:#f8fafc}.snacks-main.sidebar-closed{margin-left:80px}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#f59e0b0d;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#f59e0b4d;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#f59e0b80}@media(max-width:1024px){.snacks-sidebar{transform:translate(-100%)}.snacks-sidebar.open{transform:translate(0)}.snacks-main,.snacks-main.sidebar-open{margin-left:0}}@media(max-width:768px){.snacks-sidebar{width:100%;max-width:280px}}.pos-page{min-height:100vh;background:#f8fafc;display:flex;flex-direction:column}.pos-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.pos-status-bar{background:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000f;border-bottom:2px solid #fbbf24}.status-info{display:flex;align-items:center;gap:.75rem;font-size:1.125rem;font-weight:700;color:#1e293b}.status-info svg{font-size:1.5rem;color:#f59e0b}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:700}.status-badge.danger{background:#fee2e2;color:#991b1b}.pos-container{display:grid;grid-template-columns:1fr 420px;gap:0;flex:1}.products-section{padding:2rem;overflow-y:auto}.pos-filters{display:flex;gap:1rem;margin-bottom:2rem}.search-box{flex:1;position:relative}.search-box svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1.25rem}.search-box input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.category-filter{padding:.875rem 1.25rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s;min-width:200px}.category-filter:focus{outline:none;border-color:#f59e0b}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.25rem}.product-card{background:#fff;border-radius:16px;padding:1rem;cursor:pointer;transition:all .3s;border:2px solid transparent;position:relative}.product-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0000001f;border-color:#fbbf24}.product-image{width:100%;height:120px;object-fit:cover;border-radius:12px;margin-bottom:.75rem}.product-image-placeholder{width:100%;height:120px;background:#f1f5f9;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:3rem;margin-bottom:.75rem}.product-info{margin-bottom:.75rem}.product-name{font-size:.9375rem;font-weight:700;color:#1e293b;margin:0 0 .5rem;line-height:1.3;min-height:2.6em}.product-details{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem}.product-price{font-weight:800;color:#f59e0b;font-size:1rem}.product-stock{color:#64748b}.add-btn{width:100%;padding:.625rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:8px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.add-btn:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:scale(1.02)}.empty-products{text-align:center;padding:4rem 2rem;color:#64748b}.empty-products svg{font-size:4rem;margin-bottom:1rem;opacity:.5}.cart-section{background:#fff;border-left:2px solid #fbbf24;display:flex;flex-direction:column;height:calc(100vh - 72px)}.cart-header{padding:1.5rem;border-bottom:2px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.cart-header h2{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0;display:flex;align-items:center;gap:.75rem}.clear-cart-btn{padding:.5rem 1rem;background:#fee2e2;color:#dc2626;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s}.clear-cart-btn:hover{background:#fecaca}.cart-items{flex:1;overflow-y:auto;padding:1rem}.empty-cart{text-align:center;padding:4rem 2rem;color:#94a3b8}.empty-cart svg{font-size:4rem;margin-bottom:1rem;opacity:.3}.cart-item{background:#f8fafc;border-radius:12px;padding:1rem;margin-bottom:.75rem}.item-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.item-name{font-weight:700;color:#1e293b;font-size:.9375rem}.item-price{color:#64748b;font-size:.875rem}.item-actions{display:flex;align-items:center;gap:.75rem}.quantity-controls{display:flex;align-items:center;gap:.5rem;background:#fff;border-radius:8px;padding:.25rem}.qty-btn{width:32px;height:32px;border:none;background:#f59e0b;color:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.qty-btn:hover{background:#d97706}.qty-input{width:50px;text-align:center;border:none;font-weight:700;color:#1e293b;font-size:1rem}.item-subtotal{font-weight:800;color:#f59e0b;font-size:1rem;min-width:80px;text-align:right}.remove-btn{width:36px;height:36px;border:none;background:#fee2e2;color:#dc2626;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-btn:hover{background:#fecaca}.cart-summary{padding:1.5rem;border-top:2px solid #f1f5f9;background:#fef3c7}.summary-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.summary-row.total{font-size:1.5rem;font-weight:900;color:#78350f;margin-bottom:1.5rem}.total-amount{color:#f59e0b}.checkout-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s;box-shadow:0 8px 20px #f59e0b4d}.checkout-btn:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 12px 30px #f59e0b66}.checkout-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:24px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d}.modal-header{padding:2rem;border-bottom:2px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0}.modal-close{width:40px;height:40px;border:none;background:#f1f5f9;color:#64748b;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:all .2s}.modal-close:hover{background:#e2e8f0;color:#1e293b}.modal-body{padding:2rem}.payment-summary{background:#fef3c7;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.summary-item{display:flex;justify-content:space-between;margin-bottom:.75rem;color:#78350f}.summary-item.total{font-size:1.5rem;font-weight:900;margin-bottom:0;padding-top:.75rem;border-top:2px solid #fbbf24}.total-price{color:#f59e0b}.form-group label{display:block;font-weight:700;color:#475569;margin-bottom:.75rem}.payment-methods{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.payment-method-btn{padding:1rem;border:2px solid #e2e8f0;background:#fff;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-weight:700;color:#64748b;transition:all .2s}.payment-method-btn svg{font-size:2rem}.payment-method-btn:hover{border-color:#fbbf24}.payment-method-btn.active{border-color:#f59e0b;background:#fef3c7;color:#f59e0b}.modal-footer{padding:1.5rem 2rem;border-top:2px solid #f1f5f9;display:flex;gap:1rem}.btn{flex:1;padding:.875rem 1.5rem;border:none;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.btn-secondary{background:#f1f5f9;color:#64748b}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-primary{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.spinner-large{width:48px;height:48px;border:4px solid #fbbf24;border-top-color:#f59e0b;border-radius:50%;animation:spin .8s linear infinite}.cart-items::-webkit-scrollbar{width:8px}.cart-items::-webkit-scrollbar-track{background:#f1f5f9}.cart-items::-webkit-scrollbar-thumb{background:#fbbf24;border-radius:4px}@media(max-width:1024px){.pos-container{grid-template-columns:1fr}.cart-section{height:auto;min-height:400px}}@media(max-width:768px){.products-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.pos-filters{flex-direction:column}.modal-content{width:95%}}.payment-modal{max-width:480px}.payment-method-btn{display:flex;flex-direction:column;align-items:center;gap:.75rem}.payment-method-btn span{font-weight:700;font-size:.9375rem}.slide-down{animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.cash-page{padding:2rem;max-width:1600px;margin:0 auto}.cash-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.cash-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.header-actions{display:flex;gap:1rem}.current-cash-card{background:linear-gradient(135deg,#fef3c7,#fed7aa);border-radius:24px;padding:2rem;margin-bottom:2rem;box-shadow:0 10px 40px #f59e0b26;border:2px solid #fbbf24}.cash-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.cash-user{display:flex;align-items:center;gap:.5rem;color:#78350f;font-weight:700;font-size:1.125rem}.cash-user svg{font-size:1.5rem}.cash-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.cash-stat{background:#fff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 15px #00000014}.cash-stat .stat-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.cash-stat .stat-icon.primary{background:linear-gradient(135deg,#f59e0b,#d97706)}.cash-stat .stat-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.cash-stat .stat-icon.warning{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.cash-stat .stat-icon.info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-info{flex:1}.stat-label{font-size:.875rem;color:#64748b;font-weight:600;margin-bottom:.375rem}.stat-value{font-size:1.5rem;font-weight:900;color:#1e293b;line-height:1}.payment-methods-summary{background:#fff;border-radius:16px;padding:1.5rem;display:flex;justify-content:space-around;margin-bottom:1.5rem;box-shadow:0 4px 15px #00000014}.payment-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.payment-label{font-size:1rem;color:#64748b;font-weight:600}.payment-value{font-size:1.5rem;font-weight:900;color:#f59e0b}.cash-time-info{display:flex;align-items:center;gap:.5rem;color:#78350f;font-size:.9375rem;font-weight:600}.cash-time-info svg{font-size:1.25rem}.day-summary-card{background:#fff;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f}.section-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem}.section-title svg{color:#f59e0b}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.summary-item{text-align:center;padding:1.5rem;background:#f8fafc;border-radius:12px}.summary-label{font-size:.875rem;color:#64748b;font-weight:600;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:2rem;font-weight:900;color:#1e293b}.summary-value.primary{color:#f59e0b}.summary-value.success{color:#10b981}.summary-value.info{color:#3b82f6}.summary-value.highlight{color:#d946ef}.cash-history-section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f}.history-table{width:100%;border-collapse:collapse;min-width:900px}.history-table thead{background:linear-gradient(135deg,#fef3c7,#fed7aa)}.history-table th{padding:1rem 1.5rem;text-align:left;font-weight:700;color:#78350f;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #fbbf24}.history-table tbody tr:hover{background:#fef3c7}.user-cell{display:flex;align-items:center;gap:.5rem}.difference{font-weight:800;font-size:1rem}.difference.positive{color:#10b981}.difference.negative{color:#ef4444}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:20px;font-size:.8125rem;font-weight:700}.status-badge.success{background:#d1fae5;color:#065f46}.status-badge.secondary{background:#f1f5f9;color:#475569}.btn-icon{width:36px;height:36px;border:none;background:#ddd6fe;color:#5b21b6;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s}.btn-icon:hover{background:#c4b5fd;transform:scale(1.1)}.empty-state svg{font-size:4rem;margin-bottom:1rem;opacity:.5}.cash-form{padding:1rem 0}.close-summary{background:#fef3c7;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem}.close-summary h3{font-size:1.125rem;font-weight:700;color:#78350f;margin:0 0 1rem}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #fde68a;color:#92400e}.summary-row:last-child{border-bottom:none}.summary-row.total{font-size:1.25rem;font-weight:900;padding-top:1rem;border-top:2px solid #fbbf24}.summary-row strong.highlight{color:#f59e0b}.difference-preview{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f1f5f9;border-radius:12px;margin-bottom:1.5rem;font-size:1.125rem;font-weight:700}.difference-preview strong.positive{color:#10b981}.difference-preview strong.negative{color:#ef4444}.cash-detail{padding:1rem 0}.detail-header{margin-bottom:2rem}.detail-info{display:flex;flex-wrap:wrap;gap:1.5rem}.info-item{display:flex;align-items:center;gap:.5rem;color:#64748b;font-weight:600}.info-item svg{color:#f59e0b}.detail-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-col{text-align:center;padding:1.5rem;background:#f8fafc;border-radius:12px}.summary-col h4{font-size:.875rem;color:#64748b;font-weight:600;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.summary-col .summary-value{font-size:1.75rem;font-weight:900;color:#1e293b}.summary-col .summary-value.positive{color:#10b981}.summary-col .summary-value.negative{color:#ef4444}.detail-sales h4{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 1rem}.sales-list{max-height:400px;overflow-y:auto}.sale-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8fafc;border-radius:12px;margin-bottom:.75rem}.sale-info{display:flex;flex-direction:column;gap:.25rem}.sale-number{font-weight:700;color:#1e293b;font-family:Courier New,monospace}.sale-time{font-size:.8125rem;color:#64748b}.sale-details{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.sale-method{font-size:.75rem;padding:.25rem .625rem;background:#fef3c7;color:#92400e;border-radius:8px;font-weight:700}.sale-total{font-size:1.125rem;font-weight:900;color:#f59e0b}@media(max-width:1024px){.cash-stats-grid,.summary-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.cash-page{padding:1rem}.cash-header{flex-direction:column;gap:1rem}.cash-stats-grid{grid-template-columns:1fr}.payment-methods-summary{flex-direction:column;gap:1rem}.summary-grid,.detail-summary{grid-template-columns:1fr}}.reports-page{padding:2rem;max-width:1600px;margin:0 auto}.reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.reports-header{margin-bottom:2rem}.reports-filters{background:#fff;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.date-input-group input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.btn-quick-date{padding:.625rem 1.25rem;background:#fef3c7;color:#78350f;border:2px solid #fbbf24;border-radius:12px;font-weight:700;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-quick-date:hover{background:#fde68a;border-color:#f59e0b;transform:translateY(-2px)}.reports-tabs{display:flex;gap:1rem;margin-bottom:2rem;overflow-x:auto;padding-bottom:.5rem}.tab-btn{padding:1rem 2rem;background:#fff;color:#64748b;border:2px solid #e2e8f0;border-radius:16px;font-weight:700;font-size:.9375rem;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:all .3s;white-space:nowrap}.tab-btn svg{font-size:1.25rem}.tab-btn:hover{background:#fef3c7;border-color:#fbbf24;color:#78350f}.tab-btn.active{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-color:#f59e0b;box-shadow:0 8px 20px #f59e0b4d}.reports-content{min-height:400px}.report-section{animation:fadeIn .3s ease}.summary-card.primary{border-color:#f59e0b33}.summary-card .card-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#fff;flex-shrink:0}.summary-card.primary .card-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.summary-card.success .card-icon{background:linear-gradient(135deg,#10b981,#059669)}.summary-card.warning .card-icon{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.summary-card.info .card-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.card-value{font-size:2rem;font-weight:900;color:#1e293b;line-height:1}.report-table-container{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.table-header h3{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0}.btn-export{padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:.875rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;box-shadow:0 4px 12px #10b9814d}.btn-export:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 8px 20px #10b98166}.report-table{width:100%;border-collapse:collapse;overflow:hidden}.report-table thead{background:linear-gradient(135deg,#fef3c7,#fed7aa)}.report-table th{padding:1rem 1.5rem;text-align:left;font-weight:700;color:#78350f;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #fbbf24}.report-table td{padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9;color:#475569;font-size:.9375rem}.report-table tbody tr{transition:background .2s}.report-table tbody tr:hover{background:#fef3c7}.report-table tbody tr.row-warning{background:#fef2f2}.report-table tbody tr.row-warning:hover{background:#fee2e2}.text-center{text-align:center;font-weight:600}.text-right{text-align:right;font-weight:600}.highlight{color:#f59e0b;font-weight:900}.code{font-family:Courier New,monospace;font-weight:700;color:#f59e0b;background:#fef3c7;padding:.25rem .5rem;border-radius:6px;font-size:.8125rem}.product-name{font-weight:700;color:#1e293b}.rank{text-align:center;font-size:1.5rem}.medal{font-size:2rem;animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.rank-number{font-weight:900;color:#94a3b8}.stock-level{padding:.375rem .875rem;border-radius:20px;font-weight:700;font-size:.75rem;text-transform:uppercase}.stock-level.bajo{background:#fee2e2;color:#991b1b}.stock-level.medio{background:#fef3c7;color:#92400e}.stock-level.alto{background:#d1fae5;color:#065f46}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.category-card{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;transition:all .3s;border:2px solid transparent}.category-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0000001a;border-color:#fbbf24}.category-icon{font-size:4rem;text-align:center;margin-bottom:1.5rem}.category-info h3{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0 0 1.5rem;text-align:center}.category-stats{display:flex;flex-direction:column;gap:1rem}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:12px}.stat-label{color:#64748b;font-weight:600;font-size:.875rem}.stat-value{font-weight:900;color:#1e293b;font-size:1.125rem}.stat-value.highlight{color:#f59e0b}.empty-report{text-align:center;padding:4rem 2rem;color:#94a3b8}.empty-report svg{font-size:5rem;margin-bottom:1rem;opacity:.3}.empty-report p{font-size:1.125rem;margin:0}@media(max-width:1024px){.summary-cards{grid-template-columns:repeat(2,1fr)}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media(max-width:768px){.reports-page{padding:1rem}.reports-filters{flex-direction:column;align-items:stretch}.date-range-picker{flex-direction:column}.summary-cards{grid-template-columns:1fr}.reports-tabs{flex-wrap:nowrap}.report-table-container{overflow-x:auto}.report-table{min-width:800px}.categories-grid{grid-template-columns:1fr}.table-header{flex-direction:column;gap:1rem;align-items:stretch}}.wallet-page{padding:2rem;max-width:1400px;margin:0 auto}.wallet-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.wallet-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.page-title svg{color:#8b5cf6}.balance-card{background:linear-gradient(135deg,#ddd6fe,#c4b5fd);border-radius:24px;padding:2.5rem;margin-bottom:2rem;box-shadow:0 10px 40px #8b5cf633;border:2px solid #a78bfa}.balance-main{display:flex;align-items:center;gap:2rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid rgba(139,92,246,.3)}.balance-icon{width:80px;height:80px;border-radius:20px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.5rem;box-shadow:0 10px 30px #8b5cf666;flex-shrink:0}.balance-info{flex:1}.balance-label{font-size:1rem;color:#5b21b6;font-weight:700;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:1px}.balance-amount{font-size:3.5rem;font-weight:900;color:#5b21b6;line-height:1;margin-bottom:.75rem}.balance-updated{display:flex;align-items:center;gap:.5rem;color:#6d28d9;font-size:.875rem;font-weight:600}.balance-updated svg{font-size:1rem}.balance-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.balance-stat{background:#fff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 15px #00000014}.balance-stat .stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.balance-stat.success .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}.balance-stat.danger .stat-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.balance-stat.info .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-label{font-size:.8125rem;color:#64748b;font-weight:600;margin-bottom:.375rem}.stat-value{font-size:1.5rem;font-weight:900;color:#1e293b}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:#fff;border-radius:16px;padding:1.75rem;display:flex;align-items:center;gap:1.25rem;box-shadow:0 4px 20px #0000000f;transition:all .3s;border:2px solid transparent}.summary-card .card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.summary-card.primary .card-icon{background:linear-gradient(135deg,#10b981,#059669)}.summary-card.danger .card-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.summary-card.warning .card-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.summary-card.success .card-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.card-content{flex:1}.card-label{font-size:.875rem;color:#64748b;font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.card-value{font-size:1.75rem;font-weight:900;color:#1e293b;line-height:1}.wallet-filters{background:#fff;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.date-range-picker{display:flex;gap:1.5rem;flex-wrap:wrap}.date-input-group{display:flex;flex-direction:column;gap:.5rem}.date-input-group label{display:flex;align-items:center;gap:.5rem;font-weight:700;color:#475569;font-size:.875rem}.date-input-group input{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:.9375rem;transition:all .2s;min-width:180px}.date-input-group input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.quick-dates{display:flex;gap:.75rem;flex-wrap:wrap}.btn-quick-date{padding:.625rem 1.25rem;background:#ede9fe;color:#5b21b6;border:2px solid #c4b5fd;border-radius:12px;font-weight:700;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-quick-date:hover{background:#ddd6fe;border-color:#8b5cf6;transform:translateY(-2px)}.movements-section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f}.section-header{margin-bottom:1.5rem}.section-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0;display:flex;align-items:center;gap:.75rem}.section-title svg{color:#8b5cf6}.movements-list{display:flex;flex-direction:column;gap:1rem}.movement-card{background:#f8fafc;border-radius:16px;padding:1.5rem;display:flex;gap:1.25rem;border:2px solid #e2e8f0;transition:all .3s}.movement-card:hover{border-color:#c4b5fd;box-shadow:0 8px 20px #8b5cf61a;transform:translate(4px)}.movement-icon-wrapper{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.movement-ingreso .movement-icon-wrapper{background:#d1fae5;color:#059669}.movement-retiro .movement-icon-wrapper{background:#fee2e2;color:#dc2626}.movement-ajuste .movement-icon-wrapper{background:#fef3c7;color:#d97706}.movement-content{flex:1}.movement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.movement-concept{font-weight:700;color:#1e293b;font-size:1.125rem}.movement-amount{font-size:1.5rem;font-weight:900}.movement-amount.positive{color:#10b981}.movement-amount.negative{color:#ef4444}.movement-details{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:.75rem}.detail-item{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.875rem;font-weight:600}.detail-item svg{font-size:1rem;color:#8b5cf6}.movement-observations{background:#ede9fe;color:#5b21b6;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:.75rem}.movement-balance{display:flex;align-items:center;gap:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0;font-size:.875rem;color:#64748b}.movement-balance .arrow{color:#8b5cf6;font-weight:900}.movement-balance .new-balance{font-weight:700;color:#8b5cf6}.withdraw-form{padding:1rem 0}.withdraw-info{background:#ede9fe;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.info-row{display:flex;justify-content:space-between;align-items:center;font-size:1.125rem}.info-row strong.highlight{font-size:1.5rem;font-weight:900;color:#8b5cf6}.form-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.form-hint{display:block;margin-top:.5rem;font-size:.8125rem;color:#64748b;font-style:italic}.new-balance-preview{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#f8fafc;border-radius:12px;font-size:1.125rem;margin-bottom:1.5rem}.new-balance-preview strong.positive{font-size:1.5rem;font-weight:900;color:#10b981}.new-balance-preview strong.negative{font-size:1.5rem;font-weight:900;color:#ef4444}.btn-primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 8px 20px #8b5cf64d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-2px);box-shadow:0 12px 30px #8b5cf666}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 8px 20px #ef44444d}.empty-state svg{font-size:5rem;margin-bottom:1rem;opacity:.3}@media(max-width:1024px){.balance-stats,.summary-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.wallet-page{padding:1rem}.wallet-header{flex-direction:column;gap:1rem}.balance-main{flex-direction:column;text-align:center}.balance-amount{font-size:2.5rem}.balance-stats,.summary-cards{grid-template-columns:1fr}.wallet-filters{flex-direction:column;align-items:stretch}.date-range-picker{flex-direction:column}.movement-header{flex-direction:column;align-items:flex-start;gap:.5rem}.movement-details{flex-direction:column;gap:.5rem}}.categories-page{padding:2rem;max-width:1400px;margin:0 auto}.categories-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.categories-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.page-title svg{color:#f59e0b}.categories-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 20px #0000000f;transition:all .3s}.stat-icon.primary{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-value{font-size:2rem;font-weight:900;color:#1e293b;line-height:1;margin-bottom:.25rem}.drag-drop-info{background:linear-gradient(135deg,#fef3c7,#fed7aa);border:2px solid #fbbf24;border-radius:12px;padding:1rem 1.5rem;display:flex;align-items:center;gap:.75rem;color:#78350f;font-weight:700;margin-bottom:2rem}.drag-drop-info svg{font-size:1.5rem;color:#f59e0b}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.category-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;transition:all .3s;border:2px solid transparent;position:relative;cursor:grab}.category-card:active{cursor:grabbing}.category-card.dragging{opacity:.5;transform:scale(.95)}.category-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px #0000001f;border-color:#fbbf24}.category-card.inactive{opacity:.6}.category-drag-handle{position:absolute;top:1rem;right:1rem;color:#94a3b8;font-size:1.25rem;cursor:grab}.category-drag-handle:active{cursor:grabbing}.category-color-bar{position:absolute;top:0;left:0;right:0;height:4px;border-radius:20px 20px 0 0}.category-icon{font-size:4rem;text-align:center;margin:1rem 0 1.5rem}.category-info{margin-bottom:1.5rem}.category-name{font-size:1.25rem;font-weight:800;color:#1e293b;margin:0 0 .75rem;text-align:center}.category-meta{display:flex;justify-content:center;align-items:center;gap:1rem;flex-wrap:wrap}.category-products{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.875rem;font-weight:600}.category-products svg{font-size:1rem}.category-color-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;font-family:Courier New,monospace}.category-actions{display:flex;justify-content:center;gap:.75rem;padding-top:1.5rem;border-top:1px solid #f1f5f9}.category-form{padding:1rem 0}.form-input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.icon-picker{position:relative}.icon-preview{width:100%;padding:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:all .2s}.icon-preview:hover{background:#f1f5f9;border-color:#f59e0b}.icon-large{font-size:3rem}.icon-label{font-size:.875rem;font-weight:600;color:#64748b}.emoji-picker{position:absolute;top:100%;left:0;right:0;margin-top:.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1rem;box-shadow:0 10px 40px #00000026;z-index:10;max-height:300px;overflow-y:auto}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:.5rem}.emoji-option{width:40px;height:40px;border:2px solid transparent;background:#f8fafc;border-radius:8px;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.emoji-option:hover{background:#fef3c7;border-color:#fbbf24;transform:scale(1.1)}.emoji-option.selected{background:#fed7aa;border-color:#f59e0b;transform:scale(1.15)}.color-picker{display:flex;flex-direction:column;gap:1rem}.color-input{width:100%;height:60px;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer}.color-presets{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}.color-preset{width:100%;height:40px;border:3px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s}.color-preset:hover{transform:scale(1.1);box-shadow:0 4px 12px #0003}.color-preset.selected{border-color:#1e293b;transform:scale(1.15);box-shadow:0 6px 16px #0000004d}.form-preview{background:#f8fafc;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.preview-label{font-size:.875rem;font-weight:700;color:#64748b;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.preview-card{background:#fff;border-radius:12px;padding:1.5rem;border:2px solid;text-align:center}.preview-icon{font-size:3rem;margin-bottom:.75rem}.preview-name{font-size:1.125rem;font-weight:700;color:#1e293b}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid #f1f5f9}.btn-primary{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 8px 20px #f59e0b4d}.btn-primary:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 12px 30px #f59e0b66}@media(max-width:768px){.categories-page{padding:1rem}.categories-header{flex-direction:column;gap:1rem}.categories-grid,.form-row{grid-template-columns:1fr}.emoji-grid{grid-template-columns:repeat(6,1fr)}}.suppliers-page{padding:2rem;max-width:1600px;margin:0 auto}.suppliers-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.suppliers-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.suppliers-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.suppliers-filters{display:flex;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.search-box{flex:1;min-width:300px;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:1rem;color:#64748b;font-size:1.25rem}.search-box input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .2s}.search-box input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select svg{position:absolute;left:1rem;color:#64748b;font-size:1.25rem;pointer-events:none}.filter-select select{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E") no-repeat right 1rem center}.suppliers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.supplier-card{background:#fff;border-radius:20px;padding:1.75rem;box-shadow:0 4px 20px #0000000f;transition:all .3s;border:2px solid transparent;display:flex;flex-direction:column;gap:1.25rem}.supplier-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px #0000001f;border-color:#dbeafe}.supplier-card.inactive{opacity:.6}.supplier-header{display:flex;justify-content:space-between;align-items:center}.supplier-code{font-family:Courier New,monospace;font-weight:700;color:#3b82f6;background:#dbeafe;padding:.375rem .875rem;border-radius:8px;font-size:.875rem}.supplier-type{padding:.375rem .875rem;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase}.supplier-type.distribuidor{background:#fef3c7;color:#78350f}.supplier-type.fabricante{background:#dbeafe;color:#1e3a8a}.supplier-type.mayorista{background:#d1fae5;color:#065f46}.supplier-type.minorista{background:#fce7f3;color:#831843}.supplier-type.otro{background:#f1f5f9;color:#475569}.supplier-main{border-bottom:1px solid #f1f5f9;padding-bottom:1rem}.supplier-name{font-size:1.25rem;font-weight:800;color:#1e293b;margin:0 0 .5rem;line-height:1.3}.supplier-commercial{font-size:.9375rem;color:#64748b;margin:0 0 .375rem;font-style:italic}.supplier-ruc{font-size:.875rem;color:#94a3b8;margin:0;font-weight:600}.supplier-info{display:flex;flex-direction:column;gap:.75rem}.info-item{display:flex;align-items:center;gap:.625rem;color:#475569;font-size:.875rem}.info-item svg{color:#3b82f6;font-size:1rem;flex-shrink:0}.supplier-stats{background:#f8fafc;border-radius:12px;padding:1rem;display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.stat-item{display:flex;flex-direction:column;gap:.25rem;text-align:center}.stat-item .stat-label{font-size:.75rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-item .stat-value{font-size:1rem;font-weight:900;color:#3b82f6}.supplier-actions{display:flex;justify-content:center;gap:.75rem;padding-top:1rem;border-top:1px solid #f1f5f9}.status-toggle{padding:.625rem 1rem;border:2px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.875rem;transition:all .2s}.status-toggle.active{background:#d1fae5;color:#065f46;border-color:#10b981}.status-toggle.inactive{background:#fee2e2;color:#991b1b;border-color:#ef4444}.status-toggle:hover{transform:scale(1.05)}.btn-icon{width:40px;height:40px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s}.btn-icon.primary{background:#dbeafe;color:#1e40af}.btn-icon.primary:hover{background:#bfdbfe;transform:scale(1.1)}.btn-icon.danger:hover:not(:disabled){background:#fecaca;transform:scale(1.1)}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:20px;box-shadow:0 4px 20px #0000000f}.empty-icon{font-size:5rem;margin-bottom:1rem}.empty-state h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.empty-state p{color:#64748b;margin:0 0 2rem}.supplier-form{padding:1rem 0;max-height:70vh;overflow-y:auto}.form-section:last-of-type{border-bottom:none}.history-content{padding:1rem 0}.history-table-container{overflow-x:auto}.history-table{width:100%;border-collapse:collapse;min-width:600px}.history-table thead{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.history-table th{padding:1rem 1.5rem;text-align:left;font-weight:700;color:#1e40af;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #3b82f6}.history-table td{padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9;color:#475569;font-size:.9375rem}.history-table tbody tr{transition:background .2s}.history-table tbody tr:hover{background:#f8fafc}.code{font-family:Courier New,monospace;font-weight:700;color:#3b82f6;background:#dbeafe;padding:.25rem .5rem;border-radius:6px;font-size:.8125rem}.status-badge{padding:.375rem .875rem;border-radius:20px;font-weight:700;font-size:.75rem;text-transform:uppercase}.status-badge.pendiente{background:#fef3c7;color:#78350f}.status-badge.recibida{background:#d1fae5;color:#065f46}.status-badge.parcial{background:#dbeafe;color:#1e3a8a}.status-badge.cancelada{background:#fee2e2;color:#991b1b}.empty-history{text-align:center;padding:3rem 2rem;color:#94a3b8}.empty-history svg{font-size:4rem;margin-bottom:1rem;opacity:.3}.empty-history p{font-size:1.125rem;margin:0}@media(max-width:1024px){.suppliers-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.form-row{grid-template-columns:1fr}}@media(max-width:768px){.suppliers-page{padding:1rem}.suppliers-header{flex-direction:column;gap:1rem}.suppliers-filters{flex-direction:column}.search-box,.filter-select{min-width:100%}.suppliers-grid,.supplier-stats{grid-template-columns:1fr}.supplier-actions{flex-wrap:wrap}}.purchases-page{padding:2rem;max-width:1600px;margin:0 auto}.purchases-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.purchases-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.page-title svg{color:#3b82f6}.purchases-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:16px;padding:1.75rem;display:flex;align-items:center;gap:1.25rem;box-shadow:0 4px 20px #0000000f;transition:all .3s;border:2px solid transparent}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0000001a}.stat-card.primary{border-color:#3b82f633}.stat-card.primary:hover{border-color:#3b82f6}.stat-card.success:hover{border-color:#10b981}.stat-card.warning:hover{border-color:#f59e0b}.stat-card.info:hover{border-color:#8b5cf6}.stat-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.stat-card.primary .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-card.success .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}.stat-card.warning .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card.info .stat-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-content{flex:1}.stat-value{font-size:2rem;font-weight:900;color:#1e293b;line-height:1;margin-bottom:.375rem}.stat-label{font-size:.875rem;color:#64748b;font-weight:600}.purchases-filters{display:flex;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}.date-input input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select select{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E") no-repeat right 1rem center}.filter-select select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.purchases-table-container{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;overflow-x:auto}.purchases-table{width:100%;border-collapse:collapse;min-width:800px}.purchases-table thead{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.purchases-table th{padding:1rem 1.5rem;text-align:left;font-weight:700;color:#1e40af;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #3b82f6}.purchases-table td{padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9;color:#475569;font-size:.9375rem}.purchases-table tbody tr{transition:background .2s}.purchases-table tbody tr:hover{background:#f8fafc}.code{font-family:Courier New,monospace;font-weight:700;color:#3b82f6;background:#dbeafe;padding:.375rem .75rem;border-radius:8px;font-size:.8125rem;display:inline-block}.supplier-cell{display:flex;flex-direction:column;gap:.25rem}.supplier-cell strong{color:#1e293b}.supplier-cell small{color:#94a3b8;font-size:.8125rem}.comprobante-num{color:#64748b;font-size:.875rem}.amount{font-weight:700;color:#1e293b;text-align:right}.status-badge{padding:.375rem .875rem;border-radius:20px;font-weight:700;font-size:.75rem;text-transform:uppercase;display:inline-block}.btn-icon.info{background:#ede9fe;color:#5b21b6}.btn-icon.info:hover{background:#ddd6fe;transform:scale(1.1)}.btn-icon.success{background:#d1fae5;color:#065f46}.btn-icon.success:hover{background:#a7f3d0;transform:scale(1.1)}.purchase-form{padding:1rem 0;max-height:70vh;overflow-y:auto}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #f1f5f9}.form-section:last-of-type{border-bottom:none;padding-bottom:0}.section-title:before{content:"";width:4px;height:1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:2px}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:600;color:#475569}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.add-item-form{background:#f8fafc;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.item-form-row{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:1rem;align-items:end}.form-error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#fee2e2;border:2px solid #fecaca;border-radius:12px;color:#991b1b;font-weight:600;margin-bottom:1rem}.form-error-banner svg{font-size:1.5rem}.items-list{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:1rem;max-height:300px;overflow-y:auto;margin-bottom:1.5rem}.item-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:1rem;align-items:center;padding:1rem;background:#f8fafc;border-radius:8px;margin-bottom:.75rem}.item-row:last-child{margin-bottom:0}.item-info{display:flex;flex-direction:column;gap:.25rem}.item-code{font-family:Courier New,monospace;font-weight:700;color:#3b82f6;font-size:.8125rem}.item-name{font-weight:600;color:#1e293b}.item-qty,.item-price,.item-subtotal{font-weight:700;color:#475569;text-align:right}.btn-remove{width:32px;height:32px;border:none;background:#fee2e2;color:#991b1b;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-remove:hover{background:#fecaca;transform:scale(1.1)}.empty-items{text-align:center;padding:3rem 2rem;color:#94a3b8}.empty-items svg{font-size:3rem;margin-bottom:1rem;opacity:.3}.empty-items p{margin:0}.totals-summary{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:12px;padding:1.5rem}.total-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;color:#1e40af;font-size:1rem}.total-row.grand-total{border-top:2px solid #3b82f6;margin-top:.75rem;padding-top:1rem;font-size:1.25rem}.total-row strong{font-weight:900;font-size:1.125rem}.total-row.grand-total strong{font-size:1.5rem;color:#1e40af}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 8px 20px #3b82f64d}.btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 12px 30px #3b82f666}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 8px 20px #10b9814d}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 12px 30px #10b98166}.purchase-detail{padding:1rem 0}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #f1f5f9}.detail-info h2{font-size:1.75rem;font-weight:900;color:#1e293b;margin:0 0 .75rem}.detail-amount{text-align:right}.amount-label{font-size:.875rem;color:#64748b;font-weight:600;margin-bottom:.5rem}.amount-value{font-size:2.5rem;font-weight:900;color:#3b82f6}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.detail-item{display:flex;flex-direction:column;gap:.5rem}.detail-item label{font-size:.875rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.detail-item span{font-size:1rem;font-weight:600;color:#1e293b}.detail-items{margin-bottom:2rem}.detail-items h3{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 1rem}.detail-table{width:100%;border-collapse:collapse}.detail-table th{padding:.875rem 1rem;background:#f8fafc;text-align:left;font-weight:700;color:#475569;font-size:.875rem;border-bottom:2px solid #e2e8f0}.detail-table td{padding:.875rem 1rem;border-bottom:1px solid #f1f5f9;color:#475569}.text-center{text-align:center}.text-right{text-align:right;font-weight:700}.detail-totals{background:#f8fafc;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.detail-notes{background:#fef3c7;border:2px solid #fbbf24;border-radius:12px;padding:1.5rem}.detail-notes h3{font-size:1rem;font-weight:700;color:#78350f;margin:0 0 .75rem}.detail-notes p{color:#92400e;margin:0;line-height:1.6}.spinner-large{width:48px;height:48px;border:4px solid #f1f5f9;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:1024px){.form-row,.detail-grid,.item-form-row{grid-template-columns:1fr}}@media(max-width:768px){.purchases-page{padding:1rem}.purchases-header{flex-direction:column;gap:1rem}.purchases-filters,.date-range{flex-direction:column;align-items:stretch}.filter-select{min-width:100%}.item-row{grid-template-columns:1fr;gap:.5rem}.detail-header{flex-direction:column;gap:1rem}.detail-amount{text-align:left}}.shrinkage-page{padding:2rem;max-width:1600px;margin:0 auto}.shrinkage-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.shrinkage-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.page-title{font-size:2rem;font-weight:800;color:#1e293b;margin:0 0 .5rem;display:flex;align-items:center;gap:.75rem}.page-title svg{color:#ef4444}.page-subtitle{color:#64748b;margin:0}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:.875rem 1.5rem;border:none;border-radius:12px;font-weight:700;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .3s;box-shadow:0 8px 20px #ef44444d}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 12px 30px #ef444466}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:#fff;border-radius:16px;padding:1.75rem;display:flex;align-items:center;gap:1.25rem;box-shadow:0 4px 20px #0000000f;transition:all .3s;border-left:4px solid}.summary-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0000001a}.summary-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;background:currentColor;opacity:.1}.summary-icon svg{position:relative;z-index:1;opacity:10}.summary-content{flex:1}.summary-label{font-size:.875rem;color:#64748b;font-weight:600;margin-bottom:.5rem}.summary-value{font-size:1.75rem;font-weight:900;color:#1e293b;margin-bottom:.25rem}.summary-cost{font-size:1rem;font-weight:700;color:#ef4444}.shrinkage-filters{display:flex;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}.date-range{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.date-input{position:relative;display:flex;align-items:center}.date-input svg{position:absolute;left:1rem;color:#64748b;font-size:1.125rem;pointer-events:none}.date-input input{padding:.875rem 1rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-weight:600;transition:all .2s}.date-input input:focus{outline:none;border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.filter-select{position:relative;display:flex;align-items:center;min-width:200px}.filter-select svg{position:absolute;left:1rem;color:#64748b;font-size:1.125rem;pointer-events:none}.filter-select select{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E") no-repeat right 1rem center}.filter-select select:focus{outline:none;border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.btn-export{background:#f8fafc;color:#475569;padding:.875rem 1.5rem;border:2px solid #e2e8f0;border-radius:12px;font-weight:700;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .3s;margin-left:auto}.btn-export:hover{background:#fff;border-color:#10b981;color:#10b981}.shrinkage-table-container{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;overflow-x:auto}.shrinkage-table{width:100%;border-collapse:collapse;min-width:900px}.shrinkage-table thead{background:linear-gradient(135deg,#fee2e2,#fecaca)}.shrinkage-table th{padding:1rem 1.5rem;text-align:left;font-weight:700;color:#991b1b;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #ef4444}.shrinkage-table td{padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9;color:#475569;font-size:.9375rem}.shrinkage-table tbody tr{transition:background .2s}.shrinkage-table tbody tr:hover{background:#fef2f2}.code{font-family:Courier New,monospace;font-weight:700;color:#ef4444;background:#fee2e2;padding:.375rem .75rem;border-radius:8px;font-size:.8125rem;display:inline-block}.type-badge{padding:.375rem .875rem;border-radius:20px;font-weight:700;font-size:.75rem;text-transform:uppercase;display:inline-block}.product-cell{display:flex;flex-direction:column;gap:.25rem}.product-cell strong{color:#1e293b}.product-cell small{color:#94a3b8;font-size:.8125rem}.quantity{font-weight:700;font-size:1.125rem}.amount{font-weight:700;color:#ef4444;text-align:right}.motivo-cell{display:flex;flex-direction:column;gap:.25rem;max-width:300px}.motivo-cell small{color:#64748b;font-size:.8125rem}.table-actions{display:flex;gap:.5rem;justify-content:center}.btn-icon{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s}.btn-icon.danger{background:#fee2e2;color:#991b1b}.btn-icon.danger:hover{background:#fecaca;transform:scale(1.1)}.empty-state{text-align:center;padding:4rem 2rem;color:#94a3b8}.empty-state svg{font-size:4rem;margin-bottom:1rem;opacity:.3}.empty-state p{font-size:1.125rem;margin:0}.shrinkage-form{padding:1rem 0;max-height:70vh;overflow-y:auto}.form-section{margin-bottom:2rem}.section-title{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 1.25rem;display:flex;align-items:center;gap:.5rem}.section-title:before{content:"";width:4px;height:1.5rem;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:2px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-weight:700;color:#475569;margin-bottom:.75rem;font-size:.9375rem}.form-input{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .2s}.form-input:focus{outline:none;border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input.error{border-color:#ef4444}.form-error{display:block;margin-top:.5rem;color:#ef4444;font-size:.875rem;font-weight:600}.form-hint{display:block;margin-top:.5rem;font-size:.875rem;color:#64748b}.adjustment-preview{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:2px solid #fecaca;border-radius:12px;padding:1.5rem;margin-top:1.5rem}.adjustment-preview h4{font-size:1rem;font-weight:700;color:#991b1b;margin:0 0 1rem}.preview-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #fecaca}.preview-row:last-child{border-bottom:none}.preview-row.highlight{background:#fff;padding:.75rem 1rem;margin:.5rem -.5rem;border-radius:8px;border:2px solid #ef4444}.preview-row span{color:#64748b;font-weight:600}.preview-row strong{color:#1e293b;font-weight:700}.preview-row strong.positive{color:#10b981}.preview-row strong.negative{color:#ef4444}.preview-row strong.error{color:#ef4444;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid #f1f5f9;margin-top:2rem}.btn{padding:.875rem 1.5rem;border:none;border-radius:12px;font-weight:700;font-size:.9375rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s}.btn-outline{background:#f1f5f9;color:#64748b}.btn-outline:hover{background:#e2e8f0}.spinner-large{width:48px;height:48px;border:4px solid #f1f5f9;border-top-color:#ef4444;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.form-row{grid-template-columns:1fr}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media(max-width:768px){.shrinkage-page{padding:1rem}.shrinkage-header{flex-direction:column;gap:1rem}.shrinkage-filters,.date-range{flex-direction:column;align-items:stretch}.filter-select,.btn-export{min-width:100%;margin-left:0}.summary-grid{grid-template-columns:1fr}}#root{min-height:100vh;display:flex;flex-direction:column}.app-container{flex:1;display:flex;flex-direction:column}:root{--primary-color: #d946ef;--primary-dark: #a855f7;--primary-light: #f0abfc;--secondary-color: #fbbf24;--secondary-dark: #f59e0b;--spa-pink: #ffc2e2;--spa-purple: #d4a5ff;--spa-lavender: #a5b4fc;--spa-peach: #ffd4b5;--spa-mint: #a7f3d0;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--info-color: #3b82f6;--text-primary: #1f2937;--text-secondary: #6b7280;--text-light: #9ca3af;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--border-color: #e5e7eb;--border-light: #f3f4f6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-full: 9999px;--transition-fast: .15s ease-in-out;--transition-base: .25s ease-in-out;--transition-slow: .35s ease-in-out;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "Courier New", Courier, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-secondary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;color:var(--text-primary)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin-bottom:var(--spacing-md)}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark)}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all var(--transition-fast)}button:disabled{opacity:.6;cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:var(--text-base);outline:none;transition:all var(--transition-fast)}input:focus,textarea:focus,select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}img{max-width:100%;height:auto;display:block}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.container-fluid{width:100%;padding:0 var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-sm)}.gap-2{gap:var(--spacing-md)}.gap-3{gap:var(--spacing-lg)}.gap-4{gap:var(--spacing-xl)}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mt-4{margin-top:var(--spacing-xl)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.mb-4{margin-bottom:var(--spacing-xl)}.p-1{padding:var(--spacing-sm)}.p-2{padding:var(--spacing-md)}.p-3{padding:var(--spacing-lg)}.p-4{padding:var(--spacing-xl)}.card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;font-size:var(--text-sm);transition:all var(--transition-fast);border:none;cursor:pointer}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--secondary-dark)}.btn-outline{background-color:transparent;border:2px solid var(--primary-color);color:var(--primary-color)}.btn-outline:hover:not(:disabled){background-color:var(--primary-color);color:#fff}.btn-danger{background-color:var(--error-color);color:#fff}.btn-sm{padding:.375rem .75rem;font-size:var(--text-xs)}.btn-lg{padding:.75rem 1.5rem;font-size:var(--text-lg)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-primary);font-size:var(--text-sm)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-base);background-color:var(--bg-primary);transition:all var(--transition-fast)}.form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.form-input.error{border-color:var(--error-color)}.form-error{color:var(--error-color);font-size:var(--text-sm);margin-top:var(--spacing-xs)}.spinner{border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}.badge-success{background-color:#d1fae5;color:#065f46}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-error{background-color:#fee2e2;color:#991b1b}.badge-info{background-color:#dbeafe;color:#1e40af}@media(max-width:768px){.container{padding:0 var(--spacing-md)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-in-out}
