@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;600;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800&family=DM+Sans:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,800;1,700;1,800&family=DM+Sans:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;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-container{position:relative}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;min-width:280px;overflow:hidden}.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}.btn-spa-login{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;padding:.625rem 1.5rem;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s ease;cursor:pointer;text-decoration:none;box-shadow:0 2px 10px #d946ef4d}.btn-spa-login:hover{background:linear-gradient(135deg,#c026d3,#9333ea);transform:translateY(-2px);box-shadow:0 4px 15px #d946ef80;color:#fff}.btn-spa-login:active{transform:translateY(0);box-shadow:0 2px 10px #d946ef4d}@media(max-width:768px){.btn-spa-login{padding:.5rem 1.25rem;font-size:.8125rem}}.footer{background:linear-gradient(135deg,#1e293b,#0f172a);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;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;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:#cbd5e1;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:#d946ef1a;color:#d946ef;border-radius:var(--radius-md);font-size:1.25rem;transition:all var(--transition-fast);border:1px solid rgba(217,70,239,.2)}.social-link:hover{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #d946ef66}.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.footer-links li a{color:#cbd5e1;text-decoration:none;font-size:var(--text-sm);transition:all var(--transition-fast);display:inline-block}.footer-links li a:hover{color:#d946ef;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:#cbd5e1;font-size:var(--text-sm)}.footer-contact li svg{color:#d946ef;font-size:1.25rem;flex-shrink:0;margin-top:2px}.footer-contact li a{color:#cbd5e1;text-decoration:none;transition:color var(--transition-fast)}.footer-contact li a:hover{color:#d946ef}.footer-cta-buttons{display:flex;flex-direction:column;gap:.875rem;margin-top:1.5rem}.footer-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;padding:.75rem 1.25rem;border-radius:12px;font-size:.875rem;font-weight:700;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:center;position:relative;overflow:hidden}.footer-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.footer-btn:hover:before{left:100%}.footer-btn-primary{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;box-shadow:0 4px 12px #d946ef66;border:2px solid transparent}.footer-btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 24px #d946ef80;border-color:#ffffff4d}.footer-btn-danger{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;box-shadow:0 4px 12px #dc262666;border:2px solid transparent}.footer-btn-danger:hover{transform:translateY(-3px);box-shadow:0 8px 24px #dc262680;border-color:#ffffff4d}.footer-btn-info{background:linear-gradient(135deg,#0891b2,#0e7490);color:#fff;box-shadow:0 4px 12px #0891b266;border:2px solid transparent}.footer-btn-info:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0891b280;border-color:#ffffff4d}.footer-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(217,70,239,.3),transparent);max-width:1400px;margin:0 auto}.footer-bottom{padding:var(--spacing-lg);background:#0f172a80}.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:#94a3b8;font-size:var(--text-sm);margin:0}.footer-payments{display:flex;align-items:center;gap:var(--spacing-md)}.payment-text{color:#94a3b8;font-size:var(--text-sm)}.payment-icons{display:flex;gap:var(--spacing-sm)}.payment-icon{font-size:1.5rem;opacity:.7;transition:all var(--transition-fast)}.payment-icon:hover{opacity:1;transform:scale(1.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)}.footer-cta-buttons{margin-top:1rem}.footer-btn{padding:.875rem 1.25rem}}.footer-btn-reclamaciones{padding:.5rem;background:#fff;border:3px solid #dc2626;overflow:hidden;height:70px;display:flex;align-items:center;justify-content:center}.footer-btn-reclamaciones:hover{transform:translateY(-3px);box-shadow:0 8px 24px #dc262666;border-color:#991b1b}.reclamaciones-img{width:100%;height:100%;object-fit:contain;display:block}.footer-btn-reclamaciones:hover .reclamaciones-img{transform:scale(1.05)}@media(max-width:768px){.footer-btn-reclamaciones{max-height:80px}.reclamaciones-img{object-fit:contain}}.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:left;max-width:1200px;margin:0 auto;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}.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;flex-direction:column;gap:var(--spacing-lg);animation:fadeInUp .8s ease-out .8s both;grid-column:2;grid-row:1 / span 5}.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-img{width:100%;height:100%;object-fit:cover;display:block;border-radius:var(--radius-2xl)}.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}}.btn-spa-primary{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-lg);font-weight:600;display:inline-flex;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-base);cursor:pointer;text-decoration:none}.btn-spa-primary:hover{background:linear-gradient(135deg,#c026d3,#9333ea);transform:translateY(-2px);box-shadow:0 8px 25px #d946ef66;color:#fff}.btn-spa-primary.btn-lg{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--text-lg)}.btn-spa-glow{background:linear-gradient(135deg,#d946ef,#a855f7);box-shadow:0 4px 20px #d946ef66;position:relative;overflow:hidden;color:#fff;border:none;padding:var(--spacing-lg) var(--spacing-2xl);border-radius:var(--radius-lg);font-weight:600;display:inline-flex;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-base);cursor:pointer;text-decoration:none;font-size:var(--text-lg)}.btn-spa-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-spa-glow:hover{transform:translateY(-2px);box-shadow:0 8px 30px #d946ef99;color:#fff}.btn-spa-glow:hover:before{width:300px;height:300px}.spa-section-badge{display:inline-block;background:#d946ef1a;color:#d946ef;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);border:2px solid rgba(217,70,239,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.spa-section-title{font-size:var(--text-4xl);font-weight:700;margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#1f2937,#4b5563);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.spa-section-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0 auto;max-width:600px;line-height:1.7}.btn-spa-white{background:#fff;color:#d946ef;border:2px solid rgba(255,255,255,.5);padding:var(--spacing-lg) var(--spacing-2xl);border-radius:var(--radius-lg);font-weight:600;display:inline-flex;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-base);cursor:pointer;text-decoration:none;font-size:var(--text-lg);box-shadow:0 4px 20px #ffffff4d}.btn-spa-white:hover{background:#fffffff2;box-shadow:0 10px 40px #ffffff80;transform:translateY(-4px);color:#d946ef}.track-booking-page{min-height:100vh;background:linear-gradient(135deg,#faf5ff,#f3e8ff,#e9d5ff);padding:2rem 1rem 4rem}.track-page-wrapper{max-width:1400px;margin:0 auto}.page-header-tracking{text-align:center;margin-bottom:3rem;padding:2rem 1rem}.header-content-tracking{display:inline-block}.header-icon-large{width:80px;height:80px;margin:0 auto 1.5rem;padding:1.5rem;background:linear-gradient(135deg,#d946ef,#c026d3);border-radius:24px;color:#fff;box-shadow:0 12px 40px #d946ef4d;display:block}.page-title-tracking{font-size:2.75rem;font-weight:900;color:#0f172a;margin:0 0 .75rem;letter-spacing:-.5px}.page-subtitle-tracking{font-size:1.125rem;color:#64748b;margin:0;font-weight:500}.search-section-tracking{max-width:900px;margin:0 auto 3rem}.search-card-tracking{background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 12px 48px #0000001a;border:1px solid rgba(217,70,239,.1)}.search-form-tracking{display:flex;gap:1rem;margin-bottom:1rem}.search-input-icon{position:absolute;left:1.5rem;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1.5rem;pointer-events:none}.search-input-tracking{width:100%;padding:1.25rem 1.5rem 1.25rem 4rem;border:2px solid #e2e8f0;border-radius:16px;font-size:1.125rem;font-family:Courier New,monospace;font-weight:700;transition:all .3s;background:#f8fafc;color:#0f172a}.search-input-tracking:focus{outline:none;border-color:#d946ef;background:#fff;box-shadow:0 0 0 4px #d946ef1a}.search-input-tracking:disabled{opacity:.6;cursor:not-allowed}.search-input-tracking::placeholder{color:#cbd5e1;font-weight:600}.search-button-tracking{padding:1.25rem 3rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border:none;border-radius:16px;font-size:1.125rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:all .3s;white-space:nowrap;box-shadow:0 8px 24px #d946ef59}.search-button-tracking:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 36px #d946ef73}.search-button-tracking:disabled{opacity:.6;cursor:not-allowed;transform:none}.button-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.search-hint-tracking{text-align:center;font-size:.9375rem;color:#64748b;margin:0}.results-section-tracking{margin-top:3rem}.status-header-card{background:#fff;border-radius:20px;padding:1.75rem 2.5rem;box-shadow:0 8px 32px #00000014;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;border:2px solid #f1f5f9}.status-badge-main{display:flex;align-items:center;gap:1rem;padding:1rem 2rem;border-radius:16px;font-weight:800;font-size:1.25rem}.status-icon-main{font-size:2rem}.booking-code-main{font-size:1.125rem;color:#64748b;font-family:Courier New,monospace;font-weight:600}.booking-code-main strong{color:#0f172a;font-weight:800}.content-grid-tracking{display:grid;grid-template-columns:450px 1fr;gap:2rem;align-items:start}.timeline-column{position:sticky;top:2rem}.timeline-card{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 8px 32px #00000014;border:2px solid #f1f5f9}.card-header-tracking{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #f1f5f9}.card-icon{color:#d946ef;font-size:1.75rem}.card-title{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0}.timeline-wrapper{display:flex;flex-direction:column}.timeline-step-item{display:flex;gap:1.5rem;position:relative}.timeline-step-item:not(:last-child){margin-bottom:2.5rem}.step-indicator{display:flex;flex-direction:column;align-items:center;position:relative}.step-dot-wrapper{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;background:#fff;border:3px solid #e2e8f0;position:relative;z-index:2;transition:all .3s;box-shadow:0 4px 12px #0000000d}.step-completed .step-dot-wrapper{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;box-shadow:0 8px 24px #10b98159}.step-pending .step-dot-wrapper{background:#f1f5f9;border-color:#cbd5e1}.step-dot-inner{filter:grayscale(0)}.step-pending .step-dot-inner{filter:grayscale(1);opacity:.5}.step-connector{width:3px;flex:1;min-height:50px;background:#e2e8f0;margin-top:.75rem;border-radius:2px}.step-completed .step-connector{background:linear-gradient(180deg,#10b981,#e2e8f0)}.step-details{flex:1;padding-top:.5rem}.step-title-text{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.step-pending .step-title-text{color:#94a3b8}.step-description-text{font-size:.9375rem;color:#64748b;margin:0 0 .5rem;line-height:1.5}.step-date-text{font-size:.875rem;color:#94a3b8;margin:0 0 .75rem;font-weight:600}.step-completed-badge{display:inline-block;padding:.375rem .875rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857;border-radius:8px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.details-column{display:flex;flex-direction:column;gap:1.5rem}.info-card-tracking{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 8px 32px #00000014;border:2px solid #f1f5f9}.card-subtitle-tracking{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.card-body-tracking{padding-top:1rem}.service-name-large{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0 0 .75rem;line-height:1.3}.service-description-text{color:#64748b;line-height:1.7;margin:0}.details-grid-tracking{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.detail-box{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:16px;padding:1.5rem;display:flex;gap:1rem;transition:all .3s}.detail-box:hover{transform:translateY(-2px);box-shadow:0 8px 24px #d946ef26}.detail-box-icon{width:48px;height:48px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#d946ef;font-size:1.5rem;flex-shrink:0;box-shadow:0 4px 12px #d946ef26}.detail-box-content{flex:1;display:flex;flex-direction:column;gap:.375rem}.detail-box-label{font-size:.75rem;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.5px}.detail-box-value{font-size:1rem;font-weight:700;color:#0f172a;line-height:1.4}.detail-box-value-price{font-size:1.5rem;font-weight:900;background:linear-gradient(135deg,#d946ef,#c026d3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.detail-box-subtext{font-size:.875rem;color:#64748b;font-weight:600}.payment-pending-alert{margin-top:1.5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:12px;padding:1.25rem;text-align:center;color:#92400e;font-weight:700;font-size:1.125rem}.contact-info-list{display:flex;flex-direction:column;gap:1rem}.contact-item{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px}.contact-item svg{width:40px;height:40px;padding:.75rem;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-radius:10px;color:#d946ef;flex-shrink:0}.contact-item>div{display:flex;flex-direction:column;gap:.25rem}.contact-label{font-size:.75rem;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.5px}.contact-value{font-size:1rem;font-weight:600;color:#0f172a}.empty-state-tracking{text-align:center;padding:6rem 2rem;background:#fff;border-radius:24px;box-shadow:0 8px 32px #00000014;border:2px solid #f1f5f9}.empty-icon-large{font-size:6rem;margin-bottom:1.5rem;opacity:.4}.empty-title{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0 0 .75rem}.empty-text{font-size:1.125rem;color:#64748b;margin:0}@media(max-width:1200px){.content-grid-tracking{grid-template-columns:400px 1fr}}@media(max-width:1024px){.content-grid-tracking{grid-template-columns:1fr}.timeline-column{position:relative;top:0}}@media(max-width:768px){.track-booking-page{padding:1.5rem .75rem 3rem}.page-title-tracking{font-size:2rem}.header-icon-large{width:64px;height:64px;padding:1rem}.search-card-tracking{padding:1.5rem}.search-form-tracking{flex-direction:column}.search-button-tracking{width:100%;justify-content:center}.status-header-card{flex-direction:column;gap:1rem;padding:1.5rem;text-align:center}.details-grid-tracking{grid-template-columns:1fr}.timeline-card,.info-card-tracking{padding:1.5rem}.step-dot-wrapper{width:48px;height:48px;font-size:1.5rem}}@media(max-width:480px){.page-title-tracking{font-size:1.75rem}.search-input-tracking{font-size:1rem;padding:1rem 1rem 1rem 3.5rem}.search-input-icon{left:1rem;font-size:1.25rem}}: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}}.stat-badge{font-size:.625rem;font-weight:700;padding:.25rem .5rem;background:#fff3;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.stat-detail{font-size:.75rem;color:#fffc;margin-top:.5rem;font-weight:500}.alerts-section{margin-bottom:2rem;background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #00000014;border:2px solid #fef2f2}.alerts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #fee2e2}.alerts-title{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:#dc2626;margin:0}.alerts-title svg{font-size:1.75rem}.alerts-count{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 .75rem;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border-radius:18px;font-weight:700;font-size:1rem;box-shadow:0 4px 12px #dc26264d}.alerts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.25rem}.alert-card{display:flex;gap:1rem;padding:1.25rem;border-radius:16px;border-left:5px solid;transition:all .3s ease;position:relative;overflow:hidden}.alert-card:before{content:"";position:absolute;inset:0;opacity:.05;transition:opacity .3s ease;pointer-events:none}.alert-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.alert-card:hover:before{opacity:.1}.alert-warning{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-left-color:#f59e0b}.alert-warning:before{background:#f59e0b}.alert-info{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-left-color:#3b82f6}.alert-info:before{background:#3b82f6}.alert-danger{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-left-color:#ef4444}.alert-danger:before{background:#ef4444}.alert-success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-left-color:#10b981}.alert-success:before{background:#10b981}.alert-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;flex-shrink:0;font-size:1.5rem;font-weight:700}.alert-warning .alert-icon{background:#f59e0b26;color:#f59e0b}.alert-info .alert-icon{background:#3b82f626;color:#3b82f6}.alert-danger .alert-icon{background:#ef444426;color:#ef4444}.alert-success .alert-icon{background:#10b98126;color:#10b981}.alert-content{flex:1;display:flex;flex-direction:column;gap:.75rem}.alert-message{font-size:.9375rem;font-weight:600;color:#1f2937;margin:0;line-height:1.5}.alert-actions{display:flex;gap:.5rem;position:relative;z-index:10}.btn-alert{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;border-radius:8px;transition:all .2s;text-decoration:none;border:none;cursor:pointer!important;font-family:inherit;outline:none;pointer-events:auto!important;position:relative;z-index:10}.btn-alert:hover{transform:translateY(-1px)}.btn-alert:active{transform:translateY(0)}.btn-alert:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.alert-warning .btn-alert{background:#f59e0b;color:#fff}.alert-warning .btn-alert:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.alert-info .btn-alert{background:#3b82f6;color:#fff}.alert-info .btn-alert:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.alert-danger .btn-alert{background:#ef4444;color:#fff}.alert-danger .btn-alert:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.alert-success .btn-alert{background:#10b981;color:#fff}.alert-success .btn-alert:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}@media(max-width:768px){.alerts-section{padding:1.5rem}.alerts-grid{grid-template-columns:1fr}.alert-card{padding:1rem}.alerts-header{flex-direction:column;align-items:flex-start;gap:1rem}}.chart-empty-state{display:flex;align-items:center;justify-content:center;height:300px;color:#9ca3af;font-size:1rem}.chart-empty-state p{margin:0}.service-specialty{font-size:.75rem;color:#9ca3af;margin-top:.25rem}.empty-state-small{text-align:center;padding:2rem;color:#9ca3af}.empty-state-small p{margin:0;font-size:.875rem}.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}.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}.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}}.password-input-wrapper{position:relative}.password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#64748b;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all .3s}.password-toggle:hover{color:#d946ef}.password-input-wrapper .form-input{padding-right:3rem}.password-info-box{background:#dbeafe;border:2px solid #60a5fa;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.5rem}.password-info-box p{margin:0 0 .5rem;color:#1e40af}.password-info-box p:last-child{margin-bottom:0}.password-strength{margin-top:.5rem;display:flex;align-items:center;gap:.75rem}.strength-bar{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.strength-fill{height:100%;transition:all .3s;border-radius:3px}.strength-fill.weak{background:#ef4444;width:33%}.strength-fill.medium{background:#f59e0b;width:66%}.strength-fill.strong{background:#10b981;width:100%}.strength-text{font-size:.875rem;font-weight:600;min-width:60px}.strength-fill.weak+.strength-text{color:#ef4444}.strength-fill.medium+.strength-text{color:#f59e0b}.strength-fill.strong+.strength-text{color:#10b981}.password-match{margin-top:.5rem;font-size:.875rem;font-weight:600}.match-success{color:#10b981}.match-error{color:#ef4444}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.form-group label{font-size:.9375rem;font-weight:600;color:#0f172a}.form-input,.form-select{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:.9375rem;font-family:inherit;transition:all .3s;background:#fff}.form-input:focus,.form-select:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem;padding-right:2.5rem}.spinner-small{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:1}}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}.modal-content.modal-large{max-width:800px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{position:relative;padding:2rem;border-bottom:1px solid #e2e8f0;display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem}.modal-header-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff}.modal-header-icon.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.modal-header-icon.primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.modal-header-icon.success{background:linear-gradient(135deg,#f59e0b,#d97706)}.modal-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0}.modal-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border:none;background:#f1f5f9;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;font-size:1.25rem;color:#64748b}.modal-close:hover{background:#e2e8f0;color:#0f172a}.modal-body{padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.booking-summary-card{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.summary-item{display:flex;justify-content:space-between;align-items:center}.summary-label{color:#64748b;font-size:.9375rem;font-weight:600}.summary-value{color:#0f172a;font-weight:600}.summary-value.code{font-family:Courier New,monospace;background:#fff;padding:.25rem .75rem;border-radius:6px;color:#d946ef}.alert{display:flex;gap:1rem;padding:1rem 1.25rem;border-radius:12px;font-size:.9375rem}.alert svg{font-size:1.25rem;flex-shrink:0;margin-top:.125rem}.alert strong{display:block;margin-bottom:.25rem}.alert p{margin:0}.alert-warning{background:#fef3c7;border:2px solid #fbbf24;color:#92400e}.alert-info{background:#dbeafe;border:2px solid #60a5fa;color:#1e40af}.form-group label{font-size:.9375rem;font-weight:600;color:#0f172a;display:flex;flex-direction:column;gap:.25rem}.optional-text{font-size:.8125rem;color:#64748b;font-weight:400}.form-textarea{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:.9375rem;font-family:inherit;resize:vertical;transition:all .3s}.form-textarea:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.char-count{font-size:.8125rem;color:#94a3b8;text-align:right}.form-select{padding:.875rem 2.5rem .875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:.9375rem;font-family:inherit;cursor:pointer;transition:all .3s;background:#fff;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem}.form-select:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.motivos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.motivo-btn{padding:.875rem 1rem;border:2px solid #e2e8f0;background:#fff;border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s;text-align:left}.motivo-btn:hover{border-color:#d946ef;background:#faf5ff}.motivo-btn.active{border-color:#d946ef;background:linear-gradient(135deg,#faf5ff,#f3e8ff);color:#d946ef;font-weight:600}.current-booking{background:#f8fafc;padding:1.5rem;border-radius:12px;border:2px solid #e2e8f0}.current-booking h3{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .75rem}.booking-summary-inline{display:flex;gap:1.5rem;flex-wrap:wrap}.inline-item{display:flex;align-items:center;gap:.5rem;color:#0f172a;font-weight:600}.inline-item svg{color:#d946ef}.loading-slots{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#64748b}.time-slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.time-slot{padding:.875rem;border:2px solid #e2e8f0;background:#fff;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.time-slot:hover{border-color:#8b5cf6;background:#f5f3ff;transform:translateY(-2px)}.time-slot.active{border-color:#8b5cf6;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.time-slot.active svg{color:#fff}.empty-slots{text-align:center;padding:2rem}.empty-slots p{margin:0;color:#64748b}.rating-service-info{text-align:center;padding:1rem 0;border-bottom:1px solid #e2e8f0}.rating-service-info h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.therapist-info{color:#64748b;margin:.25rem 0}.service-date{color:#94a3b8;font-size:.875rem;margin:.25rem 0 0}.rating-container{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0}.rating-question{font-size:1.125rem;font-weight:600;color:#0f172a;margin:0}.stars-container{display:flex;gap:.5rem}.star-btn{background:none;border:none;cursor:pointer;padding:.25rem;transition:transform .2s}.star-btn:hover{transform:scale(1.1)}.star-icon{font-size:3rem;color:#e2e8f0;transition:all .3s;stroke-width:1.5}.star-icon.filled{color:#f59e0b;fill:#f59e0b}.rating-text{font-size:1.125rem;font-weight:600;color:#f59e0b;margin:0}.modal-footer{padding:1.5rem 2rem;border-top:1px solid #e2e8f0;display:flex;gap:1rem;justify-content:flex-end}.btn{padding:.875rem 1.5rem;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s;font-family:inherit}.btn-primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #8b5cf64d}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #ef44444d}.btn-success{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #f59e0b4d}.credit-info{margin-top:1rem;padding:1rem;background:#fef3c7;border-radius:10px}.credit-amount{font-size:1.5rem;font-weight:800;color:#d97706;margin:.5rem 0}.credit-expiry{font-size:.875rem;color:#92400e;margin:0}@media(max-width:768px){.modal-content{max-width:100%;border-radius:20px 20px 0 0;max-height:95vh}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;flex-direction:column-reverse}.modal-footer .btn{width:100%}.motivos-grid{grid-template-columns:1fr}.time-slots-grid{grid-template-columns:repeat(3,1fr)}.stars-container{gap:.25rem}.star-icon{font-size:2.5rem}}@media(max-width:480px){.time-slots-grid{grid-template-columns:repeat(2,1fr)}}.booking-card-item{background:#fff;border:2px solid #e2e8f0;border-radius:16px;overflow:hidden;transition:all .3s}.booking-card-item:hover{border-color:#d946ef;box-shadow:0 8px 24px #d946ef26}.booking-card-header{padding:1rem 1.5rem;background:#f8fafc;display:flex;justify-content:space-between;align-items:center;gap:1rem}.booking-card-status{padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:700;text-transform:capitalize}.booking-card-code{font-family:Courier New,monospace;font-size:.875rem;font-weight:700;color:#64748b;flex:1}.booking-card-actions{position:relative}.btn-menu{width:32px;height:32px;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b}.btn-menu:hover{border-color:#d946ef;color:#d946ef}.booking-menu{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:10;min-width:180px;overflow:hidden}.booking-menu button{width:100%;padding:.875rem 1rem;background:transparent;border:none;display:flex;align-items:center;gap:.75rem;font-size:.9375rem;font-weight:600;color:#0f172a;cursor:pointer;transition:all .3s;text-align:left}.booking-menu button:hover{background:#f8fafc;color:#d946ef}.booking-menu button.danger{color:#ef4444}.booking-menu button.danger:hover{background:#fee2e2}.booking-card-body{padding:1.5rem}.booking-service-name{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.booking-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.booking-info-item{display:flex;align-items:flex-start;gap:.75rem}.booking-info-item svg{color:#d946ef;font-size:1.25rem;flex-shrink:0;margin-top:.125rem}.booking-info-item>div{display:flex;flex-direction:column;gap:.25rem}.info-label-small{font-size:.8125rem;color:#64748b;font-weight:600}.info-value-small{font-size:.9375rem;color:#0f172a;font-weight:600}.booking-pending-payment{margin-top:1rem;padding:.875rem 1rem;background:#fef3c7;border:2px solid #fbbf24;border-radius:10px;font-weight:600;color:#92400e;text-align:center}.booking-rating{margin-top:1rem;padding:.875rem 1rem;background:#fef3c7;border-radius:10px;display:flex;align-items:center;justify-content:space-between}.booking-rating span{font-weight:600;color:#92400e}.stars{display:flex;gap:.25rem}.star{font-size:1.25rem;color:#e2e8f0}.star.filled{color:#f59e0b}@media(max-width:640px){.booking-info-grid{grid-template-columns:1fr}.booking-card-header{flex-wrap:wrap}}.profile-page{min-height:100vh;background:linear-gradient(135deg,#faf5ff,#f3e8ff);padding-bottom:4rem}.profile-container{max-width:1400px;margin:0 auto}.profile-loading,.profile-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.profile-header{position:relative;margin-bottom:2rem}.profile-header-bg{height:200px;background:linear-gradient(135deg,#d946ef,#c026d3);border-radius:0 0 32px 32px}.profile-header-content{position:relative;margin-top:-80px;padding:0 2rem;display:flex;justify-content:space-between;align-items:flex-end}.avatar-section{display:flex;gap:1.5rem;align-items:flex-end}.avatar-wrapper{position:relative}.avatar-img,.avatar-placeholder{width:160px;height:160px;border-radius:24px;border:6px solid white;box-shadow:0 8px 32px #00000026;object-fit:cover}.avatar-placeholder{background:linear-gradient(135deg,#d946ef,#c026d3);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:800;color:#fff}.avatar-upload-btn{position:absolute;bottom:0;right:0;width:48px;height:48px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #00000026;color:#d946ef;font-size:1.25rem;transition:all .3s}.avatar-upload-btn:hover{transform:scale(1.1);background:#d946ef;color:#fff}.profile-info{padding-bottom:.5rem}.profile-name{font-size:2rem;font-weight:800;color:#0f172a;margin:0 0 .25rem}.profile-email{color:#64748b;margin:0 0 .75rem}.profile-badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge{padding:.375rem .875rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;color:#64748b}.badge.badge-gold{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b;color:#92400e}.btn-logout{padding:.875rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;font-size:.9375rem;font-weight:600;color:#64748b;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;margin-bottom:.5rem}.btn-logout:hover{background:#fee2e2;border-color:#fecaca;color:#dc2626}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:0 2rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 20px #0000000f;display:flex;align-items:center;gap:1rem;transition:all .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001a}.stat-icon.primary{background:linear-gradient(135deg,#d946ef,#c026d3)}.stat-icon.gold{background:linear-gradient(135deg,#fbbf24,#f59e0b);font-size:1.75rem}.stat-value{font-size:1.75rem;font-weight:800;color:#0f172a;line-height:1}.profile-tabs{display:flex;gap:.5rem;padding:.5rem;margin:0 2rem 2rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000000f;overflow-x:auto}.tab-btn{flex:1;min-width:140px;padding:1rem;background:transparent;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap}.profile-content{padding:0 2rem}.tab-panel{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.panel-header h2{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0}.btn-sm{padding:.625rem 1.25rem;font-size:.875rem}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.info-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1rem;font-weight:600;color:#0f172a}.info-section{margin-top:2rem;padding-top:2rem;border-top:2px solid #f1f5f9}.info-section h3{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.preferences-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.pref-item{display:flex;flex-direction:column;gap:.25rem}.pref-label{font-size:.875rem;color:#64748b}.pref-value{font-weight:600;color:#0f172a}.medical-info{background:#fef3c7;border:2px solid #fbbf24;border-radius:12px;padding:1.5rem;margin-top:1rem}.medical-item{margin-bottom:1rem}.medical-item:last-child{margin-bottom:0}.medical-item strong{color:#92400e;display:block;margin-bottom:.25rem}.medical-item p{color:#78350f;margin:0}.filter-buttons{display:flex;gap:.5rem}.filter-btn{padding:.5rem 1rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .3s}.filter-btn:hover{border-color:#d946ef;color:#d946ef}.filter-btn.active{background:linear-gradient(135deg,#d946ef,#c026d3);border-color:#d946ef;color:#fff}.bookings-list{display:flex;flex-direction:column;gap:1rem}.credits-summary{display:grid;grid-template-columns:300px 1fr;gap:1.5rem;margin-bottom:2rem}.credit-total-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:16px;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.credit-icon{font-size:3rem}.credit-info{text-align:center;display:flex;flex-direction:column;gap:.5rem}.credit-label{font-size:.875rem;font-weight:600;color:#92400e;text-transform:uppercase;letter-spacing:.5px}.credit-amount{font-size:2rem;font-weight:800;color:#d97706}.credit-info-box{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem}.credit-info-box p{margin:0 0 .5rem;color:#475569}.credit-info-box p:last-child{margin-bottom:0}.text-muted{color:#94a3b8;font-size:.875rem}.credits-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.credit-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;overflow:hidden;transition:all .3s}.credit-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:#fbbf24}.credit-card-header{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:1.5rem;display:flex;align-items:center;gap:1rem}.credit-card-icon{font-size:2rem}.credit-card-info{display:flex;flex-direction:column;gap:.25rem}.credit-card-amount{font-size:1.5rem;font-weight:800;color:#d97706}.credit-card-label{font-size:.875rem;color:#92400e;font-weight:600}.credit-card-body{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.credit-detail{display:flex;justify-content:space-between;align-items:center}.detail-label{font-size:.875rem;color:#64748b;font-weight:600}.detail-value{font-size:.9375rem;color:#0f172a;font-weight:600}.detail-value.expiry{color:#f59e0b}.stats-card{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem}.stats-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}.stats-icon.primary{background:linear-gradient(135deg,#d946ef,#c026d3)}.stats-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.stats-icon.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.stats-icon.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.stats-content{display:flex;flex-direction:column;gap:.25rem}.stats-value{font-size:2rem;font-weight:800;color:#0f172a;line-height:1}.stats-label{font-size:.875rem;color:#64748b;font-weight:600}.favorite-service-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:16px;padding:2rem;margin-bottom:2rem}.favorite-service-card h3{font-size:1.125rem;font-weight:700;color:#92400e;margin:0 0 1rem}.favorite-service-content{display:flex;align-items:center;gap:1.5rem}.favorite-icon{font-size:3rem}.favorite-info{display:flex;flex-direction:column;gap:.5rem}.favorite-name{font-size:1.25rem;font-weight:700;color:#78350f}.favorite-count{font-size:.9375rem;color:#92400e;font-weight:600}.monthly-spending{margin-bottom:2rem}.monthly-spending h3{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.spending-chart{display:flex;gap:1rem;align-items:flex-end;height:200px;padding:1rem;background:#f8fafc;border-radius:12px}.spending-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%}.spending-bar-container{flex:1;width:100%;display:flex;align-items:flex-end}.spending-bar{width:100%;background:linear-gradient(135deg,#d946ef,#c026d3);border-radius:8px 8px 0 0;min-height:20px;position:relative;transition:all .3s;cursor:pointer;display:flex;align-items:flex-start;justify-content:center;padding-top:.5rem}.spending-bar:hover{opacity:.8}.spending-value{font-size:.75rem;font-weight:700;color:#fff;writing-mode:vertical-rl;text-orientation:mixed}.spending-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase}.total-invested-card{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:16px;padding:2rem;display:flex;align-items:center;gap:1.5rem;margin-bottom:1rem}.invested-icon{font-size:3rem}.invested-content{display:flex;flex-direction:column;gap:.5rem}.invested-label{font-size:1rem;color:#7c3aed;font-weight:600}.invested-amount{font-size:2rem;font-weight:800;color:#d946ef}.last-visit{text-align:center;padding:1rem;color:#64748b;font-style:italic}.config-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #f1f5f9}.config-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.config-section h3{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.config-item{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:#f8fafc;border-radius:12px;margin-bottom:1rem}.config-item:last-child{margin-bottom:0}.config-item-info{display:flex;flex-direction:column;gap:.5rem;flex:1}.config-item-title{font-size:1rem;font-weight:600;color:#0f172a}.config-item-desc{font-size:.875rem;color:#64748b}.toggle-switch{position:relative;display:inline-block;width:56px;height:32px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.4s;border-radius:32px}.toggle-slider:before{position:absolute;content:"";height:24px;width:24px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background-color:#d946ef}input:checked+.toggle-slider:before{transform:translate(24px)}.danger-zone{background:#fef2f2;border:2px solid #fecaca;border-radius:12px;padding:1.5rem}.danger-zone h3{color:#dc2626}.danger-zone .config-item{background:#fff}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.empty-state p{color:#64748b;margin:0 0 1.5rem}.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.btn{padding:.875rem 1.5rem;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s;font-family:inherit}.btn-primary{background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #d946ef4d}.btn-secondary{background:#f1f5f9;color:#475569}.btn-secondary:hover{background:#e2e8f0}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 8px 20px #ef44444d}@media(max-width:1200px){.profile-stats,.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.profile-header-content{flex-direction:column;align-items:center;gap:1.5rem;padding:0 1rem}.avatar-section{flex-direction:column;align-items:center;text-align:center}.profile-stats,.stats-grid,.info-grid,.preferences-grid,.credits-list{grid-template-columns:1fr}.profile-tabs{margin:0 1rem 2rem}.profile-content{padding:0 1rem}.tab-panel{padding:1.5rem}.credits-summary{grid-template-columns:1fr}.filter-buttons{flex-wrap:wrap}.config-item{flex-direction:column;align-items:flex-start;gap:1rem}.spending-chart{height:150px}.spending-value{font-size:.625rem}}.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.blocked{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444;color:#991b1b;cursor:not-allowed;position:relative}.calendar-day-booking.blocked:after{content:"🔒";position:absolute;bottom:4px;right:4px;font-size:.75rem}.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 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%}}.services-filters-booking{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.search-box-booking{flex:1;min-width:280px;position:relative}.search-box-booking .search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1.2rem}.search-input-booking{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .3s;background:#fff}.search-input-booking:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.filter-box-booking{position:relative;min-width:220px}.filter-box-booking .filter-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1.2rem;pointer-events:none;z-index:1}.filter-select-booking{width:100%;padding:.875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;background:#fff;cursor:pointer;transition:all .3s;appearance:none;background-image: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");background-repeat:no-repeat;background-position:right 1rem center}.filter-select-booking:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.results-info-booking{margin-bottom:1.5rem;color:#64748b;font-size:.95rem}.results-info-booking strong{color:#0f172a;font-weight:600}.loading-services-booking{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.loading-services-booking p{color:#64748b;font-size:1rem}.empty-services-booking{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-services-booking .empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-services-booking h3{color:#0f172a;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.empty-services-booking p{color:#64748b;font-size:1rem}.service-image-booking{width:100%;height:200px;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.service-image-booking img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.service-card-booking:hover .service-image-booking img{transform:scale(1.05)}.service-category-badge{display:inline-block;padding:.25rem .75rem;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-size:.75rem;font-weight:600;border-radius:6px;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.pagination-booking{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:3rem;padding-top:2rem;border-top:2px solid #f1f5f9}.pagination-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:2px solid #e2e8f0;background:#fff;border-radius:10px;color:#64748b;cursor:pointer;transition:all .3s;font-size:1.2rem}.pagination-btn:hover:not(:disabled){border-color:#d946ef;color:#d946ef;transform:translateY(-2px)}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-number{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:2px solid #e2e8f0;background:#fff;border-radius:10px;color:#64748b;cursor:pointer;transition:all .3s;font-weight:600}.pagination-number.active{background:linear-gradient(135deg,#d946ef,#c026d3);border-color:#d946ef;color:#fff;box-shadow:0 4px 12px #d946ef4d}@media(max-width:768px){.services-filters-booking{flex-direction:column}.search-box-booking,.filter-box-booking{min-width:100%}.pagination-booking{gap:.25rem}.pagination-btn,.pagination-number{width:36px;height:36px;font-size:.9rem}}.confirmation-grid{display:grid;grid-template-columns:380px 1fr;gap:2rem;margin-bottom:2rem}.confirmation-left{position:sticky;top:2rem;height:fit-content}.booking-summary-card-v2{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-radius:20px;overflow:hidden;box-shadow:0 10px 30px #d946ef26}.summary-header-v2{display:flex;align-items:center;gap:.75rem;padding:1.5rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff}.summary-icon-v2{font-size:1.5rem}.summary-header-v2 h3{font-size:1.125rem;font-weight:700;margin:0}.summary-body-v2{padding:1.5rem}.summary-service-card{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.summary-service-image{width:80px;height:80px;border-radius:12px;object-fit:cover}.summary-service-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:12px;font-size:2.5rem}.summary-service-info h4{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.summary-service-info p{font-size:.875rem;color:#64748b;margin:0}.summary-divider{height:1px;background:linear-gradient(90deg,transparent,#e2e8f0,transparent);margin:1.5rem 0}.summary-details-list{display:flex;flex-direction:column;gap:1rem}.summary-detail-item{display:flex;align-items:flex-start;gap:1rem}.detail-icon{color:#d946ef;font-size:1.25rem;margin-top:.25rem;flex-shrink:0}.detail-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.detail-label{font-size:.875rem;color:#64748b;font-weight:500}.detail-value{font-size:1rem;color:#0f172a;font-weight:600}.summary-total-v2{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#fff;border-radius:12px;margin-top:1.5rem}.summary-total-v2 span:first-child{font-size:1rem;color:#64748b;font-weight:600}.total-price{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#d946ef,#c026d3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.client-data-card-v2,.payment-card-v2{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;margin-bottom:1.5rem}.card-title-v2{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.form-grid-v2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.form-group-v2{display:flex;flex-direction:column;gap:.5rem}.form-full-v2{grid-column:1 / -1}.form-group-v2 label{font-size:.9375rem;font-weight:600;color:#0f172a}.form-input-v2{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .3s;font-family:inherit}.form-input-v2:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.form-input-v2.error{border-color:#ef4444}.form-error-v2{font-size:.875rem;color:#ef4444;margin-top:-.25rem}.yape-payment-section{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;padding:1.5rem;margin-top:1rem}.yape-header{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#fff;border-radius:16px;margin-bottom:1.5rem;box-shadow:0 2px 10px #0000000d;border:2px solid #f1f5f9}.yape-logo{width:70px;height:70px;background:linear-gradient(135deg,#722f91,#9333ea);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.125rem;color:#fff;font-weight:800;flex-shrink:0;box-shadow:0 4px 12px #722f914d;letter-spacing:1px}.yape-info{flex:1}.yape-number{font-size:1.5rem;font-weight:800;color:#722f91;margin:0 0 .375rem;letter-spacing:2px;font-family:Courier New,monospace}.yape-name{font-size:1rem;color:#64748b;margin:0;font-weight:600}.payment-amount-highlight{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem;border:2px solid #fbbf24;text-align:center}.payment-amount-highlight h4{font-size:.875rem;font-weight:600;color:#92400e;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.5px}.payment-amount-value{font-size:2.25rem;font-weight:800;background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.payment-amount-detail{font-size:.875rem;color:#78350f;margin:.5rem 0 0;font-weight:500}.payment-instructions{background:#fff;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.payment-instructions ol{margin:0;padding-left:1.5rem;display:flex;flex-direction:column;gap:.625rem}.payment-instructions li{font-size:.9375rem;color:#475569;line-height:1.6}.payment-instructions li strong{color:#722f91;font-weight:700}.voucher-upload-section{margin-top:.5rem}.voucher-upload-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1.25rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s;font-size:1rem}.voucher-upload-button:hover{background:linear-gradient(135deg,#c026d3,#a21caf);transform:translateY(-2px);box-shadow:0 8px 20px #d946ef4d}.voucher-preview-card{position:relative;border-radius:12px;overflow:hidden;border:2px solid #e2e8f0}.voucher-preview-image{width:100%;height:auto;display:block}.voucher-remove-btn{position:absolute;top:.75rem;right:.75rem;display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#ef4444f2;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;font-size:.875rem}.voucher-remove-btn:hover{background:#dc2626;transform:scale(1.05)}.step-actions-centered{display:flex;justify-content:center;gap:1rem;padding-top:2rem;border-top:2px solid #f1f5f9}@media(max-width:992px){.confirmation-grid{grid-template-columns:1fr}.confirmation-left{position:static}.form-grid-v2{grid-template-columns:1fr}}@media(max-width:640px){.yape-header{flex-direction:column;text-align:center}.yape-number{font-size:1.125rem}}.calendar-day-booking.today{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-weight:700;border:2px solid #fbbf24}.calendar-day-booking.today:not(.disabled):hover{background:linear-gradient(135deg,#fde68a,#fcd34d);transform:scale(1.05)}.calendar-day-booking.disabled.today{background:#f1f5f9;color:#cbd5e1;border:2px solid #e2e8f0;opacity:.5}.no-slots-message{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:16px;margin-top:2rem;border:2px solid #fbbf24}.no-slots-icon{font-size:3rem;margin-bottom:1rem}.no-slots-message h4{font-size:1.25rem;font-weight:700;color:#92400e;margin:0 0 .5rem}.no-slots-message p{font-size:1rem;color:#78350f;margin:0;line-height:1.6}.auth-required-overlay{min-height:60vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-radius:20px;margin:2rem;padding:3rem;text-align:center;font-size:1.25rem;color:#64748b;font-weight:600}.modal-overlay-auth{position:fixed;inset:0;background:#0f172ab3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeInAuth .3s ease}@keyframes fadeInAuth{0%{opacity:0}to{opacity:1}}.modal-content-auth{position:relative;background:linear-gradient(135deg,#fff,#faf5ff);border-radius:32px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #d946ef59;animation:slideUpAuth .4s ease;border:3px solid rgba(217,70,239,.2)}@keyframes slideUpAuth{0%{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-close-auth{position:absolute;top:1.25rem;right:1.25rem;width:40px;height:40px;background:#fff;border:2px solid #f1f5f9;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;font-size:1.25rem;color:#64748b;z-index:10}.modal-close-auth:hover{background:#fee2e2;border-color:#fecaca;color:#dc2626;transform:rotate(90deg)}.auth-modal-decoration{position:absolute;inset:0;pointer-events:none;overflow:hidden}.sparkle{position:absolute;font-size:1.5rem;animation:floatSparkle 3s ease-in-out infinite;opacity:.6}.sparkle-1{top:10%;left:10%;animation-delay:0s}.sparkle-2{top:20%;right:15%;animation-delay:1s}.sparkle-3{bottom:15%;left:15%;animation-delay:2s}@keyframes floatSparkle{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-15px) rotate(180deg)}}.auth-modal-icon{width:100px;height:100px;margin:3rem auto 0;background:linear-gradient(135deg,#d946ef,#c026d3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:3rem;box-shadow:0 12px 40px #d946ef66;animation:heartbeat 2s ease-in-out infinite;position:relative;z-index:1}@keyframes heartbeat{0%,to{transform:scale(1)}10%{transform:scale(1.1)}20%{transform:scale(1)}30%{transform:scale(1.1)}40%{transform:scale(1)}}.auth-modal-content{padding:2rem 2.5rem 2.5rem;text-align:center;position:relative;z-index:1}.auth-modal-title{font-size:1.875rem;font-weight:800;background:linear-gradient(135deg,#d946ef,#c026d3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 1rem;line-height:1.3}.auth-modal-description{font-size:1.0625rem;color:#475569;line-height:1.7;margin:0 0 2rem}.auth-benefits{background:#fff;border:2px solid #f3e8ff;border-radius:16px;padding:1.5rem;margin-bottom:2rem;text-align:left;box-shadow:0 4px 12px #d946ef14}.benefit-item{display:flex;align-items:center;gap:1rem;padding:.75rem 0;color:#475569;font-weight:600;font-size:.9375rem}.benefit-item:not(:last-child){border-bottom:1px solid #f1f5f9}.benefit-icon{width:28px;height:28px;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#047857;font-weight:800;font-size:1rem;flex-shrink:0}.auth-modal-actions{display:flex;flex-direction:column;gap:.875rem}.btn-auth-primary,.btn-auth-secondary{padding:1.125rem 2rem;border:none;border-radius:14px;font-size:1.0625rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s;font-family:inherit}.btn-auth-primary{background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;box-shadow:0 8px 24px #d946ef59}.btn-auth-primary:hover{transform:translateY(-3px);box-shadow:0 12px 32px #d946ef73}.btn-auth-secondary{background:#fff;color:#7c3aed;border:2px solid #e9d5ff}.btn-auth-secondary:hover{background:#faf5ff;border-color:#d946ef;transform:translateY(-2px)}.auth-modal-footer{margin-top:1.5rem;font-size:.9375rem;color:#64748b;font-weight:600}@media(max-width:640px){.modal-content-auth{border-radius:24px 24px 0 0;max-height:95vh}.auth-modal-icon{width:80px;height:80px;font-size:2.5rem;margin-top:2rem}.auth-modal-content{padding:1.5rem 1.5rem 2rem}.auth-modal-title{font-size:1.625rem}.auth-modal-description{font-size:1rem}.sparkle{font-size:1.25rem}}:root{--sp-pink: #d946ef;--sp-purple: #a855f7;--sp-pink-pale: #ffc2e2;--sp-lav: #d4a5ff;--sp-indigo: #a5b4fc;--sp-bg: #fef7ff;--sp-bg2: #fff5f9;--sp-text: #1e0a2e;--sp-text2: #6b21a8;--sp-text3: #9333ea;--sp-border: rgba(217,70,239,.12);--sp-shadow: rgba(168,85,247,.15);--ease: cubic-bezier(.22, 1, .36, 1)}.contact-page{min-height:100vh;background:var(--sp-bg)}.contact-hero{position:relative;min-height:320px;background:linear-gradient(135deg,#ffc2e2,#d4a5ff,#a5b4fc);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:3.5rem 2rem}.contact-hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.15) 0%,transparent 55%)}.floating-bubble{position:absolute;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffffff59,#ffffff14);animation:floatBubble 14s ease-in-out infinite}.bubble-1{width:100px;height:100px;top:10%;left:8%;animation-delay:0s;animation-duration:14s}.bubble-2{width:140px;height:140px;top:50%;right:10%;animation-delay:2.5s;animation-duration:18s}.bubble-3{width:70px;height:70px;bottom:18%;left:22%;animation-delay:4.5s;animation-duration:12s}.bubble-4{width:110px;height:110px;top:20%;right:28%;animation-delay:1.2s;animation-duration:16s}@keyframes floatBubble{0%,to{transform:translate(0) scale(1);opacity:.7}50%{transform:translate(18px,-22px) scale(1.06);opacity:.9}}.contact-hero-content{position:relative;z-index:2;text-align:center;max-width:680px;animation:fadeInUp .7s var(--ease) both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.hero-badge{display:inline-flex;align-items:center;gap:7px;padding:7px 18px;background:#ffffffe0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:100px;color:var(--sp-pink);font-weight:600;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px;box-shadow:0 4px 16px #d946ef26}.hero-badge svg{font-size:.95rem}.contact-hero-title{font-size:clamp(1.8rem,4.5vw,3rem);font-weight:800;color:#fff;margin-bottom:12px;text-shadow:0 2px 16px rgba(100,30,120,.2);line-height:1.15}.contact-hero-subtitle{font-size:.98rem;color:#ffffffeb;line-height:1.65;margin:0 auto;max-width:500px;font-weight:400}.contact-content{padding:48px 0 56px;background:linear-gradient(to bottom,#fef7ff,#fff5f9)}.contact-container{max-width:1160px;margin:0 auto;padding:0 2rem}.contact-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:28px;align-items:start}.contact-form-section{background:#fff;padding:36px 40px;border-radius:20px;box-shadow:0 4px 24px #a855f71a,0 1px 4px #a855f70f;border:1.5px solid rgba(217,70,239,.1);position:relative;overflow:hidden}.contact-form-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--sp-pink),var(--sp-purple),var(--sp-indigo))}.form-header{margin-bottom:26px;padding-bottom:20px;border-bottom:1px solid rgba(217,70,239,.1)}.form-header h2{font-size:1.45rem;font-weight:700;color:var(--sp-text);margin-bottom:5px;letter-spacing:-.02em}.form-header p{color:#888;font-size:.87rem;margin:0}.contact-form{display:flex;flex-direction:column;gap:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group-contact{display:flex;flex-direction:column;gap:6px}.form-label-contact{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--sp-text2)}.input-wrapper-contact{position:relative}.input-icon-contact{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:#c084fc;font-size:.9rem;pointer-events:none;transition:color .2s}.form-input-contact{width:100%;padding:11px 13px 11px 38px;border:1.5px solid rgba(217,70,239,.18);border-radius:10px;font-size:.88rem;font-family:inherit;color:var(--sp-text);background:var(--sp-bg);transition:border-color .2s,box-shadow .2s,background .2s;outline:none}.form-input-contact::placeholder{color:#c4a0d4}.form-input-contact:focus{border-color:var(--sp-pink);background:#fff;box-shadow:0 0 0 3px #d946ef1a}.input-wrapper-contact:focus-within .input-icon-contact{color:var(--sp-pink)}.form-input-contact.error{border-color:#f87171;background:#fff5f5}.form-textarea-contact{resize:vertical;min-height:120px;padding:11px 13px;line-height:1.6;font-family:inherit}.form-error-contact{font-size:.73rem;color:#ef4444;font-weight:500}.btn-submit-contact{padding:13px 28px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;border-radius:12px;font-size:.84rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;transition:transform .22s var(--ease),box-shadow .22s;box-shadow:0 4px 18px #d946ef59,inset 0 1px #ffffff26;position:relative;overflow:hidden}.btn-submit-contact:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,.2) 50%,transparent 62%);background-size:200% 100%;background-position:200% 0;transition:background-position .5s ease}.btn-submit-contact:hover:after{background-position:-200% 0}.btn-submit-contact:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 28px #d946ef73}.btn-submit-contact:disabled{opacity:.6;cursor:not-allowed}.spinner-contact{width:17px;height:17px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .85s linear infinite}.contact-info-section{display:flex;flex-direction:column;gap:12px}.info-card{background:#fff;padding:18px 20px;border-radius:16px;box-shadow:0 2px 10px #a855f714;border:1.5px solid rgba(217,70,239,.1);display:flex;align-items:flex-start;gap:14px;transition:transform .22s var(--ease),box-shadow .22s,border-color .22s}.info-card:hover{transform:translateY(-3px);border-color:#d946ef47;box-shadow:0 6px 22px #a855f724}.info-card-icon{width:44px;height:44px;background:linear-gradient(135deg,#ffc2e2,#d946ef);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0;box-shadow:0 4px 12px #d946ef47}.info-card-content{flex:1;min-width:0}.info-card-content h3{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sp-pink);margin-bottom:5px}.info-card-content p{color:#555;font-size:.85rem;line-height:1.55;margin:2px 0;word-break:break-word}.whatsapp-link{display:inline-flex;align-items:center;gap:5px;color:#16a34a;font-weight:600;font-size:.82rem;text-decoration:none;margin-top:4px;transition:color .2s}.whatsapp-link:hover{color:#15803d}.schedule-list{display:flex;flex-direction:column;gap:2px}.schedule-list p.closed{color:#ef4444;font-weight:600;font-size:.82rem}.social-section{background:linear-gradient(135deg,white 0%,var(--sp-bg2) 100%);padding:18px 20px;border-radius:16px;text-align:center;border:1.5px solid rgba(217,70,239,.1);box-shadow:0 2px 10px #a855f712}.social-section h3{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sp-pink);margin-bottom:14px}.social-links{display:flex;justify-content:center;gap:10px}.social-link{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;text-decoration:none;transition:transform .22s var(--ease),box-shadow .22s;box-shadow:0 3px 8px #0000001f}.social-link:hover{transform:translateY(-4px) scale(1.1);box-shadow:0 7px 18px #0000002e}.social-link.facebook{background:linear-gradient(135deg,#1877f2,#0c63d4)}.social-link.instagram{background:linear-gradient(135deg,#f58529,#dd2a7b 50%,#8134af)}.social-link.twitter{background:linear-gradient(135deg,#1da1f2,#0d8bd9)}.map-section{position:relative;overflow:hidden}.map-container{position:relative;height:440px}.map-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;pointer-events:none}.map-info{background:#fffffff7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:30px 36px;border-radius:20px;box-shadow:0 10px 40px #a855f72e;text-align:center;max-width:360px;pointer-events:auto;border:1.5px solid rgba(217,70,239,.18)}.map-icon{width:56px;height:56px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 14px;box-shadow:0 6px 18px #d946ef52}.map-info h3{font-size:1.1rem;font-weight:700;color:var(--sp-text);margin-bottom:7px}.map-info p{color:#666;font-size:.87rem;margin-bottom:18px}.map-button{display:inline-flex;align-items:center;gap:7px;padding:11px 22px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:10px;text-decoration:none;font-size:.83rem;font-weight:600;letter-spacing:.04em;transition:transform .2s var(--ease),box-shadow .2s;box-shadow:0 4px 14px #d946ef4d}.map-button:hover{transform:translateY(-2px);box-shadow:0 6px 22px #d946ef6b}.faq-section{padding:56px 0;background:linear-gradient(160deg,#fef7ff,#fce7f3,#fef7ff)}.faq-header{text-align:center;margin-bottom:36px}.faq-header h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.faq-header p{color:#888;font-size:.95rem;margin:0}.faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.faq-card{background:#fff;padding:28px 24px;border-radius:18px;border:1.5px solid rgba(217,70,239,.1);transition:transform .22s var(--ease),box-shadow .22s,border-color .22s;text-align:center;box-shadow:0 2px 10px #a855f70f;position:relative;overflow:hidden}.faq-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#d946ef,#a855f7);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}.faq-card:hover{transform:translateY(-6px);border-color:#d946ef40;box-shadow:0 10px 30px #a855f721}.faq-card:hover:after{transform:scaleX(1)}.faq-icon{font-size:2.2rem;margin-bottom:13px;display:block}.faq-card h3{font-size:.97rem;font-weight:700;color:var(--sp-text);margin-bottom:10px}.faq-card p{color:#666;font-size:.85rem;line-height:1.65;margin:0}@media(max-width:1024px){.contact-grid{grid-template-columns:1fr}}@media(max-width:768px){.contact-hero{min-height:260px;padding:3rem 1.5rem}.contact-content{padding:36px 0 48px}.contact-container{padding:0 1.25rem}.contact-form-section{padding:26px 20px}.form-row{grid-template-columns:1fr}.info-card{flex-direction:column;align-items:center;text-align:center}.map-container{height:380px}.map-info{padding:24px 20px;max-width:88%}.faq-section{padding:42px 0}}@media(max-width:480px){.contact-hero-title{font-size:1.75rem}.contact-form-section{padding:20px 16px}.btn-submit-contact{font-size:.8rem}.faq-grid{grid-template-columns:1fr}}.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:.75rem 0;background:#fff;border-bottom:1px solid rgba(217,70,239,.08);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000a}.services-container{max-width:1400px;margin:0 auto;padding:0 2rem}.categories-scroll{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.categories-scroll::-webkit-scrollbar{height:2px}.categories-scroll::-webkit-scrollbar-track{background:transparent}.categories-scroll::-webkit-scrollbar-thumb{background:#d946ef;border-radius:2rem}.category-button{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .875rem;background:#fef7ff;border:1.5px solid #f0e7f5;border-radius:50px;font-weight:600;font-size:.8125rem;color:#6b21a8;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;flex-shrink:0;line-height:1.2;letter-spacing:.01em}.category-button:hover{background:#fff;border-color:#d946ef;color:#a21caf;transform:translateY(-1px);box-shadow:0 2px 8px #d946ef26}.category-button.active{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:transparent;color:#fff;box-shadow:0 2px 12px #d946ef59}.category-icon{font-size:1rem;line-height:1;display:inline-block}.category-label{font-weight:600;font-size:.8125rem;line-height:1.2}.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:1024px){.services-container{padding:0 1.5rem}}@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:.625rem 0}.categories-scroll{gap:.375rem}.category-button{padding:.3125rem .75rem;font-size:.75rem;gap:.3125rem}.category-icon{font-size:.875rem}.category-label{font-size:.75rem}.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)}.services-categories{padding:.5rem 0}.category-button{padding:.25rem .625rem;font-size:.6875rem;gap:.25rem}.category-icon{font-size:.8125rem}.category-label{font-size:.6875rem}.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)}}.services-count{text-align:center;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-xl);font-weight:500}.pagination-wrapper{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-2xl);padding-top:var(--spacing-2xl);border-top:1px solid var(--border-light)}.pagination-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-lg);background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-lg);font-weight:600;font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.pagination-btn:hover:not(:disabled){border-color:#d946ef;color:#d946ef;transform:translateY(-2px);box-shadow:0 4px 12px #d946ef26}.pagination-btn svg{font-size:1.125rem}.pagination-numbers{display:flex;gap:var(--spacing-xs)}.pagination-number{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-lg);font-weight:600;font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.pagination-number:hover{border-color:#d946ef;color:#d946ef;transform:translateY(-2px)}.pagination-number.active{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:transparent;color:#fff;box-shadow:0 4px 15px #d946ef4d}@media(max-width:768px){.pagination-wrapper{flex-wrap:wrap;gap:var(--spacing-sm)}.pagination-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:.75rem}.pagination-numbers{order:3;width:100%;justify-content:center}.pagination-number{width:36px;height:36px;font-size:.75rem}}@media(max-width:480px){.services-count{font-size:.75rem}.pagination-btn{flex:1}.pagination-numbers{gap:.25rem}.pagination-number{width:32px;height:32px}}.spa-categories-wrapper{padding:1.25rem 0;background:#fff;border-bottom:1px solid rgba(217,70,239,.1);position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0000000d}.spa-categories-container{max-width:1400px;margin:0 auto;padding:0 2rem}.spa-categories-scroll{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.spa-categories-scroll::-webkit-scrollbar{height:3px}.spa-categories-scroll::-webkit-scrollbar-track{background:#d946ef0d;border-radius:2rem}.spa-categories-scroll::-webkit-scrollbar-thumb{background:#d946ef;border-radius:2rem}.spa-category-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#fff;border:2px solid #f0e7f5;border-radius:50px;font-weight:600;font-size:.9375rem;color:#6b21a8;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;flex-shrink:0;line-height:1.2;letter-spacing:.01em;font-family:inherit;box-shadow:0 1px 3px #0000000d}.spa-category-chip:hover{background:#fef7ff;border-color:#d946ef;color:#a21caf;transform:translateY(-2px);box-shadow:0 4px 12px #d946ef33}.spa-category-chip.active{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:transparent;color:#fff;box-shadow:0 4px 16px #d946ef66;transform:translateY(-1px)}.spa-category-chip.active:hover{box-shadow:0 6px 20px #d946ef80;transform:translateY(-2px)}.spa-category-chip-icon{font-size:1.375rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;filter:brightness(.95)}.spa-category-chip.active .spa-category-chip-icon{filter:brightness(1.1);transform:scale(1.05)}.spa-category-chip-label{font-weight:600;font-size:.9375rem;line-height:1.2}.spa-category-chip{animation:slideInUp .4s ease-out backwards}.spa-category-chip:nth-child(1){animation-delay:0s}.spa-category-chip:nth-child(2){animation-delay:.05s}.spa-category-chip:nth-child(3){animation-delay:.1s}.spa-category-chip:nth-child(4){animation-delay:.15s}.spa-category-chip:nth-child(5){animation-delay:.2s}.spa-category-chip:nth-child(6){animation-delay:.25s}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.spa-categories-container{padding:0 1.5rem}.spa-category-chip{padding:.5625rem 1.125rem;font-size:.875rem;gap:.4375rem}.spa-category-chip-icon{font-size:1.25rem}.spa-category-chip-label{font-size:.875rem}}@media(max-width:768px){.spa-categories-wrapper{padding:1rem 0}.spa-categories-container{padding:0 1rem}.spa-categories-scroll{gap:.5rem}.spa-category-chip{padding:.5rem 1rem;font-size:.8125rem;gap:.375rem}.spa-category-chip-icon{font-size:1.125rem}.spa-category-chip-label{font-size:.8125rem}}@media(max-width:640px){.spa-category-chip{padding:.4375rem .875rem;font-size:.75rem}.spa-category-chip-icon{font-size:1rem}.spa-category-chip-label{font-size:.75rem}}@media(max-width:480px){.spa-categories-wrapper{padding:.875rem 0}.spa-categories-scroll{gap:.375rem}.spa-category-chip{padding:.375rem .75rem;font-size:.6875rem;gap:.3125rem}.spa-category-chip-icon{font-size:.9375rem}.spa-category-chip-label{font-size:.6875rem}}.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 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 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:16px;box-shadow:0 4px 20px #0000000f;overflow-x:auto;overflow-y:visible;position:relative}.orders-table{width:100%;border-collapse:collapse;position:relative}.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{position:relative}.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}.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;align-items:center;justify-content:center;gap:.5rem;position:relative;overflow:visible}.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:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-actions:hover .dropdown-menu,.dropdown-actions:focus-within .dropdown-menu{display:block}.dropdown-menu button{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;text-align:left;border:none;background:none;color:#374151;font-size:.875rem;cursor:pointer;transition:all .2s;white-space:nowrap}.dropdown-menu button:hover{background:#f8fafc;color:#d946ef}.dropdown-menu button:first-child{border-radius:8px 8px 0 0}.dropdown-menu button:last-child{border-radius:0 0 8px 8px}.dropdown-menu button.danger{color:#ef4444}.dropdown-menu button.danger:hover{background:#fef2f2;color:#dc2626}.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{display:flex;flex-direction:column;gap:1.5rem}.detail-header-improved{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-radius:12px;border:2px solid #f5d0fe}.detail-header-left{display:flex;flex-direction:column;gap:.5rem}.detail-code-badge svg{font-size:1.25rem}.detail-date{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;color:#6b7280}.detail-grid-improved{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.detail-card{background:#fff;border:2px solid #f3f4f6;border-radius:12px;overflow:hidden}.detail-card-title{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f9fafb;border-bottom:2px solid #e5e7eb;margin:0;font-size:1rem;font-weight:700;color:#1f2937}.detail-card-title svg{color:#d946ef;font-size:1.125rem}.detail-card-content{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.detail-field{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.detail-label{font-size:.875rem;color:#6b7280;font-weight:500;min-width:140px}.detail-value{font-size:.9375rem;color:#1f2937;font-weight:500;text-align:right;flex:1}.detail-value.text-sm{font-size:.8125rem;color:#6b7280}.text-muted{color:#9ca3af;font-style:italic}.payment-status-badge{padding:.375rem .875rem;border-radius:12px;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.detail-notes-section{display:flex;flex-direction:column;gap:1rem}.notes-content{padding:1rem 1.25rem;background:#fffbeb;border-left:4px solid #f59e0b;border-radius:8px;color:#78350f;line-height:1.6;font-size:.9375rem;white-space:pre-wrap}.modal-actions-improved{display:flex;gap:1rem;padding-top:1.5rem;border-top:2px solid #f3f4f6;justify-content:flex-end}@media(max-width:968px){.detail-grid-improved{grid-template-columns:1fr}.detail-field{flex-direction:column;align-items:flex-start}.detail-value{text-align:left}.detail-label{min-width:auto}}@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{position:relative;overflow:visible!important}.orders-table{min-width:1000px}}.table-scroll-wrapper{overflow-x:auto;overflow-y:visible}@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}}.stat-card-orders.stat-advance{background:linear-gradient(135deg,#fef3c7,#fde68a)}.stat-advance .stat-icon-orders{background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-assign-therapist{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-assign-therapist:hover{background:linear-gradient(135deg,#c026d3,#a21caf);transform:translateY(-2px);box-shadow:0 4px 12px #d946ef4d}.payment-cell{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}.payment-badge{padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600;display:inline-flex;align-items:center;gap:.375rem}.payment-badge.success{background:#d1fae5;color:#065f46}.payment-badge.warning{background:#fef3c7;color:#92400e}.payment-badge.error{background:#fee2e2;color:#991b1b}.btn-view-voucher{display:flex;align-items:center;justify-content:center;padding:.375rem;background:#f3e8ff;color:#7c3aed;border:1px solid #e9d5ff;border-radius:6px;cursor:pointer;transition:all .3s;font-size:1rem}.btn-view-voucher:hover{background:#e9d5ff;transform:scale(1.1)}.price-cell{display:flex;flex-direction:column;gap:.25rem}.price-total{font-size:1rem;font-weight:700;color:#0f172a}.price-advance{font-size:.8125rem;color:#64748b;font-weight:500}.expanded-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1rem}.notes-text.internal{background:#fef3c7;border-left:4px solid #f59e0b;color:#92400e}.info-value.price-highlight{font-size:1.125rem;font-weight:700;color:#d946ef}.info-value.badge-success{color:#065f46;background:#d1fae5;padding:.25rem .75rem;border-radius:6px;font-weight:600}.info-value.badge-warning{color:#92400e;background:#fef3c7;padding:.25rem .75rem;border-radius:6px;font-weight:600}.info-value.badge-error{color:#991b1b;background:#fee2e2;padding:.25rem .75rem;border-radius:6px;font-weight:600}.assign-therapist-modal{padding:1.5rem}.assign-info{background:#f8fafc;padding:1.25rem;border-radius:12px;margin-bottom:1.5rem;border-left:4px solid #d946ef}.assign-info p{margin:.5rem 0;font-size:.9375rem;color:#475569}.therapist-selection label{display:block;font-size:1rem;font-weight:600;color:#0f172a;margin-bottom:1rem}.therapist-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.therapist-option{position:relative;display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .3s}.therapist-option:hover{border-color:#d946ef;transform:translateY(-2px);box-shadow:0 4px 12px #d946ef26}.therapist-option.selected{border-color:#d946ef;background:linear-gradient(135deg,#faf5ff,#f3e8ff)}.therapist-avatar-assign{width:50px;height:50px;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;flex-shrink:0}.therapist-info-assign{flex:1}.therapist-name-assign{font-size:.9375rem;font-weight:700;color:#0f172a;margin-bottom:.25rem}.therapist-specialty-assign{font-size:.8125rem;color:#64748b;margin-bottom:.25rem}.therapist-rating-assign{font-size:.8125rem;color:#f59e0b;font-weight:600}.therapist-check{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;background:#10b981;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem}.voucher-modal{padding:1.5rem}.voucher-info{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem;padding:1.25rem;background:#f8fafc;border-radius:12px}.voucher-detail{display:flex;flex-direction:column;gap:.25rem}.voucher-label{font-size:.8125rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.voucher-value{font-size:1rem;color:#0f172a;font-weight:600}.voucher-value.price{font-size:1.25rem;color:#d946ef;font-weight:700}.voucher-image-container{border-radius:12px;overflow:hidden;border:2px solid #e2e8f0;margin-bottom:1.5rem;background:#f8fafc}.voucher-image{width:100%;height:auto;display:block}@media(max-width:1024px){.expanded-grid,.therapist-grid,.voucher-info{grid-template-columns:1fr}}.assign-therapist-modal{display:flex;flex-direction:column;gap:2rem}.assign-info{background:linear-gradient(135deg,#fdf4ff,#fae8ff);border:2px solid #e879f9;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:.5rem}.assign-info p{margin:0;font-size:.9375rem;color:#581c87}.assign-info strong{color:#7e22ce;font-weight:700}.commission-alert{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-radius:12px;border:2px solid;animation:fadeIn .3s ease}.commission-alert svg{font-size:1.75rem;flex-shrink:0}.commission-alert.warning{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#f59e0b;color:#92400e}.commission-alert.warning svg{color:#f59e0b}.commission-alert.error{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#ef4444;color:#991b1b}.commission-alert.error svg{color:#ef4444}.commission-alert.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#10b981;color:#065f46}.commission-alert.success svg{color:#10b981}.commission-alert strong{display:block;font-size:1.125rem;margin-bottom:.25rem}.commission-alert p{margin:0;font-size:.9375rem}.therapist-selection{display:flex;flex-direction:column;gap:1rem}.therapist-selection label{font-size:1rem;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:.5rem}.therapist-selection label svg{font-size:1.25rem;color:#d946ef}.therapist-grid-multi{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;max-height:500px;overflow-y:auto;padding:.5rem}.therapist-option-multi{background:#fff;border:3px solid #e5e7eb;border-radius:16px;transition:all .3s ease;overflow:hidden}.therapist-option-multi:hover{border-color:#d946ef;box-shadow:0 4px 16px #d946ef26}.therapist-option-multi.selected{border-color:#d946ef;background:linear-gradient(135deg,#fdf4ff,#fae8ff);box-shadow:0 4px 16px #d946ef33}.therapist-header-multi{-webkit-user-select:none;user-select:none}.therapist-option-multi.selected .therapist-commission-editor{display:flex!important;flex-direction:column;gap:.75rem;padding:1.25rem;background:#fdf4ffe6;border-top:2px solid rgba(217,70,239,.3);pointer-events:all}.therapist-commission-editor .commission-input-group{pointer-events:all;position:relative;z-index:10}.therapist-commission-editor input.commission-input{pointer-events:all;position:relative;z-index:11;cursor:text}.therapist-header-multi:hover{background:#d946ef0d}.therapist-checkbox{width:28px;height:28px;border:3px solid #d1d5db;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}.therapist-option-multi.selected .therapist-checkbox{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:#d946ef;color:#fff;transform:scale(1.1)}.therapist-checkbox svg{font-size:1.25rem;font-weight:700}.therapist-avatar-assign{width:56px;height:56px;background:linear-gradient(135deg,#d946ef,#a855f7);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;flex-shrink:0;box-shadow:0 4px 12px #d946ef4d}.therapist-info-assign{flex:1;min-width:0}.therapist-name-assign{font-size:1rem;font-weight:700;color:#1f2937;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.therapist-specialty-assign{font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.therapist-rating-assign{font-size:.875rem;color:#f59e0b;font-weight:600}.therapist-commission-editor{padding:1.25rem;background:#fffc;border-top:2px solid rgba(217,70,239,.2);display:flex;flex-direction:column;gap:.75rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;max-height:0;padding:0 1.25rem}to{opacity:1;max-height:200px;padding:1.25rem}}.therapist-commission-editor label{font-size:.875rem;font-weight:700;color:#4b5563;display:flex;align-items:center;gap:.5rem}.therapist-commission-editor label svg{color:#d946ef}.commission-input-group{display:flex;align-items:center;gap:.5rem;background:#fff;border:2px solid #d1d5db;border-radius:10px;padding:.75rem 1rem;transition:all .3s}.commission-input{flex:1;border:none;outline:none;font-size:1.25rem;font-weight:700;color:#1f2937;text-align:right;width:80px;background:transparent;-moz-appearance:textfield}.commission-input::-webkit-outer-spin-button,.commission-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.commission-input-group{display:flex;align-items:center;gap:.5rem;background:#fff;border:2px solid #d1d5db;border-radius:10px;padding:.75rem 1rem;transition:all .3s;cursor:text}.commission-input-group:focus-within{border-color:#d946ef;box-shadow:0 0 0 4px #d946ef1a}.commission-symbol{font-size:1.25rem;font-weight:700;color:#6b7280}.commission-amount{font-size:1rem;font-weight:700;color:#10b981;text-align:center;padding:.5rem;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:8px}.assignment-summary{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #cbd5e1;border-radius:12px;padding:1.5rem}.assignment-summary h4{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.assignment-summary h4 svg{color:#10b981;font-size:1.25rem}.summary-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.summary-item{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1rem;align-items:center;padding:.875rem;background:#fff;border-radius:8px;border:1px solid #e2e8f0}.summary-therapist{font-weight:600;color:#1f2937}.summary-commission{font-weight:700;color:#d946ef;text-align:center;font-size:1.125rem}.summary-amount{font-weight:700;color:#10b981;text-align:right;font-size:1.125rem}.summary-total{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border:2px solid #d946ef;border-radius:8px;margin-top:1rem}.summary-total span:first-child{font-size:1.125rem;font-weight:700;color:#7e22ce}.total-value{font-size:1.5rem;font-weight:800;color:#d946ef}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:2px solid #e5e7eb}.btn-primary:disabled{background:#d1d5db;cursor:not-allowed;opacity:.6}.btn-primary:disabled:hover{transform:none;box-shadow:none}@media(max-width:768px){.therapist-grid-multi{grid-template-columns:1fr}.summary-item{grid-template-columns:1fr;text-align:center}.summary-amount,.summary-commission{text-align:center}.assign-info{padding:1rem}.commission-alert{flex-direction:column;text-align:center}}.therapist-primary{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#1f2937}.btn-manage-therapists{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .875rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #cbd5e1;border-radius:8px;font-size:.8125rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .3s}.btn-manage-therapists:hover{border-color:#d946ef;color:#d946ef;background:linear-gradient(135deg,#fdf4ff,#fae8ff)}.therapist-list-cell{display:flex;flex-direction:column;gap:.5rem}.therapist-names{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;color:#1f2937;font-weight:600;line-height:1.4}.therapist-names svg{color:#d946ef;flex-shrink:0;margin-top:2px;font-size:1rem}.therapist-names span{word-break:break-word}.btn-manage-therapists{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border:1.5px solid #e879f9;border-radius:8px;font-size:.8125rem;font-weight:600;color:#a21caf;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-manage-therapists:hover{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:#d946ef;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #d946ef4d}.total-value.error{color:#ef4444!important}.tam-wrapper{display:flex;flex-direction:column;gap:1.25rem}.tam-booking-card{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem}.tam-booking-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem 1.5rem}.tam-booking-field{display:flex;flex-direction:column;gap:.2rem}.tam-booking-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8}.tam-booking-value{font-size:.9375rem;font-weight:600;color:#1e293b}.tam-booking-value.tam-price{color:#7c3aed;font-size:1.0625rem}.tam-commission-bar-wrapper{display:flex;flex-direction:column;gap:.5rem}.tam-commission-bar-header{display:flex;align-items:center;justify-content:space-between}.tam-commission-bar-title{display:flex;align-items:center;gap:.4rem;font-size:.875rem;font-weight:700;color:#475569}.tam-commission-bar-title svg{color:#7c3aed}.tam-commission-bar-total{font-size:.9375rem;font-weight:800;border-radius:20px;padding:.2rem .75rem}.tam-commission-bar-total.tam-partial{background:#fef3c7;color:#92400e}.tam-commission-bar-total.tam-full{background:#d1fae5;color:#065f46}.tam-commission-bar-total.tam-over{background:#fee2e2;color:#991b1b}.tam-commission-track{position:relative;height:10px;background:#e2e8f0;border-radius:99px;overflow:visible}.tam-commission-fill{height:100%;border-radius:99px;transition:width .35s cubic-bezier(.4,0,.2,1)}.tam-fill-partial{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.tam-fill-full{background:linear-gradient(90deg,#10b981,#34d399)}.tam-fill-over{background:linear-gradient(90deg,#ef4444,#f87171)}.tam-track-mark{position:absolute;top:-3px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;pointer-events:none}.tam-track-mark:before{content:"";display:block;width:2px;height:16px;background:#cbd5e1;border-radius:1px}.tam-track-mark span{font-size:.65rem;color:#94a3b8;margin-top:2px;font-weight:600}.tam-commission-hint{font-size:.8125rem;min-height:1.25rem}.tam-hint-error{color:#dc2626;display:flex;align-items:center;gap:.35rem;font-weight:600}.tam-hint-warning{color:#92400e;font-weight:500}.tam-hint-success{color:#059669;display:flex;align-items:center;gap:.35rem;font-weight:600}.tam-section-label{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;padding-bottom:.25rem;border-bottom:1.5px solid #f1f5f9}.tam-section-label svg{color:#a855f7}.tam-therapist-list{display:flex;flex-direction:column;gap:.5rem;max-height:380px;overflow-y:auto;padding-right:2px}.tam-therapist-list::-webkit-scrollbar{width:4px}.tam-therapist-list::-webkit-scrollbar-track{background:transparent}.tam-therapist-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}.tam-therapist-row{border:2px solid #e2e8f0;border-radius:12px;transition:border-color .2s,box-shadow .2s;background:#fff}.tam-therapist-row:hover{border-color:#c4b5fd}.tam-therapist-row.tam-therapist-selected{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed14}.tam-therapist-toggle{display:flex;align-items:center;gap:.875rem;width:100%;padding:.875rem 1rem;background:transparent;border:none;cursor:pointer;text-align:left;transition:background .15s}.tam-therapist-toggle:hover,.tam-therapist-selected .tam-therapist-toggle{background:#faf5ff}.tam-check-box{width:22px;height:22px;border:2px solid #cbd5e1;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;color:#fff;font-size:.75rem}.tam-check-box.tam-checked{background:#7c3aed;border-color:#7c3aed}.tam-therapist-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;font-weight:800;font-size:1.0625rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #7c3aed40}.tam-therapist-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.tam-therapist-name{font-size:.9375rem;font-weight:700;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tam-therapist-spec{font-size:.8125rem;color:#64748b}.tam-therapist-rating{font-size:.8125rem;color:#f59e0b;font-weight:600;flex-shrink:0}.tam-commission-zone{display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem .875rem;background:#faf5ff;border-top:1.5px dashed #ddd6fe;position:relative;z-index:1;overflow:visible}.tam-commission-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#7c3aed;flex-shrink:0}.tam-commission-control{display:flex;align-items:center;background:#fff;border:2px solid #ddd6fe;border-radius:8px;padding:.375rem .625rem;gap:.25rem;transition:border-color .2s,box-shadow .2s}.tam-commission-control:focus-within{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.tam-pct-input{width:52px;border:none;outline:none;font-size:1.0625rem;font-weight:800;color:#1e293b;text-align:right;background:transparent;-moz-appearance:textfield;cursor:text}.tam-pct-input::-webkit-outer-spin-button,.tam-pct-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.tam-pct-symbol{font-size:1rem;font-weight:700;color:#7c3aed}.tam-commission-monto{margin-left:auto;font-size:.9375rem;font-weight:700;color:#059669;background:#d1fae5;padding:.25rem .625rem;border-radius:20px;flex-shrink:0}.tam-summary{border:2px solid #e2e8f0;border-radius:12px;overflow:hidden}.tam-summary-title{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#f8fafc;font-size:.875rem;font-weight:700;color:#475569;border-bottom:1.5px solid #e2e8f0}.tam-summary-title svg{color:#10b981}.tam-summary-rows{display:flex;flex-direction:column}.tam-summary-row{display:grid;grid-template-columns:1fr auto auto;gap:1rem;align-items:center;padding:.625rem 1rem;border-bottom:1px solid #f1f5f9;transition:background .15s}.tam-summary-row:last-child{border-bottom:none}.tam-summary-row:hover{background:#faf5ff}.tam-summary-name{font-size:.9rem;font-weight:600;color:#1e293b}.tam-summary-pct{font-size:.9375rem;font-weight:800;color:#7c3aed;text-align:right}.tam-summary-monto{font-size:.9rem;font-weight:700;color:#059669;text-align:right}.tam-summary-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#f8fafc;border-top:2px solid #e2e8f0;font-size:.875rem;font-weight:700;color:#475569}.tam-summary-total{display:flex;align-items:baseline;gap:.5rem;font-size:1.125rem;font-weight:800;color:#7c3aed}.tam-summary-total.tam-over{color:#dc2626}.tam-summary-total em{font-style:normal;font-size:.875rem;font-weight:600;color:#059669;background:#d1fae5;padding:.15rem .5rem;border-radius:20px}.tam-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem;border-top:1.5px solid #f1f5f9}.tam-btn-cancel{padding:.625rem 1.25rem;border:2px solid #e2e8f0;border-radius:10px;background:#fff;color:#64748b;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s}.tam-btn-cancel:hover{border-color:#94a3b8;color:#1e293b}.tam-btn-confirm{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.5rem;border:none;border-radius:10px;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;font-size:.9375rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #7c3aed4d}.tam-btn-confirm:hover:not(:disabled){background:linear-gradient(135deg,#6d28d9,#9333ea);transform:translateY(-1px);box-shadow:0 6px 16px #7c3aed66}.tam-btn-confirm:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed;box-shadow:none;transform:none}@media(max-width:640px){.tam-booking-row{grid-template-columns:1fr 1fr}.tam-commission-zone{flex-wrap:wrap}.tam-actions{flex-direction:column-reverse}.tam-btn-cancel,.tam-btn-confirm{width:100%;justify-content:center}}.refund-modal{display:flex;flex-direction:column;gap:1.5rem}.refund-info-card{background:linear-gradient(135deg,#fef3c7,#fef9e7);border:1px solid #fde68a;border-radius:12px;padding:1.5rem}.refund-info-card h4{margin:0 0 1rem;color:#92400e;font-size:1rem}.refund-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.refund-info-item{display:flex;flex-direction:column;gap:.25rem}.refund-info-item .label{font-size:.75rem;color:#78350f;font-weight:500}.refund-info-item .value{font-size:.875rem;color:#451a03;font-weight:600}.refund-info-item .value.highlight{color:#dc2626;font-size:1.125rem}.refund-form{display:flex;flex-direction:column;gap:1rem}@media(max-width:768px){.refund-info-grid{grid-template-columns:1fr}}.dropdown-menu button.refund-action{color:#f59e0b;background:#fef3c7}.dropdown-menu button.refund-action:hover{background:#fde68a;color:#d97706}.dropdown-menu button svg{font-size:1rem;flex-shrink:0}.create-booking-form{display:flex;flex-direction:column;gap:1.5rem}.create-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.create-form-section{display:flex;flex-direction:column;gap:1rem}.create-form-section h3{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;color:#1f2937;margin:1rem 0 .5rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.create-form-section h3 svg{color:#d946ef}.service-preview-card{background:linear-gradient(135deg,#faf5ff,#fff);border:1px solid #e9d5ff;border-radius:12px;padding:1rem;margin-bottom:1rem}.service-preview-card h4{margin:0 0 .5rem;color:#7c3aed}.service-preview-details{display:flex;gap:1rem;font-size:.875rem;color:#6b7280}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-input,.form-select,.form-textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.form-input.error,.form-select.error,.form-textarea.error{border-color:#ef4444}.form-error{color:#ef4444;font-size:.75rem}.form-hint{color:#6b7280;font-size:.75rem}@media(max-width:768px){.create-form-grid,.form-row{grid-template-columns:1fr}}.dropdown-smart-trigger{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;background:#fff;border-radius:8px;color:#6b7280;cursor:pointer;transition:all .2s;font-size:1.125rem}.dropdown-smart-trigger:hover{background:#faf5ff;color:#d946ef;border-color:#e9d5ff}.dropdown-smart-portal{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 30px #0003;min-width:220px;max-height:450px;overflow-y:auto;animation:dropdownFadeIn .2s cubic-bezier(.4,0,.2,1)}.dropdown-smart-portal.direction-top{transform-origin:bottom right}.dropdown-smart-portal.direction-bottom{transform-origin:top right}@keyframes dropdownFadeIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.dropdown-smart-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;text-align:left;border:none;background:none;color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;border-bottom:1px solid #f3f4f6}.dropdown-smart-item:first-child{border-radius:12px 12px 0 0}.dropdown-smart-item:last-child{border-bottom:none;border-radius:0 0 12px 12px}.dropdown-smart-item:hover{background:linear-gradient(90deg,#faf5ff 0%,transparent 100%);color:#d946ef;padding-left:1.25rem}.dropdown-smart-item.variant-danger{color:#ef4444}.dropdown-smart-item.variant-danger:hover{background:linear-gradient(90deg,#fef2f2 0%,transparent 100%);color:#dc2626}.dropdown-smart-item.variant-warning{color:#f59e0b}.dropdown-smart-item.variant-warning:hover{background:linear-gradient(90deg,#fffbeb 0%,transparent 100%);color:#d97706}.dropdown-smart-item.variant-success{color:#10b981}.dropdown-smart-item.variant-success:hover{background:linear-gradient(90deg,#ecfdf5 0%,transparent 100%);color:#059669}.dropdown-smart-item svg{font-size:1.125rem;flex-shrink:0}.dropdown-smart-portal::-webkit-scrollbar{width:6px}.dropdown-smart-portal::-webkit-scrollbar-track{background:#f9fafb;border-radius:3px}.dropdown-smart-portal::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.dropdown-smart-portal::-webkit-scrollbar-thumb:hover{background:#9ca3af}.service-add-container{display:flex;gap:.75rem;align-items:flex-start}.btn-add-service{padding:.75rem 1.25rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;white-space:nowrap;transition:all .2s;font-size:.9375rem}.btn-add-service:hover{transform:translateY(-2px);box-shadow:0 6px 16px #d946ef66}.services-list{background:#f9fafb;border-radius:12px;padding:1.25rem;margin-top:1rem}.services-list h4{margin:0 0 1rem;color:#1f2937;font-size:1rem;font-weight:700}.service-item{display:flex;align-items:center;justify-content:space-between;background:#fff;padding:1rem;border-radius:8px;margin-bottom:.75rem;border:2px solid #e5e7eb;transition:all .2s}.service-item:hover{border-color:#d946ef;box-shadow:0 2px 8px #d946ef1a}.service-item:last-child{margin-bottom:0}.service-item-info{display:flex;align-items:center;gap:1rem;flex:1}.service-number{width:32px;height:32px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.service-details{flex:1}.service-details strong{display:block;color:#1f2937;font-size:.9375rem;margin-bottom:.375rem}.service-meta{display:flex;gap:1rem;font-size:.8125rem;color:#6b7280;flex-wrap:wrap}.service-meta span{display:flex;align-items:center;gap:.25rem}.btn-remove-service{width:32px;height:32px;background:#fee2e2;color:#dc2626;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;font-size:1.125rem}.btn-remove-service:hover{background:#dc2626;color:#fff;transform:scale(1.1)}.services-summary{margin-top:1rem;padding-top:1rem;border-top:2px dashed #e5e7eb}.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;color:#6b7280;font-size:.9375rem}.summary-row.total{font-size:1.125rem;color:#1f2937;font-weight:700;padding-top:.75rem;border-top:2px solid #e5e7eb;margin-top:.5rem}.summary-row.total strong{color:#d946ef}.service-cell{display:flex;flex-direction:column;gap:.375rem}.service-name{font-weight:500;color:#374151;line-height:1.4;font-size:.9375rem}.services-count-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:12px;font-size:.6875rem;font-weight:600;width:fit-content}.service-cell{display:flex;flex-direction:column;gap:.375rem;align-items:flex-start}.service-name{font-weight:400!important;color:#374151;line-height:1.4;font-size:.875rem}.services-count-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:12px;font-size:.6875rem;font-weight:600;width:fit-content;letter-spacing:.3px}.duration-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;background:#f3f4f6;color:#6b7280;border-radius:12px;font-size:.6875rem;font-weight:500;width:fit-content}.price-hint{font-size:.75rem;color:#9ca3af;margin-top:.25rem}.appointment-detail-modal{display:flex;flex-direction:column;gap:1.5rem;max-width:100%;padding:0}.detail-header-improved{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-radius:12px;border:2px solid #f5d0fe;flex-wrap:wrap;gap:1rem}.detail-header-left{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:200px}.detail-code-badge{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;color:#d946ef}.detail-code-badge svg{font-size:1.25rem;flex-shrink:0}.detail-date{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.detail-date svg{flex-shrink:0}.detail-grid-improved{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;width:100%}.detail-card{background:#fff;border:2px solid #f3f4f6;border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.detail-card-title{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f9fafb;border-bottom:2px solid #e5e7eb;margin:0;font-size:.9375rem;font-weight:700;color:#1f2937}.detail-card-title svg{color:#d946ef;font-size:1.125rem;flex-shrink:0}.detail-card-content{padding:1.25rem;display:flex;flex-direction:column;gap:1rem;flex:1}.detail-field{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding-bottom:.75rem;border-bottom:1px solid #f3f4f6}.detail-field:last-child{border-bottom:none;padding-bottom:0}.detail-label{font-size:.8125rem;color:#6b7280;font-weight:500;min-width:120px;flex-shrink:0}.detail-value{font-size:.875rem;color:#1f2937;font-weight:500;text-align:right;flex:1;word-break:break-word}.detail-value.price-large{font-size:1.25rem;font-weight:700;color:#d946ef}.detail-value.saldo{color:#f59e0b;font-weight:600}.detail-value.highlight{color:#d946ef;font-weight:600}.detail-value.capitalize{text-transform:capitalize}.detail-value.text-sm{font-size:.75rem;color:#6b7280}.text-muted{color:#9ca3af;font-style:italic;font-size:.875rem}.payment-status-badge{display:inline-flex;padding:.375rem .875rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;width:fit-content}.payment-status-badge.success{background:#d1fae5;color:#065f46}.payment-status-badge.warning{background:#fef3c7;color:#92400e}.payment-status-badge.error{background:#fee2e2;color:#991b1b}.detail-notes-section{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;width:100%}.notes-content{padding:1rem 1.25rem;background:#fffbeb;border-left:4px solid #f59e0b;border-radius:8px;color:#78350f;line-height:1.6;font-size:.875rem;white-space:pre-wrap;word-break:break-word}.notes-content.internal{background:#eff6ff;border-left-color:#3b82f6;color:#1e40af}.modal-actions-improved{display:flex;gap:1rem;padding-top:1.5rem;border-top:2px solid #f3f4f6;justify-content:flex-end;flex-wrap:wrap}.btn-full{width:100%;justify-content:center;margin-top:.75rem}@media(max-width:1024px){.detail-grid-improved,.detail-notes-section{grid-template-columns:1fr}}@media(max-width:768px){.detail-header-improved{flex-direction:column;align-items:flex-start}.detail-field{flex-direction:column;align-items:flex-start;gap:.5rem}.detail-value{text-align:left}.detail-label{min-width:auto}.modal-actions-improved{flex-direction:column}.modal-actions-improved .btn{width:100%}}.detail-services-list{display:flex;flex-direction:column;gap:.5rem}.detail-service-item{padding:.75rem;background:#fdf4ff;border-radius:8px;border-left:3px solid #d946ef;display:flex;justify-content:space-between;align-items:center}.detail-service-name{font-weight:500;color:#1f2937;font-size:.875rem}.detail-service-meta{display:flex;gap:1rem;font-size:.75rem;color:#6b7280}.price-cell{display:flex;flex-direction:column;gap:.375rem;align-items:flex-start}.price-total{font-weight:600;color:#1f2937;font-size:1rem}.price-advance{font-size:.75rem;color:#6b7280}.status-badge-modal{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.status-badge-modal svg{font-size:1rem}.status-badge-modal.success{background:#d1fae5;color:#065f46}.status-badge-modal.warning{background:#fef3c7;color:#92400e}.status-badge-modal.info{background:#dbeafe;color:#1e40af}.status-badge-modal.completed{background:#e9d5ff;color:#6b21a8}.status-badge-modal.error{background:#fee2e2;color:#991b1b}.status-badge-modal.cancelled{background:#fce7f3;color:#9f1239}.detail-modal-wide{display:flex;flex-direction:column;gap:1.5rem;padding:.5rem}.detail-header-wide{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-radius:16px;gap:1.5rem}.detail-header-info{flex:1}.detail-code-wide{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:#d946ef;margin:0 0 .5rem}.detail-code-wide svg{font-size:1.75rem}.detail-date-wide{display:flex;align-items:center;gap:.75rem;font-size:1rem;color:#6b7280;margin:0}.status-badge-wide{display:inline-flex;align-items:center;gap:.625rem;padding:.75rem 1.5rem;border-radius:12px;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge-wide svg{font-size:1.25rem}.status-badge-wide.success{background:#d1fae5;color:#065f46}.status-badge-wide.warning{background:#fef3c7;color:#92400e}.status-badge-wide.info{background:#dbeafe;color:#1e40af}.status-badge-wide.completed{background:#e9d5ff;color:#6b21a8}.status-badge-wide.error{background:#fee2e2;color:#991b1b}.status-badge-wide.cancelled{background:#fce7f3;color:#9f1239}.detail-content-wide{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.detail-column-wide{display:flex;flex-direction:column;gap:1.5rem}.detail-section-wide{background:#fff;border:2px solid #f3f4f6;border-radius:12px;overflow:hidden}.detail-section-title{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f9fafb;border-bottom:2px solid #e5e7eb;margin:0;font-size:1rem;font-weight:700;color:#1f2937}.detail-section-title svg{color:#d946ef;font-size:1.125rem}.detail-info-wide{padding:1.25rem;display:flex;flex-direction:column;gap:.875rem}.detail-row-wide{display:flex;align-items:center;gap:.625rem;font-size:.9375rem;color:#374151;line-height:1.5}.detail-row-wide.small{font-size:.8125rem;color:#6b7280}.detail-icon-inline{color:#9ca3af;font-size:1rem;flex-shrink:0}.detail-label-inline{color:#6b7280;font-weight:500;min-width:100px}.detail-value-inline{color:#1f2937;font-weight:500}.detail-value-inline.capitalize{text-transform:capitalize}.detail-service-block{padding:1rem;background:#fdf4ff;border-radius:8px;border-left:4px solid #d946ef}.service-name-wide{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 .5rem;line-height:1.4}.service-count-wide{display:inline-block;padding:.25rem .75rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;margin-bottom:.5rem}.service-duration-wide{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280;margin:0}.price-breakdown-wide{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#f9fafb;border-radius:8px;margin-bottom:1rem}.price-item-wide{display:flex;justify-content:space-between;align-items:center;font-size:.9375rem}.price-item-wide.total{padding-top:.75rem;border-top:2px dashed #e5e7eb;font-size:1.125rem}.price-item-wide.total strong{font-size:1.5rem;color:#d946ef;font-weight:700}.price-item-wide.pending strong{color:#f59e0b;font-weight:600}.price-item-wide span:first-child{color:#6b7280}.payment-details-wide{display:flex;flex-direction:column;gap:.625rem}.payment-badge-inline{display:inline-flex;padding:.25rem .75rem;border-radius:8px;font-size:.75rem;font-weight:600;text-transform:uppercase}.payment-badge-inline.success{background:#d1fae5;color:#065f46}.payment-badge-inline.warning{background:#fef3c7;color:#92400e}.payment-badge-inline.error{background:#fee2e2;color:#991b1b}.btn-voucher-wide{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem;background:#fff;border:2px solid #d946ef;color:#d946ef;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.75rem}.btn-voucher-wide:hover{background:#d946ef;color:#fff}.note-box-wide{padding:.875rem;border-radius:8px;border-left:3px solid;margin-bottom:.75rem}.note-box-wide:last-child{margin-bottom:0}.note-box-wide small{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;opacity:.8}.note-box-wide p{margin:0;font-size:.875rem;line-height:1.6;white-space:pre-wrap}.note-box-wide.client{background:#fffbeb;border-left-color:#f59e0b;color:#78350f}.note-box-wide.internal{background:#eff6ff;border-left-color:#3b82f6;color:#1e40af}.detail-actions-wide{display:flex;gap:1rem;padding-top:1.5rem;border-top:2px solid #f3f4f6;justify-content:flex-end}@media(max-width:1200px){.detail-content-wide{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.detail-content-wide{grid-template-columns:1fr}.detail-header-wide{flex-direction:column;align-items:flex-start}.detail-actions-wide{flex-direction:column}.detail-actions-wide .btn{width:100%}}.badge-servicios-count{display:inline-block;padding:.25rem .625rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:12px;font-size:.6875rem;font-weight:600;margin-top:.375rem}.payment-modal-container{padding:1.5rem}.payment-reservation-info{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-radius:16px;padding:1.5rem;margin-bottom:2rem;border:2px solid #e9d5ff}.info-grid-payment{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.info-item-payment{display:flex;flex-direction:column;gap:.375rem}.info-item-payment.highlight{background:#fff;padding:1rem;border-radius:12px;border:2px solid #d946ef}.label-payment{font-size:.8125rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.value-payment{font-size:1rem;color:#0f172a;font-weight:600}.value-payment.price-total{font-size:1.125rem;color:#7c3aed}.value-payment.saldo-pendiente{font-size:1.5rem;color:#d946ef;font-weight:800}.payment-form{background:#fff}.form-grid-payment{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.form-group-payment{display:flex;flex-direction:column;gap:.5rem}.form-group-payment.full-width{grid-column:1 / -1}.form-group-payment label{font-size:.9375rem;font-weight:600;color:#0f172a}.form-input-payment{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .3s;font-family:inherit;width:100%}.form-input-payment:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.form-input-payment.error{border-color:#ef4444}.input-icon-payment{position:absolute;left:1rem;color:#94a3b8;font-size:1.25rem;pointer-events:none}.input-with-icon .form-input-payment{padding-left:3rem}.error-text-payment{font-size:.875rem;color:#ef4444;margin-top:-.25rem}.payment-methods-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.payment-method-option{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .3s}.payment-method-option:hover{border-color:#d946ef;transform:translateY(-2px);box-shadow:0 4px 12px #d946ef26}.payment-method-option.selected{border-color:#d946ef;background:linear-gradient(135deg,#faf5ff,#f3e8ff);box-shadow:0 4px 12px #d946ef33}.payment-method-icon{font-size:2rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.payment-method-option.selected .payment-method-icon{background:linear-gradient(135deg,#d946ef,#c026d3);filter:grayscale(0)}.payment-method-option span{font-size:.9375rem;font-weight:600;color:#0f172a}.voucher-upload-payment{margin-top:.5rem}.voucher-upload-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px dashed #cbd5e1;border-radius:12px;color:#64748b;font-weight:600;cursor:pointer;transition:all .3s}.voucher-upload-btn:hover{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);border-color:#d946ef;color:#d946ef}.voucher-preview-payment{position:relative;border-radius:12px;overflow:hidden;border:2px solid #e2e8f0;background:#f8fafc}.voucher-preview-payment img{width:100%;max-height:300px;object-fit:contain;display:block;padding:1rem}.pdf-preview{padding:2rem;text-align:center;font-size:1.125rem;color:#64748b}.remove-voucher-btn{position:absolute;top:.75rem;right:.75rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ef4444f2;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .3s;font-size:1.125rem}.remove-voucher-btn:hover{background:#dc2626;transform:scale(1.1)}.payment-modal-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1.5rem;border-top:2px solid #f1f5f9}.spinner-inline{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(max-width:1024px){.info-grid-payment,.payment-methods-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.form-grid-payment,.info-grid-payment,.payment-methods-grid{grid-template-columns:1fr}.payment-modal-actions{flex-direction:column-reverse}.payment-modal-actions .btn{width:100%}}.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}.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}}.upload-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s;width:fit-content;border:none}.upload-button:hover{background:linear-gradient(135deg,#c026d3,#a21caf);transform:translateY(-2px);box-shadow:0 8px 20px #d946ef4d}.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(3,minmax(320px,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}}.module-card[data-module=aulavirtual]{--module-gradient: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%)}.module-card.hovered[data-module=aulavirtual] .module-card-glow{background:radial-gradient(circle at center,rgba(59,130,246,.4),transparent)}.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-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}.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-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}}.image-upload-container{display:flex;flex-direction:column;gap:1rem}.upload-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s;width:fit-content}.upload-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f64d}.image-preview{position:relative;width:200px;height:200px;border-radius:12px;overflow:hidden;border:2px solid #e2e8f0}.image-preview img{width:100%;height:100%;object-fit:cover}.remove-image{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;background:#ef4444e6;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.remove-image:hover{background:#dc2626;transform:scale(1.1)}.stock-locations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:.5rem}.stock-location-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.location-header{margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.location-name{font-weight:600;color:#1f2937;font-size:.875rem}.location-stock-inputs{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.stock-input-group{display:flex;flex-direction:column;gap:.25rem}.stock-input-group label{font-size:.75rem;color:#6b7280;font-weight:500}.form-input-sm{padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:all .2s}.form-input-sm:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.alert{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem}.alert-warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e}.alert svg{font-size:1.25rem;flex-shrink:0}.locations-cell{display:flex;flex-wrap:wrap;gap:.25rem;max-width:200px}.location-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;font-size:.75rem;white-space:nowrap;cursor:help;transition:all .2s}.location-tag:hover{background:#e5e7eb;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.location-name{font-weight:600;color:#374151}.location-stock{font-weight:700;color:#f59e0b;margin-left:.125rem}@media(max-width:1200px){.locations-cell{max-width:150px}.location-tag{font-size:.7rem;padding:.2rem .4rem}}.pagination-container{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:#fff;border-top:2px solid #f3f4f6;margin-top:1rem}.pagination-info{display:flex;justify-content:center;align-items:center}.items-per-page{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.items-per-page label{font-weight:500}.items-select{padding:.5rem 2rem .5rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background:#fff;cursor:pointer;transition:all .2s;appearance:none;background-image: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='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.per-page-label{font-weight:400}@media(max-width:768px){.pagination-controls{flex-wrap:wrap}.pagination-pages{order:-1;width:100%;justify-content:center;margin-bottom:.5rem}.pagination-number{min-width:32px;height:32px;font-size:.75rem}.pagination-btn{width:32px;height:32px;font-size:.875rem}}.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;gap:1rem}.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}.location-selector{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center}.location-selector label{font-size:.875rem;font-weight:500;opacity:.9}.location-select{padding:.5rem 2.5rem .5rem 1rem;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#fff3;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;appearance:none;background-image: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='white' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;min-width:200px}.location-select:hover{background:#ffffff4d;border-color:#ffffff80}.location-select:focus{outline:none;background:#fff6;border-color:#fff}.location-select option{background:#fff;color:#1f2937}.cash-status{display:flex;gap:.5rem}.pos-container{display:grid;grid-template-columns:1fr 420px;gap:0;flex:1}.products-section{padding:2rem;overflow-y:auto;overflow:hidden}.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}.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)}.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)}}.view-toggle{display:flex;gap:.5rem;background:#fff;padding:.25rem;border-radius:8px;border:1px solid #e5e7eb}.view-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:#6b7280;border-radius:6px;cursor:pointer;transition:all .2s;font-size:1.25rem}.view-btn:hover{background:#f3f4f6;color:#f59e0b}.view-btn.active{background:#f59e0b;color:#fff}.products-container{flex:1;overflow-y:auto;min-height:0}.products-container.grid-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;padding:1rem}.products-container.list-view{display:flex;flex-direction:column;gap:.5rem;padding:1rem}.product-list-item{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s}.product-list-item:hover{border-color:#f59e0b;box-shadow:0 4px 12px #f59e0b26;transform:translateY(-2px)}.product-list-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#fef3c7;border-radius:10px;flex-shrink:0;overflow:hidden}.product-list-icon img{width:100%;height:100%;object-fit:cover}.product-list-icon svg{font-size:2rem;color:#f59e0b}.product-list-info{flex:1;min-width:0}.product-list-main{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.25rem}.product-list-name{font-size:1rem;font-weight:600;color:#1f2937;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-list-code{font-size:.75rem;color:#9ca3af;font-family:monospace;background:#f3f4f6;padding:.125rem .5rem;border-radius:4px}.product-list-category{font-size:.875rem;color:#6b7280}.product-list-stock{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:0 1rem;border-left:1px solid #e5e7eb;border-right:1px solid #e5e7eb}.stock-label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;font-weight:500}.stock-value{font-size:1.25rem;font-weight:700;color:#10b981}.stock-value.low{color:#ef4444}.product-list-price{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:0 1rem}.price-label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;font-weight:500}.price-value{font-size:1.25rem;font-weight:700;color:#f59e0b}.product-list-add-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#f59e0b;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.product-list-add-btn:hover{background:#d97706;transform:scale(1.05)}.product-list-add-btn svg{font-size:1.125rem}@media(max-width:1024px){.product-list-item{flex-wrap:wrap}.product-list-stock,.product-list-price{border:none;padding:0}}@media(max-width:768px){.view-toggle{order:-1}.product-list-code,.product-list-add-btn span{display:none}.product-list-add-btn{padding:.75rem;width:44px;justify-content:center}}.pagination-container{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:#fff;border-top:1px solid #e5e7eb;margin-top:auto}.pagination-info{display:flex;justify-content:space-between;align-items:center;gap:1rem}.pagination-text{font-size:.875rem;color:#6b7280;font-weight:500}.items-per-page{display:flex;align-items:center;gap:.5rem}.items-per-page label{font-size:.875rem;color:#6b7280;font-weight:500}.items-select{padding:.5rem 2rem .5rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background:#fff;cursor:pointer;transition:all .2s;appearance:none;background-image: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='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.items-select:hover{border-color:#f59e0b}.items-select:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:.5rem}.pagination-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#fef3c7;border-color:#f59e0b;color:#f59e0b}.pagination-pages{display:flex;gap:.25rem}.pagination-number{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 .5rem;border:1px solid #e5e7eb;background:#fff;color:#6b7280;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.pagination-number:hover{background:#fef3c7;border-color:#f59e0b;color:#f59e0b}.pagination-number.active{background:#f59e0b;border-color:#f59e0b;color:#fff}.pagination-ellipsis{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;color:#9ca3af;font-weight:600}@media(max-width:768px){.pagination-info{flex-direction:column;align-items:flex-start}.pagination-controls{flex-wrap:wrap}.pagination-pages{order:-1;width:100%;justify-content:center;margin-bottom:.5rem}.pagination-number{min-width:32px;height:32px;font-size:.75rem}.pagination-btn{width:32px;height:32px;font-size:.875rem}}@media(max-width:480px){.pagination-text{font-size:.75rem}.pagination-pages{gap:.125rem}.pagination-number{min-width:28px;height:28px}}.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{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:1.5rem;border-radius:12px;margin-bottom:2rem}.detail-info{display:flex;gap:2rem;flex-wrap:wrap}.info-item{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#475569}.info-item svg{color:#3b82f6;font-size:1.125rem}.detail-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px}.summary-col{text-align:center}.summary-col h4{font-size:.875rem;color:#64748b;margin:0 0 .5rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.summary-col .summary-value{font-size:1.5rem;font-weight:900;color:#1e293b}.summary-col .summary-value.positive{color:#10b981}.summary-col .summary-value.negative{color:#ef4444}.detail-sales{margin-top:2rem}.detail-sales h4{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.detail-sales h4:before{content:"";width:4px;height:1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:2px}.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}}.sales-table-container{overflow-x:auto;margin-top:1rem;border-radius:12px;border:2px solid #e2e8f0}.sales-detail-table{width:100%;border-collapse:collapse;min-width:900px;background:#fff}.sales-detail-table thead{background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.sales-detail-table th{padding:1rem;text-align:left;font-weight:700;color:#475569;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #cbd5e1}.sales-detail-table td{padding:1rem;border-bottom:1px solid #f1f5f9;font-size:.9375rem;vertical-align:middle}.sales-detail-table tbody tr:hover{background:#f8fafc}.sale-code{font-family:Courier New,monospace;font-weight:700;color:#3b82f6;background:#eff6ff;padding:.25rem .5rem;border-radius:6px;font-size:.8125rem;display:inline-block}.datetime-cell{display:flex;flex-direction:column;gap:.25rem}.datetime-cell .date{font-weight:600;color:#1e293b}.datetime-cell .time{font-size:.8125rem;color:#64748b}.products-cell{max-width:250px}.product-name{font-weight:600;color:#1e293b;flex:1}.products-tooltip{display:none;position:absolute;top:100%;left:0;z-index:1000;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:.75rem;margin-top:.5rem;min-width:200px;box-shadow:0 10px 30px #00000026}.tooltip-product{padding:.375rem 0;font-size:.875rem;color:#475569;border-bottom:1px solid #f1f5f9}.payment-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .875rem;border-radius:8px;font-weight:700;font-size:.8125rem;white-space:nowrap}.customer-name{color:#475569;font-weight:500}.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: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}}.detailed-sales-table .sale-code{font-family:Courier New,monospace;font-weight:700;color:#3b82f6;background:#eff6ff;padding:.25rem .5rem;border-radius:6px;font-size:.8125rem}.time-cell{color:#64748b;font-size:.875rem}.products-cell{max-width:300px}.product-item{display:flex;align-items:center;gap:.5rem}.product-name{font-weight:600;color:#1e293b}.product-qty{background:#f1f5f9;padding:.125rem .5rem;border-radius:6px;font-size:.8125rem;font-weight:700;color:#64748b}.multiple-products{position:relative;cursor:help}.products-count{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;background:#3b82f6;color:#fff;border-radius:12px;font-size:.8125rem;font-weight:700}.products-tooltip{display:none;position:absolute;top:100%;left:0;z-index:1000;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:.75rem;margin-top:.5rem;min-width:250px;box-shadow:0 10px 30px #00000026}.multiple-products:hover .products-tooltip{display:block}.tooltip-product{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.875rem;color:#475569;border-bottom:1px solid #f1f5f9;gap:1rem}.tooltip-product:last-child{border-bottom:none}.tooltip-qty{color:#64748b;font-weight:700}.tooltip-price{color:#10b981;font-weight:700}.payment-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .875rem;border-radius:8px;font-weight:700;font-size:.8125rem}.payment-badge.efectivo{background:#fef3c7;color:#92400e}.payment-badge.yape_plin{background:#dbeafe;color:#1e40af}.payment-badge.tarjeta{background:#e0e7ff;color:#3730a3}.operation-number{font-size:.75rem;color:#64748b;margin-top:.25rem;font-family:Courier New,monospace}.customer-name,.vendor-name{color:#475569;font-weight:500}.sale-amount{font-weight:700;font-size:1rem;color:#10b981}.section-header-with-export{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header-with-export h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.export-buttons{display:flex;gap:.5rem}.btn-export{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:none;border-radius:8px;font-weight:700;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-export.excel{background:#10b981;color:#fff}.btn-export.excel:hover{background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn-export.pdf{background:#ef4444;color:#fff}.btn-export.pdf:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.locations-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:1.5rem;margin-top:1.5rem}.location-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:all .3s;border:2px solid transparent}.location-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.location-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:3px solid}.location-header h3{font-size:1.25rem;font-weight:700;color:#1f2937;margin:0;display:flex;align-items:center;gap:.5rem}.location-badge{padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.location-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.location-stats-grid .stat{text-align:center;padding:1rem;background:#f9fafb;border-radius:8px;transition:all .2s}.location-stats-grid .stat:hover{background:#f3f4f6;transform:scale(1.05)}.location-stats-grid .stat-label{display:block;font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-weight:600}.location-stats-grid .stat-value{display:block;font-size:1.5rem;font-weight:700;color:#1f2937}.location-stats-grid .stat-value.highlight{color:#f59e0b}.payment-breakdown{background:#f9fafb;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.payment-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.875rem;border-bottom:1px solid #e5e7eb}.payment-item:last-child{border-bottom:none}.payment-item span:first-child{color:#6b7280;font-weight:500}.payment-item span:last-child{color:#1f2937;font-weight:700}.top-products{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;padding:1rem}.top-products h4{font-size:.875rem;color:#92400e;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .75rem;font-weight:700}.products-list{display:flex;flex-direction:column;gap:.5rem}.product-item-small{display:flex;align-items:center;gap:.5rem;background:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;transition:all .2s}.product-item-small:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.product-item-small .rank{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#f59e0b;color:#fff;border-radius:50%;font-weight:700;font-size:.75rem;flex-shrink:0}.product-item-small .product-name-small{flex:1;color:#1f2937;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-item-small .product-qty{color:#f59e0b;font-weight:700;background:#fef3c7;padding:.25rem .5rem;border-radius:4px;font-size:.75rem}@media(max-width:1024px){.locations-summary,.location-stats-grid{grid-template-columns:1fr}}@media(max-width:640px){.location-card{padding:1rem}.location-header h3{font-size:1rem}.location-stats-grid .stat-value{font-size:1.25rem}}.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}.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.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-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-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-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-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}@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}}.admin-reports-page{padding:2rem;max-width:1600px;margin:0 auto}.admin-reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.reports-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.reports-title{font-size:2rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.reports-actions{display:flex;gap:.75rem}.date-filters{display:flex;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000000f}.filter-item label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.date-input{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;font-family:inherit;transition:all .3s}.date-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.reports-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card-reports{display:flex;align-items:center;gap:1.25rem;padding:1.75rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000000f;transition:all .3s}.stat-card-reports:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001a}.stat-icon-reports{width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:14px;font-size:1.5rem;color:#fff;flex-shrink:0}.stat-card-reports.stat-primary .stat-icon-reports{background:linear-gradient(135deg,#d946ef,#c026d3)}.stat-card-reports.stat-success .stat-icon-reports{background:linear-gradient(135deg,#10b981,#059669)}.stat-card-reports.stat-warning .stat-icon-reports{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card-reports.stat-info .stat-icon-reports{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-content-reports{flex:1}.stat-value-reports{font-size:1.875rem;font-weight:800;color:#0f172a;margin-bottom:.25rem}.stat-label-reports{font-size:.875rem;color:#64748b;font-weight:600}.reports-tabs{display:flex;gap:.5rem;margin-bottom:2rem;background:#fff;padding:.5rem;border-radius:12px;box-shadow:0 2px 10px #0000000d}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:transparent;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .3s}.reports-content{background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000000f;overflow:hidden}.report-table-container{padding:2rem}.table-title{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem}.badge-count{padding:.25rem .75rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border-radius:12px;font-size:.875rem;font-weight:700}.report-table{width:100%;border-collapse:collapse}.report-table thead{background:#f8fafc}.report-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e2e8f0}.report-table td{padding:1rem;font-size:.9375rem;color:#0f172a;border-bottom:1px solid #f1f5f9}.report-table tbody tr:hover{background:#faf5ff}.report-table tfoot{background:#f8fafc;font-weight:700}.report-table tfoot td{padding:1.25rem 1rem;border-top:2px solid #e2e8f0}.total-cell{font-weight:700;color:#d946ef;font-size:1.125rem}.saldo-cell{font-weight:700;color:#f59e0b}.commission-cell{color:#10b981;font-weight:600}.spa-cell{color:#3b82f6;font-weight:600}.amount-cell{font-weight:600;color:#0f172a}.code-badge{padding:.375rem .75rem;background:#f3e8ff;color:#7c3aed;border-radius:6px;font-size:.8125rem;font-weight:700;font-family:Courier New,monospace}.status-badge-report{padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:700;text-transform:capitalize}.status-badge-report.pendiente{background:#fef3c7;color:#92400e}.status-badge-report.confirmada{background:#d1fae5;color:#065f46}.status-badge-report.completada{background:#dbeafe;color:#1e40af}.method-badge{padding:.375rem .75rem;background:#f8fafc;color:#0f172a;border-radius:6px;font-size:.8125rem;font-weight:700;text-transform:capitalize}.percentage-badge{padding:.25rem .625rem;background:#f3e8ff;color:#7c3aed;border-radius:6px;font-size:.8125rem;font-weight:700}.client-cell-report{display:flex;flex-direction:column;gap:.25rem}.client-name-report{font-weight:600;color:#0f172a}.client-contact-report{font-size:.8125rem;color:#64748b}.therapist-cell-report{display:flex;align-items:center;gap:.75rem}.therapist-avatar-report{width:40px;height:40px;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem}.therapist-name-report{font-weight:600}.payment-methods-report{padding:2rem}.methods-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.method-card{display:flex;flex-direction:column;align-items:center;padding:2rem;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-radius:16px;border:2px solid #e9d5ff;transition:all .3s}.method-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #d946ef33}.method-icon-large{font-size:3rem;margin-bottom:1rem}.method-info{width:100%;text-align:center}.method-name{font-size:1rem;font-weight:700;color:#7c3aed;margin:0 0 1rem}.method-stats{margin-bottom:1rem}.method-amount{font-size:1.75rem;font-weight:800;color:#0f172a;margin-bottom:.25rem}.method-transactions{font-size:.875rem;color:#64748b}.method-percentage{display:flex;align-items:center;gap:.75rem}.percentage-bar{flex:1;height:8px;background:#fff;border-radius:4px;overflow:hidden}.percentage-fill{height:100%;background:linear-gradient(135deg,#d946ef,#c026d3);transition:width .5s ease}.percentage-text{font-size:.875rem;font-weight:700;color:#7c3aed;min-width:45px}.methods-table-container{margin-top:2rem}.empty-state-report{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon-report{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state-report h3{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.empty-state-report p{font-size:1rem;color:#64748b;margin:0}@media(max-width:1200px){.reports-stats,.methods-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.admin-reports-page{padding:1rem}.reports-header{flex-direction:column;gap:1rem}.reports-stats{grid-template-columns:1fr}.date-filters,.reports-tabs{flex-direction:column}.methods-grid{grid-template-columns:1fr}.report-table-container{padding:1rem;overflow-x:auto}.report-table{min-width:800px}}.payment-status-cell{display:flex;flex-direction:column;gap:.25rem}.payment-badge{padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:700;display:inline-flex;align-items:center;gap:.375rem}.payment-date{font-size:.75rem;color:#64748b}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.pay-therapist-modal{padding:1.5rem}.therapist-payment-info h4{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.therapist-specialty{color:#64748b;font-size:.9375rem;margin:0 0 1.5rem}.payment-summary{background:linear-gradient(135deg,#faf5ff,#f3e8ff);padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;border:2px solid #e9d5ff}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e9d5ff}.summary-item span{color:#64748b;font-size:.9375rem}.summary-item strong{color:#0f172a;font-size:1rem;font-weight:600}.summary-item.highlight{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:1rem;border-radius:8px;margin-top:.75rem;border:2px solid #fbbf24}.summary-item.highlight span{color:#92400e;font-weight:600}.amount-to-pay{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.payment-form-simple .form-group{display:flex;flex-direction:column;gap:.5rem}.payment-form-simple .form-group label{font-size:.9375rem;font-weight:600;color:#0f172a}.payment-form-simple .form-group p{margin:0;padding:.75rem 1rem;background:#f8fafc;border-radius:8px;color:#475569;font-size:.9375rem}.payment-form-simple .form-select,.payment-form-simple .form-input{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;font-family:inherit;transition:all .3s;background:#fff}.payment-form-simple .form-select:focus,.payment-form-simple .form-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.payment-form-simple .form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem;padding-right:2.5rem}.btn-block{width:100%;padding:1rem 1.5rem;font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.75rem}.payment-info-compact{background:#f8fafc;padding:1rem;border-radius:10px;display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.25rem;border-left:4px solid #d946ef}.info-compact-label{font-size:.8125rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-compact-value{font-size:.9375rem;color:#0f172a;font-weight:600}.info-compact-value.highlight{font-size:1.25rem;font-weight:800;color:#d946ef}@media(max-width:640px){.payment-summary{padding:1rem}.summary-item{flex-direction:column;align-items:flex-start;gap:.5rem}.amount-to-pay{font-size:1.25rem}.payment-info-compact{grid-template-columns:1fr}}.summary-item:last-child{border-bottom:none}.summary-item.highlight{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:1rem;border-radius:8px;margin-top:.75rem;border:none}.amount-to-pay{font-size:1.5rem;color:#f59e0b}.btn-block{width:100%}.filter-quick-buttons{display:flex;gap:.5rem;align-items:flex-end;flex-wrap:wrap;margin-top:.5rem}.btn-sm{padding:.5rem 1rem;font-size:.875rem;height:auto}@media(max-width:768px){.date-filters{flex-direction:column}.filter-quick-buttons{width:100%;margin-top:1rem}.filter-quick-buttons .btn{flex:1;min-width:100px}}.table-header-with-info{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.filter-warning{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:2px solid #fbbf24;border-radius:12px;color:#92400e;font-size:.9375rem;font-weight:500}.filter-warning svg{color:#f59e0b;font-size:1.25rem;flex-shrink:0}.rg-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.rg-select{padding:8px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:.875rem;background:#fff;cursor:pointer;min-width:180px}.rg-select:focus{outline:none;border-color:#d946ef}.rg-servicios{font-size:.8rem;color:#6b7280;max-width:160px}.rg-terapeutas{font-size:.8rem;color:#7c3aed;max-width:140px}.rg-table td{vertical-align:middle}.rg-dashboard{display:flex;flex-direction:column;gap:24px}.rg-chart-card,.rg-table-card{background:#fff;border-radius:12px;border:1px solid #f3f4f6;padding:20px}.rg-chart-title{font-size:.95rem;font-weight:600;color:#374151;margin:0 0 16px}.rg-chart-wrapper{width:100%}.rg-line-chart{display:flex;flex-direction:column;gap:8px}.rg-svg{width:100%;height:160px;overflow:visible}.rg-chart-labels{display:flex;justify-content:space-between}.rg-chart-label{display:flex;flex-direction:column;align-items:center;gap:2px}.rg-label-citas{font-size:.75rem;font-weight:700;color:#d946ef}.rg-label-week{font-size:.7rem;color:#9ca3af}.rg-chart-empty{display:flex;flex-direction:column;align-items:center;padding:40px;color:#9ca3af;gap:8px}.rg-chart-empty span{font-size:2rem}.pdf-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.pdf-modal{background:#fff;border-radius:16px;padding:28px;width:380px;max-width:90vw}.pdf-modal-title{font-size:1.1rem;font-weight:700;color:#111827;margin:0 0 6px;display:flex;align-items:center;gap:8px}.pdf-modal-subtitle{font-size:.875rem;color:#6b7280;margin:0 0 20px}.pdf-modal-options{display:flex;flex-direction:column;gap:10px}.pdf-option-btn{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1.5px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;text-align:left;transition:all .15s}.pdf-option-btn:hover{border-color:#d946ef;background:#fdf4ff}.pdf-opt-icon{font-size:1.5rem}.pdf-option-btn strong{display:block;font-size:.9rem;color:#111827}.pdf-option-btn p{margin:2px 0 0;font-size:.8rem;color:#6b7280}.pdf-modal-cancel{margin-top:16px;width:100%;padding:10px;border:none;background:#f3f4f6;border-radius:8px;cursor:pointer;font-size:.875rem;color:#6b7280}.pdf-modal-cancel:hover{background:#e5e7eb}.rg-root{display:flex;flex-direction:column;gap:0}.rg-subtabs{display:flex;gap:0;border-bottom:2px solid #f3f4f6;margin-bottom:24px}.rg-subtab{padding:12px 24px;font-size:.875rem;font-weight:600;color:#6b7280;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .15s}.rg-subtab:hover{color:#d946ef}.rg-subtab-active{color:#d946ef;border-bottom-color:#d946ef}.rg-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.rg-kpi{padding:14px 16px;border-radius:12px;display:flex;flex-direction:column;gap:4px;border:1px solid transparent}.rg-kpi-val{font-size:1.1rem;font-weight:700;line-height:1}.rg-kpi-label{font-size:.75rem;font-weight:500;opacity:.75}.rg-kpi-purple{background:#fdf4ff;border-color:#f5d0fe;color:#9333ea}.rg-kpi-green{background:#f0fdf4;border-color:#bbf7d0;color:#16a34a}.rg-kpi-orange{background:#fffbeb;border-color:#fde68a;color:#d97706}.rg-kpi-blue{background:#eff6ff;border-color:#bfdbfe;color:#2563eb}.rg-dia-block{border:1px solid #f3f4f6;border-radius:12px;margin-bottom:10px;overflow:hidden;background:#fff;transition:box-shadow .15s}.rg-dia-block:hover{box-shadow:0 2px 12px #0000000f}.rg-dia-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:none;border:none;cursor:pointer;text-align:left;transition:background .1s}.rg-dia-header:hover{background:#fafafa}.rg-dia-left{display:flex;align-items:center;gap:12px}.rg-dia-fecha{font-size:.95rem;font-weight:700;color:#111827}.rg-dia-count{font-size:.78rem;font-weight:600;color:#7c3aed;background:#fdf4ff;padding:3px 10px;border-radius:20px}.rg-dia-right{display:flex;align-items:center;gap:20px}.rg-dia-stat{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.rg-dia-stat-label{font-size:.7rem;color:#9ca3af;font-weight:500}.rg-dia-stat-val{font-size:.875rem;font-weight:600}.rg-green{color:#16a34a}.rg-orange{color:#d97706}.rg-bold{color:#111827}.rg-purple{color:#7c3aed}.rg-chevron{color:#9ca3af;font-size:.75rem;margin-left:8px}.rg-citas-list{border-top:1px solid #f3f4f6;padding:12px;display:flex;flex-direction:column;gap:10px;background:#fafafa}.rg-cita-card{background:#fff;border:1px solid #f3f4f6;border-radius:10px;overflow:hidden}.rg-cita-top{display:flex;justify-content:space-between;align-items:center;padding:12px 14px 10px;border-bottom:1px solid #f9fafb}.rg-cita-client{display:flex;align-items:center;gap:10px}.rg-client-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#d946ef,#9333ea);color:#fff;font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rg-client-name{font-weight:600;font-size:.88rem;color:#111827}.rg-client-tel{font-size:.78rem;color:#9ca3af}.rg-cita-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.rg-estado-badge,.rg-metodo-badge{padding:4px 10px;border-radius:6px;font-size:.78rem;font-weight:600;display:flex;align-items:center}.rg-cita-body{padding:10px 14px;display:flex;flex-direction:column;gap:6px}.rg-cita-info-row{display:flex;gap:10px;font-size:.83rem}.rg-info-label{color:#9ca3af;min-width:110px;flex-shrink:0}.rg-info-val{color:#374151;font-weight:500}.rg-cita-footer{padding:10px 14px;background:#f9fafb;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;align-items:center}.rg-cita-money{display:flex;align-items:center;gap:12px}.rg-money-item{display:flex;flex-direction:column;align-items:flex-start;gap:1px}.rg-money-item span{font-size:.7rem;color:#9ca3af}.rg-money-item strong{font-size:.88rem;color:#374151}.rg-money-green strong{color:#16a34a}.rg-money-orange strong{color:#d97706}.rg-money-sep{color:#d1d5db;font-size:.9rem}.rg-codigo{font-size:.72rem;color:#d1d5db;font-family:monospace}.rg-empty{display:flex;flex-direction:column;align-items:center;padding:60px 20px;color:#9ca3af;gap:10px}.rg-empty span{font-size:2.5rem}.rg-empty p{font-size:.9rem;margin:0}.rg-empty-search{padding:80px 20px}.rg-cliente-section{padding-top:4px}.rg-search-wrap{position:relative;margin-bottom:24px;max-width:480px}.rg-search-box{display:flex;align-items:center;gap:10px;border:2px solid #e5e7eb;border-radius:12px;padding:10px 14px;background:#fff;transition:border-color .15s}.rg-search-box:focus-within{border-color:#d946ef}.rg-search-icon{font-size:1rem;flex-shrink:0}.rg-search-input{flex:1;border:none;outline:none;font-size:.9rem;color:#111827;background:transparent}.rg-search-clear{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:.85rem;padding:2px 4px}.rg-search-clear:hover{color:#374151}.rg-search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #0000001a;z-index:100;overflow:hidden}.rg-search-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;text-align:left;transition:background .1s}.rg-search-item:hover{background:#fdf4ff}.rg-search-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#d946ef,#9333ea);color:#fff;font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rg-search-nombre{font-size:.875rem;font-weight:600;color:#111827}.rg-search-tel{font-size:.78rem;color:#9ca3af}.rg-cliente-result{display:flex;flex-direction:column;gap:20px}.rg-cliente-header{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,#fdf4ff,#eff6ff);border-radius:14px;border:1px solid #f5d0fe;flex-wrap:wrap}.rg-cliente-avatar-lg{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#d946ef,#9333ea);color:#fff;font-weight:700;font-size:1.3rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rg-cliente-info{flex:1}.rg-cliente-info h3{margin:0 0 4px;font-size:1rem;font-weight:700;color:#111827}.rg-cliente-info p{margin:0;font-size:.82rem;color:#6b7280}.rg-cliente-kpis{display:flex;gap:12px;flex-wrap:wrap}.rg-ckpi{display:flex;flex-direction:column;align-items:center;padding:8px 14px;background:#fff;border-radius:10px;border:1px solid #e5e7eb;min-width:80px}.rg-ckpi-val{font-size:.95rem;font-weight:700;color:#111827}.rg-ckpi-label{font-size:.7rem;color:#9ca3af;margin-top:2px}.rg-ckpi-green .rg-ckpi-val{color:#16a34a}.rg-ckpi-orange .rg-ckpi-val{color:#d97706}.rg-ckpi-purple .rg-ckpi-val{color:#9333ea}.rg-cliente-table{margin-top:4px}@media(max-width:768px){.rg-kpi-row{grid-template-columns:repeat(2,1fr)}.rg-dia-right{gap:10px}.rg-dia-stat:nth-child(2){display:none}.rg-cita-top{flex-direction:column;align-items:flex-start;gap:8px}.rg-cita-money{flex-wrap:wrap;gap:8px}.rg-cliente-header{flex-direction:column}}.metodos-pago-chart-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:32px;box-shadow:0 1px 3px #0000001a}.metodos-pago-chart{display:flex;flex-direction:column;gap:20px;padding:20px 0}.metodo-row{display:grid;grid-template-columns:140px 1fr 180px;align-items:center;gap:20px}.metodo-label{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;text-transform:uppercase;color:#1f2937}.metodo-icon{font-size:20px}.metodo-bar-container{height:36px;background:#f3f4f6;border-radius:8px;overflow:hidden;position:relative}.metodo-bar{height:100%;border-radius:8px;transition:width .6s ease;box-shadow:inset 0 2px 4px #0000001a}.metodo-stats{display:flex;justify-content:space-between;align-items:center;gap:16px}.metodo-porcentaje{font-weight:600;font-size:15px;color:#6b7280;min-width:50px;text-align:right}.metodo-monto{font-weight:700;font-size:16px;color:#1f2937;min-width:100px;text-align:right}.no-data{text-align:center;color:#9ca3af;padding:40px;font-size:14px}@media(max-width:768px){.metodo-row{grid-template-columns:1fr;gap:12px}.metodo-bar-container{height:28px}.metodo-stats{justify-content:space-between;padding:0 4px}}.track-page-new{min-height:100vh;background:linear-gradient(135deg,#faf5ff,#f3e8ff);padding:2rem 1rem 3rem}.track-container-new{max-width:1100px;margin:0 auto}.track-header-compact{text-align:center;margin-bottom:2rem}.track-header-compact h1{font-size:2rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.track-header-compact p{font-size:1rem;color:#64748b;margin:0}.search-inline{display:flex;gap:.75rem;max-width:700px;margin:0 auto .5rem}.search-group{flex:1;position:relative;display:flex;align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:0 1rem;transition:all .3s}.search-group:focus-within{border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.search-group svg{color:#94a3b8;font-size:1.25rem;margin-right:.75rem}.search-group input{flex:1;padding:.875rem 0;border:none;font-size:1rem;font-family:Courier New,monospace;font-weight:700;color:#0f172a}.search-group input:focus{outline:none}.search-group input::placeholder{color:#cbd5e1;font-weight:600}.search-inline button{padding:.875rem 2rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s;white-space:nowrap;box-shadow:0 4px 12px #d946ef4d}.search-inline button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d946ef66}.search-inline button:disabled{opacity:.6;cursor:not-allowed}.search-hint-compact{text-align:center;font-size:.875rem;color:#64748b;margin:0 0 2rem}.results-compact{margin-top:2rem}.status-banner{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-radius:12px;border:2px solid;margin-bottom:1.5rem}.status-info{display:flex;align-items:center;gap:.75rem;font-weight:700;font-size:1.125rem}.status-info svg{font-size:1.5rem}.booking-code-compact{font-family:Courier New,monospace;font-weight:700;color:#0f172a;background:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.9375rem}.booking-card-compact{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014;border:2px solid #f1f5f9}.service-header-compact{display:flex;align-items:flex-start;gap:1rem;padding-bottom:1.5rem;margin-bottom:1.5rem;border-bottom:2px solid #f1f5f9}.service-header-compact>svg{width:48px;height:48px;padding:.75rem;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-radius:12px;color:#d946ef;flex-shrink:0}.service-header-compact h2{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.service-header-compact p{font-size:.9375rem;color:#64748b;margin:0;line-height:1.5}.booking-grid-compact{display:grid;grid-template-columns:1fr 1.2fr;gap:2rem}.timeline-compact{background:#faf5ff;border:2px solid #e9d5ff;border-radius:12px;padding:1.5rem}.timeline-compact h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:#7c3aed;margin:0 0 1.25rem}.timeline-compact h3 svg{font-size:1.25rem}.steps-compact{display:flex;flex-direction:column;gap:1rem}.step-compact{display:flex;align-items:flex-start;gap:.875rem}.step-dot-compact{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;background:#fff;border:2px solid #e2e8f0;transition:all .3s}.step-compact.completed .step-dot-compact{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;box-shadow:0 4px 12px #10b98140}.step-compact.pending .step-dot-compact{background:#f1f5f9;border-color:#cbd5e1;opacity:.6}.step-info-compact{display:flex;flex-direction:column;gap:.25rem;flex:1}.step-info-compact strong{font-size:.9375rem;font-weight:700;color:#0f172a;line-height:1.3}.step-compact.pending .step-info-compact strong{color:#94a3b8}.specialist-name{font-size:.875rem;color:#7c3aed;font-weight:600}.step-date-compact{font-size:.8125rem;color:#64748b;font-weight:500}.step-pending-text{font-size:.8125rem;color:#94a3b8;font-style:italic}.details-compact{display:flex;flex-direction:column;gap:1.5rem}.details-compact h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:#0f172a;margin:0}.details-compact h3 svg{color:#d946ef;font-size:1.25rem}.details-list-compact{display:flex;flex-direction:column;gap:1rem}.detail-row{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;transition:all .3s}.detail-row:hover{border-color:#d946ef;background:#faf5ff}.detail-row>svg{width:36px;height:36px;padding:.625rem;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-radius:8px;color:#d946ef;flex-shrink:0}.detail-row>div{display:flex;flex-direction:column;gap:.25rem;flex:1}.detail-row span{font-size:.75rem;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.5px}.detail-row strong{font-size:1rem;font-weight:700;color:#0f172a;line-height:1.4}.price-row{border-color:#e9d5ff;background:linear-gradient(135deg,#faf5ff,#f3e8ff)}.price-large{font-size:1.5rem!important;color:#d946ef!important}.price-detail{font-size:.875rem!important;color:#64748b!important;font-weight:600!important;text-transform:none!important;letter-spacing:normal!important}.alert-pending{padding:1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:10px;color:#92400e;font-weight:700;text-align:center;font-size:1rem}.contact-compact{padding-top:1.5rem;border-top:2px solid #f1f5f9}.contact-compact h4{font-size:.9375rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.contact-items-compact{display:flex;flex-direction:column;gap:.75rem}.contact-items-compact>div{display:flex;align-items:center;gap:.75rem;font-size:.9375rem;color:#475569;font-weight:600}.contact-items-compact svg{color:#d946ef;font-size:1.125rem}.empty-compact{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.empty-icon-compact{font-size:4rem;margin-bottom:1rem;opacity:.4}.empty-compact h3{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.empty-compact p{font-size:1rem;color:#64748b;margin:0}@media(max-width:1024px){.booking-grid-compact{grid-template-columns:1fr}}@media(max-width:768px){.track-page-new{padding:1.5rem .75rem 2rem}.track-header-compact h1{font-size:1.75rem}.search-inline{flex-direction:column}.search-inline button{width:100%}.status-banner{flex-direction:column;gap:.75rem;text-align:center}.booking-card-compact{padding:1.5rem}.service-header-compact{flex-direction:column;align-items:center;text-align:center}.timeline-compact,.details-compact{padding:1.25rem}.detail-row{padding:.875rem}}.therapist-reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.spinner-large{width:48px;height:48px;border:4px solid #f1f5f9;border-top-color:#d946ef;border-radius:50%;animation:spin .8s linear infinite}.reports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1.5rem}.month-selector{display:flex;align-items:center;gap:.75rem;background:#fff;padding:.75rem 1rem;border-radius:12px;box-shadow:0 4px 12px #00000014;border:2px solid #f1f5f9}.month-nav-btn{width:36px;height:36px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b;font-size:1.25rem}.month-display{display:flex;align-items:center;gap:.5rem;padding:0 .5rem;font-weight:700;color:#0f172a;min-width:200px;justify-content:center}.stat-card{background:#fff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1.25rem;box-shadow:0 4px 12px #0000000f;border:2px solid transparent;transition:all .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.stat-card.primary{border-color:#e9d5ff;background:linear-gradient(135deg,#fff,#faf5ff)}.stat-card.success{border-color:#d1fae5;background:linear-gradient(135deg,#fff,#f0fdf4)}.stat-card.warning{border-color:#fef3c7;background:linear-gradient(135deg,#fff,#fffbeb)}.stat-card.info{border-color:#dbeafe;background:linear-gradient(135deg,#fff,#eff6ff)}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.stat-card.primary .stat-icon{background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff}.stat-card.success .stat-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.stat-card.warning .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stat-card.info .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.stat-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.stat-value{font-size:1.875rem;font-weight:800;color:#0f172a;line-height:1}.stat-value small{font-size:1.125rem;color:#94a3b8;font-weight:600}.therapist-of-month-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:3px solid #fbbf24;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 32px #fbbf2440}.card-header-special{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.award-icon{font-size:2.5rem;color:#f59e0b;animation:pulse 2s ease-in-out infinite}.therapist-of-month-content{display:flex;align-items:center;gap:2rem;background:#fff;padding:2rem;border-radius:16px}.therapist-avatar-large{position:relative;width:120px;height:120px;flex-shrink:0}.therapist-avatar-large img,.avatar-placeholder-large{width:100%;height:100%;border-radius:20px;object-fit:cover;border:4px solid #fbbf24}.avatar-placeholder-large{background:linear-gradient(135deg,#d946ef,#c026d3);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:800;color:#fff}.avatar-badge{position:absolute;top:-10px;right:-10px;width:48px;height:48px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;border:3px solid #fbbf24;box-shadow:0 4px 12px #00000026}.therapist-info-large{flex:1}.therapist-info-large h3{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.speciality{font-size:1.125rem;color:#7c3aed;font-weight:600;margin:0 0 1rem}.stat-inline{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:#475569}.stat-inline svg{color:#d946ef;font-size:1.25rem}.stat-inline strong{color:#0f172a}.reports-tabs{display:flex;gap:.5rem;margin-bottom:2rem;background:#fff;padding:.5rem;border-radius:12px;box-shadow:0 4px 12px #0000000f}.tab-btn{flex:1;padding:1rem 1.5rem;background:transparent;border:none;border-radius:8px;font-size:1rem;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.tab-placeholder{text-align:center;padding:4rem;color:#64748b;font-size:1.125rem}.top-therapists-section{background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 12px #0000000f}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.section-header h2 svg{color:#d946ef;font-size:1.5rem}.btn-export{padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;box-shadow:0 4px 12px #10b98140}.btn-export:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98159}.top-therapist-item{display:flex;align-items:center;gap:1.5rem;padding:1.25rem;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:12px;transition:all .3s}.top-therapist-item:hover{transform:translate(8px);border-color:#d946ef;box-shadow:0 4px 16px #d946ef26}.rank-badge{width:48px;height:48px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#d946ef;flex-shrink:0;border:2px solid #e9d5ff}.therapist-avatar-small{width:64px;height:64px;flex-shrink:0}.therapist-avatar-small img,.avatar-placeholder-small{width:100%;height:100%;border-radius:12px;object-fit:cover;border:2px solid #d946ef}.avatar-placeholder-small{background:linear-gradient(135deg,#d946ef,#c026d3);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:800;color:#fff}.metric-item{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;color:#475569}.monthly-chart-section{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 12px #0000000f}.chart-container{padding:1.5rem;background:#f8fafc;border-radius:12px}.simple-bar-chart{display:flex;align-items:flex-end;gap:1.5rem;height:300px;padding:1rem}.chart-bar{width:100%;max-width:80px;background:linear-gradient(180deg,#d946ef,#c026d3);border-radius:8px 8px 0 0;min-height:30px;position:relative;transition:all .3s;cursor:pointer;display:flex;align-items:flex-start;justify-content:center;padding-top:.5rem}.chart-bar:hover{background:linear-gradient(180deg,#e879f9,#d946ef);transform:scaleY(1.05)}.bar-value{font-size:.75rem;font-weight:700;color:#fff;writing-mode:vertical-rl;text-orientation:mixed}@media(max-width:768px){.therapist-reports-page{padding:1rem}.reports-header,.header-title-section{flex-direction:column;align-items:flex-start}.header-icon{width:56px;height:56px;font-size:1.75rem}.reports-title{font-size:1.75rem}.month-selector{width:100%}.stats-grid{grid-template-columns:1fr}.therapist-of-month-content{flex-direction:column;text-align:center}.therapist-stats-inline{flex-direction:column;gap:.75rem}.reports-tabs{flex-direction:column}.top-therapist-item{flex-wrap:wrap}.therapist-metrics{flex-wrap:wrap;width:100%}.simple-bar-chart{gap:.75rem;height:250px}.bar-value{font-size:.625rem}}.therapist-reports-page{min-height:100vh;background:linear-gradient(135deg,#faf5ff,#f3e8ff);padding:2rem}.reports-container{max-width:1400px;margin:0 auto}.therapist-reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.therapist-reports-loading p{font-size:1.125rem;font-weight:600;color:#64748b}.reports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:#fff;padding:2rem;border-radius:20px;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.header-title-section{display:flex;align-items:center;gap:1.5rem}.reports-title{font-size:2rem;font-weight:800;color:#0f172a;margin:0 0 .25rem}.reports-subtitle{font-size:1rem;color:#64748b;margin:0}.month-selector{display:flex;align-items:center;gap:.5rem;background:#f8fafc;padding:.5rem;border-radius:12px;border:2px solid #e2e8f0}.month-nav-btn{width:40px;height:40px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b;font-size:1.25rem}.month-nav-btn:hover{background:#d946ef;border-color:#d946ef;color:#fff;transform:scale(1.1)}.month-display{display:flex;align-items:center;gap:.75rem;padding:0 1rem;font-size:1rem;font-weight:700;color:#0f172a;min-width:200px;justify-content:center}.month-display svg{color:#d946ef;font-size:1.25rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.75rem;border-radius:16px;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9;display:flex;align-items:center;gap:1.25rem;transition:all .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f}.stat-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#fff;flex-shrink:0}.stat-card.primary .stat-icon{background:linear-gradient(135deg,#d946ef,#c026d3)}.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,#3b82f6,#2563eb)}.stat-content{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:800;color:#0f172a;line-height:1}.stat-value small{font-size:1.25rem;color:#94a3b8;font-weight:600}.stat-detail{font-size:.875rem;color:#10b981;font-weight:600}.therapist-of-month-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:3px solid #fbbf24;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 32px #fbbf244d}.card-header-special{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.award-icon{font-size:2rem;color:#d97706}.card-header-special h2{font-size:1.5rem;font-weight:800;color:#92400e;margin:0}.therapist-of-month-content{display:flex;align-items:center;gap:2rem}.therapist-avatar-large{position:relative;width:120px;height:120px;border-radius:20px;overflow:hidden;border:4px solid white;box-shadow:0 8px 24px #00000026;flex-shrink:0}.therapist-avatar-large img{width:100%;height:100%;object-fit:cover}.avatar-placeholder-large{width:100%;height:100%;background:linear-gradient(135deg,#d946ef,#c026d3);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:800;color:#fff}.avatar-badge{position:absolute;top:-8px;right:-8px;width:40px;height:40px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 12px #0003}.therapist-info-large h3{font-size:1.75rem;font-weight:800;color:#78350f;margin:0 0 .5rem}.speciality{font-size:1rem;color:#92400e;font-weight:600;margin:0 0 1.25rem}.therapist-stats-inline{display:flex;gap:2rem}.stat-inline{display:flex;align-items:center;gap:.5rem;color:#92400e;font-size:1rem}.stat-inline svg{color:#d97706;font-size:1.25rem}.stat-inline strong{color:#78350f}.reports-tabs{display:flex;gap:.75rem;margin-bottom:2rem;background:#fff;padding:.75rem;border-radius:16px;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.tab-btn{flex:1;padding:1rem 1.5rem;background:transparent;border:none;border-radius:12px;font-size:1rem;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.75rem}.tab-btn:hover{background:#f8fafc;color:#0f172a}.tab-btn.active{background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;box-shadow:0 4px 12px #d946ef4d}.tab-content{min-height:400px}.tab-placeholder{text-align:center;padding:4rem 2rem;color:#64748b;font-size:1.125rem}.top-therapists-section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9;margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #f1f5f9}.section-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:800;color:#0f172a;margin:0}.section-header svg{color:#d946ef;font-size:1.5rem}.btn-export{padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;box-shadow:0 4px 12px #10b9814d}.btn-export:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.top-therapists-list{display:flex;flex-direction:column;gap:1rem}.top-therapist-item{display:flex;align-items:center;gap:1.5rem;padding:1.25rem;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:16px;transition:all .3s}.top-therapist-item:hover{transform:translate(8px);box-shadow:0 8px 24px #d946ef26}.rank-badge{width:48px;height:48px;background:#fff;border:2px solid #d946ef;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#d946ef;flex-shrink:0}.therapist-avatar-small{width:56px;height:56px;border-radius:12px;overflow:hidden;border:2px solid white;box-shadow:0 4px 12px #0000001a;flex-shrink:0}.therapist-avatar-small img{width:100%;height:100%;object-fit:cover}.avatar-placeholder-small{width:100%;height:100%;background:linear-gradient(135deg,#d946ef,#c026d3);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:800;color:#fff}.therapist-info-compact{flex:1}.therapist-info-compact h4{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.therapist-info-compact p{font-size:.875rem;color:#7c3aed;font-weight:600;margin:0}.therapist-metrics{display:flex;gap:1.5rem}.metric-item{display:flex;align-items:center;gap:.5rem;color:#475569;font-weight:600;font-size:.9375rem}.metric-item svg{color:#d946ef;font-size:1.125rem}.monthly-chart-section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.chart-container{padding:2rem 1rem}.simple-bar-chart{display:flex;align-items:flex-end;justify-content:space-around;height:300px;gap:1rem}.chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%}.chart-bar-container{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.chart-bar{width:100%;max-width:80px;background:linear-gradient(135deg,#d946ef,#c026d3);border-radius:8px 8px 0 0;min-height:40px;position:relative;transition:all .3s;cursor:pointer;display:flex;align-items:flex-start;justify-content:center;padding-top:.5rem}.chart-bar:hover{opacity:.8;transform:scaleY(1.05)}.bar-value{font-size:.75rem;font-weight:700;color:#fff;writing-mode:vertical-rl;text-orientation:mixed;white-space:nowrap}.chart-label{font-size:.875rem;font-weight:700;color:#0f172a;text-transform:uppercase}.chart-sublabel{font-size:.75rem;color:#64748b;font-weight:600}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.therapist-reports-page{padding:1rem}.reports-header{flex-direction:column;gap:1.5rem;padding:1.5rem}.header-title-section{flex-direction:column;text-align:center}.reports-title{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.therapist-of-month-content{flex-direction:column;text-align:center}.therapist-stats-inline{flex-direction:column;gap:.75rem}.reports-tabs{flex-direction:column}.top-therapist-item{flex-wrap:wrap}.therapist-metrics{width:100%;justify-content:space-around}.simple-bar-chart{height:250px;gap:.5rem}.bar-value{font-size:.625rem}}.tab-loading,.tab-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.spinner-small{width:40px;height:40px;border:3px solid #f1f5f9;border-top-color:#d946ef;border-radius:50%;animation:spin .8s linear infinite}.tab-loading p{color:#64748b;font-weight:600}.tab-error{color:#ef4444;font-weight:600}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #f1f5f9}.tab-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:800;color:#0f172a;margin:0}.tab-header svg{color:#d946ef;font-size:1.75rem}.attendance-tab-content{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.attendance-table-wrapper,.earnings-table-wrapper{overflow-x:auto;margin-bottom:2rem;border-radius:12px;border:2px solid #f1f5f9}.attendance-table,.earnings-table{width:100%;border-collapse:collapse;background:#fff}.attendance-table thead,.earnings-table thead{background:linear-gradient(135deg,#faf5ff,#f3e8ff)}.attendance-table th,.earnings-table th{padding:1.25rem 1rem;text-align:left;font-size:.875rem;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9d5ff}.attendance-table th.sortable,.earnings-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .3s;position:relative}.attendance-table th.sortable:hover,.earnings-table th.sortable:hover{background:#d946ef1a;color:#d946ef}.sort-indicator{margin-left:.5rem;font-size:1rem;color:#d946ef}.attendance-table tbody tr,.earnings-table tbody tr{border-bottom:1px solid #f1f5f9;transition:all .3s}.attendance-table tbody tr:hover,.earnings-table tbody tr:hover{background:#faf5ff}.attendance-table td,.earnings-table td{padding:1.25rem 1rem;font-size:.9375rem;color:#475569}.therapist-cell{min-width:200px}.therapist-info-row{display:flex;align-items:center;gap:.875rem}.avatar-tiny{width:40px;height:40px;border-radius:10px;overflow:hidden;border:2px solid #e9d5ff;flex-shrink:0}.avatar-tiny img{width:100%;height:100%;object-fit:cover}.avatar-placeholder-tiny{width:100%;height:100%;background:linear-gradient(135deg,#d946ef,#c026d3);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:800;color:#fff}.therapist-name{font-weight:700;color:#0f172a}.speciality-badge{display:inline-block;padding:.375rem .875rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border-radius:8px;font-size:.875rem;font-weight:600}.numeric-cell{text-align:center}.badge{display:inline-block;padding:.5rem .875rem;border-radius:8px;font-size:.875rem;font-weight:700;min-width:45px;text-align:center}.badge-primary{background:linear-gradient(135deg,#faf5ff,#f3e8ff);color:#7c3aed;border:2px solid #e9d5ff}.badge-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857;border:2px solid #6ee7b7}.badge-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:2px solid #fbbf24}.badge-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;border:2px solid #f87171}.badge-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border:2px solid #60a5fa}.progress-cell{display:flex;align-items:center;gap:.75rem;justify-content:center}.progress-bar-wrapper{flex:1;max-width:120px;height:10px;background:#f1f5f9;border-radius:5px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:5px;transition:all .3s}.progress-text{font-weight:700;font-size:.875rem;min-width:50px;text-align:right}.empty-table{padding:3rem;text-align:center;color:#64748b;font-size:1rem;font-weight:600}.attendance-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2rem}.summary-card{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1rem}.summary-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}.summary-icon.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.summary-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:1.75rem;font-weight:800;color:#0f172a}.earnings-tab-content{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.earnings-totals{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}.total-card{border-radius:16px;padding:2rem;display:flex;align-items:center;gap:1.5rem;border:2px solid}.total-card.total-primary{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-color:#e9d5ff}.total-card.total-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fbbf24}.total-card.total-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#6ee7b7}.total-icon{font-size:3rem}.total-content{display:flex;flex-direction:column;gap:.5rem}.total-label{font-size:.9375rem;font-weight:600;color:#64748b}.total-card.total-primary .total-label{color:#7c3aed}.total-card.total-warning .total-label{color:#92400e}.total-card.total-success .total-label{color:#047857}.total-amount{font-size:2rem;font-weight:900;color:#0f172a}.price-text{font-weight:700;font-size:1rem}.price-text.primary{color:#7c3aed}.price-text.warning{color:#d97706}.price-text.success{color:#059669}.totals-row{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-top:3px solid #d946ef!important}.totals-row td{font-weight:700;color:#0f172a;padding:1.5rem 1rem}.distribution-section{margin-top:2rem;padding-top:2rem;border-top:2px solid #f1f5f9}.distribution-section h3{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.distribution-chart{background:#f8fafc;border-radius:12px;padding:2rem}.distribution-bar{display:flex;height:60px;border-radius:10px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.distribution-segment{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem;transition:all .3s;cursor:pointer}.distribution-segment:hover{filter:brightness(1.1)}.distribution-segment.comision{background:linear-gradient(135deg,#f59e0b,#d97706)}.distribution-segment.ganancia{background:linear-gradient(135deg,#10b981,#059669)}@media(max-width:1200px){.attendance-summary,.earnings-totals{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.tab-header{flex-direction:column;gap:1rem;align-items:flex-start}.attendance-summary,.earnings-totals{grid-template-columns:1fr}.attendance-table,.earnings-table{font-size:.875rem}.attendance-table th,.earnings-table th,.attendance-table td,.earnings-table td{padding:.875rem .5rem}.therapist-cell{min-width:150px}.avatar-tiny{width:32px;height:32px}.therapist-name{font-size:.875rem}.distribution-bar{height:50px;flex-direction:column}.distribution-segment span{font-size:.875rem}}.export-buttons{display:flex;gap:.75rem}.btn-export{padding:.75rem 1.5rem;border:none;border-radius:10px;font-size:.9375rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;box-shadow:0 4px 12px #00000026}.btn-export:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0003}.btn-export.excel{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-export.pdf{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-export svg{font-size:1.125rem}@media(max-width:768px){.export-buttons{flex-direction:column;width:100%}.btn-export{width:100%;justify-content:center}}.schedule-page{min-height:100vh;background:linear-gradient(135deg,#faf5ff,#f3e8ff);padding:2rem}.schedule-container{max-width:1600px;margin:0 auto}.schedule-header{background:#fff;border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.header-title{display:flex;align-items:center;gap:1rem}.header-icon{width:48px;height:48px;padding:.75rem;background:linear-gradient(135deg,#d946ef,#c026d3);border-radius:12px;color:#fff;font-size:1.5rem}.header-title h1{font-size:2rem;font-weight:800;color:#0f172a;margin:0}.schedule-content{display:grid;grid-template-columns:1fr 400px;gap:2rem;align-items:start}.calendar-section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.month-navigator{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #f1f5f9}.nav-btn{width:40px;height:40px;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#d946ef;font-size:1.25rem}.nav-btn:hover{background:linear-gradient(135deg,#d946ef,#c026d3);border-color:#d946ef;color:#fff;transform:scale(1.1)}.current-month{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0;text-transform:capitalize}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.weekday-header{text-align:center;font-size:.875rem;font-weight:700;color:#7c3aed;padding:1rem 0;text-transform:uppercase;letter-spacing:.5px}.calendar-day{aspect-ratio:1;border:2px solid #e2e8f0;border-radius:12px;padding:.5rem;cursor:pointer;transition:all .3s;position:relative;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.calendar-day.empty{border:none;background:transparent;cursor:default}.calendar-day:not(.empty):hover{border-color:#d946ef;transform:translateY(-2px);box-shadow:0 4px 12px #d946ef33}.calendar-day.today{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6}.calendar-day.selected{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-color:#d946ef;border-width:3px}.calendar-day.past{opacity:.5}.calendar-day.blocked{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444}.day-number{font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:.25rem}.day-indicator{position:absolute;bottom:.375rem;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.reservations-indicator{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:.25rem .5rem;border-radius:6px;min-width:24px}.blocked-indicator{color:#ef4444;font-size:1rem}.calendar-legend{display:flex;gap:2rem;margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #f1f5f9;justify-content:center}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#64748b;font-weight:600}.legend-dot{width:12px;height:12px;border-radius:50%}.today-dot{background:#3b82f6}.reservations-dot{background:#10b981}.blocked-dot{background:#ef4444}.day-details-panel{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9;position:sticky;top:2rem;max-height:calc(100vh - 4rem);overflow-y:auto}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #f1f5f9}.panel-header h3{font-size:1.125rem;font-weight:800;color:#0f172a;margin:0;text-transform:capitalize}.close-panel-btn{width:32px;height:32px;background:#f1f5f9;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b;font-size:1.25rem}.close-panel-btn:hover{background:#fee2e2;color:#ef4444}.panel-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem}.spinner{width:40px;height:40px;border:3px solid #f1f5f9;border-top-color:#d946ef;border-radius:50%;animation:spin .8s linear infinite}.blocked-alert{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #ef4444;border-radius:12px;padding:1.25rem;display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.blocked-alert svg{color:#ef4444;font-size:1.5rem;flex-shrink:0}.blocked-alert strong{display:block;color:#991b1b;font-size:1rem;margin-bottom:.25rem}.blocked-alert p{color:#7f1d1d;margin:0;font-size:.9375rem}.btn-unblock{margin-left:auto;padding:.5rem 1rem;background:#fff;border:2px solid #10b981;border-radius:8px;color:#10b981;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;white-space:nowrap}.btn-unblock:hover{background:#10b981;color:#fff}.btn-block-day{width:100%;padding:1rem;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s;margin-bottom:1.5rem}.btn-block-day:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ef44444d}.reservations-list h4{display:flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.reservations-list h4 svg{color:#d946ef;font-size:1.25rem}.no-reservations{text-align:center;padding:2rem 1rem;color:#64748b;font-size:.9375rem}.reservation-item{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:1rem;margin-bottom:1rem;transition:all .3s}.reservation-item:hover{border-color:#d946ef;background:#faf5ff}.reservation-time{background:linear-gradient(135deg,#faf5ff,#f3e8ff);color:#7c3aed;padding:.5rem 1rem;border-radius:8px;font-weight:700;font-size:.9375rem;display:inline-block;margin-bottom:.75rem}.reservation-info strong{display:block;color:#0f172a;font-size:1rem;margin-bottom:.5rem}.reservation-meta{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;color:#64748b;margin-bottom:.75rem}.reservation-meta span{display:flex;align-items:center;gap:.5rem}.reservation-meta svg{color:#d946ef}.reservation-status{display:inline-block;padding:.375rem .875rem;border-radius:8px;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.modal-content-schedule{background:#fff;border-radius:20px;width:100%;max-width:500px;box-shadow:0 24px 80px #d946ef59;animation:slideUp .4s ease}.modal-header-schedule{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #f1f5f9}.modal-header-schedule h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0}.modal-header-schedule button{width:32px;height:32px;background:#f1f5f9;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b;font-size:1.25rem}.modal-header-schedule button:hover{background:#fee2e2;color:#ef4444}.modal-body-schedule{padding:2rem}.modal-date{font-size:1rem;font-weight:700;color:#7c3aed;margin-bottom:1.5rem;text-transform:capitalize}.modal-body-schedule label{display:block;font-size:.9375rem;font-weight:700;color:#0f172a;margin-bottom:.75rem}.modal-body-schedule textarea{width:100%;padding:1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:.9375rem;font-family:inherit;resize:vertical;transition:all .3s}.modal-body-schedule textarea:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.modal-footer-schedule{display:flex;gap:1rem;padding:1.5rem 2rem;border-top:2px solid #f1f5f9}.btn-cancel,.btn-confirm{flex:1;padding:1rem;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-cancel{background:#f1f5f9;color:#64748b}.btn-confirm{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef44444d}.btn-confirm:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ef444466}@media(max-width:1200px){.schedule-content{grid-template-columns:1fr}.day-details-panel{position:relative;top:0;max-height:none}}@media(max-width:768px){.schedule-page{padding:1rem}.schedule-header,.calendar-section,.day-details-panel{padding:1.5rem}.header-title h1{font-size:1.5rem}.current-month{font-size:1.25rem}.calendar-grid{gap:.375rem}.weekday-header{font-size:.75rem;padding:.75rem 0}.day-number{font-size:.875rem}.calendar-legend{flex-wrap:wrap;gap:1rem}.modal-content-schedule{margin:.5rem}}.block-buttons-group{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem}.btn-block-day.full{width:100%}.btn-block-hours{width:100%;padding:1rem;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-block-hours:hover{transform:translateY(-2px);box-shadow:0 8px 24px #f59e0b4d}.modal-content-schedule.modal-wide{max-width:700px}.modal-body-hours{max-height:600px;overflow-y:auto}.block-hours-form{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.block-hours-form h4{font-size:1rem;font-weight:700;color:#92400e;margin:0 0 1rem}.hours-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group-hours{display:flex;flex-direction:column;gap:.5rem}.form-group-hours label{font-size:.875rem;font-weight:700;color:#78350f}.form-select-hours,.form-textarea-hours{padding:.75rem;border:2px solid #fbbf24;border-radius:8px;font-size:.9375rem;font-family:inherit;transition:all .3s;background:#fff}.form-select-hours:focus,.form-textarea-hours:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.form-textarea-hours{resize:vertical}.btn-add-block{width:100%;padding:1rem;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:10px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s;margin-top:1rem}.btn-add-block:hover{transform:translateY(-2px);box-shadow:0 8px 24px #f59e0b66}.blocked-hours-list h4{font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.no-blocked-hours{text-align:center;padding:2rem;color:#64748b;font-size:.9375rem}.blocked-hours-items{display:flex;flex-direction:column;gap:.75rem}.blocked-hour-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;transition:all .3s}.blocked-hour-item:hover{border-color:#f59e0b;background:#fef3c7}.blocked-hour-time{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;color:#92400e;font-weight:700;white-space:nowrap}.blocked-hour-time svg{color:#f59e0b}.blocked-hour-info{flex:1}.blocked-hour-reason{font-weight:700;color:#0f172a;margin:0 0 .25rem;font-size:.9375rem}.blocked-hour-meta{font-size:.8125rem;color:#64748b;margin:0}.btn-unblock-hour{padding:.5rem 1rem;background:#fff;border:2px solid #10b981;border-radius:8px;color:#10b981;font-weight:700;font-size:.875rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;white-space:nowrap}.btn-unblock-hour:hover{background:#10b981;color:#fff}@media(max-width:768px){.block-buttons-group,.hours-form-grid{grid-template-columns:1fr}.blocked-hour-item{flex-direction:column;align-items:flex-start}.btn-unblock-hour{width:100%;justify-content:center}}.admin-categories-page{min-height:100vh;background:linear-gradient(135deg,#faf5ff,#f3e8ff);padding:2rem}.categories-container{max-width:1400px;margin:0 auto}.categories-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:2rem;border-radius:20px;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.categories-header h1{font-size:2rem;font-weight:800;color:#0f172a;margin:0 0 .25rem}.categories-header p{font-size:1rem;color:#64748b;margin:0}.loading-categories{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.loading-categories p{font-size:1.125rem;font-weight:600;color:#64748b}.empty-categories{background:#fff;border-radius:20px;padding:4rem 2rem;text-align:center;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.empty-categories h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.empty-categories p{font-size:1rem;color:#64748b;margin:0 0 2rem}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.category-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9;transition:all .3s;animation:fadeInUp .4s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.category-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #d946ef26;border-color:#d946ef}.category-card.inactive{opacity:.6;background:#f8fafc}.category-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.category-icon-large{width:64px;height:64px;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:2rem;border:2px solid #e9d5ff}.category-actions{display:flex;gap:.5rem}.action-btn.edit{border-color:#3b82f6;color:#3b82f6}.action-btn.edit:hover{background:#3b82f6;color:#fff}.action-btn.toggle.active{border-color:#10b981;color:#10b981}.action-btn.toggle.active:hover{background:#10b981;color:#fff}.action-btn.toggle.inactive{border-color:#94a3b8;color:#94a3b8}.action-btn.toggle.inactive:hover{background:#94a3b8;color:#fff}.category-card-body h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.category-description{font-size:.9375rem;color:#64748b;margin:0 0 1.25rem;line-height:1.5;min-height:3em}.category-stats{display:flex;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.stat-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#64748b}.stat-item svg{color:#d946ef;font-size:1.125rem}.stat-item.active{color:#10b981}.stat-item.active svg{color:#10b981}.category-meta{display:flex;justify-content:space-between;align-items:center}.category-orden{font-size:.875rem;color:#64748b;font-weight:600}.category-status{padding:.375rem .875rem;border-radius:8px;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.category-status.active{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.category-status.inactive{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#64748b}.btn-primary{padding:.875rem 1.75rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:all .3s;box-shadow:0 4px 12px #d946ef4d}.btn-cancel{padding:.875rem 1.75rem;background:#f1f5f9;color:#64748b;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s}.modal-content-category{background:#fff;border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #d946ef59;animation:slideUp .4s ease}.modal-close-btn{width:36px;height:36px;background:#f1f5f9;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b;font-size:1.25rem}.modal-close-btn:hover{background:#fee2e2;color:#ef4444}.error-text{display:block;color:#ef4444;font-size:.875rem;margin-top:.5rem;font-weight:600}.icon-selector{display:grid;grid-template-columns:repeat(9,1fr);gap:.5rem;margin-bottom:1rem;padding:1rem;background:#f8fafc;border-radius:12px;border:2px solid #e2e8f0}.icon-option{width:48px;height:48px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer;transition:all .3s}.icon-option:hover{border-color:#d946ef;transform:scale(1.1)}.icon-option.selected{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-color:#d946ef;border-width:3px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;font-size:.9375rem;font-weight:600;color:#0f172a;cursor:pointer;margin-top:1.75rem}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#d946ef}.modal-footer{display:flex;gap:1rem;padding:1.5rem 2rem;border-top:2px solid #f1f5f9;justify-content:flex-end}@media(max-width:1200px){.categories-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.admin-categories-page{padding:1rem}.categories-header{flex-direction:column;gap:1.5rem;padding:1.5rem}.header-left{flex-direction:column;text-align:center}.categories-header h1{font-size:1.5rem}.categories-grid{grid-template-columns:1fr}.icon-selector{grid-template-columns:repeat(6,1fr)}.form-row{grid-template-columns:1fr}.modal-footer{flex-direction:column}.btn-primary,.btn-cancel{width:100%;justify-content:center}}.admin-invoices-page{min-height:100vh;background:linear-gradient(135deg,#faf5ff,#f3e8ff);padding:2rem}.invoices-container{max-width:1600px;margin:0 auto}.invoices-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:2rem;border-radius:20px;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.header-icon{width:64px;height:64px;background:linear-gradient(135deg,#d946ef,#c026d3);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;box-shadow:0 8px 24px #d946ef4d}.invoices-header h1{font-size:2rem;font-weight:800;color:#0f172a;margin:0 0 .25rem}.invoices-header p{font-size:1rem;color:#64748b;margin:0}.invoices-tabs{display:flex;gap:1rem;margin-bottom:2rem;background:#fff;padding:1rem;border-radius:16px;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9}.tab-btn:hover{background:#f8fafc;color:#d946ef}.tab-btn.active{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-color:#d946ef;color:#d946ef}.invoices-content{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #f1f5f9;min-height:400px}.loading-invoices{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.spinner-large{width:60px;height:60px;border:4px solid #f1f5f9;border-top-color:#d946ef;border-radius:50%;animation:spin .8s linear infinite}.filters-card{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:16px;padding:1.5rem;margin-bottom:2rem}.filters-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem}.filter-group label{display:block;font-size:.875rem;font-weight:700;color:#6b21a8;margin-bottom:.5rem}.filter-input{width:100%;padding:.75rem;border:2px solid #e9d5ff;border-radius:10px;font-size:.9375rem;transition:all .3s}.filter-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.btn-filter{width:100%;padding:.875rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-filter:hover{transform:translateY(-2px);box-shadow:0 8px 24px #d946ef66}.comprobantes-table thead{background:linear-gradient(135deg,#faf5ff,#f3e8ff)}.comprobantes-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:700;color:#6b21a8;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9d5ff}.comprobantes-table tbody tr:hover{background:#faf5ff}.tipo-badge.tipo-1{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.tipo-badge.tipo-2{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.estado-badge{display:inline-block;padding:.375rem .875rem;border-radius:8px;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.font-bold{font-weight:700;color:#d946ef}.action-btn{width:36px;height:36px;border-radius:8px;border:2px solid;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;font-size:1rem;background:#fff}.action-btn.delete{border-color:#ef4444;color:#ef4444}.action-btn.delete:hover{background:#ef4444;color:#fff}.empty-state svg{font-size:5rem;color:#d946ef;margin-bottom:1.5rem}.reservas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.reserva-card{background:#fff;border:2px solid #f1f5f9;border-radius:16px;padding:1.5rem;transition:all .3s}.reserva-card:hover{border-color:#d946ef;transform:translateY(-4px);box-shadow:0 8px 30px #d946ef26}.reserva-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.reserva-codigo{font-family:Courier New,monospace;font-weight:700;color:#d946ef;font-size:.875rem}.reserva-fecha{font-size:.875rem;color:#64748b}.reserva-body h4{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.reserva-cliente,.reserva-precio{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;color:#64748b;margin-bottom:.5rem}.reserva-precio{color:#d946ef;font-weight:700;font-size:1.125rem}.btn-generate{width:100%;padding:.875rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem;transition:all .3s}.btn-generate:hover{transform:translateY(-2px);box-shadow:0 8px 24px #d946ef66}.config-card{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:16px;padding:2rem}.config-item label{font-size:.875rem;font-weight:700;color:#6b21a8;text-transform:uppercase;letter-spacing:.5px}.modal-overlay{position:fixed;inset:0;background:#0f172ab3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9000;padding:1rem;animation:fadeIn .3s ease}.modal-content-invoice{background:#fff;border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #d946ef59;animation:slideUp .4s ease}.modal-header button{width:36px;height:36px;background:#f1f5f9;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b;font-size:1.25rem}.reserva-info-box{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.reserva-info-box h4{font-size:1rem;font-weight:800;color:#6b21a8;margin:0 0 .75rem}.reserva-info-box p{font-size:.9375rem;color:#0f172a;margin:.25rem 0}.form-input{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-family:inherit;transition:all .3s}.btn-primary{flex:1;padding:.875rem;background:linear-gradient(135deg,#d946ef,#c026d3);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #d946ef66}.detail-item.total{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:2px solid #e9d5ff}.items-table{width:100%;border-collapse:collapse}.items-table th{text-align:left;padding:.75rem;background:#f8fafc;font-size:.875rem;font-weight:700;color:#64748b;border-bottom:2px solid #e2e8f0}.items-table td{padding:.75rem;border-bottom:1px solid #f1f5f9;font-size:.9375rem}.sunat-response{padding:1.25rem;border-radius:12px;display:flex;align-items:center;gap:1rem;font-weight:600}.sunat-response.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.sunat-response.error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}@media(max-width:1200px){.filters-grid{grid-template-columns:repeat(2,1fr)}.reservas-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media(max-width:768px){.admin-invoices-page{padding:1rem}.invoices-header{flex-direction:column;gap:1.5rem;padding:1.5rem}.header-left{flex-direction:column;text-align:center}.invoices-tabs{flex-direction:column}.filters-grid{grid-template-columns:1fr}.comprobantes-table{overflow-x:scroll}.config-grid,.detail-grid,.form-row{grid-template-columns:1fr}.modal-footer,.links-grid{flex-direction:column}}.swal2-container,.swal2-popup{z-index:99999!important}.swal2-backdrop-show{z-index:99998!important}.swal2-loading{z-index:99999!important}.servicios-factura{margin:.75rem 0}.servicios-factura strong{display:block;margin-bottom:.5rem;color:#374151;font-size:.875rem}.servicios-list-factura{background:#fdf4ff;border-left:3px solid #d946ef;border-radius:8px;padding:.875rem;margin-top:.5rem}.servicio-item-factura{display:flex;align-items:center;gap:.5rem;padding:.375rem 0;font-size:.875rem;color:#1f2937}.servicio-item-factura:not(:last-of-type){border-bottom:1px dashed #e9d5ff}.servicio-numero{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;flex-shrink:0}.total-servicios-badge{display:inline-flex;padding:.25rem .75rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:12px;font-size:.6875rem;font-weight:600;margin-top:.5rem}.reserva-info-box{background:linear-gradient(135deg,#fdf4ff,#fae8ff);border:2px solid #f5d0fe;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.reserva-info-box h4{margin:0 0 1rem;color:#d946ef;font-size:1rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.reserva-info-box h4:before{content:"📋";font-size:1.25rem}.reserva-info-box p{margin:.5rem 0;font-size:.9375rem;color:#374151}.reserva-info-box strong{color:#1f2937;font-weight:600;min-width:140px;display:inline-block}.aulavirtual-layout{display:flex;min-height:100vh;background:#f8fafc}.aulavirtual-sidebar{width:280px;background:linear-gradient(180deg,#1e40af,#1e3a8a);color:#fff;position:fixed;height:100vh;left:0;top:0;overflow-y:auto;z-index:1000;box-shadow:4px 0 20px #0000001a}.aulavirtual-sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.aulavirtual-back-button{width:40px;height:40px;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;margin-bottom:1rem;transition:all .3s;font-size:1.25rem}.aulavirtual-back-button:hover{background:#fff3;transform:translate(-4px)}.aulavirtual-sidebar-title h2{font-size:1.5rem;font-weight:800;margin:0 0 .25rem;color:#fff}.aulavirtual-sidebar-title p{font-size:.875rem;color:#ffffffb3;margin:0}.aulavirtual-sidebar-nav{padding:1rem 0}.aulavirtual-nav-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;color:#fffc;text-decoration:none;transition:all .3s;font-weight:600;font-size:.9375rem;position:relative}.aulavirtual-nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#fff;transform:scaleY(0);transition:transform .3s}.aulavirtual-nav-item:hover{background:#ffffff1a;color:#fff}.aulavirtual-nav-item:hover:before{transform:scaleY(1)}.aulavirtual-nav-item.active{background:#ffffff26;color:#fff}.aulavirtual-nav-item.active:before{transform:scaleY(1)}.aulavirtual-nav-item svg{font-size:1.25rem;flex-shrink:0}.av-nav-separator{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem .5rem;margin-top:.5rem}.av-nav-separator:before,.av-nav-separator:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(253,224,160,.4),transparent)}.av-nav-separator span{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fde0a099;white-space:nowrap}.aulavirtual-main-content{margin-left:280px;flex:1;min-height:100vh;width:calc(100% - 280px)}@media(max-width:1024px){.aulavirtual-sidebar{transform:translate(-100%);transition:transform .3s}.aulavirtual-sidebar.open{transform:translate(0)}.aulavirtual-main-content{margin-left:0;width:100%}}@media(max-width:768px){.aulavirtual-sidebar{width:100%}}.aulavirtual-nav-item.logout{width:100%;text-align:left;background:none;border:none;cursor:pointer;color:#ff6b6b}.aulavirtual-nav-item.logout:hover{background:#ff6b6b26;color:#ff6b6b}.aulavirtual-dashboard-v2{padding:2rem;max-width:1600px;margin:0 auto}.dashboard-hero{background:linear-gradient(135deg,#1e40af,#3b82f6,#60a5fa);border-radius:24px;padding:3rem;margin-bottom:2rem;color:#fff;box-shadow:0 20px 60px #3b82f64d;position:relative;overflow:hidden}.dashboard-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.hero-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;position:relative;z-index:2}.hero-text h1{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.hero-text p{font-size:1.125rem;opacity:.95;margin:0}.hero-icon{width:80px;height:80px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:float 3s ease-in-out infinite}.period-selector{display:flex;gap:1rem;margin-bottom:1.5rem;position:relative;z-index:2}.period-btn{padding:.75rem 1.5rem;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s}.period-btn:hover{background:#ffffff40;transform:translateY(-2px)}.period-btn.active{background:#fff;color:#3b82f6;border-color:#fff;box-shadow:0 4px 16px #ffffff4d}.custom-date-range{display:flex;align-items:center;gap:1rem;position:relative;z-index:2}.custom-date-range svg{font-size:1.5rem}.date-input-v2{padding:.75rem 1rem;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:10px;color:#fff;font-weight:600;transition:all .3s}.date-input-v2:focus{outline:none;background:#ffffff40;border-color:#fff}.date-input-v2::placeholder{color:#ffffffb3}.custom-date-range span{font-weight:700;font-size:1.25rem}.kpis-grid-v2{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}.kpi-card-v2{background:#fff;border-radius:20px;padding:1.75rem;border:2px solid #e2e8f0;transition:all .3s;position:relative;overflow:hidden}.kpi-card-v2:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;transition:all .3s}.kpi-card-v2.blue:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.kpi-card-v2.purple:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.kpi-card-v2.green:before{background:linear-gradient(90deg,#10b981,#34d399)}.kpi-card-v2.orange:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.kpi-card-v2.teal:before{background:linear-gradient(90deg,#14b8a6,#2dd4bf)}.kpi-card-v2.indigo:before{background:linear-gradient(90deg,#6366f1,#818cf8)}.kpi-card-v2:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000001a}.kpi-card-v2:hover:before{height:6px}.kpi-header-v2{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.kpi-icon-v2{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#fff;box-shadow:0 4px 16px #00000026}.kpi-card-v2.blue .kpi-icon-v2{background:linear-gradient(135deg,#3b82f6,#2563eb)}.kpi-card-v2.purple .kpi-icon-v2{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.kpi-card-v2.green .kpi-icon-v2{background:linear-gradient(135deg,#10b981,#059669)}.kpi-card-v2.orange .kpi-icon-v2{background:linear-gradient(135deg,#f59e0b,#d97706)}.kpi-card-v2.teal .kpi-icon-v2{background:linear-gradient(135deg,#14b8a6,#0d9488)}.kpi-card-v2.indigo .kpi-icon-v2{background:linear-gradient(135deg,#6366f1,#4f46e5)}.kpi-trend{display:flex;align-items:center;gap:.25rem;padding:.375rem .75rem;border-radius:8px;font-size:.875rem;font-weight:700}.kpi-trend.positive{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.kpi-trend.negative{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.kpi-trend svg{font-size:1rem}.kpi-body-v2{display:flex;flex-direction:column;gap:.5rem}.kpi-label-v2{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.kpi-value-v2{font-size:2.25rem;font-weight:800;color:#0f172a;line-height:1}.kpi-subtitle-v2{font-size:.8125rem;color:#94a3b8;font-weight:600}.kpi-footer-v2{margin-top:1rem;height:40px;position:relative;overflow:hidden}.kpi-sparkline{position:absolute;bottom:0;left:0;right:0;height:100%;opacity:.15;border-radius:8px}.kpi-sparkline.blue{background:linear-gradient(180deg,transparent,#3b82f6)}.kpi-sparkline.purple{background:linear-gradient(180deg,transparent,#8b5cf6)}.kpi-sparkline.green{background:linear-gradient(180deg,transparent,#10b981)}.kpi-sparkline.orange{background:linear-gradient(180deg,transparent,#f59e0b)}.kpi-sparkline.teal{background:linear-gradient(180deg,transparent,#14b8a6)}.kpi-sparkline.indigo{background:linear-gradient(180deg,transparent,#6366f1)}.dashboard-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-bottom:2rem}.chart-card-v2{background:#fff;border-radius:20px;padding:2rem;border:2px solid #e2e8f0;transition:all .3s}.chart-card-v2:hover{box-shadow:0 12px 40px #0000001a}.chart-header-v2{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.chart-header-v2 h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 .5rem;display:flex;align-items:center;gap:.75rem}.chart-header-v2 h3 svg{font-size:1.5rem;color:#3b82f6}.chart-header-v2 p{font-size:.875rem;color:#64748b;margin:0}.view-all-link-v2{font-size:.9375rem;font-weight:700;color:#3b82f6;text-decoration:none;transition:all .3s}.view-all-link-v2:hover{color:#2563eb;transform:translate(4px)}.chart-body-v2{min-height:300px}.chart-legend-v2{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem;padding:1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.legend-item-v2{display:flex;align-items:center;gap:1rem}.legend-color-v2{width:24px;height:24px;border-radius:8px;flex-shrink:0;box-shadow:0 2px 8px #00000026}.legend-text-v2{display:flex;flex-direction:column;gap:.25rem;flex:1}.legend-text-v2 strong{font-size:.9375rem;font-weight:700;color:#0f172a}.legend-text-v2 span{font-size:.8125rem;color:#64748b;font-weight:600}.no-data-chart{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;color:#cbd5e1}.no-data-chart svg{font-size:4rem}.no-data-chart p{font-size:1rem;font-weight:600;color:#94a3b8}.payments-timeline{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.payments-timeline::-webkit-scrollbar{width:6px}.payments-timeline::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.payments-timeline::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.payments-timeline::-webkit-scrollbar-thumb:hover{background:#94a3b8}.timeline-item{display:flex;gap:1rem;padding:1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:12px;transition:all .3s;position:relative}.timeline-item:hover{background:#fff;border-color:#3b82f6;transform:translate(4px)}.timeline-marker{width:12px;height:12px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;flex-shrink:0;margin-top:.5rem;box-shadow:0 0 0 4px #3b82f633}.timeline-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.timeline-header{display:flex;justify-content:space-between;align-items:center}.timeline-student{font-weight:700;color:#0f172a;font-size:.9375rem}.timeline-amount{font-weight:800;color:#10b981;font-size:1rem}.timeline-details{display:flex;justify-content:space-between;align-items:center}.timeline-course{font-size:.875rem;color:#64748b;font-weight:600}.timeline-date{font-size:.8125rem;color:#94a3b8;font-weight:600}.quick-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.summary-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:16px;transition:all .3s}.summary-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.summary-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#fff;flex-shrink:0}.summary-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.summary-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.summary-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.summary-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.summary-content{display:flex;flex-direction:column;gap:.25rem}.summary-value{font-size:1.75rem;font-weight:800;color:#0f172a;line-height:1}.summary-label{font-size:.875rem;color:#64748b;font-weight:600}.quick-actions-v2{background:#fff;border-radius:20px;padding:2rem;border:2px solid #e2e8f0}.quick-actions-v2 h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.quick-actions-v2 h3 svg{font-size:1.5rem;color:#3b82f6}.actions-grid-v2{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.action-card-v2{display:flex;flex-direction:column;padding:1.75rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px;text-decoration:none;transition:all .3s;position:relative;overflow:hidden}.action-card-v2:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;transition:all .3s}.action-card-v2.blue:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.action-card-v2.purple:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.action-card-v2.green:before{background:linear-gradient(90deg,#10b981,#34d399)}.action-card-v2.orange:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.action-card-v2:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026;background:#fff}.action-card-v2:hover:before{height:6px}.action-icon-v2{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#fff;margin-bottom:1rem;transition:all .3s}.action-card-v2.blue .action-icon-v2{background:linear-gradient(135deg,#3b82f6,#2563eb)}.action-card-v2.purple .action-icon-v2{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.action-card-v2.green .action-icon-v2{background:linear-gradient(135deg,#10b981,#059669)}.action-card-v2.orange .action-icon-v2{background:linear-gradient(135deg,#f59e0b,#d97706)}.action-card-v2:hover .action-icon-v2{transform:scale(1.1) rotate(5deg)}.action-content-v2{display:flex;flex-direction:column;gap:.5rem;flex:1}.action-title-v2{font-size:1rem;font-weight:800;color:#0f172a}.action-desc-v2{font-size:.875rem;color:#64748b;font-weight:600;line-height:1.4}.action-arrow-v2{font-size:1.5rem;font-weight:700;color:#cbd5e1;text-align:right;transition:all .3s}.action-card-v2:hover .action-arrow-v2{color:#3b82f6;transform:translate(4px)}.loading-dashboard-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.loading-spinner-v2{width:60px;height:60px;border:4px solid #e0f2fe;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.loading-dashboard-v2 p{font-size:1.125rem;font-weight:700;color:#64748b}.loading-bars{display:flex;gap:.5rem}.loading-bar{width:8px;height:40px;background:linear-gradient(180deg,#3b82f6,#60a5fa);border-radius:4px;animation:pulse 1s ease-in-out infinite}.loading-bar:nth-child(1){animation-delay:0s}.loading-bar:nth-child(2){animation-delay:.2s}.loading-bar:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,to{transform:scaleY(.5);opacity:.5}50%{transform:scaleY(1);opacity:1}}.error-dashboard-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.error-dashboard-v2 svg{font-size:5rem;color:#ef4444}.error-dashboard-v2 h3{font-size:1.75rem;font-weight:800;color:#0f172a;margin:0}.error-dashboard-v2 p{font-size:1rem;color:#64748b;margin:0}.btn-retry{padding:.875rem 1.75rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s}.btn-retry:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}@media(max-width:1400px){.kpis-grid-v2,.actions-grid-v2{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.dashboard-charts-grid{grid-template-columns:1fr}.quick-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.aulavirtual-dashboard-v2{padding:1rem}.dashboard-hero{padding:2rem}.hero-text h1{font-size:1.75rem}.period-selector{flex-direction:column}.kpis-grid-v2,.quick-summary,.actions-grid-v2{grid-template-columns:1fr}.custom-date-range{flex-direction:column;align-items:stretch}}.pagos-page-v2{min-height:100vh;background:linear-gradient(135deg,#eff6ff,#dbeafe);padding:2rem}.pagos-container-v2{max-width:1800px;margin:0 auto}.pagos-header-v2{background:#fff;padding:2.5rem;border-radius:24px;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #e0f2fe}.pagos-header-v2 .header-content{display:flex;align-items:center;gap:2rem}.header-icon-v2{width:80px;height:80px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.5rem;box-shadow:0 8px 24px #3b82f64d;flex-shrink:0}.header-text h1{font-size:2.25rem;font-weight:800;color:#0f172a;margin:0 0 .5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-text p{font-size:1.125rem;color:#64748b;margin:0;font-weight:500}.tabs-navigation{display:flex;gap:1rem;margin-bottom:2rem;background:#fff;padding:1rem;border-radius:20px;box-shadow:0 4px 20px #0000000f;border:2px solid #e0f2fe}.tab-btn-v2{flex:1;padding:1.25rem 1.5rem;background:transparent;border:2px solid transparent;border-radius:16px;font-size:1rem;font-weight:700;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s;position:relative}.tab-btn-v2:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#3b82f6;transform:translateY(-2px)}.tab-btn-v2.active{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#1e40af;color:#fff;box-shadow:0 8px 24px #3b82f64d}.tab-btn-v2 svg{font-size:1.5rem}.tab-badge{padding:.25rem .75rem;background:#fff3;border-radius:12px;font-size:.875rem;font-weight:800}.tab-btn-v2.active .tab-badge{background:#ffffff40}.tab-badge.alert{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.tab-content-v2{background:#fff;border-radius:20px;padding:2.5rem;box-shadow:0 4px 20px #0000000f;border:2px solid #e0f2fe;min-height:600px}@media(max-width:1024px){.tabs-navigation{overflow-x:auto;flex-wrap:nowrap}.tab-btn-v2{min-width:200px}}@media(max-width:768px){.pagos-page-v2{padding:1rem}.pagos-header-v2 .header-content{flex-direction:column;text-align:center}.header-text h1{font-size:1.75rem}.tabs-navigation{flex-direction:column}.tab-btn-v2{width:100%}}.tab-lista-pagos{width:100%}.lista-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:2rem;flex-wrap:wrap}.lista-stats{display:flex;gap:1.5rem;flex-wrap:wrap;flex:1}.stat-item-small{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:12px;transition:all .3s;flex:1;min-width:200px}.stat-item-small:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.stat-item-small svg{font-size:2rem;color:#3b82f6;flex-shrink:0}.stat-item-small>div{display:flex;flex-direction:column}.stat-item-small .stat-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.stat-item-small .stat-value{font-size:1.25rem;font-weight:800;color:#0f172a}.lista-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn-filter-toggle,.btn-export{padding:.75rem 1.25rem;border-radius:10px;font-weight:700;font-size:.9375rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;border:2px solid}.btn-filter-toggle{background:#fff;border-color:#3b82f6;color:#3b82f6}.btn-filter-toggle:hover{background:#3b82f6;color:#fff}.btn-export{background:linear-gradient(135deg,#10b981,#059669);border-color:#059669;color:#fff}.btn-export:hover{transform:translateY(-2px);box-shadow:0 4px 16px #10b9814d}.filters-panel{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #bfdbfe;border-radius:16px;padding:2rem;margin-bottom:2rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.filters-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:1.5rem}.filter-group label{font-size:.875rem;font-weight:700;color:#1e40af}.filter-group input,.filter-group select{padding:.75rem;border:2px solid #bfdbfe;border-radius:10px;font-size:.9375rem;transition:all .3s;background:#fff}.filters-actions{display:flex;justify-content:flex-end}.btn-clear-filters{padding:.75rem 1.5rem;background:#fff;border:2px solid #ef4444;border-radius:10px;color:#ef4444;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s}.btn-clear-filters:hover{background:#ef4444;color:#fff}.table-wrapper{overflow-x:auto;margin-bottom:2rem;border:2px solid #e2e8f0;border-radius:16px}.pagos-table{width:100%;border-collapse:collapse;background:#fff}.pagos-table thead{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.pagos-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:800;color:#1e40af;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #bfdbfe;white-space:nowrap}.pagos-table td{padding:1rem;border-bottom:1px solid #f1f5f9;font-size:.9375rem;color:#0f172a}.pagos-table tbody tr{transition:all .2s}.pagos-table tbody tr:hover{background:#f8fafc}.td-id{font-family:Courier New,monospace;font-weight:700;color:#3b82f6}.td-estudiante{font-weight:700;max-width:200px}.td-curso{max-width:250px;color:#64748b}.td-fecha{white-space:nowrap}.td-monto,.td-abonado,.td-pendiente{font-weight:700;white-space:nowrap}.td-monto{color:#0f172a}.td-abonado{color:#10b981}.td-pendiente{color:#f59e0b}.method-badge-v2{display:inline-block;padding:.375rem .75rem;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.method-badge-v2.efectivo{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.method-badge-v2.transferencia{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.method-badge-v2.yape{background:linear-gradient(135deg,#e9d5ff,#d8b4fe);color:#7c3aed}.method-badge-v2.plin{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.method-badge-v2.tarjeta{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.cuotas-badge{display:inline-block;padding:.375rem .75rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:8px;font-size:.8125rem;font-weight:700;color:#92400e}.cuotas-badge.complete{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981;color:#047857}.estado-badge-v2{display:inline-block;padding:.375rem .875rem;border-radius:8px;font-size:.8125rem;font-weight:700}.estado-badge-v2.pagado{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.estado-badge-v2.pendiente{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.estado-badge-v2.parcial{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.estado-badge-v2.vencido{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.td-actions{display:flex;gap:.5rem;justify-content:center}.action-btn-v2{width:36px;height:36px;border-radius:8px;border:2px solid;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;font-size:1rem;background:#fff}.action-btn-v2.view{border-color:#3b82f6;color:#3b82f6}.action-btn-v2.view:hover{background:#3b82f6;color:#fff;transform:scale(1.1)}.action-btn-v2.add{border-color:#10b981;color:#10b981}.action-btn-v2.add:hover{background:#10b981;color:#fff;transform:scale(1.1)}.pagination-wrapper{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px;flex-wrap:wrap;gap:1rem}.pagination-info{font-size:.9375rem;font-weight:600;color:#64748b}.pagination-controls{display:flex;gap:.5rem}.pagination-btn{min-width:40px;height:40px;padding:0 .75rem;background:#fff;border:2px solid #cbd5e1;border-radius:8px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s}.pagination-btn:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6;transform:translateY(-2px)}.pagination-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#1e40af;color:#fff}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-jump{display:flex;align-items:center;gap:.75rem}.pagination-jump span{font-size:.9375rem;font-weight:600;color:#64748b}.pagination-jump input{width:70px;padding:.5rem;border:2px solid #cbd5e1;border-radius:8px;text-align:center;font-weight:700}.pagination-jump input:focus{outline:none;border-color:#3b82f6}.loading-table,.empty-table{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.loading-table p,.empty-table p{font-size:1rem;color:#64748b;font-weight:600}.empty-table svg{font-size:5rem;color:#cbd5e1}.empty-table h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0}@media(max-width:1200px){.filters-grid{grid-template-columns:repeat(2,1fr)}.lista-header{flex-direction:column;align-items:stretch}.lista-stats{width:100%}.lista-actions{width:100%;justify-content:center}}@media(max-width:768px){.filters-grid{grid-template-columns:1fr}.stat-item-small{width:100%}.pagination-wrapper{flex-direction:column}.pagination-controls{flex-wrap:wrap;justify-content:center}.table-wrapper{overflow-x:scroll}.pagos-table{min-width:1200px}}.modal-overlay-detalle{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:2rem;animation:fadeIn .3s ease;overflow-y:auto}.modal-content-detalle{background:#fff;border-radius:24px;width:100%;max-width:1000px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #3b82f666;animation:slideUp .4s ease}.modal-header-detalle{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:24px 24px 0 0}.header-title-detalle{display:flex;align-items:center;gap:1rem;color:#fff}.header-title-detalle svg{font-size:2rem}.header-title-detalle h2{font-size:1.75rem;font-weight:800;margin:0;color:#fff}.btn-close-detalle{width:44px;height:44px;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#fff;font-size:1.75rem}.btn-close-detalle:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body-detalle{padding:2.5rem}.detalle-section{margin-bottom:2.5rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.detalle-section:last-of-type{margin-bottom:0}.detalle-section h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #cbd5e1}.detalle-section h3 svg{font-size:1.5rem;color:#3b82f6}.detalle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.detalle-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:10px}.detalle-item.full-width{grid-column:1 / -1}.detalle-label{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.detalle-value{font-size:1rem;font-weight:600;color:#0f172a}.detalle-value.strong{font-weight:800;color:#3b82f6;font-size:1.125rem}.font-mono{font-family:Courier New,monospace;font-weight:700;color:#3b82f6}.resumen-financiero-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.resumen-card{display:flex;flex-direction:column;padding:1.5rem;background:#fff;border:2px solid;border-radius:12px;text-align:center;transition:all .3s}.resumen-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.resumen-label{font-size:.875rem;font-weight:700;color:#64748b;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.resumen-value{font-size:1.5rem;font-weight:800}.resumen-value.total{color:#0f172a;border-color:#cbd5e1}.resumen-value.abonado{color:#10b981;border-color:#bbf7d0}.resumen-card:has(.abonado){border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.resumen-value.pendiente{color:#f59e0b;border-color:#fed7aa}.resumen-card:has(.pendiente){border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.resumen-value.cuotas{color:#3b82f6;border-color:#bfdbfe}.resumen-card:has(.cuotas){border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.cuotas-table-wrapper{overflow-x:auto;border:2px solid #e2e8f0;border-radius:12px;background:#fff}.cuotas-table{width:100%;border-collapse:collapse}.cuotas-table thead{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.cuotas-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:800;color:#1e40af;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #bfdbfe}.cuotas-table td{padding:1rem;border-bottom:1px solid #f1f5f9;font-size:.9375rem}.cuotas-table tr.cuota-pagada{background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.cuotas-table tr.cuota-pendiente{background:linear-gradient(135deg,#fffbeb,#fef3c7)}.cuotas-table tr:hover{background:#eff6ff}.td-cuota-num{font-weight:800;color:#3b82f6}.td-cuota-monto{font-weight:800;color:#10b981}.td-nro-op{font-family:Courier New,monospace;color:#64748b}.method-badge-small{display:inline-block;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase}.method-badge-small.efectivo{background:#d1fae5;color:#047857}.method-badge-small.transferencia{background:#dbeafe;color:#1e40af}.method-badge-small.yape{background:#e9d5ff;color:#7c3aed}.method-badge-small.plin{background:#fef3c7;color:#92400e}.method-badge-small.tarjeta{background:#fee2e2;color:#991b1b}.estado-badge-small{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:700}.estado-badge-small.pagado{background:#d1fae5;color:#047857}.estado-badge-small.pendiente{background:#fef3c7;color:#92400e}.btn-ver-comprobante{display:inline-flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:12px;font-weight:700;text-decoration:none;transition:all .3s;margin-top:1rem}.btn-ver-comprobante:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.notas-box{padding:1.5rem;background:#fff;border:2px solid #e2e8f0;border-left:4px solid #3b82f6;border-radius:10px;color:#0f172a;line-height:1.6;font-size:.9375rem}.detalle-footer{display:flex;justify-content:space-between;padding:1.5rem;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:12px;margin-top:2rem;gap:1rem;flex-wrap:wrap}.footer-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#64748b;font-weight:600}.footer-item svg{font-size:1rem;color:#94a3b8}@media(max-width:1024px){.resumen-financiero-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.modal-overlay-detalle{padding:0}.modal-content-detalle{max-width:100%;max-height:100vh;border-radius:0}.modal-header-detalle{border-radius:0}.modal-body-detalle,.detalle-section{padding:1.5rem}.detalle-grid,.resumen-financiero-grid{grid-template-columns:1fr}.cuotas-table-wrapper{overflow-x:scroll}.detalle-footer{flex-direction:column}}.swal2-container{z-index:999999!important}.modal-overlay-abono{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:2rem;animation:fadeIn .3s ease;overflow-y:auto}.modal-content-abono{background:#fff;border-radius:24px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #10b98166;animation:slideUp .4s ease}.modal-header-abono{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.5rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:24px 24px 0 0}.header-title-abono{display:flex;align-items:center;gap:1rem;color:#fff}.header-title-abono svg{font-size:2rem}.header-title-abono h2{font-size:1.75rem;font-weight:800;margin:0;color:#fff}.btn-close-abono{width:44px;height:44px;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#fff;font-size:1.75rem}.btn-close-abono:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body-abono{padding:2.5rem}.info-pago-section{margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #bfdbfe;border-radius:16px}.info-pago-section h3{font-size:1.125rem;font-weight:800;color:#1e40af;margin:0 0 1.25rem;text-transform:uppercase;letter-spacing:.5px}.info-pago-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-label{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1rem;font-weight:700;color:#0f172a;margin:0}.info-sub{font-size:.875rem;color:#64748b;margin:0}.resumen-abono-section{margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.resumen-abono-section h3{font-size:1.125rem;font-weight:800;color:#0f172a;margin:0 0 1.25rem;text-transform:uppercase;letter-spacing:.5px}.resumen-abono-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.resumen-abono-card{display:flex;flex-direction:column;padding:1.25rem;background:#fff;border:2px solid #cbd5e1;border-radius:12px;text-align:center;transition:all .3s}.resumen-abono-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.resumen-abono-card.destacado{border:3px solid #f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7);box-shadow:0 4px 16px #f59e0b33}.resumen-abono-label{font-size:.8125rem;font-weight:700;color:#64748b;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.resumen-abono-value{font-size:1.375rem;font-weight:800}.resumen-abono-value.total{color:#0f172a}.resumen-abono-value.abonado{color:#10b981}.resumen-abono-value.pendiente{color:#f59e0b}.resumen-abono-value.cuotas{color:#3b82f6}.form-abono{padding:2rem;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #bbf7d0;border-radius:16px}.form-abono h3{font-size:1.25rem;font-weight:800;color:#047857;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem}.form-abono-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-bottom:1.5rem}.form-abono-group{display:flex;flex-direction:column;gap:.5rem}.form-abono-group.full-width{grid-column:1 / -1}.form-abono-group label{font-size:.9375rem;font-weight:700;color:#0f172a;display:flex;justify-content:space-between;align-items:center}.monto-sugerido{font-size:.875rem;color:#10b981;font-weight:700;cursor:pointer;padding:.25rem .75rem;background:#10b9811a;border-radius:6px;transition:all .3s}.monto-sugerido:hover{background:#10b98133;transform:scale(1.05)}.form-abono-group input,.form-abono-group select,.form-abono-group textarea{padding:.875rem 1rem;border:2px solid #cbd5e1;border-radius:10px;font-size:1rem;font-family:inherit;transition:all .3s;background:#fff}.form-abono-group input:focus,.form-abono-group select:focus,.form-abono-group textarea:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-abono-group textarea{resize:vertical;min-height:80px}.form-help{font-size:.8125rem;color:#64748b;font-weight:600}.preview-abono{margin-top:1.5rem;padding:1.5rem;background:#fff;border:3px solid #3b82f6;border-radius:12px}.preview-abono h4{font-size:1.125rem;font-weight:800;color:#1e40af;margin:0 0 1rem}.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.preview-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:10px}.preview-item.full-width{grid-column:1 / -1}.preview-item span:first-child{font-size:.875rem;font-weight:700;color:#64748b}.preview-value{font-size:1.25rem;font-weight:800}.preview-value.green{color:#10b981}.preview-value.orange{color:#f59e0b}.preview-value.blue{color:#3b82f6}.preview-completo{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;border-radius:10px;color:#047857;font-weight:800;font-size:1.125rem}.preview-completo svg{font-size:1.75rem}.form-abono-actions{display:flex;gap:1rem;margin-top:2rem}.btn-cancelar-abono,.btn-guardar-abono{flex:1;padding:1rem 1.5rem;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.75rem;border:2px solid}.btn-cancelar-abono{background:#fff;border-color:#cbd5e1;color:#64748b}.btn-cancelar-abono:hover{background:#f1f5f9;border-color:#94a3b8;color:#475569}.btn-guardar-abono{background:linear-gradient(135deg,#10b981,#059669);border-color:#059669;color:#fff;box-shadow:0 4px 16px #10b9814d}.btn-guardar-abono:hover{transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.btn-guardar-abono svg{font-size:1.25rem}@media(max-width:1024px){.info-pago-grid{grid-template-columns:1fr}.resumen-abono-cards{grid-template-columns:repeat(2,1fr)}.preview-grid{grid-template-columns:1fr}}@media(max-width:768px){.modal-overlay-abono{padding:0}.modal-content-abono{max-width:100%;max-height:100vh;border-radius:0}.modal-header-abono{border-radius:0;padding:1.5rem}.modal-body-abono,.info-pago-section,.resumen-abono-section,.form-abono{padding:1.5rem}.resumen-abono-cards,.form-abono-grid{grid-template-columns:1fr}.form-abono-actions{flex-direction:column}}.tab-registrar-pago{width:100%}.wizard-progress{display:flex;align-items:center;justify-content:space-between;margin-bottom:3rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.75rem;flex:1;position:relative}.step-circle{width:60px;height:60px;background:#fff;border:3px solid #cbd5e1;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#94a3b8;transition:all .3s;z-index:2}.progress-step.active .step-circle{background:linear-gradient(135deg,#10b981,#059669);border-color:#059669;color:#fff;box-shadow:0 4px 16px #10b9814d}.progress-step.completed .step-circle{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;color:#fff}.step-label{font-size:.875rem;font-weight:700;color:#64748b;text-align:center}.progress-step.active .step-label{color:#10b981}.progress-step.completed .step-label{color:#3b82f6}.progress-line{flex:1;height:4px;background:#e2e8f0;margin:0 1rem;position:relative;top:-20px;z-index:1;transition:all .3s}.progress-line.active{background:linear-gradient(90deg,#3b82f6,#10b981)}.wizard-content{min-height:500px;margin-bottom:2rem}.wizard-step{animation:fadeInStep .4s ease}@keyframes fadeInStep{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.wizard-step h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0 0 2rem;display:flex;align-items:center;gap:1rem;padding-bottom:1rem;border-bottom:3px solid #e2e8f0}.wizard-step h3 svg{font-size:2rem;color:#10b981}.step-form{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.form-group-wizard{display:flex;flex-direction:column;gap:.75rem}.form-group-wizard.full-width{grid-column:1 / -1}.form-group-wizard label{font-size:1rem;font-weight:700;color:#0f172a}.input-wizard,.select-wizard,.textarea-wizard{padding:1rem 1.25rem;border:2px solid #cbd5e1;border-radius:12px;font-size:1rem;font-family:inherit;transition:all .3s;background:#fff}.input-wizard:focus,.select-wizard:focus,.textarea-wizard:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 4px #10b9811a}.textarea-wizard{resize:vertical;min-height:100px}.autocomplete-wrapper{position:relative}.autocomplete-results-wizard{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #10b981;border-top:none;border-radius:0 0 12px 12px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:0 8px 24px #00000026;margin-top:-2px}.autocomplete-item-wizard{padding:1rem;cursor:pointer;display:flex;align-items:center;gap:1rem;transition:all .2s;border-bottom:1px solid #f1f5f9}.autocomplete-item-wizard:last-child{border-bottom:none}.autocomplete-item-wizard:hover{background:#f0fdf4}.student-avatar{width:48px;height:48px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;font-weight:800;flex-shrink:0}.autocomplete-item-wizard div{display:flex;flex-direction:column;gap:.25rem}.autocomplete-item-wizard strong{color:#0f172a;font-weight:700}.autocomplete-item-wizard span{color:#64748b;font-size:.875rem}.selected-info{display:flex;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;border-radius:10px;color:#047857;font-weight:600}.selected-info svg{font-size:1.25rem;flex-shrink:0}.checkbox-label-wizard{display:flex;align-items:center;gap:1rem;cursor:pointer;padding:1.25rem;background:#fff;border:2px solid #cbd5e1;border-radius:12px;transition:all .3s}.checkbox-label-wizard:hover{border-color:#10b981;background:#f0fdf4}.checkbox-label-wizard input[type=checkbox]{width:24px;height:24px;cursor:pointer;accent-color:#10b981}.checkbox-label-wizard span{font-weight:600;color:#0f172a}.cuotas-preview-wizard{grid-column:1 / -1;padding:1.5rem;background:#fff;border:3px solid #10b981;border-radius:12px;margin-top:1rem}.cuotas-preview-wizard h4{font-size:1.125rem;font-weight:800;color:#047857;margin:0 0 1rem}.cuotas-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.cuota-preview-item{display:flex;flex-direction:column;padding:1rem;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:2px solid #cbd5e1;border-radius:10px;transition:all .3s}.cuota-preview-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.cuota-preview-item.primera{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981}.cuota-preview-item.total{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b;grid-column:1 / -1}.cuota-num{font-size:.8125rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.cuota-preview-item.primera .cuota-num{color:#047857}.cuota-preview-item.total .cuota-num{color:#92400e}.cuota-monto{font-size:1.25rem;font-weight:800;color:#0f172a}.cuota-monto.pendiente{color:#f59e0b;font-size:1.5rem}.confirmation-summary{display:flex;flex-direction:column;gap:2rem}.summary-section{padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.summary-section h4{font-size:1.125rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #cbd5e1}.summary-section h4 svg{font-size:1.5rem;color:#10b981}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.summary-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:10px}.summary-item.full{grid-column:1 / -1}.summary-label{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:1rem;font-weight:700;color:#0f172a}.summary-financial{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.financial-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#fff;border:2px solid #e2e8f0;border-radius:10px}.financial-item span:first-child{font-weight:600;color:#64748b}.amount{font-size:1.25rem;font-weight:800}.amount.total{color:#0f172a}.amount.abono{color:#10b981}.amount.pendiente{color:#f59e0b}.confirmation-alert{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:3px solid #f59e0b;border-radius:12px;color:#92400e}.confirmation-alert svg{font-size:2rem;flex-shrink:0}.confirmation-alert strong{display:block;font-size:1.125rem;margin-bottom:.5rem}.confirmation-alert p{margin:0;line-height:1.5}.wizard-navigation{display:flex;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:16px;border:2px solid #cbd5e1}.btn-wizard-prev,.btn-wizard-next,.btn-wizard-submit{flex:1;padding:1.25rem 2rem;border-radius:12px;font-weight:700;font-size:1.125rem;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:1rem;border:2px solid}.btn-wizard-prev{background:#fff;border-color:#cbd5e1;color:#64748b}.btn-wizard-prev:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}.btn-wizard-prev:disabled{opacity:.4;cursor:not-allowed}.btn-wizard-next{background:linear-gradient(135deg,#10b981,#059669);border-color:#059669;color:#fff;box-shadow:0 4px 16px #10b9814d}.btn-wizard-next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.btn-wizard-next:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-wizard-submit{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;color:#fff;box-shadow:0 4px 16px #3b82f64d}.btn-wizard-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}@media(max-width:1024px){.wizard-progress{overflow-x:auto}.step-form,.summary-grid,.summary-financial{grid-template-columns:1fr}}@media(max-width:768px){.wizard-progress{padding:1rem}.step-circle{width:50px;height:50px;font-size:1.25rem}.step-label{font-size:.75rem}.progress-line{margin:0 .5rem}.wizard-navigation{flex-direction:column}.cuotas-preview-grid{grid-template-columns:1fr}}.tab-pagos-pendientes{width:100%}.urgencia-alerts{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.urgencia-alert{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;border-radius:16px;border:3px solid;animation:pulseAlert 2s ease-in-out infinite}.urgencia-alert svg{font-size:2.5rem;flex-shrink:0}.urgencia-alert strong{display:block;font-size:1.25rem;margin-bottom:.25rem}.urgencia-alert p{margin:0;font-size:.9375rem}.urgencia-alert.vencido{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444;color:#991b1b}.urgencia-alert.vencido svg{color:#dc2626}.urgencia-alert.hoy{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b;color:#92400e}.urgencia-alert.hoy svg{color:#f59e0b}.urgencia-alert.semana{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6;color:#1e40af}.urgencia-alert.semana svg{color:#3b82f6}@keyframes pulseAlert{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.pendientes-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-pendiente{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#fff;border:3px solid;border-radius:16px;transition:all .3s}.stat-pendiente:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.stat-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.stat-pendiente.total{border-color:#cbd5e1}.stat-pendiente.total .stat-icon{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#0f172a}.stat-pendiente.vencido{border-color:#ef4444}.stat-pendiente.vencido .stat-icon{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626}.stat-pendiente.hoy{border-color:#f59e0b}.stat-pendiente.hoy .stat-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#f59e0b}.stat-pendiente.semana{border-color:#3b82f6}.stat-pendiente.semana .stat-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#3b82f6}.stat-pendiente .stat-label{display:block;font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.stat-pendiente .stat-value{display:block;font-size:1.75rem;font-weight:800;color:#0f172a}.pendientes-controls{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.filtros-urgencia{display:flex;gap:1rem;flex-wrap:wrap}.filtro-btn{padding:.75rem 1.5rem;background:#fff;border:2px solid #cbd5e1;border-radius:10px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s}.filtro-btn:hover{border-color:#3b82f6;color:#3b82f6}.filtro-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;color:#fff;box-shadow:0 4px 16px #3b82f64d}.filtro-btn.vencido.active{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#dc2626}.filtro-btn.hoy.active{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#d97706}.filtro-btn.semana.active{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb}.filtro-btn.futuro.active{background:linear-gradient(135deg,#10b981,#059669);border-color:#059669}.search-and-sort{display:flex;gap:1rem}.search-pendientes,.sort-pendientes{padding:.875rem 1.25rem;border:2px solid #cbd5e1;border-radius:10px;font-size:1rem;transition:all .3s}.search-pendientes{flex:1}.search-pendientes:focus,.sort-pendientes:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.sort-pendientes{min-width:250px}.pendientes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem}.pendiente-card{background:#fff;border-radius:20px;padding:1.5rem;border:3px solid;transition:all .3s;display:flex;flex-direction:column;gap:1.25rem}.pendiente-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #00000026}.pendiente-card.vencido{border-color:#ef4444;background:linear-gradient(135deg,#fffbfb,#fef2f2)}.pendiente-card.hoy{border-color:#f59e0b;background:linear-gradient(135deg,#fffcf5,#fef3c7)}.pendiente-card.semana{border-color:#3b82f6;background:linear-gradient(135deg,#f8fbff,#eff6ff)}.pendiente-card.futuro{border-color:#10b981;background:linear-gradient(135deg,#f7fef9,#f0fdf4)}.pendiente-card-header{display:flex;justify-content:space-between;align-items:center}.urgencia-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.8125rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.pendiente-card.vencido .urgencia-badge{background:#ef4444;color:#fff}.pendiente-card.hoy .urgencia-badge{background:#f59e0b;color:#fff}.pendiente-card.semana .urgencia-badge{background:#3b82f6;color:#fff}.pendiente-card.futuro .urgencia-badge{background:#10b981;color:#fff}.pago-id{font-family:Courier New,monospace;font-weight:700;color:#64748b;font-size:.9375rem}.pendiente-estudiante{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px}.estudiante-avatar-pendiente{width:56px;height:56px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:800;flex-shrink:0}.pendiente-estudiante h4{margin:0 0 .25rem;font-size:1rem;font-weight:800;color:#0f172a}.pendiente-estudiante p{margin:0;font-size:.875rem;color:#64748b}.pendiente-curso{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:10px;color:#475569;font-weight:600}.pendiente-curso svg{font-size:1.25rem;color:#3b82f6;flex-shrink:0}.pendiente-financiero{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:12px}.financiero-item{display:flex;justify-content:space-between;align-items:center;font-size:.9375rem}.financiero-item span:first-child{color:#64748b;font-weight:600}.financiero-item span:last-child{font-weight:700;color:#0f172a}.financiero-item.destacado{padding-top:.75rem;border-top:2px solid #cbd5e1}.financiero-item .monto{color:#0f172a;font-size:1rem}.financiero-item .abonado{color:#10b981;font-size:1rem}.financiero-item .pendiente{color:#ef4444;font-size:1.125rem;font-weight:800}.pendiente-acciones{display:flex;gap:.75rem}.btn-accion-pendiente{flex:1;padding:.875rem;border:2px solid;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;font-size:1.25rem;background:#fff}.btn-accion-pendiente.view{border-color:#3b82f6;color:#3b82f6}.btn-accion-pendiente.view:hover{background:#3b82f6;color:#fff}.btn-accion-pendiente.add{border-color:#10b981;color:#10b981}.btn-accion-pendiente.add:hover{background:#10b981;color:#fff}.btn-accion-pendiente.send{border-color:#f59e0b;color:#f59e0b}.btn-accion-pendiente.send:hover{background:#f59e0b;color:#fff}.loading-pendientes,.empty-pendientes{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.empty-pendientes svg{font-size:5rem;color:#10b981}.empty-pendientes h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0}.empty-pendientes p{font-size:1rem;color:#64748b;margin:0}@media(max-width:1024px){.pendientes-stats{grid-template-columns:repeat(2,1fr)}.pendientes-grid{grid-template-columns:1fr}}@media(max-width:768px){.pendientes-stats{grid-template-columns:1fr}.filtros-urgencia,.search-and-sort{flex-direction:column}.sort-pendientes{min-width:auto}}.tab-reportes{width:100%}.reportes-controls{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px;flex-wrap:wrap}.date-filters{display:flex;gap:1.5rem;flex-wrap:wrap}.date-filter-group{display:flex;flex-direction:column;gap:.5rem}.date-filter-group label{font-size:.875rem;font-weight:700;color:#0f172a;text-transform:uppercase;letter-spacing:.5px}.date-filter-group input{padding:.875rem 1.25rem;border:2px solid #cbd5e1;border-radius:10px;font-size:1rem;transition:all .3s;min-width:180px}.date-filter-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.export-buttons{display:flex;gap:1rem}.btn-export-report{padding:.875rem 1.5rem;border:2px solid;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:all .3s}.btn-export-report.excel{background:linear-gradient(135deg,#10b981,#059669);border-color:#059669;color:#fff;box-shadow:0 4px 16px #10b9814d}.btn-export-report.excel:hover{transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.btn-export-report.pdf{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#dc2626;color:#fff;box-shadow:0 4px 16px #ef44444d}.btn-export-report.pdf:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ef444466}.kpis-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.kpi-card{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:#fff;border:3px solid;border-radius:20px;transition:all .3s}.kpi-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.kpi-icon{width:70px;height:70px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.kpi-card.blue{border-color:#3b82f6}.kpi-card.blue .kpi-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 16px #3b82f64d}.kpi-card.green{border-color:#10b981}.kpi-card.green .kpi-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 16px #10b9814d}.kpi-card.orange{border-color:#f59e0b}.kpi-card.orange .kpi-icon{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 4px 16px #f59e0b4d}.kpi-card.purple{border-color:#8b5cf6}.kpi-card.purple .kpi-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 4px 16px #8b5cf64d}.kpi-content{display:flex;flex-direction:column;gap:.5rem}.kpi-label{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.kpi-value{font-size:2rem;font-weight:800;color:#0f172a;line-height:1}.kpi-sub{font-size:.875rem;color:#64748b;font-weight:600}.graficos-section{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-bottom:2rem}.grafico-card{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;transition:all .3s}.grafico-card:hover{box-shadow:0 8px 30px #0000001a}.grafico-card h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.grafico-card h3 svg{font-size:1.5rem;color:#3b82f6}.grafico-container{margin-bottom:1.5rem}.grafico-legend{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.legend-item{display:flex;align-items:center;gap:1rem;font-size:.9375rem}.legend-color{width:20px;height:20px;border-radius:6px;flex-shrink:0}.legend-name{font-weight:700;color:#0f172a;flex:1}.legend-value{font-weight:800;color:#64748b}.grafico-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:1.5rem}.stat-box{display:flex;flex-direction:column;padding:1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:10px;text-align:center}.stat-box-label{font-size:.875rem;font-weight:700;color:#64748b;margin-bottom:.5rem}.stat-box-value{font-size:1.25rem;font-weight:800;color:#0f172a;margin-bottom:.25rem}.stat-box-count{font-size:.8125rem;color:#94a3b8;font-weight:600}.top-cursos-section{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;margin-bottom:2rem}.top-cursos-section h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.top-cursos-section h3 svg{font-size:1.5rem;color:#10b981}.grafico-container-wide{margin-top:1.5rem}.tabla-cursos-section{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;margin-bottom:2rem}.tabla-cursos-section h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.tabla-cursos-section h3 svg{font-size:1.5rem;color:#3b82f6}.tabla-cursos-wrapper{overflow-x:auto;border:2px solid #e2e8f0;border-radius:12px}.tabla-cursos{width:100%;border-collapse:collapse;background:#fff}.tabla-cursos thead{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.tabla-cursos th{padding:1rem;text-align:left;font-size:.875rem;font-weight:800;color:#1e40af;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #bfdbfe}.tabla-cursos td{padding:1rem;border-bottom:1px solid #f1f5f9;font-size:.9375rem}.tabla-cursos tbody tr:hover{background:#f8fafc}.curso-nombre{font-weight:700;color:#0f172a}.font-bold{font-weight:800;color:#10b981}.porcentaje-bar{position:relative;height:30px;background:#f1f5f9;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center}.porcentaje-fill{position:absolute;left:0;top:0;height:100%;transition:width .5s ease;opacity:.7}.porcentaje-bar span{position:relative;z-index:2;font-weight:800;color:#0f172a;font-size:.875rem}.comprobantes-section{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;margin-bottom:2rem}.comprobantes-section h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.comprobantes-section h3 svg{font-size:1.5rem;color:#8b5cf6}.comprobantes-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.comprobante-stat{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:12px}.comprobante-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.comprobante-icon.total{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.comprobante-icon.factura{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.comprobante-icon.boleta{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.comprobante-label{display:block;font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.comprobante-value{display:block;font-size:1.75rem;font-weight:800;color:#0f172a}.periodo-info{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6;border-radius:12px;color:#1e40af;font-weight:600}.periodo-info svg{font-size:1.5rem}.periodo-info strong{font-weight:800}.loading-reportes,.empty-reportes{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.empty-reportes svg{font-size:5rem;color:#cbd5e1}.empty-reportes h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0}.empty-reportes p{font-size:1rem;color:#64748b;margin:0}@media(max-width:1400px){.kpis-grid{grid-template-columns:repeat(2,1fr)}.graficos-section{grid-template-columns:1fr}}@media(max-width:1024px){.comprobantes-stats{grid-template-columns:1fr}}@media(max-width:768px){.kpis-grid{grid-template-columns:1fr}.reportes-controls{flex-direction:column;align-items:stretch}.date-filters,.export-buttons{flex-direction:column}.tabla-cursos-wrapper{overflow-x:scroll}}.td-tipo-pago{white-space:nowrap}.tipo-pago-badge{display:inline-block;padding:3px 10px;border-radius:100px;font-size:.75rem;font-weight:600;white-space:nowrap}.tp-inscripcion{background:#ede9fe;color:#6d28d9}.tp-inscripcion_mensualidad{background:#dbeafe;color:#1d4ed8}.tp-pago_unico{background:#d1fae5;color:#065f46}.td-nota{max-width:160px}.nota-preview{font-size:.78rem;color:#64748b;display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:150px;cursor:default}.nota-vacia{color:#cbd5e1;font-size:.85rem}.col-tipo-pago,.col-nota{display:none}@media(min-width:1400px){.col-tipo-pago,.col-nota{display:table-cell}}.table-wrapper{overflow-x:auto!important;width:100%;display:block}.pagos-table{min-width:1100px;width:max-content;table-layout:fixed}.pagos-table th,.pagos-table td{white-space:nowrap}.td-estudiante{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.td-curso{max-width:130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.td-nota{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pagos-table th:nth-child(1),.pagos-table td:nth-child(1){width:70px}.pagos-table th:nth-child(2),.pagos-table td:nth-child(2){width:300px}.pagos-table th:nth-child(3),.pagos-table td:nth-child(3){width:200px}.pagos-table th:nth-child(4),.pagos-table td:nth-child(4){width:110px}.pagos-table th:nth-child(5),.pagos-table td:nth-child(5){width:110px}.pagos-table th:nth-child(6),.pagos-table td:nth-child(6){width:100px}.pagos-table th:nth-child(7),.pagos-table td:nth-child(7){width:90px}.pagos-table th:nth-child(8),.pagos-table td:nth-child(8){width:90px}.pagos-table th:nth-child(9),.pagos-table td:nth-child(9){width:100px}.pagos-table th:nth-child(10),.pagos-table td:nth-child(10){width:90px}.pagos-table th:nth-child(11),.pagos-table td:nth-child(11){width:70px}.pagos-table th:nth-child(12),.pagos-table td:nth-child(12){width:100px}.pagos-table th:nth-child(13),.pagos-table td:nth-child(13){width:80px}.pagos-table th{resize:horizontal;overflow:hidden}.caja-diaria-card{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;margin-bottom:2rem}.caja-diaria-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.caja-diaria-header h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 .25rem}.caja-diaria-header>div>span{font-size:.875rem;color:#64748b;font-weight:600;text-transform:capitalize}.caja-total-badge{display:flex;flex-direction:column;align-items:flex-end;padding:1rem 1.5rem;background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:14px;color:#fff}.caja-total-badge span{font-size:.75rem;font-weight:600;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.caja-total-badge strong{font-size:1.5rem;font-weight:800}.caja-empty{text-align:center;padding:2rem;color:#94a3b8;font-weight:600}.caja-metodos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem}.caja-metodo-card{padding:1.25rem;border:2px solid var(--color);border-radius:14px;background:color-mix(in srgb,var(--color) 8%,white);display:flex;flex-direction:column;gap:.75rem}.caja-metodo-top{display:flex;align-items:center;gap:.75rem}.caja-metodo-icon{font-size:1.5rem}.caja-metodo-label{font-weight:800;color:#0f172a;font-size:.9375rem}.caja-metodo-count{font-size:.75rem;color:#64748b;font-weight:600}.caja-metodo-monto{margin-left:auto;font-size:1.125rem;font-weight:800;color:var(--color)}.caja-metodo-bar-track{height:6px;background:#f1f5f9;border-radius:99px;overflow:hidden}.caja-metodo-bar-fill{height:100%;border-radius:99px;transition:width .5s ease}.caja-metodo-pct{font-size:.75rem;color:#94a3b8;font-weight:600}@media(max-width:768px){.caja-metodos-grid{grid-template-columns:1fr 1fr}.caja-diaria-header{flex-direction:column;align-items:flex-start;gap:1rem}}.action-btn-v2.edit{background:#eff6ff;color:#3b82f6;border:1.5px solid #bfdbfe}.action-btn-v2.edit:hover{background:#3b82f6;color:#fff;border-color:#3b82f6}.action-btn-v2.delete{background:#fef2f2;color:#ef4444;border:1.5px solid #fecaca}.action-btn-v2.delete:hover{background:#ef4444;color:#fff;border-color:#ef4444}.estudiantes-page-v2{padding:2rem;max-width:1600px;margin:0 auto}.estudiantes-container-v2{width:100%}.estudiantes-hero{background:linear-gradient(135deg,#3b82f6,#2563eb,#1d4ed8);border-radius:24px;padding:3rem;margin-bottom:2rem;color:#fff;box-shadow:0 20px 60px #3b82f64d;position:relative;overflow:hidden}.estudiantes-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%}.hero-content-estudiantes{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}.hero-text-estudiantes h1{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.hero-text-estudiantes p{font-size:1.125rem;opacity:.95;margin:0}.hero-icon-estudiantes{width:80px;height:80px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:float 3s ease-in-out infinite}.estudiantes-stats-dashboard{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card-estudiantes{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:#fff;border:3px solid;border-radius:20px;transition:all .3s}.stat-card-estudiantes:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.stat-card-estudiantes.blue{border-color:#3b82f6}.stat-card-estudiantes.orange{border-color:#f59e0b}.stat-card-estudiantes.green{border-color:#10b981}.stat-card-estudiantes.red{border-color:#ef4444}.stat-icon-estudiantes{width:70px;height:70px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;flex-shrink:0}.stat-card-estudiantes.blue .stat-icon-estudiantes{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 16px #3b82f64d}.stat-card-estudiantes.orange .stat-icon-estudiantes{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 16px #f59e0b4d}.stat-card-estudiantes.green .stat-icon-estudiantes{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 16px #10b9814d}.stat-card-estudiantes.red .stat-icon-estudiantes{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 16px #ef44444d}.stat-content-estudiantes{display:flex;flex-direction:column;gap:.5rem}.stat-value-estudiantes{font-size:2.25rem;font-weight:800;color:#0f172a;line-height:1}.stat-label-estudiantes{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.stat-sub-estudiantes{font-size:.8125rem;color:#94a3b8;font-weight:600}.estudiantes-tabs-v2{display:flex;gap:1rem;margin-bottom:2rem;padding:.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.tab-btn-estudiantes{flex:1;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;background:transparent;border:2px solid transparent;border-radius:12px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s}.tab-btn-estudiantes:hover{background:#fff;color:#3b82f6}.tab-btn-estudiantes.active{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;color:#fff;box-shadow:0 4px 16px #3b82f64d}.tab-btn-estudiantes svg{font-size:1.25rem}.tab-badge-estudiantes{padding:.375rem .875rem;background:#fff3;border-radius:8px;font-size:.875rem;font-weight:800}.tab-btn-estudiantes.active .tab-badge-estudiantes{background:#ffffff4d}.tab-badge-estudiantes.alert{background:#fef3c7;color:#92400e}.tab-btn-estudiantes.active .tab-badge-estudiantes.alert{background:#fef3c74d;color:#fff}.estudiantes-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:16px;flex-wrap:wrap}.toolbar-left{display:flex;gap:1rem;flex:1;flex-wrap:wrap}.search-box-estudiantes,.sort-box-estudiantes{display:flex;align-items:center;gap:1rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #cbd5e1;border-radius:12px;transition:all .3s}.search-box-estudiantes{flex:1;min-width:300px}.sort-box-estudiantes{min-width:220px}.search-box-estudiantes:focus-within,.sort-box-estudiantes:focus-within{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a}.search-box-estudiantes svg,.sort-box-estudiantes svg{font-size:1.25rem;color:#3b82f6;flex-shrink:0}.search-box-estudiantes input,.sort-box-estudiantes select{flex:1;border:none;outline:none;background:transparent;font-size:1rem;font-weight:600;color:#0f172a}.search-box-estudiantes input::placeholder{color:#94a3b8}.toolbar-right{display:flex;gap:.75rem}.btn-export-estudiantes{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;border:none;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s;color:#fff}.btn-export-estudiantes.excel{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 16px #10b9814d}.btn-export-estudiantes.pdf{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 16px #ef44444d}.btn-export-estudiantes:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.estudiantes-grid-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem;margin-bottom:2rem}.estudiante-card-v2{background:#fff;border-radius:20px;padding:2rem;border:2px solid #e2e8f0;transition:all .3s;display:flex;flex-direction:column;gap:1.25rem;position:relative}.estudiante-card-v2:hover{transform:translateY(-6px);box-shadow:0 16px 50px #0000001f;border-color:#3b82f6}.estudiante-card-header{display:flex;justify-content:space-between;align-items:center}.estudiante-avatar-v2{width:70px;height:70px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:800;box-shadow:0 4px 16px #3b82f64d}.badge-deuda-card{width:36px;height:36px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.125rem;box-shadow:0 2px 8px #f59e0b4d}.estudiante-card-body{flex:1}.estudiante-nombre-v2{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1rem;line-height:1.3}.estudiante-contact{display:flex;flex-direction:column;gap:.5rem}.email-estudiante,.phone-estudiante{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#64748b;font-weight:600;margin:0}.email-estudiante svg,.phone-estudiante svg{font-size:1rem;color:#3b82f6;flex-shrink:0}.estudiante-metrics{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.metric-estudiante{display:flex;align-items:center;gap:1rem}.metric-estudiante-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff;flex-shrink:0}.metric-estudiante-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.metric-estudiante-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.metric-estudiante-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.metric-estudiante-value{font-size:1.125rem;font-weight:800;color:#0f172a;line-height:1;display:block}.metric-estudiante-label{font-size:.75rem;color:#64748b;font-weight:600;display:block}.btn-view-estudiante{width:100%;padding:1rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-view-estudiante:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.pagination-estudiantes{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.pagination-btn-estudiantes{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:#fff;border:2px solid #cbd5e1;border-radius:12px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s}.pagination-btn-estudiantes:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6;transform:translateY(-2px)}.pagination-btn-estudiantes:disabled{opacity:.4;cursor:not-allowed}.pagination-numbers{display:flex;gap:.5rem;align-items:center}.page-number-estudiantes{min-width:44px;height:44px;padding:0 .75rem;background:#fff;border:2px solid #cbd5e1;border-radius:10px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s}.page-number-estudiantes:hover{border-color:#3b82f6;color:#3b82f6}.page-number-estudiantes.active{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;color:#fff}.pagination-dots{padding:0 .5rem;color:#94a3b8;font-weight:700}.pagination-info-estudiantes{text-align:center;font-size:.9375rem;color:#64748b;font-weight:600}.loading-estudiantes-v2,.empty-estudiantes-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.spinner-large-estudiantes{width:60px;height:60px;border:4px solid #dbeafe;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.loading-estudiantes-v2 p{font-size:1.125rem;font-weight:700;color:#64748b}.empty-estudiantes-v2 svg{font-size:5rem;color:#cbd5e1}.empty-estudiantes-v2 h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0}.empty-estudiantes-v2 p{font-size:1rem;color:#64748b;margin:0}.modal-overlay-estudiante{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:2rem;animation:fadeIn .3s ease;overflow-y:auto}.modal-content-estudiante-v2{background:#fff;border-radius:24px;width:100%;max-width:1000px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #3b82f666;animation:slideUp .4s ease}.modal-header-estudiante{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:24px 24px 0 0}.header-title-estudiante{display:flex;align-items:center;gap:1.5rem;color:#fff}.modal-avatar-estudiante{width:64px;height:64px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;flex-shrink:0}.header-title-estudiante h2{font-size:1.75rem;font-weight:800;margin:0;color:#fff}.header-title-estudiante p{font-size:1rem;opacity:.9;margin:.25rem 0 0}.btn-close-estudiante{width:44px;height:44px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#fff;font-size:1.75rem}.btn-close-estudiante:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body-estudiante{padding:2.5rem}.detail-section-estudiante{margin-bottom:2.5rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.detail-section-estudiante:last-child{margin-bottom:0}.detail-section-estudiante h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #cbd5e1}.detail-section-estudiante h3 svg{font-size:1.5rem;color:#3b82f6}.detail-grid-estudiante{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.detail-item-estudiante{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:10px}.label-estudiante{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.value-estudiante{font-size:1rem;font-weight:600;color:#0f172a;display:flex;align-items:center;gap:.5rem}.value-estudiante.strong{font-weight:800;color:#3b82f6;font-size:1.125rem}.value-estudiante svg{font-size:1.125rem;color:#3b82f6}.financial-cards-estudiante{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.financial-card-estudiante{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border:2px solid;border-radius:12px;transition:all .3s}.financial-card-estudiante:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.financial-card-estudiante.blue{border-color:#3b82f6}.financial-card-estudiante.green{border-color:#10b981}.financial-card-estudiante.orange{border-color:#f59e0b}.financial-card-estudiante svg{font-size:1.75rem;flex-shrink:0}.financial-card-estudiante.blue svg{color:#3b82f6}.financial-card-estudiante.green svg{color:#10b981}.financial-card-estudiante.orange svg{color:#f59e0b}.financial-label-estudiante{display:block;font-size:.8125rem;font-weight:700;color:#64748b;margin-bottom:.25rem}.financial-value-estudiante{display:block;font-size:1.25rem;font-weight:800;color:#0f172a}.cursos-grid-estudiante{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.curso-card-estudiante{display:flex;gap:1rem;padding:1.25rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;transition:all .3s}.curso-card-estudiante:hover{border-color:#3b82f6;transform:translateY(-2px)}.curso-icon-estudiante{width:48px;height:48px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.curso-info-estudiante{flex:1;overflow:hidden}.curso-nombre-estudiante{font-size:.9375rem;font-weight:700;color:#0f172a;margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.curso-codigo-estudiante{font-size:.8125rem;color:#64748b;margin:0 0 .5rem}.curso-fecha-estudiante{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#94a3b8;font-weight:600}.curso-fecha-estudiante svg{font-size:.875rem}.pagos-timeline-estudiante{display:flex;flex-direction:column;gap:.75rem}.pago-timeline-item-estudiante{display:flex;gap:1rem;padding:1.25rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;transition:all .3s}.pago-timeline-item-estudiante:hover{border-color:#3b82f6;background:#f8fafc}.timeline-marker-estudiante{width:12px;height:12px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;flex-shrink:0;margin-top:.5rem;box-shadow:0 0 0 4px #3b82f633}.timeline-content-estudiante{flex:1;display:flex;flex-direction:column;gap:.5rem}.pago-header-estudiante{display:flex;justify-content:space-between;align-items:center}.pago-curso-estudiante{font-weight:700;color:#0f172a;font-size:.9375rem}.pago-estado-estudiante{padding:.375rem .75rem;border-radius:8px;font-size:.8125rem;font-weight:700}.pago-estado-estudiante.pagado{background:#d1fae5;color:#047857}.pago-estado-estudiante.pendiente{background:#fef3c7;color:#92400e}.pago-estado-estudiante.parcial{background:#dbeafe;color:#1e40af}.pago-details-estudiante{display:flex;justify-content:space-between;align-items:center}.pago-monto-estudiante{font-size:1.125rem;font-weight:800;color:#10b981}.pago-fecha-estudiante{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#64748b;font-weight:600}.pago-fecha-estudiante svg{font-size:1rem}.more-info-estudiante{text-align:center;font-size:.9375rem;color:#64748b;font-weight:600;margin-top:1rem}@media(max-width:1400px){.estudiantes-stats-dashboard{grid-template-columns:repeat(2,1fr)}.financial-cards-estudiante{grid-template-columns:1fr}}@media(max-width:1024px){.estudiantes-grid-v2{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.cursos-grid-estudiante{grid-template-columns:1fr}}@media(max-width:768px){.estudiantes-page-v2{padding:1rem}.estudiantes-hero{padding:2rem}.hero-text-estudiantes h1{font-size:1.75rem}.estudiantes-stats-dashboard,.detail-grid-estudiante{grid-template-columns:1fr}.estudiantes-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{width:100%}.search-box-estudiantes{min-width:auto}.estudiantes-grid-v2{grid-template-columns:1fr}}.cursos-page-v2{padding:2rem;max-width:1600px;margin:0 auto}.cursos-container-v2{width:100%}.cursos-hero{background:linear-gradient(135deg,#7c3aed,#8b5cf6,#a78bfa);border-radius:24px;padding:3rem;margin-bottom:2rem;color:#fff;box-shadow:0 20px 60px #8b5cf64d;position:relative;overflow:hidden}.cursos-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%}.hero-content-cursos{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}.hero-text-cursos h1{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.hero-text-cursos p{font-size:1.125rem;opacity:.95;margin:0}.hero-icon-cursos{width:80px;height:80px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:float 3s ease-in-out infinite}.cursos-stats-dashboard{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card-cursos{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:#fff;border:3px solid;border-radius:20px;transition:all .3s}.stat-card-cursos:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.stat-card-cursos.blue{border-color:#3b82f6}.stat-card-cursos.purple{border-color:#8b5cf6}.stat-card-cursos.green{border-color:#10b981}.stat-card-cursos.orange{border-color:#f59e0b}.stat-icon-cursos{width:70px;height:70px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;flex-shrink:0}.stat-card-cursos.blue .stat-icon-cursos{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 16px #3b82f64d}.stat-card-cursos.purple .stat-icon-cursos{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 4px 16px #8b5cf64d}.stat-card-cursos.green .stat-icon-cursos{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 16px #10b9814d}.stat-card-cursos.orange .stat-icon-cursos{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 16px #f59e0b4d}.stat-content-cursos{display:flex;flex-direction:column;gap:.5rem}.stat-value-cursos{font-size:2.25rem;font-weight:800;color:#0f172a;line-height:1}.stat-label-cursos{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.stat-sub-cursos{font-size:.8125rem;color:#94a3b8;font-weight:600}.cursos-controls{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:20px}.search-filter-section{display:flex;gap:1.5rem;flex-wrap:wrap}.search-box-cursos{flex:1;min-width:300px;display:flex;align-items:center;gap:1rem;padding:.875rem 1.25rem;background:#fff;border:2px solid #cbd5e1;border-radius:12px;transition:all .3s}.search-box-cursos:focus-within{border-color:#8b5cf6;box-shadow:0 0 0 4px #8b5cf61a}.search-box-cursos svg{font-size:1.25rem;color:#8b5cf6;flex-shrink:0}.search-box-cursos input{flex:1;border:none;outline:none;font-size:1rem;font-weight:600;color:#0f172a}.search-box-cursos input::placeholder{color:#94a3b8}.filter-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1.5rem;background:#fff;border:2px solid #cbd5e1;border-radius:10px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s}.filter-btn:hover{border-color:#8b5cf6;color:#8b5cf6}.filter-btn.active{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-color:#7c3aed;color:#fff;box-shadow:0 4px 16px #8b5cf64d}.sort-view-section{display:flex;gap:1rem;align-items:center}.sort-select{padding:.75rem 1.25rem;background:#fff;border:2px solid #cbd5e1;border-radius:10px;font-weight:700;color:#0f172a;cursor:pointer;transition:all .3s}.sort-select:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.view-toggle{display:flex;gap:.5rem;padding:.25rem;background:#fff;border:2px solid #cbd5e1;border-radius:10px}.view-btn{width:44px;height:44px;background:transparent;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#64748b;cursor:pointer;transition:all .3s}.view-btn:hover{background:#f1f5f9;color:#8b5cf6}.cursos-container-view{display:grid;gap:2rem}.cursos-container-view.grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.cursos-container-view.list{grid-template-columns:1fr}.curso-card-v2{background:#fff;border-radius:20px;padding:2rem;border:2px solid #e2e8f0;transition:all .3s;display:flex;flex-direction:column;gap:1rem}.curso-card-v2:hover{transform:translateY(-6px);box-shadow:0 16px 50px #0000001f;border-color:#8b5cf6}.curso-card-header{display:flex;justify-content:space-between;align-items:center}.curso-icon-large{width:64px;height:64px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;box-shadow:0 4px 16px #8b5cf64d}.status-badge-curso{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:10px;font-size:.875rem;font-weight:700}.status-badge-curso.active{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.status-badge-curso.inactive{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.curso-title{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 .75rem;line-height:1.3}.curso-codigo{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;color:#64748b;margin-bottom:1rem}.curso-codigo svg{color:#8b5cf6}.curso-descripcion{font-size:.9375rem;color:#64748b;line-height:1.6;margin:0}.curso-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.metric-item{display:flex;align-items:center;gap:.75rem}.metric-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff;flex-shrink:0}.metric-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.metric-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.metric-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.metric-content{display:flex;flex-direction:column}.metric-value{font-size:1.125rem;font-weight:800;color:#0f172a;line-height:1}.metric-label{font-size:.75rem;color:#64748b;font-weight:600}.pendiente-alert{display:flex;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:10px;color:#92400e;font-weight:700;font-size:.9375rem}.pendiente-alert svg{font-size:1.25rem;flex-shrink:0}.btn-view-detail-v2{width:100%;padding:1rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-view-detail-v2:hover{transform:translateY(-2px);box-shadow:0 8px 24px #8b5cf666}.curso-list-item{display:flex;align-items:center;gap:2rem;padding:1.75rem;background:#fff;border:2px solid #e2e8f0;border-radius:16px;transition:all .3s}.curso-list-item:hover{border-color:#8b5cf6;box-shadow:0 8px 30px #0000001a}.list-item-left{display:flex;align-items:center;gap:1.5rem;flex:1}.curso-icon-list{width:56px;height:56px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#fff;flex-shrink:0}.curso-info-list h3{font-size:1.125rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.curso-codigo-list{font-size:.875rem;color:#64748b;margin:0 0 .5rem}.status-badge-list{display:inline-block;padding:.375rem .875rem;border-radius:8px;font-size:.8125rem;font-weight:700}.status-badge-list.active{background:#d1fae5;color:#047857}.status-badge-list.inactive{background:#fee2e2;color:#991b1b}.list-item-stats{display:flex;gap:2rem;padding:1rem 2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.stat-list-item{display:flex;align-items:center;gap:.75rem}.stat-list-item svg{font-size:1.5rem;color:#8b5cf6}.stat-list-item.alert svg{color:#f59e0b}.stat-list-value{display:block;font-size:1rem;font-weight:800;color:#0f172a}.stat-list-label{display:block;font-size:.75rem;color:#64748b;font-weight:600}.btn-view-list{padding:.875rem 1.75rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:10px;color:#fff;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s;flex-shrink:0}.btn-view-list:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.loading-cursos-v2,.empty-cursos-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.spinner-large-cursos{width:60px;height:60px;border:4px solid #f3e8ff;border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}.loading-cursos-v2 p{font-size:1.125rem;font-weight:700;color:#64748b}.empty-cursos-v2 svg{font-size:5rem;color:#cbd5e1}.empty-cursos-v2 h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0}.empty-cursos-v2 p{font-size:1rem;color:#64748b;margin:0}.modal-overlay-curso{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:2rem;animation:fadeIn .3s ease;overflow-y:auto}.modal-content-curso-v2{background:#fff;border-radius:24px;width:100%;max-width:1100px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #8b5cf666;animation:slideUp .4s ease}.modal-header-curso{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:24px 24px 0 0}.header-title-curso{display:flex;align-items:center;gap:1rem;color:#fff}.header-title-curso svg{font-size:2rem}.header-title-curso h2{font-size:1.75rem;font-weight:800;margin:0;color:#fff}.btn-close-curso{width:44px;height:44px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#fff;font-size:1.75rem}.btn-close-curso:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body-curso{padding:2.5rem}.detail-section-curso{margin-bottom:2.5rem;padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px}.detail-section-curso:last-child{margin-bottom:0}.detail-section-curso h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid #cbd5e1}.detail-section-curso h3 svg{font-size:1.5rem;color:#8b5cf6}.detail-grid-curso{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.detail-item-curso{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:10px}.detail-item-curso.full-width{grid-column:1 / -1}.label-curso{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.value-curso{font-size:1rem;font-weight:600;color:#0f172a}.value-curso.strong{font-weight:800;color:#8b5cf6;font-size:1.125rem}.value-curso.green{color:#10b981;font-weight:700}.value-curso.red{color:#ef4444;font-weight:700}.description-box{padding:1.25rem;background:#fff;border:2px solid #e2e8f0;border-left:4px solid #8b5cf6;border-radius:10px;color:#0f172a;line-height:1.6;font-size:.9375rem}.financial-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.financial-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border:2px solid;border-radius:12px;transition:all .3s}.financial-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.financial-card.blue{border-color:#3b82f6}.financial-card.green{border-color:#10b981}.financial-card.teal{border-color:#14b8a6}.financial-card.orange{border-color:#f59e0b}.financial-card svg{font-size:1.75rem;flex-shrink:0}.financial-card.blue svg{color:#3b82f6}.financial-card.green svg{color:#10b981}.financial-card.teal svg{color:#14b8a6}.financial-card.orange svg{color:#f59e0b}.financial-label{display:block;font-size:.8125rem;font-weight:700;color:#64748b;margin-bottom:.25rem}.financial-value{display:block;font-size:1.25rem;font-weight:800;color:#0f172a}.estudiantes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.estudiante-card-modal{display:flex;gap:1rem;padding:1.25rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;transition:all .3s}.estudiante-card-modal:hover{border-color:#8b5cf6;transform:translateY(-2px)}.estudiante-avatar-modal{width:48px;height:48px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;font-weight:800;flex-shrink:0}.estudiante-info-modal{flex:1;overflow:hidden}.estudiante-nombre-modal{font-size:.9375rem;font-weight:700;color:#0f172a;margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.estudiante-email-modal{font-size:.8125rem;color:#64748b;margin:0 0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.estudiante-fecha-modal{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#94a3b8;font-weight:600}.estudiante-fecha-modal svg{font-size:.875rem}.pagos-timeline-modal{display:flex;flex-direction:column;gap:.75rem}.pago-timeline-item{display:flex;gap:1rem;padding:1.25rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;transition:all .3s}.pago-timeline-item:hover{border-color:#8b5cf6;background:#f8fafc}.timeline-marker-pago{width:12px;height:12px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:50%;flex-shrink:0;margin-top:.5rem;box-shadow:0 0 0 4px #8b5cf633}.timeline-content-pago{flex:1;display:flex;flex-direction:column;gap:.5rem}.pago-header-timeline{display:flex;justify-content:space-between;align-items:center}.pago-estudiante-timeline{font-weight:700;color:#0f172a;font-size:.9375rem}.pago-estado-timeline{padding:.375rem .75rem;border-radius:8px;font-size:.8125rem;font-weight:700}.pago-estado-timeline.pagado{background:#d1fae5;color:#047857}.pago-estado-timeline.pendiente{background:#fef3c7;color:#92400e}.pago-estado-timeline.parcial{background:#dbeafe;color:#1e40af}.pago-details-timeline{display:flex;justify-content:space-between;align-items:center}.pago-monto-timeline{font-size:1.125rem;font-weight:800;color:#10b981}.pago-fecha-timeline{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#64748b;font-weight:600}.pago-fecha-timeline svg{font-size:1rem}.more-info-modal{text-align:center;font-size:.9375rem;color:#64748b;font-weight:600;margin-top:1rem}@media(max-width:1400px){.cursos-stats-dashboard,.financial-cards,.estudiantes-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.cursos-container-view.grid,.curso-metrics{grid-template-columns:1fr}.list-item-stats{flex-direction:column;gap:1rem;padding:1rem}}@media(max-width:768px){.cursos-page-v2{padding:1rem}.cursos-hero{padding:2rem}.hero-text-cursos h1{font-size:1.75rem}.cursos-stats-dashboard,.financial-cards,.estudiantes-grid{grid-template-columns:1fr}.search-filter-section{flex-direction:column}.sort-view-section,.curso-list-item{flex-direction:column;align-items:stretch}.btn-view-list{width:100%;justify-content:center}}.reportes-page{padding:2rem;max-width:1800px;margin:0 auto}.reportes-container{width:100%}.reportes-hero{background:linear-gradient(135deg,#f59e0b,#d97706,#b45309);border-radius:24px;padding:3rem;margin-bottom:2rem;color:#fff;box-shadow:0 20px 60px #f59e0b4d;position:relative;overflow:hidden}.reportes-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%}.hero-content-reportes{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}.hero-text-reportes h1{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.hero-text-reportes p{font-size:1.125rem;opacity:.95;margin:0}.hero-icon-reportes{width:80px;height:80px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:float 3s ease-in-out infinite}.reportes-tabs{display:flex;gap:1rem;margin-bottom:2rem;padding:.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:16px;overflow-x:auto}.tab-reporte{flex:1;min-width:200px;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;background:transparent;border:2px solid transparent;border-radius:12px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s;white-space:nowrap}.tab-reporte:hover{background:#fff;color:#f59e0b}.tab-reporte.active{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#d97706;color:#fff;box-shadow:0 4px 16px #f59e0b4d}.tab-reporte svg{font-size:1.25rem;flex-shrink:0}.reportes-filtros{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;margin-bottom:2rem}.filtros-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.filter-item{display:flex;flex-direction:column;gap:.5rem}.filter-item label{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.filter-input{padding:.875rem 1.25rem;border:2px solid #cbd5e1;border-radius:12px;font-size:1rem;font-weight:600;transition:all .3s}.filter-input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 4px #f59e0b1a}.filtros-actions{display:flex;gap:1rem;justify-content:flex-end;flex-wrap:wrap}.btn-clear-filtros,.btn-export{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s;border:none}.btn-clear-filtros{background:#fff;border:2px solid #cbd5e1;color:#64748b}.btn-clear-filtros:hover{border-color:#94a3b8;color:#475569}.btn-export.excel{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 16px #10b9814d}.btn-export.pdf{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 16px #ef44444d}.btn-export:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.loading-reportes{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1.5rem}.spinner-large-reportes{width:60px;height:60px;border:4px solid #fef3c7;border-top-color:#f59e0b;border-radius:50%;animation:spin .8s linear infinite}.loading-reportes p{font-size:1.125rem;font-weight:700;color:#64748b}.reporte-content{animation:fadeIn .5s ease}.reporte-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.kpi-reporte{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:#fff;border:3px solid;border-radius:20px;transition:all .3s}.kpi-reporte:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.kpi-reporte.green{border-color:#10b981}.kpi-reporte.blue{border-color:#3b82f6}.kpi-reporte.orange{border-color:#f59e0b}.kpi-reporte.purple{border-color:#8b5cf6}.kpi-reporte.red{border-color:#ef4444}.kpi-reporte-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;flex-shrink:0}.kpi-reporte.green .kpi-reporte-icon{background:linear-gradient(135deg,#10b981,#059669)}.kpi-reporte.blue .kpi-reporte-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.kpi-reporte.orange .kpi-reporte-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.kpi-reporte.purple .kpi-reporte-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.kpi-reporte.red .kpi-reporte-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.kpi-reporte-label{display:block;font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.kpi-reporte-value{display:block;font-size:2rem;font-weight:800;color:#0f172a}.reportes-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-bottom:2rem}.chart-reporte{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem}.chart-reporte.full-width{grid-column:1 / -1}.chart-reporte h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.tabla-reporte{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;margin-bottom:2rem}.tabla-reporte h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0 0 1.5rem}.tabla-wrapper{overflow-x:auto}.tabla-wrapper table{width:100%;border-collapse:collapse}.tabla-wrapper thead{background:linear-gradient(135deg,#f59e0b,#d97706)}.tabla-wrapper th{padding:1rem;text-align:left;font-weight:700;color:#fff;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.tabla-wrapper tbody tr{border-bottom:1px solid #e2e8f0;transition:all .3s}.tabla-wrapper tbody tr:hover{background:#f8fafc}.tabla-wrapper tbody tr.urgente{background:#fef2f2}.tabla-wrapper td{padding:1rem;font-size:.9375rem;color:#0f172a;font-weight:600}.badge-metodo,.badge-estado,.badge-dias,.badge-tipo,.badge-comprobante{display:inline-block;padding:.375rem .875rem;border-radius:8px;font-size:.8125rem;font-weight:700;text-transform:uppercase}.badge-metodo.efectivo{background:#d1fae5;color:#047857}.badge-metodo.yape{background:#dbeafe;color:#1e40af}.badge-metodo.plin{background:#fef3c7;color:#92400e}.badge-metodo.transferencia{background:#e0e7ff;color:#4338ca}.badge-metodo.tarjeta{background:#fce7f3;color:#9f1239}.badge-estado.pagado{background:#d1fae5;color:#047857}.badge-estado.pendiente{background:#fef3c7;color:#92400e}.badge-estado.parcial{background:#dbeafe;color:#1e40af}.badge-estado.emitido{background:#d1fae5;color:#047857}.badge-estado.anulado{background:#fee2e2;color:#991b1b}.badge-dias.warning{background:#fef3c7;color:#92400e}.badge-dias.critico{background:#fee2e2;color:#991b1b}.badge-tipo.ingreso{background:#d1fae5;color:#047857}.badge-tipo.egreso{background:#fee2e2;color:#991b1b}.badge-comprobante.factura{background:#dbeafe;color:#1e40af}.badge-comprobante.boleta{background:#fef3c7;color:#92400e}.text-green{color:#10b981}.text-red{color:#ef4444}.text-orange{color:#f59e0b}.font-bold{font-weight:800}.font-mono{font-family:Courier New,monospace}.btn-accion-tabla{padding:.5rem 1rem;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:8px;color:#fff;font-weight:700;font-size:.8125rem;cursor:pointer;transition:all .3s}.btn-accion-tabla:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b4d}@media(max-width:1400px){.reportes-charts-grid{grid-template-columns:1fr}}@media(max-width:1024px){.reporte-kpis{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.reportes-page{padding:1rem}.reportes-hero{padding:2rem}.hero-text-reportes h1{font-size:1.75rem}.reportes-tabs{flex-direction:column}.tab-reporte{min-width:auto}.filtros-row{grid-template-columns:1fr}.filtros-actions{flex-direction:column}.btn-clear-filtros,.btn-export{width:100%;justify-content:center}.reporte-kpis{grid-template-columns:1fr}.tabla-wrapper{font-size:.75rem}.tabla-wrapper th,.tabla-wrapper td{padding:.5rem}}.comprobantes-page{min-height:100vh;background:linear-gradient(135deg,#eff6ff,#dbeafe);padding:2rem}.comprobantes-container{max-width:1800px;margin:0 auto}.comprobantes-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:2rem;border-radius:20px;margin-bottom:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #e0f2fe}.comprobantes-header .header-left{display:flex;align-items:center;gap:1.5rem}.comprobantes-header .header-icon{width:64px;height:64px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;box-shadow:0 8px 24px #3b82f64d}.comprobantes-header h1{font-size:2rem;font-weight:800;color:#0f172a;margin:0 0 .25rem}.comprobantes-header p{font-size:1rem;color:#64748b;margin:0}.ambiente-badge{display:flex;align-items:center}.badge-ambiente{padding:.75rem 1.5rem;border-radius:12px;font-size:.9375rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 12px #00000026}.badge-ambiente.demo{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.badge-ambiente.produccion{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.comprobantes-tabs{display:flex;gap:1rem;margin-bottom:2rem;background:#fff;padding:1rem;border-radius:16px;box-shadow:0 4px 20px #0000000f;border:2px solid #e0f2fe}.tab-btn{flex:1;padding:1rem 1.5rem;background:transparent;border:2px solid transparent;border-radius:12px;font-size:1rem;font-weight:700;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.tab-btn:hover{background:#f8fafc;color:#3b82f6}.tab-btn.active{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;color:#3b82f6}.comprobantes-content{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000f;border:2px solid #e0f2fe;min-height:400px}.loading-comprobantes{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1.5rem}.spinner-large{width:60px;height:60px;border:4px solid #e0f2fe;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.filters-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #bfdbfe;border-radius:16px;padding:1.5rem;margin-bottom:2rem}.filters-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.filter-group label{display:block;font-size:.875rem;font-weight:700;color:#1e40af;margin-bottom:.5rem}.filter-group input,.filter-group select{width:100%;padding:.75rem;border:2px solid #bfdbfe;border-radius:10px;font-size:.9375rem;transition:all .3s}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-filter{width:100%;padding:.875rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-filter:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.comprobantes-table thead{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.comprobantes-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:700;color:#1e40af;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #bfdbfe}.comprobantes-table td{padding:1rem;border-bottom:1px solid #f1f5f9;font-size:.9375rem;color:#0f172a}.comprobantes-table tbody tr:hover{background:#f8fafc}.tipo-badge{display:inline-block;padding:.375rem .875rem;border-radius:8px;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.tipo-badge.tipo-01{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.tipo-badge.tipo-03{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.sunat-badge{display:inline-block;padding:.375rem .875rem;border-radius:8px;font-size:.8125rem;font-weight:700}.sunat-badge.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.sunat-badge.error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.font-mono{font-family:Courier New,monospace;font-weight:700}.font-bold{font-weight:700;color:#3b82f6}.action-btn{width:36px;height:36px;border-radius:8px;border:2px solid;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;font-size:1rem;background:#fff;text-decoration:none}.action-btn.view{border-color:#3b82f6;color:#3b82f6}.action-btn.view:hover{background:#3b82f6;color:#fff}.action-btn.download{border-color:#10b981;color:#10b981}.action-btn.download:hover{background:#10b981;color:#fff}.empty-state{text-align:center;padding:4rem 2rem}.empty-state svg{font-size:5rem;color:#3b82f6;margin-bottom:1.5rem}.empty-state h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0 0 .5rem}.empty-state p{font-size:1rem;color:#64748b;margin:0}.info-card{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6;border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;margin-bottom:2rem;color:#1e40af;font-weight:600}.info-card svg{font-size:1.5rem;flex-shrink:0}.pagos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.pago-card{background:#fff;border:2px solid #e0f2fe;border-radius:16px;padding:1.5rem;transition:all .3s}.pago-card:hover{border-color:#3b82f6;transform:translateY(-4px);box-shadow:0 8px 30px #3b82f626}.pago-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.pago-id{font-family:Courier New,monospace;font-weight:700;color:#3b82f6;font-size:.875rem}.pago-fecha{font-size:.875rem;color:#64748b}.pago-body h4{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.pago-estudiante,.pago-monto{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;color:#64748b;margin-bottom:.5rem}.pago-monto{color:#3b82f6;font-weight:700;font-size:1.125rem}.btn-generate{width:100%;padding:.875rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem;transition:all .3s}.btn-generate:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.config-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #bfdbfe;border-radius:16px;padding:2rem}.config-card h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0 0 2rem}.config-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.config-item label{font-size:.875rem;font-weight:700;color:#1e40af;text-transform:uppercase;letter-spacing:.5px}.config-value{font-size:1.125rem;font-weight:700;color:#0f172a}.config-alert{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;color:#92400e;font-weight:600}.modal-overlay{position:fixed;inset:0;background:#0f172ab3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeIn .3s ease}.modal-content-invoice{background:#fff;border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #3b82f659;animation:slideUp .4s ease}@keyframes slideUp{0%{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #f1f5f9}.modal-header h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0}.modal-header button{width:36px;height:36px;background:#f1f5f9;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b;font-size:1.5rem;line-height:1}.modal-header button:hover{background:#fee2e2;color:#ef4444}.modal-body{padding:2rem}.pago-info-box{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #bfdbfe;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.pago-info-box h4{font-size:1rem;font-weight:800;color:#1e40af;margin:0 0 .75rem}.pago-info-box p{font-size:.9375rem;color:#0f172a;margin:.25rem 0}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.9375rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.form-group small{display:block;font-size:.8125rem;color:#64748b;margin-top:.5rem}.form-group input,.form-group select{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-family:inherit;transition:all .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-footer{display:flex;gap:1rem;padding:1.5rem 2rem;border-top:2px solid #f1f5f9}.btn-cancel{flex:1;padding:.875rem;background:#f1f5f9;color:#64748b;border:none;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s}.btn-cancel:hover{background:#e2e8f0}.btn-primary{flex:1;padding:.875rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.detail-section h4{font-size:1.125rem;font-weight:800;color:#0f172a;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:2px solid #f1f5f9}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:8px}.detail-item.total{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #bfdbfe}.detail-item .label{font-size:.875rem;font-weight:600;color:#64748b}.text-green{color:#10b981;font-weight:700}.text-red{color:#ef4444;font-weight:700}.links-grid{display:flex;gap:1rem}.link-btn{flex:1;padding:.875rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:12px;font-weight:700;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.link-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}@media(max-width:1200px){.filters-grid{grid-template-columns:repeat(2,1fr)}.pagos-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media(max-width:768px){.comprobantes-page{padding:1rem}.comprobantes-header{flex-direction:column;gap:1.5rem;padding:1.5rem}.comprobantes-tabs{flex-direction:column}.filters-grid{grid-template-columns:1fr}.comprobantes-table{overflow-x:scroll}.config-grid,.detail-grid,.form-row{grid-template-columns:1fr}.modal-footer,.links-grid{flex-direction:column}}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{overflow:visible;text-transform:none;-webkit-appearance:button;-moz-appearance:button;appearance:button;cursor:pointer}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{-webkit-box-sizing:border-box;box-sizing:border-box;height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar *:before,.rbc-calendar *:after{-webkit-box-sizing:inherit;box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{overflow:hidden;position:absolute;inset:0}.rbc-ellipsis,.rbc-show-more,.rbc-row-segment .rbc-event-content,.rbc-event-label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{overflow:hidden;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;text-overflow:ellipsis;white-space:nowrap;padding:0 3px;text-align:center;vertical-align:middle;font-weight:700;font-size:90%;min-height:0;border-bottom:1px solid #ddd}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{color:inherit;background:none;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.rbc-row-content{position:relative;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{height:100%;overflow-y:scroll;-ms-overflow-style:none;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:10px;font-size:16px}.rbc-toolbar .rbc-toolbar-label{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{color:#373a3c;display:inline-block;margin:0;text-align:center;vertical-align:middle;background:none;background-image:none;border:1px solid #ccc;padding:.375rem 1rem;border-radius:4px;line-height:normal;white-space:nowrap}.rbc-toolbar button:active,.rbc-toolbar button.rbc-active{background-image:none;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px #00000020;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button.rbc-active:focus{color:#373a3c;background-color:#d4d4d4;border-color:#8c8c8c}.rbc-toolbar button:focus{color:#373a3c;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:hover{color:#373a3c;cursor:pointer;background-color:#e6e6e6;border-color:#adadad}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:0 4px 4px 0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px 0 0 4px}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media(max-width:767px){.rbc-toolbar{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}}.rbc-event,.rbc-day-slot .rbc-background-event{border:none;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-box-shadow:none;box-shadow:none;margin:0;padding:2px 5px;background-color:#3174ad;border-radius:5px;color:#fff;cursor:pointer;width:100%;text-align:left}.rbc-slot-selecting .rbc-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-slot-selecting .rbc-background-event{cursor:inherit;pointer-events:none}.rbc-event.rbc-selected,.rbc-day-slot .rbc-selected.rbc-background-event{background-color:#265985}.rbc-event:focus,.rbc-day-slot .rbc-background-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{-webkit-box-shadow:-1px 1px 5px 0px rgba(51,51,51,.5);box-shadow:-1px 1px 5px #33333380}.rbc-event-continues-prior{border-top-left-radius:0;border-bottom-left-radius:0}.rbc-event-continues-after{border-top-right-radius:0;border-bottom-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;z-index:4;font-weight:700;font-size:85%;height:auto;line-height:normal;color:#3174ad}.rbc-show-more:hover,.rbc-show-more:focus{color:#265985}.rbc-month-view{position:relative;border:1px solid #ddd;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;height:100%}.rbc-month-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-month-row{display:-webkit-box;display:-ms-flexbox;display:flex;position:relative;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px;overflow:hidden;height:100%}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:hidden;right:1px}.rbc-day-bg{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{position:absolute;z-index:5;border:1px solid #e5e5e5;background-color:#fff;-webkit-box-shadow:0 5px 15px rgba(0,0,0,.25);box-shadow:0 5px 15px #00000040;padding:10px}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{width:100%;border:1px solid #ddd;border-spacing:0;border-collapse:collapse}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{padding:3px 5px;text-align:left;border-bottom:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{-webkit-box-flex:1;-ms-flex:1;flex:1}.rbc-timeslot-group{border-bottom:1px solid #ddd;min-height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.rbc-time-gutter,.rbc-header-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{inset:0;position:absolute;margin-right:10px}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-event,.rbc-day-slot .rbc-background-event{border:1px solid #265985;display:-webkit-box;display:-ms-flexbox;display:flex;max-height:100%;min-height:20px;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column wrap;flex-flow:column wrap;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{-webkit-box-flex:0;-ms-flex:none;flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{width:100%;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;word-wrap:break-word;line-height:1;height:100%;min-height:1em}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{position:sticky;left:0;background-color:#fff;border-right:1px solid #ddd;z-index:10;margin-right:-1px}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{min-width:auto;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-header,.rbc-time-view-resources .rbc-day-bg{width:140px;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;-ms-flex-preferred-size:0 px;flex-basis:0 px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{z-index:10;position:absolute;background-color:#00000080;color:#fff;font-size:75%;width:100%;padding:3px}.rbc-slot-selecting{cursor:move}.rbc-time-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1;flex:1;width:100%;border:1px solid #ddd;min-height:0}.rbc-time-view .rbc-time-gutter{white-space:nowrap;text-align:right}.rbc-time-view .rbc-allday-cell{-webkit-box-sizing:content-box;box-sizing:content-box;width:100%;height:100%;position:relative}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{-webkit-box-sizing:border-box;box-sizing:border-box;min-height:20px}.rbc-time-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-right-width:0;border-left:1px solid #ddd}.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{-webkit-box-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-ms-flexbox;display:flex;min-width:0;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;border-left:1px solid #ddd}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;-ms-flex-negative:0;flex-shrink:0}.rbc-time-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;width:100%;border-top:2px solid #ddd;overflow-y:auto;position:relative}.rbc-time-content>.rbc-time-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none}.rbc-current-time-indicator{position:absolute;z-index:3;left:0;right:0;height:1px;background-color:#74ad31;pointer-events:none}.rbc-resource-grouping.rbc-time-header-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.calendario-pagos-page{padding:2rem;max-width:1600px;margin:0 auto}.calendario-container{width:100%}.calendario-hero{background:linear-gradient(135deg,#8b5cf6,#7c3aed,#6d28d9);border-radius:24px;padding:3rem;margin-bottom:2rem;color:#fff;box-shadow:0 20px 60px #8b5cf64d;position:relative;overflow:hidden}.calendario-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%}.hero-content-calendario{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}.hero-text-calendario h1{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.hero-text-calendario p{font-size:1.125rem;opacity:.95;margin:0}.hero-icon-calendario{width:80px;height:80px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:float 3s ease-in-out infinite}.calendario-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card-calendario{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:#fff;border:3px solid;border-radius:20px;transition:all .3s}.stat-card-calendario:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.stat-card-calendario.blue{border-color:#3b82f6}.stat-card-calendario.green{border-color:#10b981}.stat-card-calendario.orange{border-color:#f59e0b}.stat-card-calendario.red{border-color:#ef4444}.stat-icon-calendario{width:70px;height:70px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;flex-shrink:0}.stat-card-calendario.blue .stat-icon-calendario{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 16px #3b82f64d}.stat-card-calendario.green .stat-icon-calendario{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 16px #10b9814d}.stat-card-calendario.orange .stat-icon-calendario{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 16px #f59e0b4d}.stat-card-calendario.red .stat-icon-calendario{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 16px #ef44444d}.stat-content-calendario{display:flex;flex-direction:column;gap:.5rem}.stat-value-calendario{font-size:2.25rem;font-weight:800;color:#0f172a;line-height:1}.stat-label-calendario{font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.calendario-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:16px;flex-wrap:wrap}.toolbar-filtros{display:flex;gap:1rem;flex:1;flex-wrap:wrap}.filter-group-calendario{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #cbd5e1;border-radius:12px;min-width:200px}.filter-group-calendario svg{font-size:1.25rem;color:#8b5cf6;flex-shrink:0}.filter-select-calendario{flex:1;border:none;outline:none;background:transparent;font-size:1rem;font-weight:600;color:#0f172a;cursor:pointer}.btn-clear-filters{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.25rem;background:#ef4444;border:none;border-radius:12px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s}.btn-clear-filters:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn-export-calendar{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 16px #8b5cf64d}.btn-export-calendar:hover{transform:translateY(-2px);box-shadow:0 8px 24px #8b5cf666}.calendario-leyenda{display:flex;gap:2rem;padding:1rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem}.leyenda-item{display:flex;align-items:center;gap:.75rem}.leyenda-color{width:24px;height:24px;border-radius:6px}.leyenda-color.pagado{background:#10b981}.leyenda-color.pendiente{background:#f59e0b}.leyenda-color.vencido{background:#ef4444}.leyenda-item span{font-size:.9375rem;font-weight:700;color:#64748b}.calendario-wrapper{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #0000000d}.custom-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e2e8f0;flex-wrap:wrap;gap:1rem}.toolbar-navigation{display:flex;gap:.5rem}.toolbar-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border:2px solid #cbd5e1;border-radius:10px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s}.toolbar-btn:hover{border-color:#8b5cf6;color:#8b5cf6}.toolbar-btn.today{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-color:#7c3aed;color:#fff}.toolbar-center{flex:1;text-align:center}.toolbar-label{font-size:1.5rem;font-weight:800;color:#0f172a;text-transform:capitalize}.toolbar-views{display:flex;gap:.5rem;padding:.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:10px}.view-btn{padding:.75rem 1.25rem;background:transparent;border:none;border-radius:8px;font-weight:700;color:#64748b;cursor:pointer;transition:all .3s}.view-btn:hover{color:#8b5cf6}.view-btn.active{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.rbc-calendar{font-family:inherit}.rbc-header{padding:1rem;font-weight:700;color:#0f172a;border-bottom:2px solid #e2e8f0;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.rbc-today{background-color:#fef3c7!important}.rbc-off-range-bg{background:#f8fafc}.rbc-date-cell{padding:.5rem;text-align:right}.rbc-now .rbc-button-link{font-weight:800;color:#8b5cf6}.rbc-event{padding:4px 8px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600}.rbc-event:hover{opacity:1!important;transform:scale(1.02)}.rbc-day-slot .rbc-time-slot{border-top:1px solid #e2e8f0}.rbc-time-header-content{border-left:1px solid #e2e8f0}.rbc-month-view,.rbc-time-view{border:2px solid #e2e8f0;border-radius:12px;overflow:hidden}.rbc-month-row{border:none}.loading-calendario{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1.5rem}.spinner-large-calendario{width:60px;height:60px;border:4px solid #f3e8ff;border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}.loading-calendario p{font-size:1.125rem;font-weight:700;color:#64748b}.modal-overlay-calendario{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:2rem;animation:fadeIn .3s ease;overflow-y:auto}.modal-content-calendario{background:#fff;border-radius:24px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px #8b5cf666;animation:slideUp .4s ease}.modal-header-calendario{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:24px 24px 0 0}.modal-header-calendario h2{font-size:1.75rem;font-weight:800;margin:0;color:#fff;display:flex;align-items:center;gap:1rem}.modal-header-calendario h2 svg{font-size:2rem}.btn-close-calendario{width:44px;height:44px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#fff;font-size:1.75rem}.btn-close-calendario:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body-calendario{padding:2.5rem}.pagos-dia-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}.stat-dia{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:12px}.stat-dia svg{font-size:2rem;color:#8b5cf6}.stat-dia-value{display:block;font-size:1.5rem;font-weight:800;color:#0f172a}.stat-dia-label{display:block;font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase}.pagos-dia-list{display:flex;flex-direction:column;gap:1.5rem}.pago-dia-card{padding:1.75rem;background:#fff;border:3px solid;border-radius:16px;transition:all .3s}.pago-dia-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001a}.pago-dia-card.pagado{border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.pago-dia-card.pendiente{border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.pago-dia-card.vencido{border-color:#ef4444;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.pago-dia-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:2px solid rgba(0,0,0,.1)}.estudiante-info-dia{display:flex;align-items:center;gap:1rem}.estudiante-avatar-dia{width:56px;height:56px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:800}.estudiante-info-dia h4{font-size:1.125rem;font-weight:800;color:#0f172a;margin:0 0 .25rem}.estudiante-info-dia p{font-size:.875rem;color:#64748b;margin:0;font-weight:600}.estado-badge-dia{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:10px;font-size:.875rem;font-weight:700}.estado-badge-dia.pagado{background:#10b981;color:#fff}.estado-badge-dia.pendiente{background:#f59e0b;color:#fff}.estado-badge-dia.vencido{background:#ef4444;color:#fff}.pago-dia-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:1rem}.detail-row span:first-child{color:#64748b;font-weight:600}.detail-row span:last-child{font-weight:800;color:#0f172a}.monto-total{font-size:1.125rem!important}.monto-abonado{color:#10b981!important}.monto-pendiente{color:#ef4444!important;font-size:1.125rem!important}.btn-agregar-abono-calendario{width:100%;padding:1rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;color:#fff;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-agregar-abono-calendario:hover{transform:translateY(-2px);box-shadow:0 8px 24px #8b5cf666}@media(max-width:1400px){.calendario-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.custom-toolbar{flex-direction:column;align-items:stretch}.toolbar-center{order:-1;margin-bottom:1rem}.pagos-dia-stats{grid-template-columns:1fr}}@media(max-width:768px){.calendario-pagos-page{padding:1rem}.calendario-hero{padding:2rem}.hero-text-calendario h1{font-size:1.75rem}.calendario-stats{grid-template-columns:1fr}.calendario-toolbar{flex-direction:column;align-items:stretch}.toolbar-filtros{flex-direction:column}.filter-group-calendario{min-width:auto}.calendario-leyenda{flex-direction:column;gap:1rem}.toolbar-navigation,.toolbar-views{width:100%}.toolbar-btn,.view-btn{flex:1;justify-content:center}}.metas-page{padding:2rem;max-width:1600px;margin:0 auto}.metas-container{width:100%}.metas-hero{background:linear-gradient(135deg,#10b981,#059669,#047857);border-radius:24px;padding:3rem;margin-bottom:2rem;color:#fff;box-shadow:0 20px 60px #10b9814d;position:relative;overflow:hidden}.metas-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%}.hero-content-metas{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}.hero-text-metas h1{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.hero-text-metas p{font-size:1.125rem;opacity:.95;margin:0}.hero-icon-metas{width:80px;height:80px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:float 3s ease-in-out infinite}.alerta-estado{display:flex;align-items:center;gap:1.5rem;padding:2rem;border-radius:20px;margin-bottom:2rem;border:3px solid;animation:slideInDown .5s ease}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.alerta-estado.cumplida{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981}.alerta-estado.en_camino{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.alerta-estado.en_riesgo{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444}.alerta-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0;background:#fff;box-shadow:0 4px 16px #0000001a}.alerta-estado.cumplida .alerta-icon{color:#10b981}.alerta-estado.en_camino .alerta-icon{color:#f59e0b}.alerta-estado.en_riesgo .alerta-icon{color:#ef4444}.alerta-content{flex:1}.alerta-content h3{font-size:1.5rem;font-weight:800;margin:0 0 .5rem}.alerta-estado.cumplida .alerta-content h3{color:#047857}.alerta-estado.en_camino .alerta-content h3{color:#92400e}.alerta-estado.en_riesgo .alerta-content h3{color:#991b1b}.alerta-content p{margin:0;font-size:1rem;font-weight:600;opacity:.9}.btn-edit-meta{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#fff;border:2px solid;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s;flex-shrink:0}.alerta-estado.cumplida .btn-edit-meta{border-color:#10b981;color:#047857}.alerta-estado.en_camino .btn-edit-meta{border-color:#f59e0b;color:#92400e}.alerta-estado.en_riesgo .btn-edit-meta{border-color:#ef4444;color:#991b1b}.btn-edit-meta:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.metas-kpis{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1.5rem;margin-bottom:2rem}.kpi-meta{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;transition:all .3s}.kpi-meta.grande{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;box-shadow:0 8px 30px #10b9814d}.kpi-meta:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.kpi-meta-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.kpi-meta-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.kpi-meta.grande .kpi-meta-icon{background:#fff3;color:#fff}.kpi-meta-icon.green{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.kpi-meta-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.kpi-meta-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.kpi-meta-label{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.kpi-meta.grande .kpi-meta-label{color:#ffffffe6}.kpi-meta-label{color:#64748b}.kpi-meta-value{font-size:2rem;font-weight:800;color:#0f172a;margin-bottom:.5rem}.kpi-meta.grande .kpi-meta-value{color:#fff;font-size:2.5rem}.kpi-meta-sub{font-size:.875rem;font-weight:600}.kpi-meta.grande .kpi-meta-sub{color:#fffc}.kpi-meta-sub{color:#64748b}.kpi-meta-sub .positive{color:#10b981;display:flex;align-items:center;gap:.25rem}.kpi-meta-sub .negative{color:#ef4444;display:flex;align-items:center;gap:.25rem}.btn-definir-meta{width:100%;padding:1rem;margin-top:1rem;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;color:#fff;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-definir-meta:hover{background:#ffffff4d;transform:translateY(-2px)}.metas-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-bottom:2rem}.chart-card-metas{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:2rem;transition:all .3s}.chart-card-metas.full-width{grid-column:1 / -1}.chart-card-metas:hover{box-shadow:0 8px 30px #0000001a}.chart-header-metas{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.chart-header-metas h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0;display:flex;align-items:center;gap:.75rem}.chart-header-metas h3 svg{font-size:1.5rem;color:#10b981}.chart-body-metas{min-height:300px}.progress-circular-wrapper{display:flex;justify-content:center;margin-bottom:2rem}.progress-circular{position:relative;width:200px;height:200px}.progress-circular svg{transform:rotate(0)}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.progress-value{display:block;font-size:3rem;font-weight:800;color:#0f172a;line-height:1}.progress-label{display:block;font-size:.875rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-top:.5rem}.progress-details{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.progress-detail-item{display:flex;justify-content:space-between;align-items:center;font-size:1rem}.progress-detail-item span:first-child{color:#64748b;font-weight:600}.progress-detail-item .bold{font-weight:800;color:#0f172a}.progress-detail-item .green{color:#10b981}.progress-detail-item .orange{color:#f59e0b}.historico-section,.metas-curso-section{margin-bottom:2rem}.section-header-metas{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header-metas h2{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0;display:flex;align-items:center;gap:.75rem}.section-header-metas h2 svg{font-size:1.75rem;color:#10b981}.btn-nueva-meta-curso{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 16px #10b9814d}.btn-nueva-meta-curso:hover{transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.empty-metas-curso{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1.5rem;background:#fff;border:2px dashed #cbd5e1;border-radius:20px}.empty-metas-curso svg{font-size:5rem;color:#cbd5e1}.empty-metas-curso h3{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0}.empty-metas-curso p{font-size:1rem;color:#64748b;margin:0}.btn-create-first{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s;margin-top:1rem}.btn-create-first:hover{transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.metas-curso-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.meta-curso-card{background:#fff;border:3px solid;border-radius:20px;padding:2rem;transition:all .3s}.meta-curso-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.meta-curso-card.cumplida{border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.meta-curso-card.en_camino{border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.meta-curso-card.en_riesgo{border-color:#ef4444;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.meta-curso-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.meta-curso-header h4{font-size:1.125rem;font-weight:800;color:#0f172a;margin:0;flex:1}.btn-delete-meta{width:36px;height:36px;background:#fff;border:2px solid #cbd5e1;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#64748b;flex-shrink:0}.btn-delete-meta:hover{border-color:#ef4444;color:#ef4444;transform:scale(1.1)}.meta-curso-progress{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.progress-bar-wrapper{flex:1;height:16px;background:#ffffff80;border-radius:8px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.progress-bar-fill{height:100%;border-radius:8px;transition:width .8s ease}.progress-percentage{font-size:1rem;font-weight:800;color:#0f172a;min-width:60px;text-align:right}.meta-curso-stats{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.meta-curso-stat{display:flex;justify-content:space-between;align-items:center;font-size:.9375rem}.meta-curso-stat span:first-child{color:#64748b;font-weight:600}.meta-curso-stat .value{font-weight:800;color:#0f172a}.meta-curso-stat .value.green{color:#10b981}.meta-curso-stat .value.orange{color:#f59e0b}.meta-curso-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;border-radius:10px;font-size:.875rem;font-weight:700}.meta-curso-badge.cumplida{background:#10b981;color:#fff}.meta-curso-badge.en_camino{background:#f59e0b;color:#fff}.meta-curso-badge.en_riesgo{background:#ef4444;color:#fff}.modal-overlay-metas{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:2rem;animation:fadeIn .3s ease}.modal-content-metas{background:#fff;border-radius:24px;width:100%;max-width:600px;box-shadow:0 24px 80px #10b98166;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-header-metas{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.5rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:24px 24px 0 0}.modal-header-metas h2{font-size:1.75rem;font-weight:800;margin:0;color:#fff;display:flex;align-items:center;gap:1rem}.modal-header-metas h2 svg{font-size:2rem}.btn-close-metas{width:44px;height:44px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:#fff;font-size:1.75rem}.btn-close-metas:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body-metas{padding:2.5rem}.form-group-metas{margin-bottom:1.5rem}.form-group-metas label{display:block;font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:.75rem}.input-metas{width:100%;padding:1rem 1.25rem;border:2px solid #cbd5e1;border-radius:12px;font-size:1rem;font-weight:600;transition:all .3s}.input-metas:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 4px #10b9811a}.help-text{margin-top:.75rem;font-size:.875rem;color:#64748b;line-height:1.5}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.btn-cancel-metas,.btn-save-metas{flex:1;padding:1rem 1.5rem;border-radius:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s}.btn-cancel-metas{background:#fff;border:2px solid #cbd5e1;color:#64748b}.btn-cancel-metas:hover{border-color:#94a3b8;color:#475569}.btn-save-metas{background:linear-gradient(135deg,#10b981,#059669);border:none;color:#fff;box-shadow:0 4px 16px #10b9814d}.btn-save-metas:hover{transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.loading-metas{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1.5rem}.spinner-large-metas{width:60px;height:60px;border:4px solid #d1fae5;border-top-color:#10b981;border-radius:50%;animation:spin .8s linear infinite}.loading-metas p{font-size:1.125rem;font-weight:700;color:#64748b}@media(max-width:1400px){.metas-kpis{grid-template-columns:1fr 1fr}.kpi-meta.grande{grid-column:1 / -1}.metas-charts-grid{grid-template-columns:1fr}}@media(max-width:1024px){.metas-curso-grid{grid-template-columns:1fr}}@media(max-width:768px){.metas-page{padding:1rem}.metas-hero{padding:2rem}.hero-text-metas h1{font-size:1.75rem}.metas-kpis{grid-template-columns:1fr}.kpi-meta.grande{grid-column:auto}.alerta-estado{flex-direction:column;text-align:center}.section-header-metas{flex-direction:column;align-items:stretch;gap:1rem}.btn-nueva-meta-curso{width:100%;justify-content:center}}.btn-delete-meta-mensual{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#fff;border:2px solid #ef4444;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s;color:#ef4444;flex-shrink:0}.btn-delete-meta-mensual:hover{background:#ef4444;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px #ef44444d}.therapists-management-page{padding:2rem;max-width:1400px;margin:0 auto}.therapists-management-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.tm-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.tm-title{font-size:2rem;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:.75rem;margin:0}.tm-title svg{color:#d946ef}.tm-subtitle{color:#6b7280;margin-top:.5rem}.tm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.tm-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;overflow:hidden;transition:all .3s ease}.tm-card:hover{box-shadow:0 10px 25px #d946ef1a;border-color:#d946ef;transform:translateY(-2px)}.tm-card-header{padding:1.5rem;background:linear-gradient(135deg,#faf5ff,#fff);border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem}.tm-avatar{position:relative;width:64px;height:64px;border-radius:50%;overflow:hidden;border:3px solid white;box-shadow:0 4px 12px #0000001a}.tm-avatar img{width:100%;height:100%;object-fit:cover}.tm-avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#d946ef,#a855f7);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff}.tm-status{position:absolute;bottom:2px;right:2px;width:20px;height:20px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:12px}.tm-status.active{color:#10b981}.tm-status.inactive{color:#ef4444}.tm-info h3{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 .25rem}.tm-specialty{display:inline-block;padding:.25rem .75rem;background:#f3e8ff;color:#a855f7;border-radius:20px;font-size:.875rem;font-weight:500}.tm-card-body{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.tm-detail{display:flex;align-items:center;gap:.75rem;color:#6b7280;font-size:.875rem}.tm-detail .tm-icon{color:#d946ef;font-size:1rem;flex-shrink:0}.tm-card-footer{padding:1rem 1.5rem;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:.5rem}.tm-btn{flex:1;padding:.5rem 1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.tm-btn-view{background:#f3e8ff;color:#a855f7}.tm-btn-view:hover{background:#e9d5ff;color:#9333ea}.tm-btn-edit{background:#dbeafe;color:#3b82f6}.tm-btn-edit:hover{background:#bfdbfe;color:#2563eb}.tm-btn-delete{background:#fee2e2;color:#ef4444;padding:.5rem;flex:0}.tm-btn-delete:hover{background:#fecaca;color:#dc2626}.tm-empty{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;border:2px dashed #e5e7eb}.tm-empty-icon{font-size:4rem;color:#d1d5db;margin-bottom:1rem}.tm-empty h3{font-size:1.5rem;color:#1f2937;margin:0 0 .5rem}.tm-empty p{color:#6b7280;margin-bottom:1.5rem}.tm-form{display:flex;flex-direction:column;gap:1.5rem}.tm-tabs{display:flex;gap:.5rem;border-bottom:2px solid #e5e7eb;margin-bottom:1.5rem}.tm-tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;color:#6b7280;font-weight:500;cursor:pointer;transition:all .2s}.tm-tab:hover{color:#d946ef;background:#faf5ff}.tm-tab.active{color:#d946ef;border-bottom-color:#d946ef}.tm-tab-content{display:flex;flex-direction:column;gap:1rem}.tm-tab-content h4{font-size:1.125rem;color:#1f2937;margin:1rem 0 .5rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.tm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.tm-form-group{display:flex;flex-direction:column;gap:.5rem}.tm-form-group label{font-size:.875rem;font-weight:500;color:#374151}.tm-form-group input,.tm-form-group select,.tm-form-group textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s}.tm-form-group input:focus,.tm-form-group select:focus,.tm-form-group textarea:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.tm-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer}.tm-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.tm-form-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.tm-payments-modal{display:flex;flex-direction:column;gap:1.5rem}.tm-payments-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.tm-payment-stat{background:linear-gradient(135deg,#faf5ff,#fff);border:1px solid #e9d5ff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem}.tm-payment-stat-icon{width:48px;height:48px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#d946ef}.tm-payment-stat-icon.success{color:#10b981}.tm-payment-stat-label{font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.tm-payment-stat-value{font-size:1.5rem;font-weight:700;color:#1f2937}.tm-payments-table{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.tm-payments-table table{width:100%;border-collapse:collapse}.tm-payments-table thead{background:#f9fafb}.tm-payments-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.tm-payments-table td{padding:1rem;font-size:.875rem;color:#6b7280;border-bottom:1px solid #f3f4f6}.tm-payments-table tbody tr:hover{background:#faf5ff}.tm-payment-amount{font-weight:600;color:#d946ef}.tm-payment-method{display:inline-block;padding:.25rem .75rem;background:#f3f4f6;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:uppercase}.tm-payments-empty{padding:3rem;text-align:center;color:#9ca3af}.tm-payments-empty svg{font-size:3rem;margin-bottom:1rem}@media(max-width:768px){.therapists-management-page{padding:1rem}.tm-header{flex-direction:column;align-items:stretch}.tm-grid,.tm-form-row{grid-template-columns:1fr}.tm-tabs{overflow-x:auto;white-space:nowrap}.tm-payments-summary{grid-template-columns:1fr}.tm-payments-table{overflow-x:auto}}.tm-photo-upload{display:flex;gap:1.5rem;align-items:flex-start}.tm-photo-preview{position:relative;width:120px;height:120px;border-radius:12px;overflow:hidden;border:2px dashed #d1d5db;background:#f9fafb;flex-shrink:0}.tm-photo-preview img{width:100%;height:100%;object-fit:cover}.tm-photo-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9ca3af;font-size:.875rem}.tm-photo-placeholder svg{font-size:2.5rem;margin-bottom:.5rem}.tm-photo-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s}.tm-photo-remove:hover{background:#dc2626;transform:scale(1.1)}.tm-photo-actions{display:flex;flex-direction:column;gap:.75rem}.tm-photo-actions label{cursor:pointer;margin:0}.tm-photo-hint{color:#6b7280;font-size:.75rem}.refunds-management-page{padding:2rem;max-width:1400px;margin:0 auto}.refunds-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.refunds-header{margin-bottom:2rem}.refunds-title{font-size:2rem;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:.75rem;margin:0}.refunds-title svg{color:#ec4899}.refunds-subtitle{color:#6b7280;margin-top:.5rem}.refunds-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;background:#fff;padding:1.5rem;border-radius:12px;border:1px solid #e5e7eb;margin-bottom:2rem}.filter-group input,.filter-group select{padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#ec4899;box-shadow:0 0 0 3px #ec48991a}.refunds-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.refund-stat-card{background:linear-gradient(135deg,#fce7f3,#fff);border:1px solid #fbcfe8;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1.5rem}.refund-stat-card .stat-icon{width:56px;height:56px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#ec4899;flex-shrink:0}.refund-stat-card .stat-content{flex:1}.refund-stat-card .stat-label{font-size:.875rem;color:#9f1239;margin-bottom:.25rem}.refund-stat-card .stat-value{font-size:1.75rem;font-weight:700;color:#be123c}.refunds-table-container{background:#fff;border-radius:12px;border:1px solid #e5e7eb;overflow:hidden}.refunds-table{width:100%;border-collapse:collapse}.refunds-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.refunds-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:#374151;white-space:nowrap}.refunds-table td{padding:1rem;font-size:.875rem;color:#6b7280;border-bottom:1px solid #f3f4f6}.refunds-table tbody tr:hover{background:#fef3f9}.refunds-table tbody tr:last-child td{border-bottom:none}.code-badge{display:inline-block;padding:.25rem .75rem;background:#dbeafe;color:#1e40af;border-radius:20px;font-size:.75rem;font-weight:600;font-family:monospace}.amount-cell{font-weight:600;color:#ec4899;font-size:1rem}.method-badge{display:inline-block;padding:.25rem .75rem;background:#f3f4f6;color:#1f2937;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:uppercase}.motivo-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.view-voucher-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f3e8ff;color:#7c3aed;border-radius:8px;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s}.view-voucher-btn:hover{background:#e9d5ff;color:#6d28d9}.empty-refunds{padding:4rem 2rem;text-align:center;color:#9ca3af}.empty-icon{font-size:4rem;margin-bottom:1rem;color:#d1d5db}.empty-refunds h3{font-size:1.25rem;color:#6b7280;margin:0 0 .5rem}.empty-refunds p{color:#9ca3af;margin:0}@media(max-width:768px){.refunds-management-page{padding:1rem}.refunds-filters,.refunds-stats{grid-template-columns:1fr}.refunds-table-container{overflow-x:auto}.refunds-table{min-width:800px}}.reclamaciones-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:2rem 1rem}.reclamaciones-container{max-width:900px;margin:0 auto}.reclamaciones-header{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 12px #0000001a;text-align:center;border-top:6px solid #d946ef}.header-logo{margin-bottom:.75rem}.header-logo img{max-width:300px;height:auto}.reclamaciones-header h1{font-size:1.75rem;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .375rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}.header-subtitle{color:#6b7280;font-size:.875rem;margin:0;line-height:1.6}.reclamaciones-form{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden}.form-section{padding:1.5rem;border-bottom:2px solid #f3f4f6}.form-section:last-of-type{border-bottom:none}.section-title{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;color:#1f2937;margin:0 0 .375rem;font-weight:700}.section-number{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-radius:50%;font-size:1.125rem;font-weight:800;flex-shrink:0}.section-note{color:#d946ef;font-size:.8125rem;margin:0 0 .75rem;font-weight:600}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}@media(max-width:1024px){.form-grid{grid-template-columns:repeat(2,1fr)}}.form-group{display:flex;flex-direction:column;margin:0}.form-group.full-width{grid-column:1 / -1}.form-label{font-size:.8125rem;font-weight:600;color:#374151;margin-bottom:.25rem;display:block}.form-input{padding:.625rem .875rem;border:2px solid #d1d5db;border-radius:8px;font-size:.9rem;transition:all .2s;font-family:inherit}.form-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.form-input.error{border-color:#ef4444}.form-input:disabled{background-color:#f9fafb;cursor:not-allowed}textarea.form-input{resize:vertical;min-height:80px}.form-hint{font-size:.6875rem;color:#6b7280;margin-top:.125rem;display:block;line-height:1.3}.error-message{color:#ef4444;font-size:.75rem;margin-top:.125rem;display:flex;align-items:center;gap:.25rem}.checkbox-label{display:flex;align-items:flex-start;gap:.75rem;font-size:.95rem;color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label.error{color:#ef4444}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;flex-shrink:0;margin-top:2px;accent-color:#dc2626}.checkbox-label a{color:#d946ef;text-decoration:underline;font-weight:600}.checkbox-label a:hover{color:#a855f7}.legal-section{background:#fef2f2}.legal-info{background:#fff;border:2px solid #fecaca;border-radius:8px;padding:1rem;margin-bottom:1rem}.legal-info h3{color:#d946ef;font-size:1rem;margin:0 0 .75rem;font-weight:700}.legal-info ul{list-style:none;padding:0;margin:0 0 .75rem}.legal-info li{padding:.375rem 0;border-bottom:1px solid #fee2e2;color:#374151;line-height:1.5;font-size:.875rem}.legal-info li:last-child{border-bottom:none}.legal-notice{display:flex;gap:.75rem;padding:.75rem;background:#fffbeb;border-left:4px solid #f59e0b;border-radius:8px;margin-bottom:.75rem}.legal-notice svg{color:#f59e0b;font-size:1.5rem;flex-shrink:0}.legal-notice p{margin:0 0 .25rem;color:#374151;line-height:1.5;font-size:.875rem}.legal-notice p:last-child{margin-bottom:0}.legal-points{font-size:.8125rem;color:#6b7280;line-height:1.5}.legal-points p{margin:.5rem 0}.legal-points strong{color:#d946ef;font-weight:700}.form-actions{display:flex;gap:.75rem;padding:1.25rem 1.5rem;background:#f9fafb;justify-content:flex-end}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-danger{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;box-shadow:0 4px 12px #d946ef4d}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#a855f7,#9333ea);transform:translateY(-2px);box-shadow:0 6px 16px #d946ef66}.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}.success-message{background:#fff;border-radius:12px;padding:3rem;text-align:center;box-shadow:0 4px 12px #0000001a}.success-icon{width:80px;height:80px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:#dcfce7;border-radius:50%}.success-icon svg{font-size:3rem;color:#16a34a}.success-message h2{font-size:2rem;color:#1f2937;margin:0 0 .5rem;font-weight:800}.success-message>p{color:#6b7280;font-size:1rem;margin:0 0 2rem}.codigo-box{background:linear-gradient(135deg,#fdf4ff,#fae8ff);border:3px dashed #d946ef;border-radius:12px;padding:2rem;margin:2rem 0}.codigo-label{display:block;font-size:.875rem;color:#6b7280;text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:.75rem}.codigo-value{font-size:2.5rem;color:#d946ef;font-weight:900;letter-spacing:2px;font-family:Courier New,monospace;word-break:break-all}.codigo-hint{font-size:.875rem;color:#6b7280;margin-top:1rem;margin-bottom:0}.success-info{display:flex;gap:1rem;align-items:flex-start;background:#fffbeb;border-left:4px solid #f59e0b;padding:1.5rem;border-radius:8px;margin:2rem 0;text-align:left}.success-info svg{color:#f59e0b;font-size:1.5rem;flex-shrink:0;margin-top:2px}.success-info p{margin:0;color:#374151;line-height:1.6}.success-actions{margin-top:2rem}.btn-primary{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;box-shadow:0 4px 12px #d946ef4d}.btn-primary:hover{background:linear-gradient(135deg,#a855f7,#9333ea);transform:translateY(-2px);box-shadow:0 6px 16px #d946ef66}.reclamaciones-footer{background:#fff;border-radius:12px;padding:1.5rem;margin-top:1.5rem;box-shadow:0 4px 12px #0000001a;border-top:4px solid #1e40af}.footer-content{text-align:center;color:#6b7280;font-size:.8125rem;line-height:1.6}.footer-content p{margin:.375rem 0}.footer-content strong{color:#1f2937;font-weight:700}.footer-content a{color:#1e40af;text-decoration:underline;font-weight:600}.footer-content a:hover{color:#1e3a8a}@media(max-width:768px){.reclamaciones-page{padding:1rem .5rem}.reclamaciones-header h1{font-size:1.5rem}.header-logo img{max-width:200px}.form-section{padding:1.25rem;border-bottom:2px solid #f3f4f6}.section-title{font-size:1.25rem}.section-number{width:32px;height:32px;font-size:1rem}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn{width:100%;justify-content:center}.codigo-value{font-size:1.75rem}.success-message{padding:2rem 1.5rem}}.link-button{background:none;border:none;color:#d946ef;text-decoration:underline;font-weight:700;cursor:pointer;padding:0;font-size:inherit;transition:color .2s}.link-button:hover{color:#a855f7}.checkbox-label span{line-height:1.6}.policy-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.policy-modal{background:#fff;border-radius:24px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #0000004d;animation:slideUp .3s ease-out}.policy-modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,#d946ef,#a855f7);border-radius:24px 24px 0 0;color:#fff}.policy-header-content{display:flex;align-items:center;gap:1rem}.policy-icon{font-size:2rem}.policy-modal-header h2{font-size:1.75rem;font-weight:800;margin:0}.policy-close-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;border:none;border-radius:50%;color:#fff;font-size:1.5rem;cursor:pointer;transition:all .2s}.policy-close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.policy-modal-body{flex:1;overflow-y:auto;padding:2rem}.policy-section{margin-bottom:2.5rem}.policy-section:last-child{margin-bottom:0}.policy-section h3{display:flex;align-items:center;gap:.75rem;font-size:1.375rem;font-weight:800;color:#1f2937;margin:0 0 1rem}.policy-section h3 svg{color:#d946ef;font-size:1.5rem}.policy-section h4{font-size:1.125rem;font-weight:700;color:#374151;margin:1.5rem 0 .75rem}.policy-section p{color:#4b5563;line-height:1.8;margin:0 0 1rem;font-size:1rem}.policy-section ul{list-style:none;padding:0;margin:0 0 1rem}.policy-section li{padding:.625rem 0 .625rem 1.5rem;color:#4b5563;line-height:1.7;position:relative}.policy-section li:before{content:"✓";position:absolute;left:0;color:#d946ef;font-weight:900;font-size:1.125rem}.policy-section li strong{color:#1f2937;font-weight:700}.highlight{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:1rem 1.25rem;border-left:4px solid #f59e0b;border-radius:8px;margin:1rem 0}.last-updated{background:#f3f4f6;padding:.75rem 1rem;border-radius:8px;margin-top:1rem;font-size:.9375rem}.contact-section{background:linear-gradient(135deg,#eff6ff,#dbeafe);padding:1.5rem;border-radius:12px;border:2px solid #bfdbfe}.contact-info{margin-top:1rem}.contact-info p{margin:.5rem 0;font-weight:600;color:#1e40af}.cookie-type{background:#f9fafb;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;border:2px solid #e5e7eb;position:relative}.cookie-badge{display:inline-block;padding:.375rem .875rem;border-radius:20px;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.cookie-badge.essential{background:#fef3c7;color:#92400e}.cookie-badge.performance{background:#dbeafe;color:#1e40af}.cookie-badge.functional{background:#dcfce7;color:#166534}.cookie-badge.marketing{background:#fce7f3;color:#9f1239}.duration{background:#fff;padding:.625rem 1rem;border-radius:6px;margin-top:1rem;font-size:.9375rem;border-left:3px solid #d946ef}.note{background:#fffbeb;padding:.875rem 1.125rem;border-radius:8px;margin-top:1rem;font-size:.9375rem;border-left:3px solid #f59e0b}.browser-controls{background:#fff;padding:1.5rem;border-radius:12px;margin:1rem 0;border:2px solid #e5e7eb}.browser-controls h4{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.warning-box{background:#fef2f2;padding:1rem 1.25rem;border-left:4px solid #dc2626;border-radius:8px;margin:1rem 0;color:#991b1b;font-weight:500}.policy-modal-footer{padding:1.5rem 2rem;border-top:2px solid #f3f4f6;display:flex;justify-content:flex-end;gap:1rem}.btn-accept{padding:.875rem 2rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #d946ef4d}.btn-accept:hover{transform:translateY(-2px);box-shadow:0 8px 24px #d946ef66}.policy-modal-body::-webkit-scrollbar{width:8px}.policy-modal-body::-webkit-scrollbar-track{background:#f9fafb;border-radius:4px}.policy-modal-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.policy-modal-body::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media(max-width:768px){.policy-modal{max-height:95vh}.policy-modal-header{padding:1.5rem}.policy-modal-header h2{font-size:1.375rem}.policy-icon{font-size:1.5rem}.policy-modal-body{padding:1.5rem}.policy-section h3{font-size:1.125rem}.policy-modal-footer{padding:1rem 1.5rem}.btn-accept{width:100%}}.reclamaciones-admin-page{padding:2rem;background:#f8fafc;min-height:100vh}.reclamaciones-admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.spinner-large{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#dc2626;border-radius:50%;animation:spin .8s linear infinite}.page-header-enhanced{background:linear-gradient(135deg,#dc2626,#991b1b);border-radius:16px;padding:2.5rem;margin-bottom:2rem;box-shadow:0 10px 40px #dc262633}.header-content{display:flex;align-items:center;gap:1.5rem}.header-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;font-size:2rem;color:#fff}.header-text{flex:1}.page-title-enhanced{font-size:2rem;font-weight:800;color:#fff;margin:0 0 .5rem;letter-spacing:-.5px}.page-subtitle-enhanced{font-size:1rem;color:#ffffffe6;margin:0;font-weight:500}.stats-grid-enhanced{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card-enhanced{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014;transition:all .3s cubic-bezier(.4,0,.2,1);border:2px solid transparent;position:relative;overflow:hidden}.stat-card-enhanced:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,currentColor,transparent);opacity:0;transition:opacity .3s}.stat-card-enhanced:hover{transform:translateY(-8px);box-shadow:0 12px 40px #00000026;border-color:currentColor}.stat-card-enhanced:hover:before{opacity:1}.stat-card-enhanced.total{color:#3b82f6}.stat-card-enhanced.warning{color:#f59e0b}.stat-card-enhanced.info{color:#8b5cf6}.stat-card-enhanced.success{color:#10b981}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.stat-icon-wrapper{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:currentColor;color:#fff;font-size:1.5rem;opacity:.9}.stat-trend{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:currentColor;opacity:.8}.stat-value-large{font-size:3rem;font-weight:900;color:#1f2937;line-height:1;margin-bottom:.5rem;font-variant-numeric:tabular-nums}.stat-label{font-size:1rem;color:#6b7280;font-weight:600;margin-bottom:.75rem}.stat-footer{font-size:.875rem;color:#9ca3af;padding-top:1rem;border-top:1px solid #f3f4f6;margin-top:1rem}.filters-container-enhanced{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014;margin-bottom:1.5rem}.search-box-enhanced{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:1.5rem;transition:all .3s}.search-box-enhanced:focus-within{background:#fff;border-color:#dc2626;box-shadow:0 0 0 4px #dc26261a}.search-box-enhanced svg{color:#9ca3af;font-size:1.5rem;flex-shrink:0}.search-box-enhanced input{flex:1;border:none;outline:none;background:transparent;font-size:1rem;color:#1f2937;font-weight:500}.search-box-enhanced input::placeholder{color:#9ca3af}.filters-row-enhanced{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.filter-group-enhanced{display:flex;align-items:center;gap:.75rem;background:#f9fafb;padding:.5rem 1rem;border-radius:12px;border:2px solid #e5e7eb;transition:all .2s}.filter-group-enhanced:hover{border-color:#d1d5db}.filter-icon{color:#6b7280;font-size:1.125rem}.filter-select-enhanced{border:none;background:transparent;font-size:.95rem;font-weight:600;color:#1f2937;cursor:pointer;outline:none;padding:.25rem .5rem}.btn-export-enhanced{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#dc2626;color:#fff;border:none;border-radius:12px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s;margin-left:auto}.btn-export-enhanced:hover{background:#b91c1c;transform:translateY(-2px);box-shadow:0 8px 24px #dc26264d}.results-info-enhanced{padding:1rem 0;color:#6b7280;font-size:.95rem;font-weight:500}.results-info-enhanced strong{color:#1f2937;font-weight:700}.table-container-enhanced{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden}.reclamaciones-table-enhanced{width:100%;border-collapse:collapse}.reclamaciones-table-enhanced thead{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-bottom:2px solid #e5e7eb}.reclamaciones-table-enhanced th{padding:1.25rem 1.5rem;text-align:left;font-size:.75rem;font-weight:800;color:#6b7280;text-transform:uppercase;letter-spacing:1px}.reclamaciones-table-enhanced tbody tr{border-bottom:1px solid #f3f4f6;transition:all .2s}.reclamaciones-table-enhanced tbody tr:hover{background:#fef3c7;transform:scale(1.01)}.reclamaciones-table-enhanced tbody tr.row-urgent{background:#fef2f2;border-left:4px solid #dc2626}.reclamaciones-table-enhanced tbody tr.row-urgent:hover{background:#fee2e2}.reclamaciones-table-enhanced td{padding:1.25rem 1.5rem;font-size:.95rem;color:#374151}.codigo-cell-enhanced{display:flex;align-items:center;gap:.5rem}.codigo-text{font-family:Courier New,monospace;font-weight:700;color:#dc2626;font-size:.875rem;background:#fef2f2;padding:.375rem .75rem;border-radius:6px;border:1px solid #fecaca}.urgent-indicator{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#dc2626;color:#fff;border-radius:50%;font-weight:900;font-size:.875rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.cliente-cell-enhanced{display:flex;align-items:center;gap:1rem}.cliente-avatar{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;border-radius:12px;font-weight:700;font-size:.875rem;flex-shrink:0}.cliente-info{display:flex;flex-direction:column;gap:.25rem}.cliente-nombre{font-weight:700;color:#1f2937;font-size:.95rem}.cliente-doc{font-size:.8rem;color:#6b7280;font-weight:500}.tipo-badge-enhanced{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:700;white-space:nowrap;border:2px solid}.detalle-preview{color:#6b7280;font-size:.875rem;line-height:1.5;max-width:300px}.text-muted-enhanced{color:#9ca3af;font-size:.875rem}.status-badge-enhanced{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.status-badge-enhanced svg{font-size:1rem}.status-badge-enhanced.badge-warning{background:#fef3c7;color:#92400e;border:2px solid #fde68a}.status-badge-enhanced.badge-info{background:#dbeafe;color:#1e40af;border:2px solid #bfdbfe}.status-badge-enhanced.badge-success{background:#dcfce7;color:#166534;border:2px solid #bbf7d0}.status-badge-enhanced.badge-secondary{background:#f3f4f6;color:#6b7280;border:2px solid #e5e7eb}.days-badge{display:inline-block;padding:.375rem .75rem;background:#f3f4f6;color:#6b7280;border-radius:6px;font-size:.875rem;font-weight:700}.days-badge.urgent{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-action-enhanced{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:.875rem;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-action-enhanced:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.empty-state-enhanced{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:#f9fafb;border-radius:50%;margin-bottom:1.5rem}.empty-icon svg{font-size:2.5rem;color:#d1d5db}.empty-state-enhanced h3{font-size:1.5rem;color:#1f2937;margin:0 0 .5rem;font-weight:700}.empty-state-enhanced p{color:#6b7280;margin:0;font-size:1rem}.reclamacion-modal-enhanced{display:flex;flex-direction:column;max-height:80vh}.modal-header-enhanced{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,#dc2626,#991b1b);border-radius:16px 16px 0 0;margin:-1.5rem -1.5rem 0}.modal-header-left{display:flex;align-items:center;gap:1.5rem}.modal-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;color:#fff;font-size:1.75rem}.modal-title{font-size:1.75rem;font-weight:800;color:#fff;margin:0 0 .25rem}.modal-subtitle{font-size:.95rem;color:#ffffffe6;margin:0;font-family:Courier New,monospace;font-weight:600}.modal-header-right{flex-shrink:0}.status-badge-large{display:inline-flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;border-radius:12px;font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;background:#fff}.status-badge-large svg{font-size:1.25rem}.modal-tabs{display:flex;gap:.5rem;padding:1.5rem 2rem 0;border-bottom:2px solid #f3f4f6;margin-bottom:1.5rem}.tab-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#6b7280;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;position:relative}.tab-btn:hover{color:#dc2626;background:#fef2f2;border-radius:8px 8px 0 0}.tab-btn.active{color:#dc2626;border-bottom-color:#dc2626}.tab-btn svg{font-size:1.125rem}.notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:#dc2626;border-radius:50%;animation:pulse 2s infinite}.modal-content-enhanced{flex:1;overflow-y:auto;padding:0 2rem 2rem}.tab-content{animation:fadeIn .3s ease-in}.info-section{margin-bottom:2.5rem}.info-section:last-child{margin-bottom:0}.info-section.highlight{background:#fffbeb;padding:1.5rem;border-radius:12px;border-left:4px solid #f59e0b}.info-section.important{background:#fef2f2;padding:1.5rem;border-radius:12px;border-left:4px solid #dc2626}.info-section.response-existing{background:#ecfdf5;padding:1.5rem;border-radius:12px;border:2px solid #a7f3d0;margin-bottom:2rem}.info-section.response-form{background:#f9fafb;padding:2rem;border-radius:12px}.section-title-enhanced{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:800;color:#1f2937;margin:0 0 1.5rem}.section-title-enhanced svg{color:#dc2626;font-size:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.info-card{display:flex;gap:1rem;padding:1.25rem;background:#fff;border:2px solid #f3f4f6;border-radius:12px;transition:all .2s}.info-card:hover{border-color:#dc2626;box-shadow:0 4px 12px #dc26261a;transform:translateY(-2px)}.info-card.full-width{grid-column:1 / -1}.info-card.alert-card{background:#fef2f2;border-color:#fecaca}.info-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#f3f4f6;color:#6b7280;border-radius:10px;font-size:1.25rem;flex-shrink:0}.info-icon.tipo{background:#fef3c7;color:#f59e0b}.info-icon.price{background:#dcfce7;color:#16a34a}.info-icon.alert{background:#fecaca;color:#dc2626}.info-content{flex:1;display:flex;flex-direction:column;gap:.375rem}.info-label{font-size:.75rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1rem;font-weight:600;color:#1f2937;line-height:1.5}.info-value.code{font-family:Courier New,monospace;background:#f9fafb;padding:.25rem .5rem;border-radius:4px;display:inline-block}.info-value.price{font-size:1.5rem;color:#16a34a;font-weight:800}.info-hint{font-size:.8rem;color:#9ca3af;font-style:italic}.tipo-badge-large{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:8px;font-size:1rem;font-weight:700;border:2px solid}.timeline-info{display:flex;flex-direction:column;gap:1.25rem}.timeline-item{display:flex;align-items:center;gap:1.25rem;padding:1rem;background:#fff;border-radius:12px;border-left:4px solid #e5e7eb}.timeline-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#f3f4f6;color:#6b7280;border-radius:50%;font-size:1.25rem;flex-shrink:0}.timeline-icon.success{background:#dcfce7;color:#16a34a}.timeline-content{display:flex;flex-direction:column;gap:.25rem}.timeline-label{font-size:.875rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.timeline-value{font-size:1rem;font-weight:600;color:#1f2937}.timeline-alert{color:#dc2626;font-weight:700}.dates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.date-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border:2px solid #f3f4f6;border-radius:10px}.date-label{font-size:.875rem;font-weight:700;color:#6b7280}.date-value{font-size:1rem;font-weight:600;color:#1f2937}.description-box{padding:1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;color:#374151;line-height:1.8;white-space:pre-wrap}.description-box.highlight{background:#fffbeb;border-color:#fde68a}.description-box.important{background:#fef2f2;border-color:#fecaca}.description-box p{margin:0}.legal-notice-box{display:flex;gap:1rem;padding:1.25rem;background:#eff6ff;border-left:4px solid #3b82f6;border-radius:8px;margin-top:1.5rem}.legal-notice-box svg{color:#3b82f6;font-size:1.5rem;flex-shrink:0}.legal-notice-box strong{color:#1e40af}.response-header-box{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.response-icon-success{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:#dcfce7;color:#16a34a;border-radius:12px;font-size:1.75rem}.response-date{font-size:.875rem;color:#6b7280;margin:0}.response-content-box{padding:1.5rem;background:#fff;border:2px solid #a7f3d0;border-radius:12px;font-size:1rem;color:#374151;line-height:1.8;white-space:pre-wrap}.form-group-enhanced{margin-bottom:2rem}.form-label-enhanced{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:700;color:#1f2937;margin-bottom:.75rem}.form-label-enhanced svg{color:#dc2626}.form-input-enhanced{width:100%;padding:.875rem 1.25rem;border:2px solid #e5e7eb;border-radius:10px;font-size:1rem;font-family:inherit;font-weight:500;transition:all .2s;background:#fff}.form-input-enhanced:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 4px #dc26261a}.form-textarea-enhanced{width:100%;padding:1rem 1.25rem;border:2px solid #e5e7eb;border-radius:10px;font-size:.95rem;font-family:inherit;line-height:1.8;resize:vertical;transition:all .2s;background:#fff}.form-textarea-enhanced:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 4px #dc26261a}.textarea-info{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;font-size:.875rem}.char-count{color:#9ca3af;font-weight:600}.textarea-hint{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-weight:500}.textarea-hint svg{color:#3b82f6}.estado-descriptions{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;padding:1rem;background:#fff;border-radius:8px}.estado-desc{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:6px;font-size:.875rem;color:#6b7280;opacity:.5;transition:all .2s}.estado-desc.active{opacity:1;background:#fef2f2;color:#1f2937;font-weight:600;border-left:4px solid #dc2626}.estado-desc svg{font-size:1.125rem;color:#dc2626}.response-templates{background:#fff;padding:1.5rem;border-radius:12px;border:2px solid #e5e7eb;margin-bottom:1.5rem}.templates-title{font-size:1rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.templates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.template-btn{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s;font-weight:600;color:#374151}.template-btn:hover{background:#fff;border-color:#dc2626;color:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #dc262633}.template-btn svg{font-size:2rem}.response-warning-box{display:flex;gap:1rem;padding:1.25rem;background:#fffbeb;border-left:4px solid #f59e0b;border-radius:8px;margin-top:1.5rem}.response-warning-box svg{color:#f59e0b;font-size:1.5rem;flex-shrink:0;margin-top:2px}.response-warning-box strong{color:#92400e;display:block;margin-bottom:.5rem}.response-warning-box ul{margin:0;padding-left:1.5rem;color:#78350f;line-height:1.8}.response-warning-box li{margin-bottom:.375rem}.modal-footer-tech{padding:1.25rem 2rem;background:#f9fafb;border-top:2px solid #e5e7eb;margin:1.5rem -1.5rem -1.5rem;border-radius:0 0 16px 16px}.tech-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.tech-info-item{display:flex;flex-direction:column;gap:.25rem}.tech-label{font-size:.75rem;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.tech-value{font-size:.875rem;color:#6b7280;font-family:Courier New,monospace;word-break:break-all}.modal-actions-enhanced{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem;background:#fff;border-top:2px solid #f3f4f6;margin:1.5rem -1.5rem -1.5rem;border-radius:0 0 16px 16px}.btn-modal{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-modal:disabled{opacity:.5;cursor:not-allowed}.btn-modal.secondary{background:#f3f4f6;color:#374151}.btn-modal.secondary:hover:not(:disabled){background:#e5e7eb}.btn-modal.primary{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;box-shadow:0 4px 12px #dc26264d}.btn-modal.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #dc262666}.btn-modal svg{font-size:1.125rem}.spinner-small{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(max-width:1200px){.stats-grid-enhanced{grid-template-columns:repeat(2,1fr)}.info-grid{grid-template-columns:1fr}}@media(max-width:768px){.reclamaciones-admin-page{padding:1rem}.page-header-enhanced{padding:1.5rem}.header-content{flex-direction:column;align-items:flex-start;gap:1rem}.header-icon{width:48px;height:48px;font-size:1.5rem}.page-title-enhanced{font-size:1.5rem}.page-subtitle-enhanced{font-size:.875rem}.stats-grid-enhanced{grid-template-columns:1fr}.stat-card-enhanced{padding:1.5rem}.stat-value-large{font-size:2.5rem}.filters-container-enhanced{padding:1.5rem}.search-box-enhanced{padding:.875rem 1rem}.filters-row-enhanced{flex-direction:column;width:100%}.filter-group-enhanced{width:100%}.btn-export-enhanced{width:100%;justify-content:center;margin-left:0}.table-container-enhanced{overflow-x:auto}.reclamaciones-table-enhanced{min-width:1000px}.reclamaciones-table-enhanced th,.reclamaciones-table-enhanced td{padding:1rem}.modal-header-enhanced{flex-direction:column;gap:1rem;padding:1.5rem}.modal-header-left,.modal-header-right{width:100%}.status-badge-large{width:100%;justify-content:center}.modal-tabs{flex-direction:column;padding:1rem}.tab-btn{width:100%;justify-content:center;border-bottom:none;border-left:3px solid transparent}.tab-btn.active{border-left-color:#dc2626;border-bottom-color:transparent}.modal-content-enhanced{padding:0 1rem 1rem}.info-grid,.dates-grid,.templates-grid,.tech-info-grid{grid-template-columns:1fr}.modal-footer-tech{padding:1rem}.modal-actions-enhanced{flex-direction:column;padding:1rem}.btn-modal{width:100%;justify-content:center}}@media(max-width:480px){.page-title-enhanced{font-size:1.25rem}.stat-value-large{font-size:2rem}.cliente-cell-enhanced{flex-direction:column;gap:.75rem}.cliente-avatar{width:40px;height:40px;font-size:.75rem}.modal-icon{width:48px;height:48px;font-size:1.5rem}.modal-title{font-size:1.5rem}.section-title-enhanced{font-size:1.125rem}.form-textarea-enhanced{font-size:.875rem}}@media print{.page-header-enhanced,.filters-container-enhanced,.btn-action-enhanced,.btn-export-enhanced,.modal-actions-enhanced{display:none!important}.table-container-enhanced{box-shadow:none;border:1px solid #e5e7eb}.reclamaciones-table-enhanced tbody tr:hover{background:#fff}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.reclamaciones-table-enhanced tbody tr{animation:slideInUp .3s ease-out}.stat-card-enhanced{animation:slideInRight .4s ease-out}.stat-card-enhanced:nth-child(1){animation-delay:.1s}.stat-card-enhanced:nth-child(2){animation-delay:.2s}.stat-card-enhanced:nth-child(3){animation-delay:.3s}.stat-card-enhanced:nth-child(4){animation-delay:.4s}.modal-content-enhanced::-webkit-scrollbar{width:8px}.modal-content-enhanced::-webkit-scrollbar-track{background:#f9fafb;border-radius:4px}.modal-content-enhanced::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.modal-content-enhanced::-webkit-scrollbar-thumb:hover{background:#9ca3af}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.font-semibold{font-weight:600}.font-medium{font-weight:500}.seguimiento-page{min-height:100vh;background:linear-gradient(135deg,#fdf4ff,#fae8ff,#f5f3ff);padding:3rem 1rem}.seguimiento-container{max-width:1000px;margin:0 auto}.seguimiento-header{text-align:center;margin-bottom:3rem}.header-icon-large{width:100px;height:100px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#d946ef,#a855f7);border-radius:50%;color:#fff;font-size:3rem;box-shadow:0 12px 40px #d946ef66;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.seguimiento-header h1{font-size:2.75rem;background:linear-gradient(135deg,#d946ef,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .75rem;font-weight:900;letter-spacing:-1px}.header-subtitle{font-size:1.25rem;color:#6b7280;margin:0;line-height:1.6;font-weight:500}.search-section{background:#fff;border-radius:24px;padding:3rem;box-shadow:0 8px 32px #d946ef26;margin-bottom:2.5rem;border:2px solid rgba(217,70,239,.1)}.search-form{display:flex;gap:1rem;margin-bottom:1.5rem}.search-input-wrapper{flex:1;position:relative}.input-icon{position:absolute;left:1.5rem;top:50%;transform:translateY(-50%);color:#d946ef;font-size:1.75rem;z-index:1}.search-input{width:100%;padding:1.375rem 1.5rem 1.375rem 4.25rem;border:3px solid #e5e7eb;border-radius:16px;font-size:1.25rem;font-weight:700;font-family:Courier New,monospace;transition:all .3s;text-transform:uppercase;letter-spacing:2px;background:#fafafa}.search-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 6px #d946ef26;background:#fff}.search-input::placeholder{text-transform:none;font-family:Arial,sans-serif;font-weight:500;letter-spacing:normal;color:#9ca3af}.search-button{display:flex;align-items:center;gap:.75rem;padding:1.375rem 2.5rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;border-radius:16px;font-size:1.125rem;font-weight:800;cursor:pointer;transition:all .3s;white-space:nowrap;box-shadow:0 8px 24px #d946ef66}.search-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #d946ef80}.search-button:disabled{opacity:.6;cursor:not-allowed}.search-button svg{font-size:1.5rem}.spinner-small{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.search-hint{display:flex;gap:1.25rem;padding:1.5rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-left:5px solid #3b82f6;border-radius:12px}.search-hint svg{color:#3b82f6;font-size:1.75rem;flex-shrink:0;margin-top:2px}.search-hint p{margin:0;color:#1e40af;line-height:1.8;font-size:1rem}.search-hint strong{font-family:Courier New,monospace;background:#fff;padding:.25rem .625rem;border-radius:6px;color:#d946ef;font-weight:800}.result-section{display:flex;flex-direction:column;gap:2rem;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.status-card{background:#fff;border-radius:24px;padding:3rem;box-shadow:0 8px 32px #0000001a;border-left:8px solid;position:relative;overflow:hidden}.status-card:before{content:"";position:absolute;top:0;right:0;width:200px;height:200px;background:radial-gradient(circle,currentColor 0%,transparent 70%);opacity:.05}.status-header{display:flex;align-items:center;gap:2rem;position:relative;z-index:1}.status-icon{width:100px;height:100px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:3rem;flex-shrink:0;box-shadow:0 8px 24px #00000026}.status-info{flex:1}.status-title{font-size:2.25rem;font-weight:900;color:#1f2937;margin:0 0 .75rem;line-height:1.2}.status-description{font-size:1.25rem;color:#6b7280;margin:0;line-height:1.6}.timeline-card{background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 8px 32px #0000001a}.section-title{display:flex;align-items:center;gap:1rem;font-size:1.5rem;font-weight:800;color:#1f2937;margin:0 0 2rem}.section-title svg{color:#d946ef;font-size:1.75rem}.timeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;position:relative}.timeline-item{position:relative;background:linear-gradient(135deg,#fafafa,#f5f5f5);border-radius:16px;padding:1.75rem;transition:all .3s;border:2px solid transparent;display:flex;flex-direction:column;gap:1rem}.timeline-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.timeline-item.completed{border-color:#d946ef;background:linear-gradient(135deg,#fdf4ff,#fae8ff)}.timeline-item.active{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#dbeafe);box-shadow:0 0 0 4px #3b82f633;animation:pulse-border 2s infinite}.timeline-item.pending{border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}@keyframes pulse-border{0%,to{box-shadow:0 0 0 4px #3b82f633}50%{box-shadow:0 0 0 8px #3b82f61a}}.timeline-marker{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#fff;border:3px solid #e5e7eb;border-radius:50%;font-size:1.5rem;color:#9ca3af;box-shadow:0 4px 12px #0000001a;margin:0 auto 1rem}.timeline-item.completed .timeline-marker{background:linear-gradient(135deg,#d946ef,#a855f7);border-color:#d946ef;color:#fff}.timeline-item.active .timeline-marker{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#3b82f6;color:#fff;animation:pulse-icon 2s infinite}.timeline-item.pending .timeline-marker{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b;color:#f59e0b}@keyframes pulse-icon{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.timeline-content{text-align:center}.timeline-title{font-size:1.125rem;font-weight:800;color:#1f2937;margin-bottom:.625rem;line-height:1.3}.timeline-date{font-size:.9375rem;color:#6b7280;font-weight:600;margin-bottom:.5rem;line-height:1.4}.timeline-days{font-size:.875rem;color:#9ca3af;font-style:italic;line-height:1.4}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.detail-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 16px #00000014;display:flex;gap:1.5rem;transition:all .3s;border:2px solid transparent}.detail-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #d946ef33;border-color:#d946ef}.detail-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-radius:16px;color:#d946ef;font-size:1.75rem;flex-shrink:0}.detail-content{flex:1}.detail-label{font-size:.8125rem;font-weight:800;color:#9ca3af;text-transform:uppercase;letter-spacing:1px;margin-bottom:.625rem}.detail-value{font-size:1.25rem;font-weight:800;color:#1f2937;word-wrap:break-word}.detail-value.code{font-family:Courier New,monospace;color:#d946ef;background:linear-gradient(135deg,#fdf4ff,#fae8ff);padding:.5rem 1rem;border-radius:8px;display:inline-block;border:2px solid rgba(217,70,239,.2)}.response-card{background:#fff;border-radius:24px;padding:3rem;box-shadow:0 8px 32px #0000001a;border:3px solid #a7f3d0}.response-date{font-size:.9375rem;color:#6b7280;margin-bottom:1.5rem;font-weight:700}.response-content{background:linear-gradient(135deg,#ecfdf5,#d1fae5);padding:2.5rem;border-radius:16px;border-left:6px solid #10b981;font-size:1.125rem;color:#374151;line-height:1.9;white-space:pre-wrap;box-shadow:inset 0 2px 8px #0000000d}.contact-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:24px;padding:3rem;border:3px solid #bfdbfe}.contact-text{font-size:1.125rem;color:#1e40af;margin:0 0 1.75rem;line-height:1.7;font-weight:500}.contact-methods{display:flex;flex-direction:column;gap:1.25rem}.contact-item{display:flex;align-items:center;gap:1.25rem;font-size:1.25rem;color:#1e40af;font-weight:700;background:#fff;padding:1.25rem;border-radius:12px;transition:all .2s}.contact-item:hover{transform:translate(8px);box-shadow:0 4px 16px #3b82f633}.contact-item svg{font-size:1.75rem;color:#3b82f6}.action-buttons{display:flex;justify-content:center;gap:1.25rem;margin-top:1.5rem}.btn-new-search{display:inline-flex;align-items:center;gap:.875rem;padding:1.125rem 2.5rem;background:#fff;color:#d946ef;border:3px solid #d946ef;border-radius:16px;font-size:1.125rem;font-weight:800;cursor:pointer;transition:all .3s;box-shadow:0 4px 16px #d946ef33}.btn-new-search:hover{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;transform:translateY(-3px);box-shadow:0 12px 32px #d946ef66}.btn-new-search svg{font-size:1.5rem}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2.5rem}.info-card{background:#fff;border-radius:24px;padding:2rem 1.5rem;box-shadow:0 8px 32px #0000001a;text-align:center;transition:all .3s;border:2px solid transparent;min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.info-card:hover{transform:translateY(-10px);box-shadow:0 16px 48px #d946ef33;border-color:#d946ef}.info-card-icon{width:80px;height:80px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-radius:50%;color:#d946ef;font-size:2.5rem;box-shadow:0 8px 24px #d946ef33}.info-card h3{font-size:1.25rem;color:#1f2937;margin:0 0 1rem;font-weight:800;line-height:1.3;word-wrap:break-word;width:100%}.info-card p{font-size:.9375rem;color:#6b7280;margin:0;line-height:1.6;word-wrap:break-word;width:100%}.seguimiento-footer{background:#fff;border-radius:24px;padding:2.5rem;margin-top:4rem;text-align:center;box-shadow:0 8px 32px #0000001a;border-top:6px solid #1e40af}.seguimiento-footer p{margin:.625rem 0;color:#6b7280;font-size:.9375rem;line-height:1.9}.seguimiento-footer strong{color:#1f2937;font-weight:800}.seguimiento-footer a{color:#1e40af;text-decoration:none;font-weight:700;border-bottom:2px solid transparent;transition:all .2s}.seguimiento-footer a:hover{color:#1e3a8a;border-bottom-color:#1e3a8a}@media(max-width:768px){.seguimiento-page{padding:2rem 1rem}.seguimiento-header h1{font-size:2rem}.header-subtitle{font-size:1.0625rem}.header-icon-large{width:80px;height:80px;font-size:2.5rem}.search-section{padding:2rem}.search-form{flex-direction:column}.search-button{width:100%;justify-content:center}.status-card{padding:2rem}.status-header{flex-direction:column;text-align:center}.status-icon{width:80px;height:80px;font-size:2.5rem}.status-title{font-size:1.75rem}.timeline-card,.response-card,.contact-card{padding:2rem}.section-title{font-size:1.375rem}.timeline{grid-template-columns:1fr}.timeline-item{padding:1.5rem}.timeline-marker{width:48px;height:48px;font-size:1.25rem}.details-grid,.info-cards{grid-template-columns:1fr}}@media(max-width:480px){.seguimiento-header h1{font-size:1.75rem}.header-icon-large{width:70px;height:70px;font-size:2rem}.search-input{font-size:1rem;padding:1.125rem 1.125rem 1.125rem 3.5rem}.search-button{padding:1.125rem 1.75rem;font-size:1rem}.timeline-item{padding:1.25rem}.timeline-marker{width:44px;height:44px;font-size:1.125rem}.timeline-title{font-size:1rem}}.therapist-payments-page{padding:2rem;max-width:1400px;margin:0 auto}.therapist-payments-loading p{font-size:1.125rem;color:#6b7280}.year-view{display:flex;flex-direction:column;gap:2rem}.year-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-radius:20px;border:3px solid #f5d0fe}.year-header-left{display:flex;align-items:center;gap:1.5rem}.header-icon-large{width:70px;height:70px;background:linear-gradient(135deg,#d946ef,#a855f7);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;box-shadow:0 10px 30px #d946ef4d}.year-header h1{margin:0;font-size:2rem;font-weight:800;color:#1f2937}.year-header p{margin:.5rem 0 0;font-size:1rem;color:#6b7280}.year-selector{display:flex;align-items:center;gap:1rem;background:#fff;padding:.75rem 1.5rem;border-radius:50px;box-shadow:0 4px 15px #0000001a}.year-display{font-size:1.5rem;font-weight:700;color:#d946ef;min-width:80px;text-align:center}.btn-year-nav{width:40px;height:40px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:1.25rem}.btn-year-nav:hover:not(:disabled){background:#d946ef;border-color:#d946ef;color:#fff;transform:scale(1.1)}.btn-year-nav:disabled{opacity:.3;cursor:not-allowed}.year-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.summary-card{background:#fff;border-radius:16px;padding:1.5rem;display:flex;align-items:center;gap:1.25rem;box-shadow:0 4px 15px #00000014;transition:all .3s}.summary-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.summary-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.summary-icon.primary{background:linear-gradient(135deg,#d946ef,#a855f7)}.summary-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.summary-icon.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.summary-icon.info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.summary-content{flex:1}.summary-value{font-size:1.75rem;font-weight:800;color:#1f2937;line-height:1}.summary-label{font-size:.875rem;color:#6b7280;margin-top:.5rem}.months-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.month-card{background:#fff;border-radius:16px;padding:1.5rem;border:3px solid #f3f4f6;transition:all .3s;position:relative;overflow:hidden}.month-card:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#d946ef,#a855f7);transform:scaleX(0);transition:transform .3s}.month-card:hover:before{transform:scaleX(1)}.month-card:hover{transform:translateY(-8px);box-shadow:0 12px 30px #d946ef26;border-color:#d946ef}.month-card.empty{opacity:.5;background:#fafafa}.month-card.future{opacity:.4;background:#f9fafb;cursor:not-allowed!important}.month-card.completed{border-color:#10b981}.month-card.partial{border-color:#f59e0b}.month-card.pending{border-color:#ef4444}.month-status-indicator{font-size:2rem;text-align:right;margin-bottom:.75rem}.month-name{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.month-stats{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1rem}.month-stat-item{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;color:#6b7280}.month-stat-item.primary{color:#d946ef;font-weight:600;font-size:1.125rem}.month-stat-item svg{font-size:1rem;flex-shrink:0}.month-status-label{font-size:.8125rem;font-weight:600;padding:.5rem .75rem;background:#f9fafb;border-radius:8px;text-align:center;margin-bottom:1rem}.btn-view-month{width:100%;padding:.75rem;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s}.btn-view-month:hover{transform:scale(1.05);box-shadow:0 8px 20px #d946ef4d}.month-detail-view{display:flex;flex-direction:column;gap:2rem}.month-detail-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-radius:16px;border:3px solid #f5d0fe}.btn-back{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#6b7280;font-weight:600;cursor:pointer;transition:all .2s}.btn-back:hover{background:#d946ef;border-color:#d946ef;color:#fff}.month-detail-header h2{margin:0;font-size:1.75rem;font-weight:800;color:#1f2937}.month-summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.month-summary-card{background:#fff;border-radius:16px;padding:1.5rem;border:3px solid #f3f4f6;transition:all .3s}.month-summary-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000001a;border-color:#d946ef}.summary-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:#6b7280;font-size:.875rem;font-weight:600}.summary-card-header svg{font-size:1.25rem}.summary-card-value{font-size:2rem;font-weight:800;color:#d946ef;line-height:1;margin-bottom:.5rem}.summary-card-value.comision{color:#f59e0b}.summary-card-value.spa{color:#10b981}.summary-card-value.pending{color:#ef4444}.summary-card-subtitle{font-size:.8125rem;color:#9ca3af;margin-top:.5rem}.month-actions{display:flex;justify-content:center;padding:1.5rem 0}.btn-large{padding:1.25rem 3rem;font-size:1.125rem;display:flex;align-items:center;gap:1rem}.btn-large svg{font-size:1.5rem}.therapists-table-container{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 15px #00000014}.therapists-table{width:100%;border-collapse:collapse}.therapists-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.therapists-table th{padding:1.25rem 1rem;text-align:left;font-size:.875rem;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.5px}.therapists-table tbody tr{border-bottom:1px solid #f3f4f6;transition:all .2s}.therapists-table tbody tr:hover{background:#fdf4ff}.therapists-table td{padding:1.25rem 1rem;font-size:.9375rem;color:#1f2937}.therapist-cell{display:flex;align-items:center;gap:1rem}.therapist-avatar{width:45px;height:45px;border-radius:50%;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;flex-shrink:0}.center-cell{text-align:center}.amount-cell{font-weight:600;text-align:right}.comision-cell{color:#f59e0b}.spa-cell{color:#10b981}.payment-status-cell{display:flex;flex-direction:column;gap:.375rem}.payment-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:10px;font-size:.8125rem;font-weight:600;width:fit-content}.payment-badge.paid{background:#d1fae5;color:#065f46}.payment-badge.pending{background:#fef3c7;color:#92400e}.payment-date{font-size:.75rem;color:#6b7280}.therapists-table tfoot{background:#f9fafb;border-top:3px solid #e5e7eb}.therapists-table tfoot td{padding:1.5rem 1rem;font-weight:700}.total-row{background:#fdf4ff}.pay-therapist-modal{display:flex;flex-direction:column;gap:1.5rem}.therapist-payment-info{background:linear-gradient(135deg,#fdf4ff,#fae8ff);border:2px solid #f5d0fe;border-radius:12px;padding:1.5rem}.therapist-payment-info h4{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:#1f2937}.therapist-specialty{margin:0 0 1.5rem;color:#6b7280;font-size:.9375rem}.payment-info-compact{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.info-compact-item{display:flex;flex-direction:column;gap:.25rem}.info-compact-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.info-compact-value{font-size:.9375rem;color:#1f2937;font-weight:600}.info-compact-value.highlight{color:#d946ef;font-size:1.125rem;font-weight:700}.payment-form-simple{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:#374151}.form-select,.form-input{padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:.9375rem;transition:all .2s}.form-select:focus,.form-input:focus{outline:none;border-color:#d946ef;box-shadow:0 0 0 3px #d946ef1a}.btn-block{width:100%;justify-content:center;padding:1rem;font-size:1rem}@media(max-width:1024px){.year-summary,.month-summary-cards,.months-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.therapist-payments-page{padding:1rem}.year-header{flex-direction:column;gap:1.5rem}.year-summary,.month-summary-cards,.months-grid{grid-template-columns:1fr}.month-detail-header{flex-direction:column;align-items:flex-start;gap:1rem}.therapists-table-container{overflow-x:auto}.payment-info-compact{grid-template-columns:1fr}}.view-mode-tabs{display:flex;gap:1rem;margin-bottom:2rem;background:#fff;padding:1rem;border-radius:16px;box-shadow:0 4px 15px #00000014}.view-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;background:transparent;border:2px solid transparent;border-radius:12px;color:#6b7280;font-weight:600;cursor:pointer;transition:all .3s;position:relative}.view-tab:hover{background:#fdf4ff;color:#d946ef}.view-tab.active{background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;border-color:#d946ef}.tab-badge{position:absolute;top:-8px;right:-8px;background:#ef4444;color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:12px;min-width:24px;text-align:center}.pending-view{display:flex;flex-direction:column;gap:2rem}.pending-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:20px;border:3px solid #fbbf24}.pending-header-left{display:flex;align-items:center;gap:1.5rem}.header-icon-large.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.custom-date-filter{display:flex;align-items:center;gap:.75rem;background:#fff;padding:.75rem 1.25rem;border-radius:12px;box-shadow:0 4px 15px #0000001a}.date-input-small{padding:.5rem .75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.875rem}.custom-date-filter span{color:#6b7280;font-size:.875rem;font-weight:500}.pending-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.empty-state-large{text-align:center;padding:4rem 2rem;background:#fff;border-radius:20px;box-shadow:0 4px 15px #00000014}.empty-icon{font-size:5rem;margin-bottom:1.5rem}.history-header{text-align:center;padding:2rem}.history-header h2{font-size:2rem;font-weight:800;color:#1f2937;margin-bottom:.5rem}.history-header p{font-size:1.125rem;color:#6b7280}@media(max-width:768px){.view-mode-tabs{flex-direction:column}.pending-header{flex-direction:column;gap:1.5rem}.custom-date-filter{flex-direction:column;width:100%}.pending-summary{grid-template-columns:1fr}}.info-compact-item.full-width{grid-column:1 / -1}.period-inputs{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.form-input-small{padding:.5rem .75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.875rem;flex:1}.period-inputs span{color:#6b7280;font-size:.875rem}.history-view{display:flex;flex-direction:column;gap:2rem}.history-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:20px;border:3px solid #93c5fd;flex-wrap:wrap;gap:1.5rem}.history-header-left{display:flex;align-items:center;gap:1.5rem}.header-icon-large.info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.history-filters{display:flex;align-items:center;gap:.75rem;background:#fff;padding:.75rem 1.25rem;border-radius:12px;box-shadow:0 4px 15px #0000001a;flex-wrap:wrap}.history-filters span{color:#6b7280;font-size:.875rem;font-weight:500}.history-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.history-table{width:100%;border-collapse:collapse}.history-table th{padding:1.25rem 1rem;text-align:left;font-size:.875rem;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.5px}.history-table td{padding:1.25rem 1rem;font-size:.9375rem;color:#1f2937;vertical-align:middle}.date-cell{display:flex;align-items:center;gap:.5rem;color:#6b7280}.date-cell svg{color:#3b82f6;font-size:1rem}.period-cell{font-size:.875rem;color:#6b7280;white-space:nowrap}.highlight-cell{color:#d946ef;font-weight:600}.payment-method-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#f3f4f6;border-radius:8px;font-size:.8125rem;font-weight:600;color:#374151;text-transform:capitalize}.therapist-name{font-weight:600;color:#1f2937;margin-bottom:.25rem}.therapist-specialty-small{font-size:.75rem;color:#9ca3af}.history-table tfoot td{padding:1.5rem 1rem;font-weight:700;color:#1f2937}.history-table tfoot .amount-cell{color:#d946ef}@media(max-width:1200px){.history-summary{grid-template-columns:repeat(2,1fr)}.history-table-container{overflow-x:auto}.history-table{min-width:1000px}}@media(max-width:768px){.history-header{flex-direction:column;align-items:flex-start}.history-filters{width:100%;flex-direction:column}.history-filters input,.history-filters button{width:100%}.history-summary{grid-template-columns:1fr}}.empty-state-large{text-align:center;padding:4rem 2rem;background:#fff;border-radius:20px;box-shadow:0 4px 15px #00000014;border:2px dashed #e5e7eb}.empty-icon{font-size:5rem;margin-bottom:1.5rem;opacity:.5}.empty-state-large h3{font-size:1.75rem;font-weight:700;color:#1f2937;margin-bottom:.75rem}.empty-state-large p{font-size:1.125rem;color:#6b7280}.spinner-large{width:60px;height:60px;border:4px solid #f3f4f6;border-top-color:#d946ef;border-radius:50%;animation:spin 1s linear infinite}.therapist-payments-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.therapist-payments-loading p{font-size:1.125rem;color:#6b7280;font-weight:500}.date-cell-compact{padding:1rem .75rem!important}.date-display{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#374151;font-weight:500}.date-display:before{content:"📅";font-size:.875rem}.therapist-cell-compact{display:flex;align-items:center;gap:.75rem}.therapist-avatar-small{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.therapist-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.therapist-name-compact{font-weight:600;color:#1f2937;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.therapist-specialty-compact{font-size:.75rem;color:#9ca3af}.period-cell-compact{padding:1rem .5rem!important}.period-range{font-size:.8125rem;color:#6b7280;line-height:1.3}.period-separator{font-size:.75rem;color:#d1d5db;text-align:center;margin:.125rem 0}.badge-citas{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:24px;padding:0 .5rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border-radius:12px;font-weight:700;font-size:.8125rem}.payment-method-compact{display:flex;align-items:center;gap:.375rem;font-size:.8125rem}.method-icon{font-size:1rem;line-height:1}.method-text{font-weight:500;color:#374151;text-transform:capitalize}.operation-cell{font-family:Courier New,monospace}.operation-code{display:inline-block;padding:.25rem .5rem;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;font-size:.75rem;color:#374151;font-weight:600}.text-muted{color:#d1d5db;font-size:.875rem}.admin-cell{font-size:.8125rem;color:#6b7280;font-weight:500}.history-table td{padding:.875rem .75rem!important;vertical-align:middle}.history-table th{padding:1rem .75rem!important;font-size:.8125rem!important;white-space:nowrap}.history-table .payment-method-badge{display:none}@media(max-width:1400px){.history-table th:nth-child(8),.history-table td:nth-child(8){display:none}}@media(max-width:1200px){.history-table th:nth-child(5),.history-table td:nth-child(5){display:none}}@media(max-width:1000px){.therapist-specialty-compact{display:none}}.history-table-container{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 15px #00000014}.history-table{width:100%;border-collapse:collapse;table-layout:auto}.history-table thead{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-bottom:2px solid #e5e7eb}.history-table thead th{padding:1rem .75rem;text-align:left;font-size:.8125rem;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;vertical-align:middle}.history-table tbody tr{border-bottom:1px solid #f3f4f6;transition:all .2s}.history-table tbody tr:hover{background:#f0f9ff}.history-table tbody td{padding:1rem .75rem;font-size:.9375rem;color:#1f2937;vertical-align:middle}.history-table .hist-date-col{width:110px}.history-table .hist-therapist-col{min-width:200px}.history-table .hist-period-col{width:160px}.history-table .hist-citas-col{width:70px;text-align:center}.history-table .hist-ingresos-col,.history-table .hist-comision-col{width:110px;text-align:right}.history-table .hist-metodo-col{width:130px}.history-table .hist-numop-col{width:100px}.history-table .hist-admin-col{width:140px}.hist-date-cell{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem;font-weight:500}.hist-date-cell svg{color:#3b82f6;font-size:1rem;flex-shrink:0}.hist-therapist-cell{display:flex;align-items:center;gap:.75rem}.hist-therapist-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#d946ef,#a855f7);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.hist-therapist-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.hist-therapist-name{font-weight:600;color:#1f2937;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-therapist-specialty{font-size:.75rem;color:#9ca3af}.hist-period-cell{font-size:.8125rem;color:#6b7280;line-height:1.6}.hist-period-separator{color:#d1d5db;margin:0 .25rem}.hist-badge-citas{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:28px;padding:0 .625rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border-radius:14px;font-weight:700;font-size:.875rem}.hist-method-cell{display:flex;align-items:center;gap:.5rem}.hist-method-icon{font-size:1.125rem;line-height:1}.hist-method-text{font-weight:500;color:#374151;text-transform:capitalize;font-size:.875rem}.hist-operation-code{display:inline-block;padding:.375rem .625rem;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;font-size:.75rem;color:#374151;font-weight:600;font-family:Courier New,monospace}.hist-text-muted{color:#d1d5db;font-size:.875rem}.hist-admin-name{font-size:.875rem;color:#6b7280;font-weight:500}.hist-highlight-cell{color:#d946ef;font-weight:700}.history-table tfoot{background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-top:3px solid #e5e7eb}.history-table tfoot td{padding:1.25rem .75rem;font-weight:700;color:#1f2937}.history-table tfoot .hist-highlight-cell{color:#d946ef}@media(max-width:1400px){.history-table .hist-numop-col{display:none}}@media(max-width:1200px){.history-table .hist-ingresos-col,.hist-therapist-specialty{display:none}}@media(max-width:1000px){.history-table .hist-admin-col{display:none}}@media(max-width:768px){.history-table-container{overflow-x:auto}.history-table{min-width:800px}}.an-nav{position:fixed;top:0;left:0;right:0;z-index:200;background:#fdf8f3f7;border-bottom:1px solid #ede0d4;transition:box-shadow .3s;font-family:DM Sans,sans-serif}.an-scrolled{box-shadow:0 2px 16px #c96b741f}.an-inner{max-width:1160px;margin:0 auto;padding:0 2rem;height:66px;display:flex;align-items:center;gap:28px}.an-logo{display:flex;align-items:center;gap:11px;text-decoration:none;flex-shrink:0}.an-logo-icon{width:36px;height:36px;border-radius:10px;background:#c96b74;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.an-logo-title{display:block;font-size:.97rem;font-weight:800;font-family:Playfair Display,serif;color:#2c2c3e}.an-logo-sub{display:block;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#c96b74}.an-links{display:flex;gap:2px;flex:1}.an-link{display:flex;align-items:center;gap:6px;padding:7px 15px;border-radius:50px;text-decoration:none;font-size:.86rem;font-weight:500;color:#6b5e6e;transition:color .2s,background .2s}.an-link svg{font-size:.88rem}.an-link:hover{color:#2c2c3e;background:#e8b4b833}.an-link.active{color:#c96b74;background:#e8b4b838;font-weight:700}.an-actions{display:flex;align-items:center;gap:10px;margin-left:auto}.an-spa-link{display:flex;align-items:center;gap:5px;font-size:.8rem;text-decoration:none;color:#a8969a;transition:color .2s}.an-spa-link:hover{color:#6b5e6e}.an-link.an-link-cert{color:#c9a84c;border:1px solid rgba(201,168,76,.3);background:#c9a84c0f}.an-link.an-link-cert:hover{background:#c9a84c26;color:#b8922a;border-color:#c9a84c80}.an-cta{padding:9px 22px;border-radius:50px;text-decoration:none;background:#c96b74;color:#fff;font-size:.84rem;font-weight:700;transition:transform .2s,background .2s}.an-cta:hover{background:#d4888f;transform:translateY(-1px)}.an-burger{display:none;background:none;border:none;color:#6b5e6e;font-size:1.35rem;cursor:pointer;padding:4px}.an-burger:hover{color:#c96b74}.an-mobile{display:flex;flex-direction:column;gap:2px;padding:10px 14px 18px;border-top:1px solid #ede0d4;background:#fdf8f3fc}.an-m-link{display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:10px;text-decoration:none;font-size:.9rem;font-weight:500;color:#6b5e6e;transition:color .2s,background .2s}.an-m-link:hover,.an-m-link.active{color:#c96b74;background:#e8b4b826}.an-m-cta{margin-top:10px;padding:13px;border-radius:50px;text-align:center;background:#c96b74;color:#fff;font-weight:700;font-size:.9rem;text-decoration:none}@media(max-width:768px){.an-links{display:none}.an-burger{display:flex}.an-spa-link{display:none}}.al-root{min-height:100vh;display:flex;flex-direction:column;background:#fdf8f3;font-family:DM Sans,sans-serif}.al-main{flex:1;padding-top:66px}.al-footer{background:#2c1f28;position:relative}.al-footer-wave{width:100%;overflow:hidden;line-height:0;background:#fdf8f3}.al-footer-wave svg{display:block;width:100%;height:60px}.al-fw{max-width:1160px;margin:0 auto;padding:52px 2rem 36px;display:grid;grid-template-columns:1.9fr 1fr 1fr 1fr;gap:40px}.al-f-brand p{font-size:.83rem;color:#fdf8f380;line-height:1.75;margin:14px 0 18px}.al-f-logo{display:flex;align-items:center;gap:11px;margin-bottom:4px}.al-f-logo-ic{width:38px;height:38px;border-radius:10px;background:#e8b4b826;border:1px solid rgba(232,180,184,.22);display:flex;align-items:center;justify-content:center;font-size:1.3rem}.al-f-logo-title{display:block;font-size:1rem;font-weight:800;color:#fff;font-family:Playfair Display,serif}.al-f-logo-sub{display:block;font-size:.62rem;color:#e8b4b88c;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.al-f-social{display:flex;gap:9px;margin-bottom:18px}.al-f-social a{width:36px;height:36px;border-radius:50%;background:#e8b4b81a;border:1px solid rgba(232,180,184,.18);display:flex;align-items:center;justify-content:center;color:#e8b4b880;font-size:.95rem;text-decoration:none;transition:color .2s,background .2s}.al-f-social a:hover{color:#e8b4b8;background:#e8b4b833}.al-f-reclamaciones{display:flex;flex-direction:column;gap:8px}.al-f-recla-btn,.al-f-seguim-btn{display:flex;align-items:center;gap:9px;padding:9px 14px;border-radius:9px;text-decoration:none;font-size:.78rem;font-weight:600;transition:background .2s,transform .15s}.al-f-recla-btn{background:#c96b7426;border:1px solid rgba(201,107,116,.3);color:#e8b4b8d9}.al-f-recla-btn:hover{background:#c96b7440;transform:translate(3px)}.al-f-seguim-btn{background:#fdf8f312;border:1px solid rgba(253,248,243,.15);color:#fdf8f3a6}.al-f-seguim-btn:hover{background:#fdf8f31f;transform:translate(3px)}.al-f-recla-icon{width:26px;height:26px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.al-f-recla-icon svg{width:16px;height:16px}.al-f-links{display:flex;flex-direction:column;gap:3px}.al-f-links h4,.al-f-contact h4{font-size:.67rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#e8b4b866;margin-bottom:14px}.al-f-links a{font-size:.83rem;color:#fdf8f373;text-decoration:none;padding:4px 0;transition:color .2s}.al-f-links a:hover{color:#fdf8f3e6}.al-f-contact{display:flex;flex-direction:column;gap:3px}.al-f-contact a{display:flex;align-items:center;gap:8px;font-size:.83rem;color:#fdf8f373;text-decoration:none;padding:4px 0;transition:color .2s}.al-f-contact a:hover{color:#fdf8f3e6}.al-f-contact a svg{font-size:.85rem;color:#e8b4b866;flex-shrink:0}.al-f-wa-link{color:#25d366b3!important}.al-f-wa-link:hover{color:#25d366!important}.al-f-wa-link svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}.al-f-hours{font-size:.74rem;color:#fdf8f34d;margin-top:4px}.al-f-badge{display:inline-flex;align-items:center;gap:7px;margin-top:14px;padding:7px 14px;border-radius:50px;background:#e8b4b81a;border:1px solid rgba(232,180,184,.18);font-size:.76rem;color:#e8b4b8a6;width:fit-content}.al-f-bottom{border-top:1px solid rgba(232,180,184,.1);padding:16px 2rem;max-width:1160px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.al-f-bottom p{font-size:.75rem;color:#fdf8f340}.al-f-bottom-links{display:flex;align-items:center;gap:8px}.al-f-bottom-links a,.al-f-bottom-links span{font-size:.75rem;color:#e8b4b859;text-decoration:none;transition:color .2s}.al-f-bottom-links a:hover{color:#e8b4b8b3}.wa-widget{position:fixed;bottom:28px;right:28px;z-index:500;display:flex;flex-direction:column;align-items:flex-end;gap:12px}.wa-btn{width:58px;height:58px;border-radius:50%;background:#25d366;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #25d36666;transition:transform .2s;position:relative}.wa-btn:hover{transform:scale(1.08)}.wa-btn svg{width:30px;height:30px;fill:#fff}.wa-btn-open{transform:scale(.92)}@keyframes waPulse{0%,to{opacity:.6;transform:scale(1)}70%{opacity:0;transform:scale(1.4)}}.wa-pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(37,211,102,.5);animation:waPulse 2s ease-out infinite}@keyframes waSlideIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.wa-bubble{width:300px;background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000026;overflow:hidden;animation:waSlideIn .25s ease}.wa-bubble-header{background:#128c7e;padding:14px 16px;display:flex;align-items:center;gap:10px}.wa-bubble-avatar{width:38px;height:38px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.wa-bubble-header strong{display:block;font-size:.88rem;font-weight:700;color:#fff}.wa-bubble-header span{font-size:.72rem;color:#ffffffbf}.wa-bubble-header>div:nth-child(2){flex:1}.wa-bubble-close{background:#ffffff26;border:none;border-radius:50%;width:26px;height:26px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center}.wa-bubble-body{padding:16px;background:#f0f0f0}.wa-bubble-body p{background:#fff;border-radius:0 10px 10px;padding:10px 13px;font-size:.84rem;color:#2c2c3e;line-height:1.6;margin:0}.wa-bubble-cta{display:block;padding:13px;background:#25d366;color:#fff;text-decoration:none;font-size:.86rem;font-weight:700;text-align:center}.wa-bubble-cta:hover{background:#20ba5a}.scroll-top-btn{position:fixed;bottom:28px;right:98px;z-index:499;width:42px;height:42px;border-radius:50%;background:#fdf8f3;border:1.5px solid #e8d9d2;color:#c96b74;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px #0000001a;opacity:0;transform:scale(.8);transition:opacity .3s,transform .3s;pointer-events:none}.scroll-top-btn.visible{opacity:1;transform:scale(1);pointer-events:auto}.scroll-top-btn:hover{background:#c96b74;color:#fff}@media(max-width:900px){.al-fw{grid-template-columns:1fr 1fr}}@media(max-width:560px){.al-fw{grid-template-columns:1fr;gap:28px}.al-f-bottom{flex-direction:column;gap:8px;text-align:center}.wa-widget{bottom:20px;right:20px}.scroll-top-btn{bottom:20px;right:90px}}:root{--cr: #fdf8f3;--cr2: #f5ede3;--cr3: #ede0d4;--rs: #e8b4b8;--rs2: #d4888f;--rs3: #c96b74;--gd: #c9a84c;--gd2: #e8c97a;--wn: #2c1f28;--wn2: #3d2a35;--tx: #2c2c3e;--tx2: #6b5e6e;--tx3: #a8969a;--bd: #e8d9d2}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.ah-page{min-height:100vh;background:var(--cr);color:var(--tx);font-family:DM Sans,sans-serif}.ah-w{max-width:1160px;margin:0 auto;padding:0 2rem}.ah-oferta-banner{background:#3d2a35;position:relative;z-index:199;border-bottom:1px solid rgba(232,180,184,.2)}.ah-oferta-inner{max-width:1160px;margin:0 auto;padding:11px 2rem;display:flex;align-items:center;justify-content:space-between;gap:12px}.ah-oferta-content{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ah-oferta-tag{padding:3px 12px;border-radius:50px;background:#c96b74;color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;white-space:nowrap}.ah-oferta-content p{font-size:.84rem;color:#fdf8f3cc;margin:0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ah-oferta-link{color:var(--gd2);font-weight:700;text-decoration:none;padding:2px 10px;border-radius:50px;border:1px solid rgba(232,201,122,.4)}.ah-oferta-link:hover{background:#e8c97a26}.ah-oferta-close{background:none;border:none;cursor:pointer;color:#fdf8f380;font-size:1rem;display:flex;align-items:center;padding:4px}.ah-oferta-close:hover{color:#fdf8f3e6}.ah-hero{background:#3d2a35;position:relative;overflow:hidden}.ah-hero-deco{position:absolute;inset:0;pointer-events:none}.ah-deco-circle{position:absolute;border-radius:50%}.ah-deco-circle.c1{width:500px;height:500px;top:-150px;right:-100px;background:#e8b4b814;filter:blur(60px)}.ah-deco-circle.c2{width:350px;height:350px;bottom:-80px;left:-80px;background:#c9a84c12;filter:blur(50px)}.ah-deco-circle.c3{width:250px;height:250px;top:30%;left:40%;background:#f0a89c0f;filter:blur(40px)}.ah-deco-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(253,248,243,.05) 1px,transparent 1px);background-size:30px 30px}.ah-hero-inner{display:grid;grid-template-columns:1fr 400px;gap:48px;align-items:center;max-width:1160px;margin:0 auto;padding:120px 2rem 64px;position:relative;z-index:1}.ah-hero-txt{color:#fff}.ah-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 18px;border-radius:100px;background:#e8b4b826;border:1px solid rgba(232,180,184,.3);color:#fdf8f3cc;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:24px}.ah-pill-heart{color:var(--rs)}.ah-hero-txt h1{font-family:Playfair Display,serif;font-size:clamp(2.4rem,4vw,3.8rem);font-weight:800;line-height:1.1;margin-bottom:20px;color:#fff}.ah-hero-txt h1 em{font-style:italic;color:var(--gd2)}.ah-hero-txt>p{font-size:.95rem;color:#fdf8f3ad;line-height:1.8;margin-bottom:34px;max-width:420px}.ah-hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}.ah-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:50px;background:#c96b74;color:#fff;font-weight:700;font-size:.9rem;text-decoration:none;border:none;cursor:pointer;font-family:inherit;transition:background .2s,transform .2s}.ah-btn-primary:hover{background:#d4888f;transform:translateY(-2px)}.ah-btn-outline{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:50px;border:1.5px solid rgba(232,180,184,.4);color:#fdf8f3e0;font-weight:600;font-size:.9rem;text-decoration:none;background:#ffffff12;transition:background .2s}.ah-btn-outline:hover{background:#ffffff21}.ah-trust{display:flex;align-items:center;gap:12px}.ah-avs{display:flex}.ah-avs>div{width:30px;height:30px;border-radius:50%;background:#c96b74;border:2px solid rgba(253,248,243,.35);display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:700;color:#fff;margin-left:-7px}.ah-avs>div:first-child{margin-left:0}.ah-trust p{font-size:.8rem;color:#fdf8f399;margin:0}.ah-trust p strong{color:#fdf8f3e0}.ah-hero-card{background:#ffffff12;border:1px solid rgba(232,180,184,.2);border-radius:20px;padding:22px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.ah-hc-badge{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:50px;background:#c9a84c;color:#2c1f28;font-size:.74rem;font-weight:700;margin-bottom:16px}.ah-hc-body{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:12px;border-radius:12px;background:#ffffff14}.ah-hc-avatar{width:42px;height:42px;border-radius:10px;background:#e8b4b840;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.ah-hc-text{flex:1}.ah-hc-text strong{display:block;font-size:.86rem;font-weight:700;color:#fff}.ah-hc-text span{font-size:.72rem;color:#fdf8f380}.ah-hc-stars{display:flex;align-items:center;gap:2px}.ah-hc-stars svg{color:var(--gd2);font-size:.7rem;fill:var(--gd2)}.ah-hc-stars span{font-size:.72rem;font-weight:700;color:var(--gd2);margin-left:3px}.ah-hc-progress{margin-bottom:14px;padding:11px 12px;border-radius:10px;background:#ffffff0f}.ah-hc-progress span{font-size:.7rem;color:#fdf8f380;display:flex;align-items:center;gap:5px;margin-bottom:7px}.ah-hc-bar{height:5px;border-radius:3px;background:#ffffff1a}.ah-hc-fill{height:100%;width:38%;border-radius:3px;background:#c96b74}.ah-hc-alumnas{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;background:#e8b4b81a;border:1px solid rgba(232,180,184,.15)}.ah-hc-avs{display:flex;gap:4px;font-size:1rem}.ah-hc-alumnas p{font-size:.74rem;color:#fdf8f399;margin:0}.ah-statsbar{display:flex;justify-content:center;border-top:1px solid rgba(232,180,184,.15)}.ah-stat{flex:1;max-width:290px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;border-right:1px solid rgba(232,180,184,.1);position:relative;overflow:hidden;transition:background .25s}.ah-stat:last-child{border-right:none}.ah-stat:hover{background:#ffffff0a}.ah-stat strong{font-size:2.8rem;font-weight:900;line-height:1;color:var(--accent, #e8b4b8);font-family:Playfair Display,serif;letter-spacing:-1px;margin-bottom:6px;text-shadow:0 0 30px rgba(var(--accent, 232,180,184),.3)}.ah-stat span{font-size:.78rem;color:#fdf8f380;font-weight:500;text-align:center;line-height:1.3;text-transform:uppercase;letter-spacing:.06em}.ah-stat-line{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:var(--accent, #e8b4b8);border-radius:2px;transition:width .35s ease}.ah-stat:hover .ah-stat-line{width:60%}.ah-moodle-banner{background:#1a1424;border-top:1px solid rgba(232,180,184,.12);border-bottom:1px solid rgba(232,180,184,.12);padding:22px 0;position:relative;overflow:hidden}.ah-moodle-banner:before{content:"";position:absolute;left:-10%;top:-50%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(232,180,184,.04),transparent);transform:skew(-20deg)}.ah-moodle-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.ah-moodle-left{display:flex;flex-direction:column;gap:3px}.ah-moodle-badge{display:inline-flex;width:fit-content;padding:2px 10px;border-radius:50px;background:#e8b4b81f;border:1px solid rgba(232,180,184,.25);color:#e8b4b8b3;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px}.ah-moodle-left strong{display:block;font-size:1.05rem;font-weight:700;color:#fff;font-family:Playfair Display,serif}.ah-moodle-left span{font-size:.8rem;color:#fdf8f380}.ah-moodle-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;flex-wrap:wrap}.ah-moodle-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:50px;background:#c96b74;color:#fff;font-weight:700;font-size:.86rem;text-decoration:none;white-space:nowrap;box-shadow:0 3px 12px #c96b7466;transition:background .2s,transform .2s}.ah-moodle-btn:hover{background:#d4888f;transform:translateY(-2px)}.ah-moodle-btn-cert{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:50px;background:transparent;color:#c9a84c;border:1.5px solid rgba(201,168,76,.4);font-weight:700;font-size:.86rem;text-decoration:none;white-space:nowrap;transition:background .2s,border-color .2s,transform .2s}.ah-moodle-btn-cert:hover{background:#c9a84c1f;border-color:#c9a84cb3;transform:translateY(-2px)}.ah-sh{text-align:center;margin-bottom:44px}.ah-sh-tag{display:inline-block;padding:5px 16px;border-radius:50px;background:var(--cr2);color:var(--rs3);font-size:.71rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px;border:1px solid var(--bd)}.ah-sh-tag-light{background:#e8b4b81f!important;color:var(--rs)!important;border-color:#e8b4b838!important}.ah-sh h2{font-family:Playfair Display,serif;font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;color:var(--tx);margin-bottom:10px}.ah-sh h2 em{font-style:italic;color:var(--rs3)}.ah-sh>p{font-size:.92rem;color:var(--tx2);max-width:480px;margin:0 auto}.ah-seeall{display:inline-flex;align-items:center;gap:6px;font-size:.84rem;font-weight:600;color:var(--rs3);text-decoration:none;margin-top:12px}.ah-cats{padding:70px 0;background:var(--cr)}.ah-cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}.ah-cat{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 10px;border-radius:16px;text-decoration:none;background:#fff;border:1.5px solid var(--bd);transition:transform .2s,box-shadow .2s,border-color .2s;animation:fadeUp .4s ease both;animation-delay:calc(var(--i) * .06s)}.ah-cat:hover{transform:translateY(-5px);box-shadow:0 10px 24px #c96b741f;border-color:var(--rs)}.ah-cat-emoji{font-size:1.9rem}.ah-cat strong{font-size:.82rem;font-weight:700;color:var(--tx);text-align:center}.ah-cat span{font-size:.69rem;color:var(--tx3);text-align:center}.ah-feat{padding:0 0 70px;background:var(--cr)}.ah-cg{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.ah-cc{background:#fff;border-radius:18px;border:1.5px solid var(--bd);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;animation:fadeUp .4s ease both;animation-delay:calc(var(--i) * .09s)}.ah-cc:hover{transform:translateY(-5px);box-shadow:0 12px 30px #c96b741f}.ah-cc-thumb{position:relative;height:190px;overflow:hidden;flex-shrink:0;background:var(--cr2)}.ah-thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s}.ah-cc:hover .ah-thumb-img{transform:scale(1.05)}.ah-thumb-fallback{position:absolute;inset:0;background:var(--cr2)}.ah-thumb-pattern{position:absolute;inset:0;opacity:.15;background-image:radial-gradient(#c96b74 1.5px,transparent 1.5px);background-size:18px 18px}.ah-cc-badge{position:absolute;top:10px;left:10px;z-index:2;padding:3px 10px;border-radius:50px;background:#fdf8f3ed;color:var(--rs3);font-size:.65rem;font-weight:700;border:1px solid rgba(201,107,116,.2)}.ah-cc-body{padding:16px;flex:1;display:flex;flex-direction:column}.ah-cc-body h3{font-family:Playfair Display,serif;font-size:.96rem;font-weight:700;color:var(--tx);margin-bottom:6px;line-height:1.3}.ah-cc-body>p{font-size:.76rem;color:var(--tx2);line-height:1.65;margin-bottom:11px;flex:1}.ah-cc-meta{display:flex;align-items:center;gap:12px;padding:7px 10px;border-radius:8px;background:var(--cr);border:1px solid var(--bd);margin-bottom:11px}.ah-cc-meta span{display:flex;align-items:center;gap:4px;font-size:.72rem;color:var(--tx2);font-weight:500}.ah-cc-actions{display:flex;gap:7px}.ah-cc-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:8px;border-radius:50px;text-decoration:none;background:var(--cr);border:1.5px solid var(--bd);color:var(--tx);font-size:.76rem;font-weight:600;transition:background .2s,color .2s}.ah-cc-btn:hover{background:var(--wn);color:#fff;border-color:var(--wn)}.ah-cc-moodle{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 13px;border-radius:50px;text-decoration:none;background:#c96b74;color:#fff;font-size:.76rem;font-weight:700;white-space:nowrap;transition:background .2s}.ah-cc-moodle:hover{background:#d4888f}.ah-feat-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:50px 0;color:var(--tx3)}.ah-feat-spinner{width:26px;height:26px;border-radius:50%;border:3px solid var(--bd);border-top-color:var(--rs3);animation:spin .8s linear infinite}.ah-feat-error{display:flex;align-items:center;justify-content:center;gap:10px;padding:44px 0;color:var(--tx3);flex-wrap:wrap}.ah-feat-error button{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:50px;border:1.5px solid var(--bd);background:#fff;color:var(--tx);font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit}.ah-feat-empty{text-align:center;padding:44px 0;color:var(--tx3)}.ah-why{background:#2c2c3e;padding:80px 0}.ah-why-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.ah-why-l{color:#fff}.ah-why-l h2{font-family:Playfair Display,serif;font-size:clamp(1.7rem,2.6vw,2.4rem);font-weight:800;color:#fff;margin:12px 0 14px;line-height:1.15}.ah-why-l h2 em{font-style:italic;color:var(--gd2)}.ah-why-desc{font-size:.9rem;color:#fdf8f39e;line-height:1.8;margin-bottom:22px}.ah-why-list{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:10px}.ah-why-list li{display:flex;align-items:center;gap:11px;font-size:.86rem;color:#fdf8f3c7}.ah-why-check{width:21px;height:21px;border-radius:50%;flex-shrink:0;background:#c96b74;display:flex;align-items:center;justify-content:center;font-size:.68rem;color:#fff}.ah-why-btns{display:flex;gap:11px;flex-wrap:wrap}.ah-why-r{display:grid;grid-template-columns:1fr 1fr;gap:13px}.ah-why-card{padding:20px 16px;border-radius:16px;background:#ffffff0f;border:1px solid rgba(232,180,184,.15);transition:background .2s,transform .2s;animation:fadeUp .4s ease both;animation-delay:calc(var(--i) * .09s)}.ah-why-card:hover{background:#ffffff1a;transform:translateY(-3px)}.ah-why-icon{font-size:1.7rem;margin-bottom:10px}.ah-why-card h4{font-size:.86rem;font-weight:700;color:#fff;margin-bottom:6px}.ah-why-card p{font-size:.76rem;color:#fdf8f385;line-height:1.65;margin:0}.ah-testi{padding:72px 0;background:var(--cr2)}.ah-tg{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.ah-tc{background:#fff;border-radius:18px;padding:24px 20px;border:1.5px solid var(--bd);display:flex;flex-direction:column;gap:12px;animation:fadeUp .4s ease both;animation-delay:calc(var(--i) * .09s);transition:transform .2s}.ah-tc:hover{transform:translateY(-4px)}.ah-tstars{display:flex;gap:3px}.ah-tstars svg{color:var(--gd);font-size:.82rem;fill:var(--gd)}.ah-tc>p{font-size:.85rem;color:var(--tx2);line-height:1.75;font-style:italic;flex:1;margin:0}.ah-ta{display:flex;align-items:center;gap:11px}.ah-tav{width:38px;height:38px;border-radius:50%;flex-shrink:0;background:#c96b74;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff}.ah-ta strong{display:block;font-size:.84rem;font-weight:700;color:var(--tx)}.ah-ta span{font-size:.71rem;color:var(--tx3)}.ah-cta{background:#2c1f28;padding:84px 0;text-align:center}.ah-cta-in h2{font-family:Playfair Display,serif;font-size:clamp(1.9rem,3.5vw,3rem);font-weight:800;color:#fff;margin-bottom:12px}.ah-cta-in p{font-size:.96rem;color:#fdf8f399;margin-bottom:34px}.ah-cta-btns{display:flex;justify-content:center;gap:13px;flex-wrap:wrap}.ah-btn-primary-lg{display:inline-flex;align-items:center;gap:8px;padding:13px 30px;border-radius:50px;background:#c96b74;color:#fff;font-weight:700;font-size:.93rem;text-decoration:none;transition:background .2s,transform .2s}.ah-btn-primary-lg:hover{background:#d4888f;transform:translateY(-2px)}.ah-btn-moodle-lg{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:50px;background:#c9a84c;color:#2c1f28;font-weight:700;font-size:.93rem;text-decoration:none;transition:background .2s,transform .2s}.ah-btn-moodle-lg:hover{background:#e8c97a;transform:translateY(-2px)}.ah-btn-ghost-lg{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:50px;border:1.5px solid rgba(232,180,184,.35);background:#ffffff12;color:#fdf8f3d1;font-weight:600;font-size:.93rem;text-decoration:none;transition:background .2s}.ah-btn-ghost-lg:hover{background:#ffffff1f}@media(max-width:1000px){.ah-hero-inner{grid-template-columns:1fr;padding:100px 2rem 50px}.ah-hero-card{display:none}.ah-cat-grid{grid-template-columns:repeat(3,1fr)}.ah-cg{grid-template-columns:repeat(2,1fr)}.ah-why-inner{grid-template-columns:1fr;gap:36px}.ah-tg{grid-template-columns:1fr 1fr}}@media(max-width:640px){.ah-hero-inner{padding:88px 1rem 44px}.ah-w{padding:0 1rem}.ah-cat-grid{grid-template-columns:repeat(2,1fr)}.ah-cg,.ah-why-r,.ah-tg{grid-template-columns:1fr}.ah-cta-btns{flex-direction:column;align-items:center}.ah-statsbar{flex-wrap:wrap}.ah-stat{width:50%;border-right:none}.ah-oferta-inner{flex-direction:column;align-items:flex-start;gap:8px}.ah-moodle-inner{flex-direction:column;align-items:flex-start}.ah-moodle-actions{width:100%}.ah-moodle-btn,.ah-moodle-btn-cert{width:100%;justify-content:center}}.acp-page{min-height:100vh;background:#fdf8f3;color:#2c1f28;font-family:DM Sans,sans-serif}.acp-header{position:relative;padding:52px 2rem 44px;overflow:hidden;background:linear-gradient(140deg,#2c1f28,#3d2a35 60%,#2c1f28)}.acp-header-bg{position:absolute;inset:0;pointer-events:none}.acp-h-orb{position:absolute;width:440px;height:440px;top:-130px;right:-60px;border-radius:50%;background:#c96b7421;filter:blur(65px)}.acp-hw{max-width:1200px;margin:0 auto;position:relative;z-index:1}.acp-ey{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fdf8f380;margin-bottom:10px}.acp-hw h1{font-size:clamp(1.9rem,3vw,2.7rem);font-weight:800;color:#fff;margin-bottom:8px;letter-spacing:-.02em;font-family:Playfair Display,serif}.acp-hw>p{color:#fdf8f3a6;font-size:.93rem;margin-bottom:22px}.acp-header-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.acp-header-meta{display:flex;align-items:center;gap:22px;flex-wrap:wrap}.acp-header-meta span{display:flex;align-items:center;gap:7px;font-size:.83rem;color:#fdf8f3b3;font-weight:500}.acp-header-meta svg{font-size:.95rem;opacity:.6}.acp-header-moodle-btn{display:inline-flex;align-items:center;gap:9px;padding:12px 24px;border-radius:50px;background:#c96b74;color:#fff;font-weight:700;font-size:.9rem;text-decoration:none;white-space:nowrap;box-shadow:0 4px 16px #c96b7473;transition:background .2s,transform .2s,box-shadow .2s;border:none;cursor:pointer}.acp-header-moodle-btn:hover{background:#d4888f;transform:translateY(-2px);box-shadow:0 7px 22px #c96b748c}.acp-toolbar{background:#fff;border-bottom:1px solid #e8d9d2;position:sticky;top:62px;z-index:50;box-shadow:0 1px 6px #2c1f280d}.acp-tw{max-width:1200px;margin:0 auto;padding:11px 2rem;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.acp-search{flex:1;min-width:220px;display:flex;align-items:center;gap:9px;background:#fdf8f3;border:1.5px solid #e8d9d2;border-radius:50px;padding:9px 13px;transition:border-color .2s,box-shadow .2s}.acp-search:focus-within{border-color:#c96b74;box-shadow:0 0 0 3px #c96b741a}.acp-search svg{color:#a8969a;font-size:.95rem;flex-shrink:0}.acp-search input{flex:1;background:none;border:none;outline:none;color:#2c1f28;font-size:.87rem;font-family:inherit}.acp-search input::placeholder{color:#a8969a}.acp-search button{background:none;border:none;cursor:pointer;color:#a8969a;display:flex;padding:0}.acp-search button:hover{color:#6b5e6e}.acp-sort-sel{background:#fdf8f3;border:1.5px solid #e8d9d2;border-radius:50px;padding:9px 13px;color:#6b5e6e;font-size:.84rem;outline:none;cursor:pointer;font-family:inherit;transition:border-color .2s}.acp-sort-sel:focus{border-color:#c96b74}.acp-filter-btn{display:flex;align-items:center;gap:7px;padding:9px 16px;border-radius:50px;background:#fdf8f3;border:1.5px solid #e8d9d2;color:#6b5e6e;font-size:.84rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.acp-filter-btn:hover,.acp-filter-btn.open{border-color:#c96b74;color:#c96b74;background:#fdf0f0}.acp-fbadge{width:7px;height:7px;border-radius:50%;background:#c96b74;display:inline-block}.acp-filter-arrow{transition:transform .25s;font-size:.85rem}.acp-filter-arrow.up{transform:rotate(180deg)}.acp-view-toggle{display:flex;border:1.5px solid #e8d9d2;border-radius:9px;overflow:hidden}.acp-view-toggle button{padding:9px 12px;border:none;background:#fff;cursor:pointer;color:#a8969a;font-size:.95rem;transition:background .15s,color .15s;display:flex;align-items:center}.acp-view-toggle button.active{background:#2c1f28;color:#fff}.acp-toolbar-moodle{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:50px;text-decoration:none;background:#c96b74;color:#fff;font-weight:700;font-size:.83rem;border:2px solid #c96b74;box-shadow:0 3px 10px #c96b744d;transition:background .2s,transform .15s,box-shadow .2s;white-space:nowrap}.acp-toolbar-moodle:hover{background:#d4888f;transform:translateY(-1px);box-shadow:0 5px 14px #c96b7466}.acp-body{padding:28px 0 60px}.acp-bw{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;gap:22px;align-items:start}.acp-sidebar{width:200px;flex-shrink:0;background:#fff;border:1.5px solid #e8d9d2;border-radius:13px;padding:18px 14px;display:flex;flex-direction:column;position:sticky;top:116px;gap:0}.acp-sb-section{margin-bottom:20px}.acp-sb-section h4{font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#a8969a;margin-bottom:9px}.acp-filter-item{display:block;width:100%;text-align:left;padding:7px 10px;border-radius:7px;border:none;cursor:pointer;font-size:.83rem;font-weight:500;color:#6b5e6e;background:none;transition:background .15s,color .15s;margin-bottom:2px;font-family:inherit}.acp-filter-item:hover{background:#fdf0f0;color:#c96b74}.acp-filter-item.active{background:#f5e8e8;color:#c96b74;font-weight:700}.acp-clear{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;border:1px solid #fca5a5;background:#fef2f2;color:#dc2626;font-size:.79rem;cursor:pointer;font-family:inherit;transition:background .2s;margin-bottom:12px;width:100%}.acp-clear:hover{background:#fee2e2}.acp-sidebar-moodle{display:flex;align-items:center;justify-content:center;gap:7px;padding:10px 14px;border-radius:50px;margin-top:6px;background:#c96b74;color:#fff;font-weight:700;font-size:.79rem;text-decoration:none;border:2px solid #c96b74;box-shadow:0 3px 10px #c96b744d;transition:background .2s,transform .15s}.acp-sidebar-moodle:hover{background:#d4888f;transform:translateY(-1px)}.acp-main{flex:1;min-width:0}.acp-results-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}.acp-count{font-size:.84rem;color:#6b5e6e;margin:0}.acp-count strong{color:#2c1f28;font-weight:700}.acp-pagesize{display:flex;align-items:center;gap:6px}.acp-pagesize>span{font-size:.79rem;color:#a8969a;font-weight:500}.acp-ps-btn{padding:5px 13px;border-radius:6px;border:1.5px solid #e8d9d2;background:#fff;color:#6b5e6e;font-size:.79rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.acp-ps-btn:hover{border-color:#c96b74;color:#c96b74}.acp-ps-btn.active{background:#2c1f28;border-color:#2c1f28;color:#fff}.acp-loading{display:flex;flex-direction:column;align-items:center;gap:14px;padding:72px 0;color:#a8969a}.acp-spinner{width:36px;height:36px;border-radius:50%;border:3px solid #e8d9d2;border-top-color:#c96b74;animation:acpSpin .8s linear infinite}@keyframes acpSpin{to{transform:rotate(360deg)}}.acp-loading p{font-size:.88rem}.acp-error{display:flex;flex-direction:column;align-items:center;gap:12px;padding:72px 0}.acp-error svg{font-size:2.4rem;color:#fca5a5}.acp-error p{font-size:.88rem;color:#6b5e6e}.acp-error button{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;border-radius:50px;background:#fdf8f3;border:1.5px solid #e8d9d2;color:#2c1f28;font-weight:600;font-size:.85rem;cursor:pointer;font-family:inherit;transition:background .2s}.acp-error button:hover{background:#f5e8e8}.acp-empty{text-align:center;padding:64px 0}.acp-empty span{font-size:3rem;display:block;margin-bottom:14px}.acp-empty p{color:#a8969a;margin-bottom:18px;font-size:.9rem}.acp-empty button{padding:9px 20px;border-radius:50px;background:#fdf8f3;border:1.5px solid #e8d9d2;color:#2c1f28;cursor:pointer;font-family:inherit;font-weight:600}.acp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.acp-card{background:#fff;border:1.5px solid #e8d9d2;border-radius:13px;overflow:hidden;display:flex;flex-direction:column;transition:transform .22s cubic-bezier(.22,1,.36,1),box-shadow .22s,border-color .22s;animation:fadeUp .36s cubic-bezier(.22,1,.36,1) both;animation-delay:calc(var(--i) * .04s)}.acp-card:hover{transform:translateY(-5px);box-shadow:0 14px 32px #c96b741f;border-color:#e8b4b8}.acp-card-inactive{opacity:.6}.acp-card-thumb{position:relative;height:165px;overflow:hidden;flex-shrink:0;background:#2c1f28}.acp-thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.acp-card:hover .acp-thumb-img{transform:scale(1.04)}.acp-thumb-fallback{position:absolute;inset:0;background:linear-gradient(135deg,#2c1f28,#3d2a35 60%,#2c1f28)}.acp-badge{position:absolute;top:10px;left:10px;z-index:2;padding:4px 10px;border-radius:5px;font-size:.67rem;font-weight:700;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.acp-badge.popular{background:#fef3c7;color:#92400e}.acp-badge.nuevo{background:#f5e8e8;color:#7a3040}.acp-badge.disponible{background:#d1fae5e6;color:#065f46}.acp-badge-inactive{position:absolute;top:10px;right:10px;z-index:2;padding:4px 10px;border-radius:5px;font-size:.67rem;font-weight:700;background:#0000008c;color:#d1d5db}.acp-card-body{padding:15px;flex:1;display:flex;flex-direction:column}.acp-card-meta-top{display:flex;gap:5px;margin-bottom:9px;flex-wrap:wrap}.acp-cat-chip{padding:3px 9px;border-radius:5px;font-size:.65rem;font-weight:700;background:#f5e8e8;color:#7a3040}.acp-lv-chip{padding:3px 9px;border-radius:5px;font-size:.65rem;font-weight:700;background:#fdf8f3;color:#6b5e6e}.acp-card-body h3{font-size:.91rem;font-weight:700;color:#2c1f28;margin-bottom:6px;line-height:1.35;font-family:Playfair Display,serif}.acp-card-desc{font-size:.77rem;color:#6b5e6e;line-height:1.6;margin-bottom:11px;flex:1}.acp-card-public-meta{display:flex;align-items:center;gap:14px;padding:9px 11px;border-radius:8px;background:#fdf8f3;border:1px solid #e8d9d2;margin-bottom:13px}.acp-meta-students,.acp-meta-cert{display:flex;align-items:center;gap:5px;font-size:.75rem;color:#6b5e6e;font-weight:500}.acp-meta-students svg{color:#c96b74;font-size:.85rem}.acp-meta-cert svg{color:#c9a84c;font-size:.85rem}.acp-card-footer{display:flex;align-items:center;gap:8px;margin-top:auto}.acp-btn-detail{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 12px;border-radius:50px;text-decoration:none;background:#fdf8f3;border:1.5px solid #e8d9d2;color:#2c1f28;font-size:.8rem;font-weight:700;transition:background .2s,border-color .2s,color .2s,transform .15s}.acp-btn-detail:hover{background:#2c1f28;color:#fff;border-color:#2c1f28;transform:translateY(-1px)}.acp-btn-detail svg{font-size:.85rem}.acp-btn-moodle{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 14px;border-radius:50px;text-decoration:none;background:#c96b74;color:#fff;font-size:.8rem;font-weight:700;border:2px solid #c96b74;white-space:nowrap;box-shadow:0 3px 10px #c96b744d;transition:background .2s,transform .15s,box-shadow .2s}.acp-btn-moodle:hover{background:#d4888f;transform:translateY(-1px);box-shadow:0 5px 14px #c96b7466}.acp-btn-moodle svg{font-size:.85rem}.acp-grid.acp-list{grid-template-columns:1fr}.acp-grid.acp-list .acp-card{flex-direction:row}.acp-grid.acp-list .acp-card-thumb{width:190px;flex-shrink:0;height:auto;min-height:140px}.acp-grid.acp-list .acp-card-body{padding:16px 18px}.acp-pagination-wrap{margin-top:36px;display:flex;flex-direction:column;align-items:center;gap:12px}.acp-pagination{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center}.acp-page-btn{min-width:38px;height:38px;border-radius:9px;border:1.5px solid #e8d9d2;background:#fff;color:#6b5e6e;font-size:.84rem;font-weight:600;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;transition:all .18s;padding:0 10px}.acp-page-btn:hover:not(:disabled){border-color:#c96b74;color:#c96b74;background:#fdf0f0}.acp-page-btn.active{background:#2c1f28;border-color:#2c1f28;color:#fff;box-shadow:0 3px 10px #2c1f2840}.acp-page-btn:disabled{opacity:.35;cursor:not-allowed}.acp-page-nav{font-size:1rem}.acp-page-ellipsis{min-width:38px;height:38px;display:flex;align-items:center;justify-content:center;color:#a8969a;font-size:.9rem}.acp-pagination-info{font-size:.78rem;color:#a8969a;margin:0}@media(max-width:900px){.acp-sidebar{display:none}.acp-sidebar.open{display:flex;position:fixed;inset:0;z-index:200;width:100%;height:100%;border-radius:0;overflow-y:auto;padding:28px;background:#fff}.acp-bw{flex-direction:column}.acp-header-bottom{flex-direction:column;align-items:flex-start}}@media(max-width:640px){.acp-toolbar-moodle{display:none}.acp-grid{grid-template-columns:1fr}.acp-grid.acp-list .acp-card{flex-direction:column}.acp-grid.acp-list .acp-card-thumb{width:100%;height:165px}.acp-tw{padding:10px 1rem}.acp-bw,.acp-hw{padding:0 1rem}.acp-results-bar{flex-direction:column;align-items:flex-start;gap:10px}}.acd-page{min-height:100vh;background:#f8f9fb;font-family:Inter,DM Sans,sans-serif;color:#111827}.acd-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px}.acd-spinner{width:38px;height:38px;border-radius:50%;border:3px solid #e5e7eb;border-top-color:#1c3557;animation:acdSpin .8s linear infinite}@keyframes acdSpin{to{transform:rotate(360deg)}}.acd-loading p{font-size:.9rem;color:#9ca3af}.acd-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:14px}.acd-error svg{font-size:2.8rem;color:#fca5a5}.acd-error p{font-size:.92rem;color:#6b7280}.acd-error-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.acd-error-btns button,.acd-error-btns a{padding:9px 20px;border-radius:8px;font-size:.86rem;font-weight:600;display:inline-flex;align-items:center;gap:7px;cursor:pointer;text-decoration:none;font-family:inherit;border:1.5px solid #e5e7eb;background:#f8f9fb;color:#1c3557}.acd-error-btns button:hover,.acd-error-btns a:hover{background:#e8edf5}.acd-hero{position:relative;overflow:hidden;padding:36px 0 52px;background:linear-gradient(140deg,#1c3557,#2d4f7c 60%,#1a3a6b)}.acd-hero-bg{position:absolute;inset:0;pointer-events:none}.acd-orb1{position:absolute;width:500px;height:500px;top:-160px;right:-80px;border-radius:50%;background:#3b82f61f;filter:blur(70px)}.acd-orb2{position:absolute;width:280px;height:280px;bottom:-80px;left:-40px;border-radius:50%;background:#f59e0b12;filter:blur(55px)}.acd-hw{max-width:1200px;margin:0 auto;padding:0 2rem;position:relative;z-index:1}.acd-back{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;color:#fff9;text-decoration:none;margin-bottom:24px;font-weight:500;transition:color .2s}.acd-back:hover{color:#fff}.acd-hero-inner{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start}.acd-hero-left{color:#fff}.acd-hero-tag{display:inline-flex;padding:4px 14px;border-radius:20px;font-size:.72rem;font-weight:700;margin-bottom:14px}.acd-hero-tag.active{background:#34d39933;color:#6ee7b7}.acd-hero-tag.inactive{background:#9ca3af33;color:#d1d5db}.acd-hero-left h1{font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:800;line-height:1.18;margin-bottom:14px;letter-spacing:-.02em}.acd-hero-summary{font-size:.88rem;color:#ffffffa6;line-height:1.75;margin-bottom:20px}.acd-hero-meta{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:28px}.acd-hero-meta span{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#ffffffa6}.acd-hero-meta svg{font-size:.9rem}.acd-hero-moodle-btn{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;border-radius:9px;background:#f59e0b;color:#111827;font-weight:700;font-size:.92rem;text-decoration:none;box-shadow:0 4px 18px #f59e0b73;transition:background .2s,transform .2s,box-shadow .2s}.acd-hero-moodle-btn:hover{background:#fbbf24;transform:translateY(-2px);box-shadow:0 7px 24px #f59e0b8c}.acd-hero-right{position:sticky;top:80px}.acd-enroll-card{background:#fff;border-radius:14px;box-shadow:0 12px 40px #0000002e;overflow:hidden}.acd-preview{position:relative;height:240px;overflow:hidden;background:#1c3557}.acd-preview-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.acd-enroll-card:hover .acd-preview-img{transform:scale(1.04)}.acd-preview-overlay{position:absolute;inset:0;z-index:2;background:#1c355766;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.acd-enroll-card:hover .acd-preview-overlay{opacity:1}.acd-preview-play-over{width:52px;height:52px;border-radius:50%;background:#ffffffeb;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#1c3557;box-shadow:0 4px 16px #00000040}.acd-preview-fallback{position:absolute;inset:0;background:linear-gradient(135deg,#1c3557,#2d4f7c 55%,#1a3a6b)}.acd-preview-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:#ffffffe6;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#1c3557;box-shadow:0 4px 16px #00000038;z-index:2}.acd-preview-code{position:absolute;bottom:12px;left:50%;transform:translate(-50%);font-size:.72rem;font-weight:700;color:#ffffffa6;letter-spacing:.06em;z-index:2}.acd-ec-body{padding:20px;display:flex;flex-direction:column;gap:10px}.acd-public-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px}.acd-stat-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:9px;background:#f8f9fb;border:1px solid #e5e7eb;min-width:0}.acd-stat-ic{font-size:1.2rem;color:#2563eb;flex-shrink:0}.acd-stat-ic.cert{color:#7c3aed}.acd-stat-ic.time{color:#059669}.acd-stat-item>div{min-width:0}.acd-stat-item>div strong{display:block;font-size:.86rem;font-weight:800;color:#111827;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.acd-stat-item>div span{font-size:.7rem;color:#9ca3af;white-space:nowrap}.acd-stat-full{grid-column:1 / -1}.acd-moodle-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:8px;text-decoration:none;background:#f59e0b;color:#111827;font-weight:700;font-size:.9rem;box-shadow:0 3px 12px #f59e0b66;transition:background .2s,transform .15s}.acd-moodle-btn:hover{background:#fbbf24;transform:translateY(-2px)}.acd-enroll-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:11px;border-radius:8px;text-decoration:none;background:#1c3557;color:#fff;font-weight:600;font-size:.86rem;transition:background .2s,transform .15s}.acd-enroll-btn:hover{background:#2d4f7c;transform:translateY(-1px)}.acd-info-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:10px;border-radius:8px;text-decoration:none;background:#f8f9fb;border:1.5px solid #e5e7eb;color:#1c3557;font-weight:600;font-size:.84rem;transition:background .2s}.acd-info-btn:hover{background:#e8edf5}.acd-body{padding:36px 0 56px}.acd-bw{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start}.acd-main{display:flex;flex-direction:column;gap:24px}.acd-section{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;padding:24px}.acd-section h2{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;color:#111827;margin-bottom:16px;padding-bottom:12px;border-bottom:1.5px solid #f3f4f6}.acd-section h2 svg{color:#2563eb;font-size:1rem}.acd-summary{font-size:.87rem;color:#4b5563;line-height:1.8}.acd-summary p{margin-bottom:10px}.acd-summary ul{padding-left:20px;margin-bottom:10px}.acd-summary li{margin-bottom:4px}.acd-summary h1,.acd-summary h2,.acd-summary h3{font-size:.95rem;font-weight:700;color:#111827;margin-bottom:8px;margin-top:16px}.acd-benefits-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.acd-benefit-item{display:flex;align-items:center;gap:10px;font-size:.85rem;color:#4b5563;padding:10px 12px;border-radius:8px;background:#f8f9fb}.acd-benefit-ic{color:#059669;font-size:.9rem;flex-shrink:0}.acd-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.acd-info-card{padding:14px 16px;border-radius:10px;background:#f8f9fb;border:1px solid #e5e7eb;display:flex;flex-direction:column;gap:4px}.acd-info-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#9ca3af}.acd-info-value{font-size:.88rem;font-weight:700;color:#111827}.acd-sidebar{display:flex;flex-direction:column;gap:16px;position:sticky;top:90px}.acd-sidebar-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:10px}.acd-sidebar-card h4{font-size:.92rem;font-weight:700;color:#111827;margin:0}.acd-sidebar-card p{font-size:.81rem;color:#6b7280;margin:0;line-height:1.5}.acd-sidebar-more{background:#f8f9fb}.acd-cta{background:linear-gradient(90deg,#1c3557,#2d4f7c);padding:28px 2rem}.acd-cta-w{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.acd-cta-w h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:4px}.acd-cta-w p{font-size:.8rem;color:#ffffff8c}.acd-cta-btns{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.acd-moodle-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:8px;text-decoration:none;background:#f59e0b;color:#111827;font-weight:700;font-size:.87rem;box-shadow:0 4px 14px #f59e0b66;transition:background .2s,transform .15s;white-space:nowrap}.acd-moodle-cta-btn:hover{background:#fbbf24;transform:translateY(-2px)}@media(max-width:900px){.acd-hero-inner{grid-template-columns:1fr}.acd-hero-right{position:static}.acd-bw{grid-template-columns:1fr}.acd-sidebar{position:static}}@media(max-width:640px){.acd-hw,.acd-bw{padding:0 1rem}.acd-hero-left h1{font-size:1.5rem}.acd-benefits-grid,.acd-info-grid{grid-template-columns:1fr}.acd-public-stats{flex-direction:column}.acd-cta-w{flex-direction:column;align-items:flex-start}.acd-cta-btns{flex-direction:column;width:100%}.acd-moodle-cta-btn,.acd-enroll-btn,.acd-info-btn{justify-content:center}}.acp2-page{min-height:100vh;background:#fdf8f3;color:#2c1f28;font-family:DM Sans,sans-serif}.acp2-hero{position:relative;padding:44px 2rem 36px;overflow:hidden;background:linear-gradient(140deg,#2c1f28,#3d2a35 60%,#2c1f28)}.acp2-orb1{position:absolute;width:360px;height:360px;top:-80px;right:-50px;border-radius:50%;background:#c96b7421;filter:blur(60px)}.acp2-orb2{position:absolute;width:280px;height:280px;bottom:-60px;left:-30px;border-radius:50%;background:#c9a84c14;filter:blur(50px)}.acp2-hw{max-width:1100px;margin:0 auto;position:relative;z-index:1}.acp2-back{display:inline-flex;align-items:center;gap:6px;color:#fdf8f399;font-size:.82rem;text-decoration:none;margin-bottom:18px;transition:color .2s}.acp2-back:hover{color:#fdf8f3e6}.acp2-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:100px;background:#e8b4b826;border:1px solid rgba(232,180,184,.25);color:#fdf8f3cc;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}.acp2-hw h1{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:800;color:#fff;margin-bottom:10px;letter-spacing:-.02em;line-height:1.15;font-family:Playfair Display,serif}.acp2-hw p{color:#fdf8f3a6;font-size:.93rem;max-width:480px}.acp2-body{padding:44px 0 60px}.acp2-bw{max-width:1100px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:start}.acp2-form-card{background:#fff;border:1px solid #e8d9d2;border-radius:16px;padding:32px 36px;position:relative;overflow:hidden;box-shadow:0 2px 12px #2c1f280f}.acp2-form-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#2c1f28,#c96b74,#c9a84c)}.acp2-form-hd{margin-bottom:26px;padding-bottom:18px;border-bottom:1px solid #f5ede3}.acp2-form-hd h2{font-size:1.25rem;font-weight:800;color:#2c1f28;margin-bottom:4px;font-family:Playfair Display,serif}.acp2-form-hd p{color:#a8969a;font-size:.85rem}.acp2-form{display:flex;flex-direction:column;gap:16px}.acp2-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.acp2-fg{display:flex;flex-direction:column;gap:6px}.acp2-fg label{font-size:.71rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#6b5e6e}.acp2-fg>span{font-size:.71rem;color:#dc2626;font-weight:500}.acp2-inp-w{position:relative}.acp2-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#a8969a;font-size:.88rem;pointer-events:none}.acp2-inp-w input,.acp2-inp-w select,.acp2-fg textarea{width:100%;padding:11px 12px 11px 38px;border:1.5px solid #e8d9d2;border-radius:50px;font-size:.87rem;font-family:inherit;color:#2c1f28;background:#fdf8f3;transition:border-color .2s,box-shadow .2s;outline:none}.acp2-fg textarea{padding:11px 12px;border-radius:12px;resize:vertical;min-height:110px;line-height:1.6}.acp2-inp-w input::placeholder,.acp2-fg textarea::placeholder{color:#c8b8bc}.acp2-inp-w select{appearance:none;color:#2c1f28}.acp2-inp-w input:focus,.acp2-inp-w select:focus,.acp2-fg textarea:focus{border-color:#c96b74;box-shadow:0 0 0 3px #c96b741a}.acp2-inp-w input.err,.acp2-inp-w select.err,.acp2-fg textarea.err{border-color:#fca5a5}.acp2-form button{padding:13px 24px;border-radius:50px;border:none;cursor:pointer;background:#c96b74;color:#fff;font-size:.87rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s,transform .2s,box-shadow .2s;font-family:inherit;box-shadow:0 4px 14px #c96b7459}.acp2-form button:hover:not(:disabled){background:#d4888f;transform:translateY(-2px);box-shadow:0 6px 18px #c96b7473}.acp2-form button:disabled{opacity:.55;cursor:not-allowed}.acp2-spin{width:16px;height:16px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:acp2spin .85s linear infinite}@keyframes acp2spin{to{transform:rotate(360deg)}}.acp2-info{display:flex;flex-direction:column;gap:14px}.acp2-info-card{background:#fff;border:1px solid #e8d9d2;border-radius:12px;padding:16px 18px;display:flex;gap:13px;align-items:flex-start;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 4px #2c1f280a}.acp2-info-card:hover{transform:translate(3px);box-shadow:0 4px 14px #c96b741a}.acp2-info-ic{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#2c1f28,#c96b74);display:flex;align-items:center;justify-content:center;font-size:1.05rem;color:#fff;flex-shrink:0}.acp2-info-card h4{font-size:.77rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#c96b74;margin-bottom:4px}.acp2-info-card p{font-size:.81rem;color:#6b5e6e;line-height:1.55;margin:0}.acp2-faq{background:#fff;border:1px solid #e8d9d2;border-radius:12px;padding:20px 18px;box-shadow:0 1px 4px #2c1f280a}.acp2-faq h3{font-size:.77rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#a8969a;margin-bottom:14px}.acp2-faq-item{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #f5ede3}.acp2-faq-item:last-child{border-bottom:none;margin:0;padding:0}.acp2-faq-q{display:flex;align-items:center;gap:7px;font-size:.84rem;font-weight:600;color:#2c1f28;margin-bottom:4px}.acp2-faq-q svg{color:#c96b74;flex-shrink:0;font-size:.9rem}.acp2-faq-item p{font-size:.78rem;color:#6b5e6e;line-height:1.6;margin:0;padding-left:20px}.acp2-social{background:#fff;border:1px solid #e8d9d2;border-radius:12px;padding:18px;text-align:center;box-shadow:0 1px 4px #2c1f280a}.acp2-social h4{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#a8969a;margin-bottom:12px}.acp2-slinks{display:flex;justify-content:center;gap:10px}.acp2-sl{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;color:#fff;text-decoration:none;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 8px #00000026}.acp2-sl:hover{transform:translateY(-3px) scale(1.07)}.acp2-sl.fb{background:#1877f2}.acp2-sl.ig{background:linear-gradient(135deg,#f58529,#dd2a7b 50%,#8134af)}.acp2-sl.yt{background:red}@media(max-width:900px){.acp2-bw{grid-template-columns:1fr}}@media(max-width:580px){.acp2-form-card{padding:22px 16px}.acp2-row{grid-template-columns:1fr}}.ar-page{min-height:100vh;background:#f5ede3;padding:2rem 1rem}.ar-container{max-width:900px;margin:0 auto}.ar-header{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 12px #c96b741a;text-align:center;border-top:6px solid #c96b74}.ar-header-logo{font-size:2.5rem;margin-bottom:.5rem}.ar-header h1{font-size:1.75rem;color:#c96b74;margin:0 0 .375rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;font-family:Playfair Display,serif}.ar-header-subtitle{color:#6b5e6e;font-size:.875rem;margin:0;line-height:1.6}.ar-form{background:#fff;border-radius:12px;box-shadow:0 4px 12px #c96b741a;overflow:hidden}.ar-section{padding:1.5rem;border-bottom:2px solid #f5ede3}.ar-section:last-of-type{border-bottom:none}.ar-section-title{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;color:#2c2c3e;margin:0 0 .375rem;font-weight:700}.ar-section-num{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#c96b74;color:#fff;border-radius:50%;font-size:1.125rem;font-weight:800;flex-shrink:0}.ar-section-note{color:#c96b74;font-size:.8125rem;margin:0 0 .75rem;font-weight:600}.ar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}@media(max-width:1024px){.ar-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.ar-grid{grid-template-columns:1fr}}.ar-group{display:flex;flex-direction:column;margin:0}.ar-group.ar-full{grid-column:1 / -1}.ar-group label{font-size:.8125rem;font-weight:600;color:#374151;margin-bottom:.25rem}.ar-group input,.ar-group select,.ar-group textarea{padding:.625rem .875rem;border:2px solid #e8d9d2;border-radius:8px;font-size:.9rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;background:#fff;color:#2c2c3e}.ar-group input:focus,.ar-group select:focus,.ar-group textarea:focus{outline:none;border-color:#c96b74;box-shadow:0 0 0 3px #c96b741f}.ar-group input.err,.ar-group select.err,.ar-group textarea.err{border-color:#ef4444}.ar-group input:disabled,.ar-group select:disabled{background:#f9fafb;cursor:not-allowed}.ar-group textarea{resize:vertical;min-height:80px}.ar-hint{font-size:.6875rem;color:#6b5e6e;margin-top:.125rem;display:block;line-height:1.3}.ar-err{color:#ef4444;font-size:.75rem;margin-top:.125rem}.ar-check-label{display:flex;align-items:flex-start;gap:.75rem;font-size:.875rem;color:#374151;cursor:pointer}.ar-check-label input[type=checkbox]{width:18px;height:18px;flex-shrink:0;margin-top:2px;accent-color:#c96b74;cursor:pointer}.ar-check-label.err{color:#ef4444}.ar-check-label span{line-height:1.6}.ar-link-btn{background:none;border:none;cursor:pointer;padding:0;color:#c96b74;text-decoration:underline;font-weight:700;font-size:inherit;transition:color .2s}.ar-link-btn:hover{color:#d4888f}.ar-legal-section{background:#fdf8f3}.ar-legal-info{background:#fff;border:2px solid #e8d9d2;border-radius:8px;padding:1rem;margin-bottom:1rem}.ar-legal-info h3{color:#c96b74;font-size:1rem;margin:0 0 .75rem;font-weight:700}.ar-legal-info ul{list-style:none;padding:0;margin:0 0 .75rem}.ar-legal-info li{padding:.375rem 0;border-bottom:1px solid #f5ede3;color:#374151;line-height:1.5;font-size:.875rem}.ar-legal-info li:last-child{border-bottom:none}.ar-legal-notice{display:flex;gap:.75rem;padding:.75rem;background:#fffbeb;border-left:4px solid #f59e0b;border-radius:8px;margin-bottom:.75rem}.ar-legal-notice svg{color:#f59e0b;font-size:1.5rem;flex-shrink:0}.ar-legal-notice p{margin:0 0 .25rem;color:#374151;line-height:1.5;font-size:.875rem}.ar-legal-notice p:last-child{margin-bottom:0}.ar-legal-points{font-size:.8125rem;color:#6b5e6e;line-height:1.5}.ar-legal-points p{margin:.5rem 0}.ar-legal-points strong{color:#c96b74;font-weight:700}.ar-actions{display:flex;gap:.75rem;padding:1.25rem 1.5rem;background:#f9fafb;justify-content:flex-end}.ar-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;font-family:inherit}.ar-btn:disabled{opacity:.5;cursor:not-allowed}.ar-btn-secondary{background:#f3f4f6;color:#374151}.ar-btn-secondary:hover:not(:disabled){background:#e5e7eb}.ar-btn-primary{background:#c96b74;color:#fff;box-shadow:0 4px 12px #c96b744d}.ar-btn-primary:hover:not(:disabled){background:#d4888f;transform:translateY(-2px);box-shadow:0 6px 16px #c96b7466}.ar-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:arSpin .6s linear infinite}.ar-success{background:#fff;border-radius:12px;padding:3rem;text-align:center;box-shadow:0 4px 12px #c96b741a}.ar-success-icon{width:80px;height:80px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:#dcfce7;border-radius:50%}.ar-success-icon svg{font-size:3rem;color:#16a34a}.ar-success h2{font-size:2rem;color:#2c2c3e;margin:0 0 .5rem;font-weight:800;font-family:Playfair Display,serif}.ar-success>p{color:#6b5e6e;font-size:1rem;margin:0 0 2rem}.ar-codigo-box{background:#fdf8f3;border:3px dashed #c96b74;border-radius:12px;padding:2rem;margin:2rem 0}.ar-codigo-label{display:block;font-size:.875rem;color:#6b5e6e;text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:.75rem}.ar-codigo-value{font-size:2.5rem;color:#c96b74;font-weight:900;letter-spacing:2px;font-family:Courier New,monospace;word-break:break-all}.ar-codigo-hint{font-size:.875rem;color:#6b5e6e;margin-top:1rem;margin-bottom:0}.ar-success-info{display:flex;gap:1rem;align-items:flex-start;background:#fffbeb;border-left:4px solid #f59e0b;padding:1.5rem;border-radius:8px;margin:2rem 0;text-align:left}.ar-success-info svg{color:#f59e0b;font-size:1.5rem;flex-shrink:0;margin-top:2px}.ar-success-info p{margin:0;color:#374151;line-height:1.6}.ar-success-actions{margin-top:2rem}.ar-footer{background:#fff;border-radius:12px;padding:1.5rem;margin-top:1.5rem;box-shadow:0 4px 12px #c96b7414;border-top:4px solid #2c2c3e}.ar-footer-content{text-align:center;color:#6b5e6e;font-size:.8125rem;line-height:1.6}.ar-footer-content p{margin:.375rem 0}.ar-footer-content strong{color:#2c2c3e;font-weight:700}.ar-footer-content a{color:#c96b74;text-decoration:underline;font-weight:600}.ar-footer-content a:hover{color:#d4888f}@media(max-width:768px){.ar-page{padding:1rem .5rem}.ar-header h1{font-size:1.5rem}.ar-section{padding:1.25rem}.ar-actions{flex-direction:column}.ar-btn{width:100%;justify-content:center}.ar-codigo-value{font-size:1.75rem}.ar-success{padding:2rem 1.5rem}}.as-page{min-height:100vh;background:#f5ede3;padding:3rem 1rem}.as-container{max-width:1000px;margin:0 auto}.as-header{text-align:center;margin-bottom:3rem}.as-header-icon{width:90px;height:90px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:#c96b74;border-radius:50%;color:#fff;font-size:2.5rem;box-shadow:0 8px 28px #c96b7466}.as-header h1{font-size:clamp(1.8rem,3vw,2.5rem);color:#c96b74;font-weight:900;letter-spacing:-.5px;margin:0 0 .75rem;font-family:Playfair Display,serif}.as-header p{font-size:1rem;color:#6b5e6e;margin:0;line-height:1.6}.as-search-section{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 6px 24px #c96b741f;margin-bottom:2.5rem;border:2px solid rgba(201,107,116,.1)}.as-search-form{display:flex;gap:1rem;margin-bottom:1.5rem}.as-input-wrapper{flex:1;position:relative}.as-input-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:#c96b74;font-size:1.5rem;z-index:1}.as-search-input{width:100%;padding:1.125rem 1.25rem 1.125rem 3.75rem;border:2px solid #e8d9d2;border-radius:12px;font-size:1.125rem;font-weight:700;font-family:Courier New,monospace;letter-spacing:2px;text-transform:uppercase;background:#fdf8f3;transition:border-color .2s,box-shadow .2s}.as-search-input:focus{outline:none;border-color:#c96b74;box-shadow:0 0 0 4px #c96b741f;background:#fff}.as-search-input::placeholder{text-transform:none;font-family:inherit;font-weight:500;letter-spacing:normal;color:#a8969a;font-size:.95rem}.as-search-btn{display:flex;align-items:center;gap:.75rem;padding:1.125rem 2rem;background:#c96b74;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;white-space:nowrap;box-shadow:0 4px 16px #c96b7459;transition:background .2s,transform .2s}.as-search-btn:hover:not(:disabled){background:#d4888f;transform:translateY(-2px)}.as-search-btn:disabled{opacity:.6;cursor:not-allowed}.as-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:asSpin .6s linear infinite}@keyframes asSpin{to{transform:rotate(360deg)}}.as-search-hint{display:flex;gap:1rem;padding:1.25rem;background:#fdf8f3;border-left:4px solid #c96b74;border-radius:10px}.as-search-hint svg{color:#c96b74;font-size:1.5rem;flex-shrink:0;margin-top:2px}.as-search-hint p{margin:0;color:#6b5e6e;line-height:1.7;font-size:.9rem}.as-result{display:flex;flex-direction:column;gap:2rem;animation:asSlideUp .4s ease}@keyframes asSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.as-status-card{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 6px 24px #00000014;border-left:6px solid}.as-status-header{display:flex;align-items:center;gap:1.5rem}.as-status-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:2.5rem;flex-shrink:0}.as-status-header h2{font-size:1.75rem;font-weight:800;color:#2c2c3e;margin:0 0 .5rem;font-family:Playfair Display,serif}.as-status-header p{font-size:1rem;color:#6b5e6e;margin:0;line-height:1.6}.as-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 16px #00000012}.as-card-title{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:#2c2c3e;margin:0 0 1.5rem}.as-card-title svg{color:#c96b74;font-size:1.4rem}.as-timeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}.as-titem{border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;border:2px solid transparent;transition:transform .2s}.as-titem:hover{transform:translateY(-3px)}.as-completed{background:#fdf8f3;border-color:#c96b74}.as-active{background:#eff6ff;border-color:#3b82f6}.as-pending{background:#fffbeb;border-color:#f59e0b}.as-tmarker{width:48px;height:48px;margin:0 auto .5rem;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid #e8d9d2;border-radius:50%;font-size:1.3rem;color:#a8969a}.as-completed .as-tmarker{background:#c96b74;border-color:#c96b74;color:#fff}.as-active .as-tmarker{background:#3b82f6;border-color:#3b82f6;color:#fff}.as-pending .as-tmarker{background:#fef3c7;border-color:#f59e0b;color:#f59e0b}.as-tcontent{text-align:center}.as-ttitle{font-size:1rem;font-weight:700;color:#2c2c3e;margin-bottom:.375rem}.as-tdate{font-size:.875rem;color:#6b5e6e;font-weight:600;margin-bottom:.25rem}.as-tdays{font-size:.8rem;color:#a8969a;font-style:italic}.as-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}.as-detail-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 3px 12px #00000012;display:flex;gap:1.25rem;transition:transform .2s,box-shadow .2s;border:2px solid transparent}.as-detail-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #c96b7426;border-color:#e8b4b8}.as-detail-icon{width:54px;height:54px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fdf8f3;border-radius:12px;color:#c96b74;font-size:1.5rem}.as-detail-label{font-size:.75rem;font-weight:700;color:#a8969a;text-transform:uppercase;letter-spacing:1px;margin-bottom:.375rem}.as-detail-value{font-size:1.1rem;font-weight:700;color:#2c2c3e;word-wrap:break-word}.as-code{font-family:Courier New,monospace;color:#c96b74;background:#fdf8f3;padding:.25rem .75rem;border-radius:6px;display:inline-block;border:1.5px solid rgba(201,107,116,.25)}.as-response-card{border:2px solid #a7f3d0}.as-response-date{font-size:.875rem;color:#6b5e6e;margin-bottom:1rem;font-weight:600}.as-response-content{background:#ecfdf5;padding:1.5rem;border-radius:10px;border-left:4px solid #10b981;font-size:1rem;color:#374151;line-height:1.9;white-space:pre-wrap}.as-contact-card{background:#fdf8f3;border-radius:16px;padding:2rem;border:2px solid #e8d9d2}.as-contact-card p{font-size:.95rem;color:#6b5e6e;margin:0 0 1.5rem;line-height:1.7}.as-contact-methods{display:flex;flex-direction:column;gap:.875rem}.as-contact-item{display:flex;align-items:center;gap:1rem;font-size:1rem;color:#2c2c3e;font-weight:600;background:#fff;padding:1rem;border-radius:10px;transition:transform .2s}.as-contact-item:hover{transform:translate(6px)}.as-contact-item svg{font-size:1.4rem;color:#c96b74}.as-action-btns{display:flex;justify-content:center;margin-top:1rem}.as-btn-new{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:#fff;color:#c96b74;border:2px solid #c96b74;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s}.as-btn-new:hover{background:#c96b74;color:#fff;transform:translateY(-2px)}.as-info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.as-info-card{background:#fff;border-radius:16px;padding:2rem 1.5rem;box-shadow:0 4px 16px #00000014;text-align:center;transition:transform .2s,box-shadow .2s;border:2px solid transparent}.as-info-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px #c96b7426;border-color:#e8b4b8}.as-info-icon{width:68px;height:68px;margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center;background:#fdf8f3;border-radius:50%;color:#c96b74;font-size:2rem}.as-info-card h3{font-size:1.1rem;color:#2c2c3e;margin:0 0 .75rem;font-weight:700}.as-info-card p{font-size:.875rem;color:#6b5e6e;margin:0;line-height:1.6}.as-footer{background:#fff;border-radius:16px;padding:2rem;margin-top:3rem;text-align:center;box-shadow:0 4px 16px #00000012;border-top:4px solid #2c1f28}.as-footer p{margin:.375rem 0;color:#6b5e6e;font-size:.875rem;line-height:1.7}.as-footer strong{color:#2c2c3e;font-weight:700}.as-footer a{color:#c96b74;text-decoration:underline;font-weight:600}.as-footer a:hover{color:#d4888f}@media(max-width:768px){.as-page{padding:2rem .75rem}.as-search-form{flex-direction:column}.as-search-btn{width:100%;justify-content:center}.as-status-header{flex-direction:column;text-align:center}.as-timeline,.as-details-grid,.as-info-cards{grid-template-columns:1fr}}.webcontent-page{padding:2rem;max-width:1100px}.wc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.wc-header-info{display:flex;align-items:center;gap:1rem}.wc-header-icon{width:52px;height:52px;background:linear-gradient(135deg,#2c1f28,#c96b74);border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;flex-shrink:0}.wc-header-info h1{font-size:1.5rem;font-weight:800;color:#2c1f28;margin:0 0 .2rem}.wc-header-info p{font-size:.875rem;color:#78717a;margin:0}.btn-wc-new{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#c96b74,#e8b4b8);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #c96b744d}.btn-wc-new:hover{transform:translateY(-2px);box-shadow:0 6px 18px #c96b7466}.wc-form-card{background:#fff;border-radius:18px;box-shadow:0 4px 24px #2c1f281a;margin-bottom:2rem;overflow:hidden;border:1px solid #f0e5dc}.wc-form-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.75rem;background:linear-gradient(135deg,#2c1f28,#4a3040);color:#fff}.wc-form-header h2{font-size:1.1rem;font-weight:700;margin:0}.wc-form-close{background:#ffffff26;border:none;color:#fff;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background .2s}.wc-form-close:hover{background:#ffffff40}.wc-form{padding:1.75rem}.wc-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.5rem}.wc-field{display:flex;flex-direction:column;gap:.4rem}.wc-field.full{grid-column:1 / -1}.wc-field label{font-size:.8rem;font-weight:700;color:#4a3040;text-transform:uppercase;letter-spacing:.05em}.wc-field input,.wc-field textarea,.wc-field select{padding:.65rem .9rem;border:1.5px solid #e8ddd5;border-radius:9px;font-size:.9rem;color:#2c1f28;background:#fdf8f3;transition:border-color .2s;font-family:inherit}.wc-field input:focus,.wc-field textarea:focus,.wc-field select:focus{outline:none;border-color:#c96b74;background:#fff}.wc-color-row{display:flex;gap:.5rem;align-items:center}.wc-color-row input[type=color]{width:44px;height:38px;padding:2px;border-radius:8px;cursor:pointer;flex-shrink:0}.wc-color-row input[type=text]{flex:1}.wc-checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:.6rem;cursor:pointer;font-size:.875rem!important;font-weight:500!important;text-transform:none!important;letter-spacing:0!important;color:#4a3040!important}.wc-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#c96b74}.wc-img-preview{width:100%;max-height:120px;object-fit:cover;border-radius:8px;margin-top:.4rem;border:1px solid #e8ddd5}.wc-preview{background:#f8f4f0;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.wc-preview-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#78717a;display:block;margin-bottom:.75rem}.wc-popup-preview{max-width:360px;margin:0 auto;border-radius:16px;padding:1.5rem;box-shadow:0 8px 32px #0003;text-align:center}.wc-popup-preview img{width:100%;border-radius:10px;margin-bottom:1rem;max-height:140px;object-fit:cover}.wc-popup-preview h3{font-size:1.1rem;font-weight:800;margin:0 0 .5rem}.wc-popup-preview p{font-size:.875rem;margin:0 0 1rem;opacity:.9;line-height:1.5}.wc-popup-preview button{padding:.6rem 1.5rem;border:none;border-radius:999px;font-weight:700;font-size:.85rem;cursor:default}.wc-form-actions{display:flex;justify-content:flex-end;gap:1rem}.btn-wc-cancel{padding:.7rem 1.5rem;background:#f1ece8;border:none;border-radius:10px;color:#4a3040;font-weight:600;cursor:pointer;transition:background .2s}.btn-wc-cancel:hover{background:#e8ddd5}.btn-wc-save{display:flex;align-items:center;gap:.5rem;padding:.7rem 1.75rem;background:linear-gradient(135deg,#2c1f28,#c96b74);color:#fff;border:none;border-radius:10px;font-weight:700;cursor:pointer;transition:all .2s}.btn-wc-save:hover{transform:translateY(-1px);box-shadow:0 4px 14px #c96b7459}.wc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.wc-card{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 2px 12px #2c1f2814;border:1.5px solid #f0e5dc;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column;gap:.6rem}.wc-card:hover{box-shadow:0 6px 24px #2c1f281f;transform:translateY(-2px)}.wc-card.inactive{opacity:.65}.wc-card-header{display:flex;align-items:center;gap:.6rem}.wc-card-color-dot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(0,0,0,.1);flex-shrink:0}.wc-status{font-size:.72rem;font-weight:700}.wc-status.active{color:#16a34a}.wc-status.inactive{color:#94a3b8}.wc-card-pagina{margin-left:auto;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:#f0e5dc;color:#4a3040;padding:.2rem .55rem;border-radius:999px}.wc-card-img{width:100%;height:100px;object-fit:cover;border-radius:10px;border:1px solid #f0e5dc}.wc-card-title{font-size:1rem;font-weight:800;color:#2c1f28;margin:0;line-height:1.3}.wc-card-msg{font-size:.82rem;color:#78717a;margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.wc-card-dates,.wc-card-link{display:flex;align-items:center;gap:.4rem;font-size:.76rem;color:#94a3b8}.wc-card-link .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}.wc-card-actions{display:flex;gap:.5rem;margin-top:auto;padding-top:.5rem;border-top:1px solid #f0e5dc}.wc-btn-toggle,.wc-btn-edit,.wc-btn-delete{flex:1;height:36px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s}.wc-btn-toggle{background:#f0e5dc;color:#4a3040}.wc-btn-toggle:hover{background:#e8ddd5}.wc-btn-edit{background:#eff6ff;color:#2563eb}.wc-btn-edit:hover{background:#dbeafe}.wc-btn-delete{background:#fef2f2;color:#dc2626}.wc-btn-delete:hover{background:#fee2e2}.wc-loading,.wc-empty{text-align:center;padding:4rem 2rem;color:#78717a}.wc-empty svg{font-size:3rem;color:#e8b4b8;margin-bottom:1rem}.wc-empty h3{font-size:1.2rem;color:#2c1f28;margin:0 0 .5rem}.wc-empty p{margin:0 0 1.5rem}.wc-positions-guide{background:#fff;border:1.5px solid #f0e5dc;border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1.75rem}.wc-positions-guide h3{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:700;color:#4a3040;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.wc-positions-grid{display:flex;flex-wrap:wrap;gap:.6rem}.wc-position-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#78717a}.wc-pos-badge{background:#f0e5dc;color:#4a3040;font-size:.68rem;font-weight:700;padding:.2rem .55rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.wc-pos-badge.gold{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#78350f}.wc-posicion-grupo{margin-bottom:2rem}.wc-posicion-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1.5px solid #f0e5dc}.wc-pos-count{margin-left:auto;font-size:.75rem;color:#94a3b8;font-weight:600}.wc-banner-preview{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.25rem;border-radius:10px;max-width:100%}.wc-banner-preview-content{display:flex;flex-direction:column;gap:.2rem}.wc-banner-preview strong{font-size:.9rem;font-weight:700}.wc-banner-preview span{font-size:.78rem;opacity:.85}.wc-banner-preview button{padding:.45rem 1.1rem;border:none;border-radius:999px;font-weight:700;font-size:.78rem;cursor:default;white-space:nowrap;flex-shrink:0}.wc-mini-banner{padding:.6rem .9rem;border-radius:8px;display:flex;align-items:center;justify-content:space-between;font-size:.78rem;gap:.5rem}.wc-mini-banner strong{font-weight:700}.wc-mini-banner span{opacity:.85;white-space:nowrap}:root{--av-blue: #1c3557;--av-blue2: #2563eb;--av-blue3: #3b82f6;--av-purple: #7c3aed;--av-green: #10b981;--av-bg: #f0f4f8;--av-card: #ffffff;--av-border: #e2e8f0;--av-text: #1e293b;--av-muted: #64748b;--av-light: #f8fafc}.ar-page{min-height:100vh;background:var(--av-bg);font-family:Inter,sans-serif;color:var(--av-text)}.ar-container{max-width:900px;margin:0 auto;padding:32px 24px 60px}.ar-hero{position:relative;padding:48px 24px 40px;overflow:hidden;background:linear-gradient(135deg,#1c3557,#2563eb 60%,#3b82f6)}.ar-hero-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 80% 50%,rgba(124,58,237,.25) 0%,transparent 60%),radial-gradient(ellipse at 10% 80%,rgba(16,185,129,.15) 0%,transparent 50%)}.ar-hero-content{max-width:900px;margin:0 auto;position:relative;z-index:1}.ar-hero-pill{display:inline-flex;align-items:center;gap:7px;padding:5px 14px;border-radius:100px;background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#ffffffe6;font-size:.75rem;font-weight:600;letter-spacing:.06em;margin-bottom:16px}.ar-hero-content h1{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;color:#fff;margin:0 0 12px;line-height:1.2}.ar-hero-content p{color:#ffffffb3;font-size:.93rem;max-width:520px;margin:0}.ar-back{display:inline-flex;align-items:center;gap:7px;background:none;border:none;cursor:pointer;color:var(--av-muted);font-size:.85rem;font-weight:600;padding:0;margin-bottom:24px;transition:color .2s}.ar-back:hover{color:var(--av-blue2)}.ar-section-title{display:flex;align-items:center;gap:14px;margin-bottom:24px}.ar-st-icon{width:48px;height:48px;border-radius:12px;flex-shrink:0;background:linear-gradient(135deg,var(--av-blue),var(--av-blue2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;box-shadow:0 4px 12px #2563eb59}.ar-st-icon--purple{background:linear-gradient(135deg,var(--av-purple),#a855f7);box-shadow:0 4px 12px #7c3aed59}.ar-section-title h2{font-size:1.25rem;font-weight:800;color:var(--av-blue);margin:0 0 3px}.ar-section-title p{font-size:.82rem;color:var(--av-muted);margin:0}.ar-cards-menu{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.ar-card-menu{background:var(--av-card);border:1.5px solid var(--av-border);border-radius:16px;padding:28px 24px;text-align:left;cursor:pointer;transition:transform .22s,box-shadow .22s,border-color .22s;display:flex;flex-direction:column;gap:16px;box-shadow:0 2px 8px #0000000a}.ar-card-menu:hover{transform:translateY(-4px);box-shadow:0 12px 28px #2563eb1f;border-color:var(--av-blue3)}.ar-cm-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;flex-shrink:0}.ar-cm-icon--blue{background:linear-gradient(135deg,#1c3557,#2563eb);box-shadow:0 4px 14px #2563eb59}.ar-cm-icon--purple{background:linear-gradient(135deg,#5b21b6,#7c3aed);box-shadow:0 4px 14px #7c3aed59}.ar-cm-body h2{font-size:1.05rem;font-weight:800;color:var(--av-blue);margin:0 0 8px}.ar-cm-body p{font-size:.82rem;color:var(--av-muted);line-height:1.6;margin:0 0 14px}.ar-cm-cta{display:inline-flex;align-items:center;gap:5px;font-size:.83rem;font-weight:700;color:var(--av-blue2)}.ar-cm-cta--purple{color:var(--av-purple)}.ar-legal-box{display:flex;align-items:flex-start;gap:12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;padding:16px 18px;font-size:.82rem;color:#1e40af;line-height:1.6}.ar-legal-box svg{color:var(--av-blue2);flex-shrink:0;margin-top:2px;font-size:1rem}.ar-legal-box--form{margin-bottom:24px}.ar-exito-wrap{display:flex;justify-content:center;padding-top:48px}.ar-exito-card{background:var(--av-card);border:1.5px solid var(--av-border);border-radius:20px;padding:48px 40px;text-align:center;max-width:520px;width:100%;box-shadow:0 8px 24px #2563eb1a}.ar-exito-icon{width:72px;height:72px;border-radius:50%;margin:0 auto 20px;background:linear-gradient(135deg,#d1fae5,#a7f3d0);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--av-green)}.ar-exito-card h2{font-size:1.4rem;font-weight:800;color:var(--av-blue);margin:0 0 10px}.ar-exito-card>p{font-size:.88rem;color:var(--av-muted);margin:0 0 24px}.ar-exito-codigo{background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:12px;padding:16px 20px;margin-bottom:16px}.ar-exito-codigo span{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--av-muted);margin-bottom:6px}.ar-exito-codigo strong{font-size:1.4rem;font-weight:800;color:var(--av-blue);letter-spacing:.05em}.ar-exito-nota{font-size:.8rem;color:var(--av-muted);margin:0 0 28px}.ar-exito-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.ar-consulta-card{background:var(--av-card);border:1.5px solid var(--av-border);border-radius:16px;padding:28px;box-shadow:0 2px 8px #0000000a}.ar-consulta-form{margin-bottom:0}.ar-ci-wrap{display:flex;align-items:center;gap:10px;position:relative;margin-bottom:12px}.ar-ci-ico{position:absolute;left:14px;color:var(--av-muted);font-size:.95rem;pointer-events:none}.ar-ci-input{flex:1;padding:12px 12px 12px 40px;border:1.5px solid var(--av-border);border-radius:10px;font-size:.9rem;font-family:inherit;color:var(--av-text);background:var(--av-light);outline:none;transition:border-color .2s,box-shadow .2s}.ar-ci-input:focus{border-color:var(--av-blue2);box-shadow:0 0 0 3px #2563eb1a}.ar-resultado{margin-top:24px;border-top:1.5px solid var(--av-border);padding-top:24px}.ar-res-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:20px}.ar-res-cod{font-size:1.1rem;font-weight:800;color:var(--av-blue);margin-bottom:4px}.ar-res-fecha-reg{font-size:.8rem;color:var(--av-muted)}.ar-res-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:100px;font-size:.8rem;font-weight:700}.ar-res-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.ar-res-item{background:var(--av-light);border:1px solid var(--av-border);border-radius:10px;padding:12px 14px}.ar-res-item span{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--av-muted);margin-bottom:4px}.ar-res-item strong{font-size:.88rem;color:var(--av-text);font-weight:700}.ar-res-respuesta{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:12px;padding:18px 20px}.ar-res-resp-head{display:flex;align-items:center;gap:7px;font-size:.82rem;font-weight:700;color:var(--av-green);margin-bottom:10px}.ar-res-resp-head span{font-weight:400;color:var(--av-muted)}.ar-res-respuesta p{font-size:.88rem;color:var(--av-text);line-height:1.7;margin:0}.ar-res-pending{display:flex;align-items:center;gap:8px;background:#fef9c3;border:1px solid #fde68a;border-radius:10px;padding:14px 16px;font-size:.84rem;color:#92400e}.ar-alert{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:10px;font-size:.84rem;margin-bottom:20px}.ar-alert--error{background:#fef2f2;border:1px solid #fca5a5;color:#dc2626}.ar-form{display:flex;flex-direction:column;gap:20px}.ar-form-section{background:var(--av-card);border:1.5px solid var(--av-border);border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000a}.ar-fs-header{display:flex;align-items:center;gap:14px;padding:18px 24px;border-bottom:1.5px solid var(--av-border);background:var(--av-light)}.ar-fs-num{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--av-blue),var(--av-blue2));color:#fff;font-size:.85rem;font-weight:800;display:flex;align-items:center;justify-content:center}.ar-fs-header h3{font-size:.95rem;font-weight:800;color:var(--av-blue);margin:0 0 2px}.ar-fs-header p{font-size:.78rem;color:var(--av-muted);margin:0}.ar-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:20px 24px}.ar-fg{display:flex;flex-direction:column;gap:6px}.ar-fg--full{grid-column:1 / -1}.ar-fg label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--av-muted)}.ar-fg input,.ar-fg select,.ar-fg textarea{width:100%;padding:10px 13px;border:1.5px solid var(--av-border);border-radius:9px;font-size:.87rem;font-family:inherit;color:var(--av-text);background:var(--av-light);outline:none;transition:border-color .2s,box-shadow .2s}.ar-fg input:focus,.ar-fg select:focus,.ar-fg textarea:focus{border-color:var(--av-blue2);box-shadow:0 0 0 3px #2563eb14;background:#fff}.ar-fg input.err,.ar-fg select.err,.ar-fg textarea.err{border-color:#fca5a5;background:#fff5f5}.ar-fg textarea{resize:vertical;line-height:1.6}.ar-err{display:flex;align-items:center;gap:4px;font-size:.73rem;color:#dc2626;font-weight:500}.ar-checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:8px;cursor:pointer;font-size:.85rem!important;font-weight:500!important;text-transform:none!important;letter-spacing:0!important;color:var(--av-text)!important}.ar-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--av-blue2)}.ar-radio-group{display:flex;flex-direction:column;gap:10px;grid-column:1 / -1}.ar-radio{display:flex;flex-direction:column;gap:3px;padding:14px 16px;border-radius:10px;border:1.5px solid var(--av-border);cursor:pointer;transition:border-color .2s,background .2s;background:var(--av-light)}.ar-radio input{display:none}.ar-radio.active{border-color:var(--av-blue2);background:#eff6ff}.ar-radio strong{font-size:.9rem;color:var(--av-blue)}.ar-radio span{font-size:.78rem;color:var(--av-muted)}.ar-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:10px;border:none;cursor:pointer;background:linear-gradient(135deg,#1c3557,#2563eb);color:#fff;font-size:.87rem;font-weight:700;font-family:inherit;box-shadow:0 4px 14px #2563eb59;transition:transform .2s,box-shadow .2s}.ar-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 18px #2563eb73}.ar-btn-primary:disabled{opacity:.55;cursor:not-allowed}.ar-btn-submit{padding:14px 32px;font-size:.92rem}.ar-btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:10px;cursor:pointer;background:var(--av-card);border:1.5px solid var(--av-border);color:var(--av-muted);font-size:.87rem;font-weight:600;font-family:inherit;transition:border-color .2s,color .2s}.ar-btn-ghost:hover:not(:disabled){border-color:var(--av-blue2);color:var(--av-blue2)}.ar-btn-ghost:disabled{opacity:.55;cursor:not-allowed}.ar-form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:4px;flex-wrap:wrap}.ar-spin{display:inline-block;width:16px;height:16px;border-radius:50%;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;animation:arSpin .8s linear infinite}@keyframes arSpin{to{transform:rotate(360deg)}}@media(max-width:700px){.ar-cards-menu,.ar-form-grid,.ar-res-grid{grid-template-columns:1fr}.ar-container{padding:20px 16px 48px}.ar-hero{padding:36px 16px 30px}.ar-exito-card{padding:32px 20px}.ar-form-section .ar-form-grid{padding:16px}.ar-form-actions{justify-content:stretch}.ar-form-actions button{flex:1;justify-content:center}.ar-ci-wrap{flex-wrap:wrap}.ar-ci-input{min-width:0}}.ara-page{padding:28px;background:#f0f4f8;min-height:100vh;font-family:Inter,sans-serif}.ara-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:300px;color:#64748b;font-size:.9rem}.ara-spinner{width:36px;height:36px;border-radius:50%;border:3px solid #dbeafe;border-top-color:#2563eb;animation:araSpin .8s linear infinite}@keyframes araSpin{to{transform:rotate(360deg)}}.ara-spin{display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:araSpin .8s linear infinite}.ara-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.ara-header-left{display:flex;align-items:center;gap:14px}.ara-header-icon{width:48px;height:48px;border-radius:12px;flex-shrink:0;background:linear-gradient(135deg,#1c3557,#2563eb);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;box-shadow:0 4px 12px #2563eb59}.ara-header h1{font-size:1.3rem;font-weight:800;color:#1e293b;margin:0 0 2px}.ara-header p{font-size:.8rem;color:#64748b;margin:0}.ara-btn-refresh{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:9px;border:1.5px solid #e2e8f0;background:#fff;color:#64748b;font-size:.83rem;font-weight:600;cursor:pointer;transition:all .2s}.ara-btn-refresh:hover{border-color:#2563eb;color:#2563eb}.ara-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.ara-stat{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:20px 18px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000a}.ara-stat:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;border-radius:0 0 14px 14px}.ara-stat--default:after{background:#2563eb}.ara-stat--warn:after{background:#f59e0b}.ara-stat--blue:after{background:#3b82f6}.ara-stat--green:after{background:#10b981}.ara-stat-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:4px}.ara-stat--default .ara-stat-icon{background:#dbeafe;color:#2563eb}.ara-stat--warn .ara-stat-icon{background:#fef3c7;color:#f59e0b}.ara-stat--blue .ara-stat-icon{background:#dbeafe;color:#3b82f6}.ara-stat--green .ara-stat-icon{background:#d1fae5;color:#10b981}.ara-stat-val{font-size:1.9rem;font-weight:800;color:#1e293b;line-height:1}.ara-stat-lbl{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.06em}.ara-toolbar{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.ara-search{flex:1;min-width:240px;display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:0 14px}.ara-search svg{color:#94a3b8;flex-shrink:0}.ara-search input{flex:1;border:none;outline:none;padding:11px 0;font-size:.87rem;font-family:inherit;color:#1e293b;background:transparent}.ara-filters{display:flex;gap:10px;flex-wrap:wrap}.ara-filter-wrap{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:0 12px}.ara-filter-wrap svg{color:#94a3b8;font-size:.85rem}.ara-filter-wrap select{border:none;outline:none;padding:10px 0;background:transparent;font-size:.84rem;font-family:inherit;color:#1e293b;cursor:pointer}.ara-results-info{font-size:.82rem;color:#64748b;margin-bottom:16px}.ara-table-wrap{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;box-shadow:0 2px 8px #0000000a}.ara-table{width:100%;border-collapse:collapse}.ara-table thead tr{background:#f8fafc;border-bottom:1.5px solid #e2e8f0}.ara-table th{padding:12px 16px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#64748b}.ara-table td{padding:14px 16px;border-bottom:1px solid #f1f5f9;font-size:.84rem}.ara-table tr:last-child td{border-bottom:none}.ara-table tr:hover td{background:#f8fafc}.ara-row-urgent td{background:#fff7ed!important}.ara-row-urgent:hover td{background:#fef3c7!important}.ara-cod-cell{display:flex;align-items:center;gap:6px}.ara-cod-cell span{font-weight:700;color:#1c3557;font-size:.82rem}.ara-urg-dot{width:18px;height:18px;border-radius:50%;background:#dc2626;color:#fff;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center}.ara-client-cell{display:flex;align-items:center;gap:10px}.ara-avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,#1c3557,#2563eb);color:#fff;font-size:.72rem;font-weight:800;display:flex;align-items:center;justify-content:center}.ara-client-name{font-weight:600;color:#1e293b;font-size:.84rem}.ara-client-doc{font-size:.74rem;color:#94a3b8}.ara-tipo-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:.75rem;font-weight:700;border:1px solid;white-space:nowrap}.ara-detalle{color:#64748b;max-width:220px}.ara-muted{color:#94a3b8;font-size:.8rem;white-space:nowrap}.ara-estado-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:100px;font-size:.75rem;font-weight:700;white-space:nowrap}.badge-warn{background:#fef3c7;color:#92400e}.badge-blue{background:#dbeafe;color:#1e40af}.badge-green{background:#d1fae5;color:#065f46}.badge-gray{background:#f3f4f6;color:#374151}.ara-days{font-size:.8rem;font-weight:600;color:#64748b}.ara-days.urgent{color:#dc2626}.ara-btn-view{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1.5px solid #dbeafe;background:#eff6ff;color:#2563eb;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s}.ara-btn-view:hover{background:#2563eb;color:#fff;border-color:#2563eb}.ara-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px;color:#94a3b8}.ara-empty svg{font-size:2.5rem;opacity:.4}.ara-empty h3{font-size:1rem;font-weight:700;color:#64748b;margin:0}.ara-empty p{font-size:.84rem;margin:0}.ara-modal{display:flex;flex-direction:column;gap:0}.ara-modal-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1.5px solid #e2e8f0;background:linear-gradient(135deg,#1c3557,#2563eb);border-radius:8px 8px 0 0;flex-wrap:wrap;gap:12px}.ara-modal-head-left{display:flex;align-items:center;gap:12px}.ara-modal-icon{width:40px;height:40px;border-radius:10px;background:#ffffff26;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.ara-modal-head h2{font-size:1rem;font-weight:800;color:#fff;margin:0 0 2px}.ara-modal-head p{font-size:.78rem;color:#ffffffb3;margin:0}.ara-estado-badge-lg{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:100px;font-size:.8rem;font-weight:700}.ara-tabs{display:flex;border-bottom:1.5px solid #e2e8f0;background:#f8fafc}.ara-tab{display:flex;align-items:center;gap:7px;position:relative;padding:13px 20px;border:none;background:none;cursor:pointer;font-size:.84rem;font-weight:600;color:#64748b;font-family:inherit;transition:color .2s;border-bottom:2.5px solid transparent;margin-bottom:-1.5px}.ara-tab:hover{color:#2563eb}.ara-tab.active{color:#2563eb;border-bottom-color:#2563eb}.ara-tab-dot{width:7px;height:7px;border-radius:50%;background:#dc2626;position:absolute;top:10px;right:10px}.ara-modal-body{padding:24px;overflow-y:auto;max-height:420px}.ara-tab-content{display:flex;flex-direction:column;gap:20px}.ara-section-lbl{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#1c3557;margin:0;padding-bottom:8px;border-bottom:1.5px solid #e2e8f0}.ara-section-lbl--blue{color:#2563eb;border-color:#bfdbfe}.ara-section-lbl--warn{color:#92400e;border-color:#fde68a}.ara-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ara-info-card{display:flex;align-items:flex-start;gap:10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px}.ara-info-card--full{grid-column:1 / -1}.ara-info-ic{width:30px;height:30px;border-radius:8px;background:#dbeafe;color:#2563eb;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}.ara-info-lbl{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;margin-bottom:3px}.ara-info-val{display:block;font-size:.87rem;font-weight:600;color:#1e293b;line-height:1.5}.ara-price{color:#059669;font-size:1rem!important;font-weight:800!important}.ara-timeline{display:flex;flex-direction:column;gap:12px}.ara-tl-item{display:flex;align-items:center;gap:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px}.ara-tl-ic{width:30px;height:30px;border-radius:8px;background:#dbeafe;color:#2563eb;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}.ara-tl-ic--green{background:#d1fae5;color:#10b981}.ara-tl-item span{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8}.ara-tl-item strong{display:block;font-size:.87rem;font-weight:700;color:#1e293b}.ara-urgent-text{color:#dc2626!important}.ara-desc-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;font-size:.87rem;color:#1e293b;line-height:1.7}.ara-desc-box--blue{background:#eff6ff;border-color:#bfdbfe}.ara-desc-box--warn{background:#fffbeb;border-color:#fde68a}.ara-legal-note{display:flex;align-items:center;gap:8px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:12px 14px;font-size:.82rem;color:#1e40af}.ara-existing-resp{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:12px;padding:16px 18px}.ara-er-head{display:flex;align-items:center;gap:10px;margin-bottom:10px;color:#10b981}.ara-er-head svg{font-size:1.1rem;flex-shrink:0}.ara-er-head h4{font-size:.88rem;font-weight:800;margin:0 0 2px;color:#065f46}.ara-er-head span{font-size:.75rem;color:#6b7280}.ara-existing-resp p{font-size:.86rem;color:#1e293b;line-height:1.7;margin:0}.ara-resp-form{display:flex;flex-direction:column;gap:10px}.ara-resp-label{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#64748b}.ara-resp-select,.ara-resp-textarea{width:100%;padding:10px 13px;border:1.5px solid #e2e8f0;border-radius:9px;font-size:.87rem;font-family:inherit;color:#1e293b;background:#f8fafc;outline:none;transition:border-color .2s,box-shadow .2s}.ara-resp-select:focus,.ara-resp-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb14;background:#fff}.ara-resp-textarea{resize:vertical;line-height:1.6}.ara-resp-meta{display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px;font-size:.74rem;color:#94a3b8}.ara-resp-meta span{display:flex;align-items:center;gap:5px}.ara-templates{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px}.ara-tpl-title{font-size:.8rem;font-weight:700;color:#64748b;margin:0 0 10px}.ara-tpl-grid{display:flex;gap:8px;flex-wrap:wrap}.ara-tpl-btn{padding:7px 14px;border-radius:8px;border:1.5px solid #dbeafe;background:#eff6ff;color:#2563eb;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .2s}.ara-tpl-btn:hover{background:#2563eb;color:#fff;border-color:#2563eb}.ara-resp-warning{display:flex;align-items:flex-start;gap:10px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:14px 16px;font-size:.8rem;color:#92400e}.ara-resp-warning svg{flex-shrink:0;margin-top:2px}.ara-resp-warning ul{margin:0;padding-left:16px;line-height:1.8}.ara-modal-foot{display:flex;gap:20px;flex-wrap:wrap;padding:10px 24px;background:#f8fafc;border-top:1px solid #e2e8f0;font-size:.72rem;color:#94a3b8}.ara-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:14px 24px;border-top:1.5px solid #e2e8f0}.ara-btn-cancel{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:9px;border:1.5px solid #e2e8f0;background:#fff;color:#64748b;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.ara-btn-cancel:hover:not(:disabled){border-color:#94a3b8;color:#1e293b}.ara-btn-send{display:inline-flex;align-items:center;gap:7px;padding:10px 24px;border-radius:9px;border:none;background:linear-gradient(135deg,#1c3557,#2563eb);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit;box-shadow:0 4px 12px #2563eb59}.ara-btn-send:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #2563eb73}.ara-btn-send:disabled,.ara-btn-cancel:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.ara-page{padding:16px}.ara-stats{grid-template-columns:1fr 1fr}.ara-toolbar{flex-direction:column}.ara-search{min-width:unset}.ara-info-grid{grid-template-columns:1fr}.ara-modal-body{max-height:300px}.ara-table-wrap{overflow-x:auto}.ara-table{min-width:700px}}.ara-report{display:flex;flex-direction:column;gap:1.5rem}.ara-report-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.ara-kpi{display:flex;flex-direction:column;align-items:center;padding:1.5rem 1rem;border-radius:16px;border:2px solid;text-align:center;gap:.5rem}.ara-kpi-icon{font-size:1.75rem}.ara-kpi-val{font-size:1.75rem;font-weight:800;color:#0f172a}.ara-kpi-lbl{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase}.ara-kpi--blue{border-color:#3b82f6;background:#eff6ff}.ara-kpi--blue .ara-kpi-icon{color:#3b82f6}.ara-kpi--green{border-color:#10b981;background:#f0fdf4}.ara-kpi--green .ara-kpi-icon{color:#10b981}.ara-kpi--warn{border-color:#f59e0b;background:#fffbeb}.ara-kpi--warn .ara-kpi-icon{color:#f59e0b}.ara-kpi--purple{border-color:#8b5cf6;background:#f5f3ff}.ara-kpi--purple .ara-kpi-icon{color:#8b5cf6}.ara-kpi--teal{border-color:#06b6d4;background:#ecfeff}.ara-kpi--teal .ara-kpi-icon{color:#06b6d4}.ara-report-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1.5rem}.ara-report-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem}.ara-report-card h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:800;color:#0f172a;margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:2px solid #f1f5f9}.ara-report-card--wide{grid-column:span 1}.ara-bar-chart{display:flex;align-items:flex-end;gap:.75rem;height:160px;padding:.5rem 0}.ara-bar-col{display:flex;flex-direction:column;align-items:center;flex:1;height:100%}.ara-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end}.ara-bar-fill{width:100%;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:6px 6px 0 0;min-height:4px;display:flex;align-items:flex-start;justify-content:center;transition:height .4s ease;position:relative}.ara-bar-num{font-size:.75rem;font-weight:800;color:#fff;margin-top:4px}.ara-bar-label{font-size:.75rem;color:#64748b;font-weight:600;margin-top:.5rem}.ara-donut-wrap{display:flex;justify-content:center;margin-bottom:1rem}.ara-donut{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center}.ara-donut-inner{width:80px;height:80px;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}.ara-donut-pct{font-size:1.25rem;font-weight:800;color:#0f172a}.ara-donut-sub{font-size:.7rem;color:#64748b}.ara-legend{display:flex;flex-direction:column;gap:.5rem}.ara-legend-item{display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-weight:600}.ara-legend-dot{width:12px;height:12px;border-radius:4px;flex-shrink:0}.ara-legend-item strong{margin-left:auto;color:#0f172a}.ara-estado-bar{margin-bottom:1rem}.ara-eb-header{display:flex;justify-content:space-between;font-size:.875rem;margin-bottom:.4rem}.ara-eb-track{height:8px;background:#f1f5f9;border-radius:99px;overflow:hidden}.ara-eb-fill{height:100%;border-radius:99px;transition:width .4s ease}.ara-report-table-card{margin-top:0}.ara-report-table{width:100%;border-collapse:collapse}.ara-report-table th{padding:.75rem 1rem;background:#eff6ff;font-size:.8rem;font-weight:800;color:#1e40af;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #bfdbfe;text-align:left}.ara-report-table td{padding:.75rem 1rem;border-bottom:1px solid #f1f5f9;font-size:.9rem}.ara-report-table tbody tr:hover{background:#f8fafc}.ara-rpt-num{font-weight:800;color:#3b82f6}.ara-pct-cell{display:flex;align-items:center;gap:.75rem}.ara-pct-bar{height:8px;background:#3b82f6;border-radius:99px;min-width:2px;max-width:80px}@media(max-width:1200px){.ara-report-kpis{grid-template-columns:repeat(3,1fr)}.ara-report-grid{grid-template-columns:1fr 1fr}}@media(max-width:768px){.ara-report-kpis{grid-template-columns:repeat(2,1fr)}.ara-report-grid{grid-template-columns:1fr}}.ara-btn-print{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-weight:700;font-size:.9375rem;border:none;cursor:pointer;transition:all .3s}.ara-btn-print:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ef444459}@media print{nav,aside,header,.aula-sidebar,.aula-nav,.aula-layout-sidebar,[class*=sidebar],[class*=navbar],[class*=nav-]{display:none!important}.ara-header,.ara-stats,.ara-toolbar,.ara-results-info,.ara-table-wrap,.ara-btn-print,.ara-btn-refresh{display:none!important}.ara-page{display:block!important;padding:0!important}.ara-report{display:flex!important;flex-direction:column!important}body,#root,[class*=layout],[class*=content]{background:#fff!important;padding:0!important;margin:0!important}@page{size:A4;margin:15mm}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.ara-report-card{break-inside:avoid;page-break-inside:avoid}.ara-report-kpis{break-inside:avoid}.ara-report-grid{grid-template-columns:1fr 1fr!important}.ara-report-kpis{grid-template-columns:repeat(5,1fr)!important}.ara-report:before{content:"Reporte — Libro de Reclamaciones · Encantos Academia";display:block;font-size:1.25rem;font-weight:800;color:#1c3557;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:3px solid #1c3557}}.admin-snacks-invoices-page{min-height:100vh;background:#f3f4f6;padding:2rem}.invoices-container{max-width:1400px;margin:0 auto}.invoices-header{background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:1.5rem}.header-icon{width:60px;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px}.invoices-header h1{margin:0;font-size:1.75rem;color:#1f2937}.invoices-header p{margin:.25rem 0 0;color:#6b7280;font-size:.95rem}.ambiente-badge .badge-ambiente{padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600}.badge-ambiente.demo{background:#fef3c7;color:#92400e}.badge-ambiente.produccion{background:#d1fae5;color:#065f46}.invoices-tabs{display:flex;gap:1rem;margin-bottom:2rem}.tab-btn{flex:1;padding:1rem 1.5rem;background:#fff;border:none;border-radius:12px;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000000d}.tab-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea66}.tab-btn svg{font-size:1.25rem}.invoices-content{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 6px #0000001a;min-height:500px}.loading-invoices{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem}.spinner-large{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.filters-card{background:#f9fafb;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:#374151}.filter-input{padding:.625rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s}.filter-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-filter{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:500;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s;margin-left:auto}.btn-filter:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.empty-state{text-align:center;padding:4rem 2rem;color:#6b7280}.empty-state svg{font-size:4rem;color:#d1d5db;margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;color:#374151;font-size:1.25rem}.empty-state p{margin:0;font-size:.95rem}.comprobantes-table{overflow-x:auto}.comprobantes-table table{width:100%;border-collapse:collapse}.comprobantes-table thead{background:#f9fafb}.comprobantes-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.comprobantes-table td{padding:1rem;border-bottom:1px solid #e5e7eb;font-size:.875rem;color:#1f2937}.comprobantes-table tbody tr:hover{background:#f9fafb}.tipo-badge{padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;display:inline-block}.tipo-badge.tipo-1{background:#dbeafe;color:#1e40af}.tipo-badge.tipo-2{background:#fce7f3;color:#be185d}.estado-badge{padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;display:inline-block}.font-mono{font-family:Courier New,monospace;font-weight:600}.font-bold{font-weight:700}.action-buttons{display:flex;gap:.5rem}.action-btn{width:32px;height:32px;border:none;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:1rem}.action-btn.view{background:#dbeafe;color:#1e40af}.action-btn.view:hover{background:#bfdbfe}.action-btn.download{background:#d1fae5;color:#065f46}.action-btn.download:hover{background:#a7f3d0}.action-btn.delete{background:#fee2e2;color:#991b1b}.action-btn.delete:hover{background:#fecaca}.info-card{background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;padding:1rem 1.5rem;margin-bottom:2rem;display:flex;align-items:center;gap:1rem;color:#1e40af;font-size:.95rem}.info-card svg{font-size:1.5rem}.ventas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.venta-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .2s}.venta-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a;border-color:#667eea}.venta-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.venta-numero{font-family:Courier New,monospace;font-weight:600;color:#667eea;font-size:.95rem}.venta-fecha{font-size:.875rem;color:#6b7280}.venta-body{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.venta-info,.venta-cliente,.venta-precio{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:#374151}.venta-info svg,.venta-cliente svg,.venta-precio svg{font-size:1.25rem;color:#667eea}.venta-precio span{font-weight:700;font-size:1.1rem;color:#667eea}.btn-generate{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:all .2s}.btn-generate:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.config-tab{max-width:800px;margin:0 auto}.config-card{background:#fff;border-radius:12px;padding:2rem}.config-card h3{margin:0 0 2rem;font-size:1.5rem;color:#1f2937}.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.config-item{display:flex;flex-direction:column;gap:.5rem}.config-item.full-width{grid-column:1 / -1}.config-item label{font-size:.875rem;font-weight:500;color:#6b7280}.config-value{font-size:1rem;font-weight:600;color:#1f2937}.config-alert{background:#fef3c7;border:1px solid #fde68a;border-radius:8px;padding:1rem;display:flex;align-items:center;gap:.75rem;color:#92400e;font-size:.95rem}.config-alert svg{font-size:1.5rem;flex-shrink:0}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content-invoice{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-content-invoice.detail-modal{max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:1.25rem;color:#1f2937}.modal-header button{width:32px;height:32px;border:none;background:#f3f4f6;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:1.25rem;color:#6b7280}.modal-header button:hover{background:#e5e7eb}.modal-body{padding:1.5rem}.venta-info-box{background:#f9fafb;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.venta-info-box h4{margin:0 0 .75rem;font-size:1rem;color:#374151}.venta-info-box p{margin:.375rem 0;font-size:.875rem;color:#6b7280}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:#374151}.form-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;transition:all .2s}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-row{display:grid;grid-template-columns:1fr 2fr;gap:1rem}.form-group small{display:block;margin-top:.375rem;font-size:.75rem;color:#6b7280}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #e5e7eb}.btn-cancel{padding:.75rem 1.5rem;background:#f3f4f6;color:#374151;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#e5e7eb}.btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:500;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.detail-section{margin-bottom:2rem}.detail-section h4{margin:0 0 1rem;font-size:1.125rem;color:#1f2937;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item.full-width{grid-column:1 / -1}.detail-item.total{padding-top:1rem;border-top:2px solid #e5e7eb}.detail-item .label{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase}.items-table{width:100%;border-collapse:collapse;font-size:.875rem}.items-table thead{background:#f9fafb}.items-table th{padding:.75rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.items-table td{padding:.75rem;border-bottom:1px solid #e5e7eb;color:#1f2937}.sunat-response{padding:1rem;border-radius:8px;display:flex;align-items:center;gap:.75rem;font-size:.95rem}.sunat-response.success{background:#d1fae5;color:#065f46}.sunat-response.error{background:#fee2e2;color:#991b1b}.sunat-response svg{font-size:1.5rem;flex-shrink:0}.links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.link-btn{padding:.75rem 1rem;background:#f3f4f6;color:#374151;border-radius:8px;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500;transition:all .2s}.link-btn:hover{background:#e5e7eb}@media(max-width:768px){.admin-snacks-invoices-page{padding:1rem}.invoices-header{flex-direction:column;align-items:flex-start;gap:1rem}.invoices-tabs{flex-direction:column}.filters-grid,.ventas-grid,.config-grid,.form-row{grid-template-columns:1fr}.modal-footer{flex-direction:column-reverse}.btn-cancel,.btn-primary{width:100%;justify-content:center}}#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}
