.tooltip-wrapper{position:relative;display:inline-block}.tooltip{position:absolute;z-index:9999;padding:10px 14px;background:var(--gray-900);color:#fff;border-radius:6px;font-size:.875rem;white-space:nowrap;box-shadow:0 4px 12px #00000026;pointer-events:none;animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.tooltip-top{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-bottom{top:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-left{right:calc(100% + 8px);top:50%;transform:translateY(-50%)}.tooltip-right{left:calc(100% + 8px);top:50%;transform:translateY(-50%)}.tooltip-arrow{position:absolute;width:0;height:0;border:6px solid transparent}.tooltip-top .tooltip-arrow{bottom:-12px;left:50%;transform:translate(-50%);border-top-color:var(--gray-900)}.tooltip-bottom .tooltip-arrow{top:-12px;left:50%;transform:translate(-50%);border-bottom-color:var(--gray-900)}.tooltip-left .tooltip-arrow{right:-12px;top:50%;transform:translateY(-50%);border-left-color:var(--gray-900)}.tooltip-right .tooltip-arrow{left:-12px;top:50%;transform:translateY(-50%);border-right-color:var(--gray-900)}.tooltip-content{max-width:200px;white-space:normal;line-height:1.4}.tooltip-info-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--gray-500);cursor:help;transition:color .2s ease}.tooltip-info-icon:hover{color:var(--accent)}.tooltip-info-icon svg{width:100%;height:100%}.navbar{background:var(--primary);border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;z-index:1000;box-shadow:0 2px 8px #0000001a}.navbar-content{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}.navbar-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;transition:var(--transition)}.navbar-brand:hover{opacity:.9}.logo-icon{width:40px;height:40px;background:var(--accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;letter-spacing:-1px;flex-shrink:0}.logo-text{color:#fff;font-size:1.4rem;font-weight:700;letter-spacing:.5px}.navbar-links{display:flex;align-items:center;gap:1.5rem}.nav-link{color:#ffffffd9;text-decoration:none;font-size:.95rem;font-weight:500;padding:.5rem 0;position:relative;transition:var(--transition);white-space:nowrap}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent);transition:var(--transition)}.nav-link:hover{color:#fff}.nav-link:hover:after,.nav-link.active:after{width:100%}.nav-link.active{color:#fff}.nav-user{display:flex;align-items:center;gap:1rem;padding-left:1.5rem;border-left:1px solid rgba(255,255,255,.2)}.user-name{color:#ffffffe6;font-size:.9rem;font-weight:500;white-space:nowrap}.navbar .btn-primary{background:var(--accent);color:#fff;border:2px solid var(--accent)}.navbar .btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:none;box-shadow:none}.navbar .btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6)}.navbar .btn-outline:hover{background:#ffffff1a;border-color:#fff;color:#fff}@media (max-width: 900px){.navbar-links{gap:.75rem}.nav-link{font-size:.85rem}}@media (max-width: 768px){.user-name,.logo-text{display:none}.navbar-links{gap:.5rem}}.footer{background:var(--primary);color:#ffffffb3;text-align:center;padding:2rem 0;margin-top:auto}.footer-text{font-size:.9rem;margin-bottom:.5rem}.footer-subtext{font-size:.85rem;opacity:.8}.index-page{min-height:calc(100vh - 80px)}.hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;padding:5rem 0;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(90deg,transparent,transparent 50px,rgba(255,255,255,.03) 50px,rgba(255,255,255,.03) 51px),repeating-linear-gradient(0deg,transparent,transparent 50px,rgba(255,255,255,.03) 50px,rgba(255,255,255,.03) 51px);pointer-events:none}.hero-content{position:relative;z-index:1;max-width:700px}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.hero-highlight{color:var(--accent);position:relative}.hero-description{font-size:1.2rem;line-height:1.8;opacity:.9;margin-bottom:2.5rem}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.features{padding:5rem 0;background:#fff}.section-title{text-align:center;font-size:2.5rem;font-weight:700;color:var(--gray-900);margin-bottom:1rem}.section-description{text-align:center;font-size:1.1rem;color:var(--gray-600);max-width:600px;margin:0 auto 3rem}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.feature-card{padding:2rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);transition:var(--transition)}.feature-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-4px)}.feature-number{display:inline-block;font-size:2rem;font-weight:800;color:var(--accent);margin-bottom:1rem}.feature-title{font-size:1.4rem;font-weight:700;color:var(--gray-900);margin-bottom:.75rem}.feature-description{color:var(--gray-600);line-height:1.7}.benefits{padding:5rem 0;background:var(--gray-50)}.benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}.benefit-item{text-align:center}.benefit-icon{width:60px;height:60px;margin:0 auto 1rem;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.benefit-icon svg{width:30px;height:30px}.benefit-item h4{font-size:1.1rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.benefit-item p{color:var(--gray-600);font-size:.95rem}.cta{padding:5rem 0;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);color:#fff}.cta-content{text-align:center;max-width:700px;margin:0 auto}.cta-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta-description{font-size:1.2rem;opacity:.95;margin-bottom:2rem}.cta .btn-primary{background:#fff;color:var(--accent)}.cta .btn-primary:hover{background:var(--gray-100);transform:translateY(-2px)}@media (max-width: 1024px){.features-grid{grid-template-columns:1fr}.benefits-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-description{font-size:1rem}.section-title{font-size:2rem}.benefits-grid{grid-template-columns:1fr}.cta-title{font-size:2rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.animate-fade-in-up{animation:fadeInUp .6s ease-out forwards}.animate-fade-in{animation:fadeIn .4s ease-out}.animate-slide-down{animation:slideDown .3s ease-out}.delay-1{animation-delay:.1s;opacity:0}.delay-2{animation-delay:.2s;opacity:0}.delay-3{animation-delay:.3s;opacity:0}.btn-hover-lift{transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.btn-hover-lift:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;opacity:0;box-shadow:0 10px 25px #3498db4d;transition:opacity .3s ease}.btn-hover-lift:hover{transform:translateY(-3px)}.btn-hover-lift:hover:before{opacity:1}.btn-hover-lift:active{transform:translateY(-1px)}.btn-hover-glow{transition:all .3s ease;position:relative;overflow:hidden}.btn-hover-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 ease,height .6s ease}.btn-hover-glow:hover:before{width:300px;height:300px}.btn-hover-scale{transition:transform .2s ease}.btn-hover-scale:hover{transform:scale(1.05)}.btn-hover-scale:active{transform:scale(.95)}.btn-hover-rotate{transition:all .3s ease}.btn-hover-rotate:hover svg{transform:rotate(180deg);transition:transform .6s ease}.btn-hover-rotate:disabled{opacity:.5;cursor:not-allowed}.btn-hover-rotate:disabled:hover svg{transform:rotate(0)}.card-hover-float{transition:all .4s cubic-bezier(.4,0,.2,1);position:relative}.card-hover-float:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;box-shadow:0 20px 40px #0000001a;opacity:0;transition:opacity .4s ease;pointer-events:none}.card-hover-float:hover{transform:translateY(-8px)}.card-hover-float:hover:after{opacity:1}.card-hover-border-glow{position:relative;border:2px solid transparent;transition:all .3s ease}.card-hover-border-glow:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:inherit;background:linear-gradient(45deg,var(--accent),var(--accent-hover));opacity:0;transition:opacity .3s ease;z-index:-1}.card-hover-border-glow:hover:before{opacity:1}.input-focus-glow{transition:all .3s ease}.input-focus-glow:focus{box-shadow:0 0 0 3px #3498db1a;border-color:var(--accent)}.input-wrapper{position:relative;transition:all .3s ease}.input-wrapper.error{animation:shake .5s ease}.input-wrapper.error input{border-color:var(--error)}.input-wrapper.success input{border-color:var(--success)}.input-status{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;animation:scaleIn .3s ease}@keyframes scaleIn{0%{opacity:0;transform:translateY(-50%) scale(0)}to{opacity:1;transform:translateY(-50%) scale(1)}}.input-status.error{color:var(--error)}.input-status.success{color:var(--success)}.link-hover-underline{position:relative;transition:color .3s ease}.link-hover-underline:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:currentColor;transition:width .3s ease}.link-hover-underline:hover:after{width:100%}.table-row-hover{transition:all .2s ease;cursor:pointer}.table-row-hover:hover{background-color:var(--gray-50);transform:scale(1.01);box-shadow:0 2px 8px #0000000d}.live-indicator{display:inline-block;width:8px;height:8px;background:var(--success);border-radius:50%;margin-right:6px}.live-indicator.pulse{animation:pulse 2s infinite}.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translate(-50%);animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(-50%) translateY(0)}40%{transform:translate(-50%) translateY(-15px)}60%{transform:translate(-50%) translateY(-7px)}}.scroll-mouse{width:24px;height:40px;border:2px solid rgba(255,255,255,.5);border-radius:12px;display:flex;justify-content:center;padding-top:8px;cursor:pointer;transition:border-color .3s ease}.scroll-mouse:hover{border-color:#fffc}.scroll-wheel{width:4px;height:8px;background:#ffffff80;border-radius:2px;animation:scrollWheel 2s infinite}@keyframes scrollWheel{0%,20%{transform:translateY(0);opacity:1}to{transform:translateY(12px);opacity:0}}.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;margin-right:8px}.error-shake{animation:shake .5s ease}.error-banner{background:#fee;border:1px solid var(--error);border-radius:6px;padding:1rem;display:flex;align-items:center;gap:12px;margin-bottom:1.5rem}.error-banner svg{width:24px;height:24px;color:var(--error);flex-shrink:0}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff80;transform:translate(-50%,-50%);transition:width .6s,height .6s}.ripple:active:after{width:200px;height:200px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.bg-dots{background-color:var(--primary);background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:30px 30px;position:relative}.bg-dots:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(52,152,219,.1) 0%,transparent 50%,rgba(52,152,219,.1) 100%);pointer-events:none}.bg-stripes{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);position:relative}.bg-stripes:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 35px,rgba(255,255,255,.03) 35px,rgba(255,255,255,.03) 70px);pointer-events:none}.bg-circles{background:var(--primary);position:relative;overflow:hidden}.bg-circles:before,.bg-circles:after{content:"";position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.05);pointer-events:none}.bg-circles:before{width:800px;height:800px;top:-400px;right:-200px}.bg-circles:after{width:600px;height:600px;bottom:-300px;left:-100px}.bg-hexagon{background-color:var(--primary);background-image:linear-gradient(30deg,rgba(255,255,255,.02) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.02) 87.5%,rgba(255,255,255,.02)),linear-gradient(150deg,rgba(255,255,255,.02) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.02) 87.5%,rgba(255,255,255,.02)),linear-gradient(30deg,rgba(255,255,255,.02) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.02) 87.5%,rgba(255,255,255,.02)),linear-gradient(150deg,rgba(255,255,255,.02) 12%,transparent 12.5%,transparent 87%,rgba(255,255,255,.02) 87.5%,rgba(255,255,255,.02)),linear-gradient(60deg,rgba(255,255,255,.03) 25%,transparent 25.5%,transparent 75%,rgba(255,255,255,.03) 75%,rgba(255,255,255,.03)),linear-gradient(60deg,rgba(255,255,255,.03) 25%,transparent 25.5%,transparent 75%,rgba(255,255,255,.03) 75%,rgba(255,255,255,.03));background-size:80px 140px;background-position:0 0,0 0,40px 70px,40px 70px,0 0,40px 70px}.bg-gradient-animated{background:linear-gradient(-45deg,var(--primary),#2c4e60,#1e3a4a,var(--primary-light));background-size:400% 400%;animation:gradientShift 15s ease infinite;position:relative}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.bg-gradient-animated:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(52,152,219,.1) 0%,transparent 50%);pointer-events:none}.bg-waves{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);position:relative;overflow:hidden}.bg-waves:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(ellipse at top,rgba(255,255,255,.04) 0%,transparent 60%),radial-gradient(ellipse at bottom,rgba(255,255,255,.04) 0%,transparent 60%);pointer-events:none}.bg-topographic{background-color:var(--primary);background-image:repeating-radial-gradient(circle at 0 0,transparent 0,rgba(255,255,255,.03) 10px,transparent 20px),repeating-linear-gradient(#ffffff05,#ffffff05)}.chat-widget-button{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);border:none;cursor:pointer;box-shadow:0 4px 12px #3498db66;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:9998}.chat-widget-button:hover{transform:scale(1.1);box-shadow:0 6px 20px #3498db80}.chat-widget-button:active{transform:scale(.95)}.chat-widget-button.open{background:var(--gray-700)}.chat-widget-button svg{width:28px;height:28px;color:#fff}.chat-notification-badge{position:absolute;top:0;right:0;width:22px;height:22px;background:var(--error);color:#fff;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;animation:pulse 2s infinite}.chat-widget-window{position:fixed;bottom:100px;right:24px;width:380px;max-width:calc(100vw - 48px);height:600px;max-height:calc(100vh - 140px);background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;z-index:9999;animation:chatSlideIn .3s ease-out}@keyframes chatSlideIn{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-widget-header{padding:1.25rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center}.chat-widget-header-info{display:flex;align-items:center;gap:12px}.chat-avatar{width:40px;height:40px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.chat-widget-title{font-weight:600;font-size:1rem}.chat-widget-status{font-size:.85rem;opacity:.9;display:flex;align-items:center;gap:6px}.status-dot{width:8px;height:8px;background:#2ecc71;border-radius:50%;animation:pulse 2s infinite}.chat-widget-close{width:32px;height:32px;border:none;background:#fff3;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.chat-widget-close:hover{background:#ffffff4d}.chat-widget-close svg{width:18px;height:18px;color:#fff}.chat-widget-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:var(--gray-50)}.chat-widget-messages::-webkit-scrollbar{width:6px}.chat-widget-messages::-webkit-scrollbar-track{background:transparent}.chat-widget-messages::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.chat-message{display:flex;gap:10px;animation:messageSlideIn .3s ease-out}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{justify-content:flex-end}.chat-message-avatar{width:32px;height:32px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.chat-message-bubble{max-width:70%;padding:12px 16px;border-radius:12px;line-height:1.5;font-size:.95rem}.chat-message.bot .chat-message-bubble{background:#fff;color:var(--gray-800);border:1px solid var(--gray-200)}.chat-message.user .chat-message-bubble{background:var(--accent);color:#fff}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;background:var(--gray-400);border-radius:50%;animation:typingBounce 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}.chat-quick-actions{padding:0 1.5rem 1rem;display:flex;flex-direction:column;gap:8px;background:var(--gray-50)}.chat-quick-action-btn{padding:10px 14px;background:#fff;border:1px solid var(--gray-300);border-radius:6px;cursor:pointer;font-size:.9rem;color:var(--gray-700);transition:all .2s;text-align:left}.chat-quick-action-btn:hover{background:var(--gray-100);border-color:var(--accent);color:var(--accent)}.chat-widget-input{padding:1rem 1.5rem;border-top:1px solid var(--gray-200);background:#fff;display:flex;gap:10px;border-radius:0 0 12px 12px}.chat-widget-input input{flex:1;padding:10px 14px;border:1px solid var(--gray-300);border-radius:20px;font-size:.95rem;outline:none;transition:border-color .2s}.chat-widget-input input:focus{border-color:var(--accent)}.chat-widget-input button{width:40px;height:40px;border:none;background:var(--accent);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.chat-widget-input button:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.05)}.chat-widget-input button:disabled{opacity:.5;cursor:not-allowed}.chat-widget-input button svg{width:20px;height:20px;color:#fff}@media (max-width: 768px){.chat-widget-window{width:calc(100vw - 48px);height:calc(100vh - 140px);bottom:90px}.chat-widget-button{bottom:20px;right:20px}}.skeleton{background:linear-gradient(90deg,var(--gray-200) 0%,var(--gray-100) 50%,var(--gray-200) 100%);background-size:200% 100%;animation:skeletonLoading 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeletonLoading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:#fff;border-radius:8px;overflow:hidden;border:1px solid var(--gray-200)}.skeleton-card-image{width:100%;border-radius:0}.skeleton-card-content{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.skeleton-table{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid var(--gray-200)}.skeleton-table-row{display:grid;grid-template-columns:repeat(7,1fr);gap:1rem;padding:1rem 0;border-bottom:1px solid var(--gray-100)}.skeleton-table-row:last-child{border-bottom:none}.skeleton-table-header{padding:.75rem 0;border-bottom:2px solid var(--gray-200)}.skeleton-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.skeleton-metric-card{background:#fff;padding:1.5rem;border-radius:8px;border:1px solid var(--gray-200);display:flex;flex-direction:column;gap:.75rem}.skeleton-metric-value{margin:.5rem 0}.skeleton-chart{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid var(--gray-200)}.skeleton-chart-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-100)}.skeleton-chart-bars{display:flex;align-items:flex-end;gap:4px;height:200px}.skeleton-chart-bar{flex:1;border-radius:3px 3px 0 0}.skeleton-button{border-radius:6px}@media (max-width: 1024px){.skeleton-metrics{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.skeleton-metrics{grid-template-columns:1fr}.skeleton-table-row{grid-template-columns:1fr;gap:.5rem}}.dashboard-page{background:var(--gray-50);min-height:calc(100vh - 80px)}.dashboard-container{max-width:1400px;margin:0 auto;padding:2rem;width:100%}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.dashboard-title{font-size:2rem;font-weight:700;color:var(--gray-900);margin:0}.dashboard-subtitle{color:var(--gray-600);margin-top:.5rem;font-size:1rem}.dashboard-header-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.metrics-section{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.metric-card{background:#fff;padding:1.5rem;border-radius:12px;border:1px solid var(--gray-200);transition:all .3s ease}.metric-card.primary{background:var(--accent);border-color:var(--accent);color:#fff}.metric-card.primary .metric-label{color:#fffc}.metric-card.primary .metric-value{color:#fff}.metric-label{font-size:.8rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-bottom:.5rem}.metric-value{font-size:2.25rem;font-weight:700;color:var(--gray-900);line-height:1.1;margin:.25rem 0}.metric-value.large{font-size:2.75rem}.metric-trend{font-size:.875rem;color:var(--gray-500);margin-top:.25rem}.metric-trend.positive{color:var(--success, #27ae60)}.metric-status{display:inline-block;margin-top:.5rem;padding:.2rem .65rem;border-radius:20px;font-size:.75rem;font-weight:600}.metric-status.active{background:#27ae6026;color:#27ae60}.metric-unit{font-size:.875rem;color:var(--gray-500);margin-top:.25rem}.card{background:#fff;border-radius:12px;padding:1.75rem;border:1px solid var(--gray-200);box-shadow:0 1px 3px #0000000a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.card-header h3{font-size:1.125rem;font-weight:600;color:var(--gray-900);margin:0}.chart-section,.table-section,.alerts-section{margin-bottom:2rem}.alerts-section h3{font-size:1.125rem;font-weight:600;color:var(--gray-900);margin:0 0 1rem}.simple-chart{height:200px;padding:.5rem 0 1rem;position:relative}.chart-bars{display:flex;align-items:flex-end;height:100%;gap:3px;padding-bottom:24px}.chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;position:relative;min-width:0}.chart-bar{width:100%;background:linear-gradient(180deg,var(--accent, #3498db) 0%,#2980b9 100%);border-radius:4px 4px 0 0;min-height:4px;transition:height .5s ease}.chart-bar-wrapper:hover .chart-bar{background:linear-gradient(180deg,#5dade2 0%,var(--accent, #3498db) 100%)}.chart-label{position:absolute;bottom:-22px;font-size:.65rem;color:var(--gray-400);white-space:nowrap;transform:translate(-50%);left:50%}.chart-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--gray-400);font-style:italic;font-size:.95rem}.live-badge{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500;color:var(--gray-600)}.live-dot{display:inline-block;width:8px;height:8px;background:var(--success, #27ae60);border-radius:50%;flex-shrink:0}.live-dot.pulse{animation:livePulse 2s infinite}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.table-responsive{overflow-x:auto;margin:0 -1.75rem;padding:0 1.75rem}.data-table{width:100%;border-collapse:separate;border-spacing:0;min-width:700px}.data-table thead{background:var(--gray-50)}.data-table th{padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.6px;border-bottom:2px solid var(--gray-200);white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none}.data-table tbody tr{transition:all .2s ease}.data-table tbody tr:hover{background:var(--gray-50)}.data-table td{padding:1rem;color:var(--gray-700);border-bottom:1px solid var(--gray-100);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.banda-number{font-weight:700;color:var(--gray-800)}.encargado-name{font-weight:500;color:var(--gray-800)}.pieces-count{font-weight:700;color:var(--accent, #3498db);font-size:1.05rem}.pieces-rate{color:var(--gray-700);font-weight:500}.efficiency-bar{position:relative;width:100%;min-width:90px;height:22px;background:var(--gray-100);border-radius:11px;overflow:hidden;display:flex;align-items:center;padding:0 8px}.efficiency-fill{position:absolute;left:0;top:0;height:100%;border-radius:11px;transition:width .7s ease}.efficiency-fill.good{background:linear-gradient(90deg,#27ae60,#2ecc71)}.efficiency-fill.medium{background:linear-gradient(90deg,#e67e22,#f39c12)}.efficiency-fill.low{background:linear-gradient(90deg,#c0392b,#e74c3c)}.efficiency-text{position:relative;z-index:1;font-size:.75rem;font-weight:700;color:var(--gray-700)}.status-badge{display:inline-block;padding:.3rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}.status-badge.active{background:#27ae601f;color:#27ae60}.info-badge{background:var(--gray-100);color:var(--gray-700);padding:.3rem .875rem;border-radius:16px;font-size:.85rem;font-weight:600}.alert-item{display:flex;align-items:flex-start;gap:.875rem;padding:1rem 1.25rem;border-radius:10px;margin-bottom:.75rem}.alert-item:last-child{margin-bottom:0}.alert-info{background:#e8f4fd;border:1px solid #bee3f8;color:#1a5276}.alert-item svg{width:20px;height:20px;flex-shrink:0;margin-top:1px}.alert-item p{margin:0;font-size:.9rem;line-height:1.5}.error-banner{background:#fef0f0;border:1px solid #fbd5d5;border-radius:10px;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.error-content{display:flex;align-items:center;gap:.875rem;flex:1}.error-content svg{width:24px;height:24px;color:#c0392b;flex-shrink:0}.error-content strong{display:block;color:#922b21;font-weight:600;font-size:.95rem}.error-content p{margin:.1rem 0 0;color:#922b21;font-size:.85rem}.btn-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.1rem;background:#fff;border:1px solid var(--gray-300);border-radius:8px;font-size:.875rem;font-weight:500;color:var(--gray-700);cursor:pointer;transition:all .2s ease}.btn-toggle.active{background:var(--success, #27ae60);border-color:var(--success, #27ae60);color:#fff}.btn-toggle:hover{border-color:var(--accent);color:var(--accent)}.btn-toggle.active:hover{background:#229954;border-color:#229954;color:#fff}.btn.btn-icon{width:40px!important;height:40px!important;padding:0!important;display:inline-flex!important;align-items:center;justify-content:center;background:#fff!important;border:1px solid var(--gray-300)!important;border-radius:8px!important;cursor:pointer;transition:all .2s ease;flex-shrink:0;box-shadow:none!important;transform:none!important}.btn.btn-icon:hover{background:var(--gray-50)!important;border-color:var(--accent)!important;transform:none!important;box-shadow:none!important}.btn.btn-icon:disabled{opacity:.5!important;cursor:not-allowed!important}.btn.btn-icon svg{width:18px;height:18px;color:var(--gray-600);display:block}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#fff;border:1px solid var(--gray-300);border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-icon svg{width:18px;height:18px;color:var(--gray-600);display:block}@media (max-width: 1200px){.metrics-section{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard-container{padding:1.25rem}.dashboard-header{flex-direction:column;gap:1rem}.dashboard-header-actions{width:100%;justify-content:flex-start}.metrics-section{grid-template-columns:repeat(2,1fr);gap:1rem}.card{padding:1.25rem}.table-responsive{margin:0 -1.25rem;padding:0 1.25rem}}@media (max-width: 500px){.metrics-section{grid-template-columns:1fr}}.auth-page{min-height:calc(100vh - 160px);display:flex;align-items:center;justify-content:center;padding:2rem 0}.auth-container{width:100%;max-width:450px;margin:0 auto;padding:0 var(--spacing-lg)}.auth-card{background:#fff;padding:3rem 2.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--gray-200)}.auth-title{font-size:2rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem;text-align:center}.auth-subtitle{color:var(--gray-600);text-align:center;margin-bottom:2rem;font-size:.95rem}.auth-form{margin-top:2rem}.btn-block{width:100%}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--gray-600);font-size:.9rem}.auth-link{color:var(--accent);text-decoration:none;font-weight:600}.auth-link:hover{text-decoration:underline}.alert{padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem}.alert-error{background:#e74c3c1a;color:var(--error);border:1px solid var(--error)}.alert-success{background:#27ae601a;color:var(--success);border:1px solid var(--success)}.required{color:var(--error);margin-left:3px}.contact-page{padding:3rem 0;min-height:calc(100vh - 160px)}.page-title{text-align:center;font-size:2.5rem;font-weight:700;color:var(--gray-900);margin-bottom:1rem}.page-subtitle{text-align:center;color:var(--gray-600);max-width:600px;margin:0 auto 2.5rem;font-size:1.05rem;line-height:1.6}.contact-card{background:#fff;padding:2.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--gray-200)}.contact-form textarea{resize:vertical;font-family:inherit}.char-counter{text-align:right;font-size:.85rem;color:var(--gray-500);margin-top:var(--spacing-xs)}.char-counter.error{color:var(--error)}.not-found-page{min-height:calc(100vh - 160px);display:flex;align-items:center;justify-content:center;padding:2rem 0}.error-content{text-align:center;max-width:600px;margin:0 auto}.error-code{font-size:8rem;font-weight:900;color:var(--accent);line-height:1;margin-bottom:1rem}.error-title{font-size:2rem;font-weight:700;color:var(--gray-900);margin-bottom:1rem}.error-message{color:var(--gray-600);font-size:1.1rem;margin-bottom:2.5rem}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.admin-page{min-height:100vh;background:var(--gray-50)}.admin-container{max-width:1400px;margin:0 auto;padding:2rem}.admin-header{margin-bottom:3rem}.admin-header h1{font-size:2.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.admin-subtitle{font-size:1.1rem;color:var(--gray-600)}.admin-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--gray-100)}.section-header h2{font-size:1.5rem;font-weight:600;color:var(--gray-900);margin:0}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background:var(--gray-50)}.admin-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--gray-700);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--gray-200)}.admin-table td{padding:1rem;color:var(--gray-700);border-bottom:1px solid var(--gray-100)}.admin-table tbody tr:hover{background:var(--gray-50)}.action-buttons{display:flex;gap:.5rem}.btn-edit{color:var(--accent);border-color:var(--accent)}.btn-edit:hover{background:var(--accent);color:#fff}.btn-delete{color:var(--error);border-color:var(--error)}.btn-delete:hover{background:var(--error);color:#fff}.role-select{padding:.5rem 1rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s ease}.role-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--gray-200)}.modal-header h3{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin:0}.modal-close{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--gray-500);transition:all .2s ease}.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}.modal-close svg{width:20px;height:20px}.modal-form{padding:1.5rem}.modal-form .input-group{margin-bottom:1.25rem}.modal-form .input-group:last-of-type{margin-bottom:0}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid var(--gray-200);margin-top:1.5rem}@media (max-width: 768px){.admin-container{padding:1rem}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.admin-table{font-size:.875rem}.admin-table th,.admin-table td{padding:.75rem .5rem}.modal-content{width:95%}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.error-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.error-container{max-width:800px;margin:0 auto;padding:4rem 2rem;display:flex;flex-direction:column;align-items:center;gap:3rem}.error-content{text-align:center}.error-icon{width:120px;height:120px;margin:0 auto 2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.error-401{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 30px #667eea4d}.error-403{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 10px 30px #f5576c4d}.error-404{background:linear-gradient(135deg,#4facfe,#00f2fe);box-shadow:0 10px 30px #4facfe4d}.error-icon svg{width:60px;height:60px;color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.error-code{font-size:8rem;font-weight:900;color:var(--primary);margin:0;line-height:1;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.error-title{font-size:2.5rem;font-weight:700;color:var(--gray-900);margin:1rem 0}.error-description{font-size:1.125rem;color:var(--gray-600);max-width:500px;margin:0 auto 2rem;line-height:1.7}.error-description strong{color:var(--gray-900);font-weight:600}.role-badge{display:inline-block;padding:.25rem .75rem;background:var(--accent);color:#fff;border-radius:12px;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}.error-help{text-align:center}.error-help p{color:var(--gray-600);margin-bottom:.5rem}.error-help button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:1rem;padding:.5rem}.permissions-info{background:#fff;border-radius:12px;padding:1.5rem;margin-top:2rem;box-shadow:0 4px 12px #0000001a;max-width:400px;margin-left:auto;margin-right:auto}.permissions-info h3{font-size:1.125rem;font-weight:600;color:var(--gray-900);margin-bottom:1rem;text-align:left}.permissions-info ul{list-style:none;padding:0;margin:0;text-align:left}.permissions-info li{padding:.5rem 0;color:var(--gray-700);border-bottom:1px solid var(--gray-100)}.permissions-info li:last-child{border-bottom:none}.error-illustration{opacity:.6}.error-illustration svg{width:100%;max-width:400px;height:auto}.success-icon,.error-icon{width:80px;height:80px;margin:0 auto 1.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.success-icon{background:linear-gradient(135deg,#2ecc71,#27ae60)}.success-icon svg,.error-icon svg{width:40px;height:40px;color:#fff}@media (max-width: 768px){.error-container{padding:2rem 1rem}.error-code{font-size:5rem}.error-title{font-size:1.75rem}.error-description{font-size:1rem}.error-actions{flex-direction:column;width:100%}.error-actions button{width:100%}.error-icon{width:100px;height:100px}.error-icon svg{width:50px;height:50px}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.loading-container p{color:var(--gray-600);font-size:1rem}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .6s linear infinite;margin-right:.5rem}.input-wrapper{position:relative}.input-wrapper input{padding-right:3rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;font-size:1.25rem;padding:.25rem;opacity:.6;transition:opacity .2s ease}.password-toggle:hover{opacity:1}*{box-sizing:border-box;margin:0;padding:0}#root{min-height:100vh;display:flex;flex-direction:column}.app-container{display:flex;flex-direction:column;min-height:100vh}main{flex:1}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem;width:100%}.container-narrow{max-width:800px;margin:0 auto;padding:0 1.5rem;width:100%}.container-wide{max-width:1400px;margin:0 auto;padding:0 2rem;width:100%}*{transition-timing-function:cubic-bezier(.4,0,.2,1)}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2c3e50;--primary-light: #34495e;--accent: #3498db;--accent-hover: #2980b9;--success: #27ae60;--warning: #f39c12;--error: #e74c3c;--info: #3498db;--gray-50: #f8f9fa;--gray-100: #ecf0f1;--gray-200: #dce1e6;--gray-300: #bdc3c7;--gray-400: #95a5a6;--gray-500: #7f8c8d;--gray-600: #5a6c7d;--gray-700: #34495e;--gray-800: #2c3e50;--gray-900: #1a252f;--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;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .12);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--transition: all .3s ease}body{font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--gray-800);background:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.container-wide{max-width:1400px}.container-narrow{max-width:800px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;text-decoration:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);font-family:inherit}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:#fff;color:var(--gray-800);border:2px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-300)}.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}.btn-outline:hover{background:var(--accent);color:#fff}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:1rem 2rem;font-size:1.1rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg)}.input-group{margin-bottom:var(--spacing-lg)}.input-label{display:block;font-weight:600;color:var(--gray-700);margin-bottom:var(--spacing-sm);font-size:.9rem}.input{width:100%;padding:.75rem 1rem;font-size:.95rem;font-family:inherit;color:var(--gray-800);background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius-md);transition:var(--transition)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3498db1a}.input.error{border-color:var(--error);background:#fef5f5}.input.success{border-color:var(--success);background:#f0fdf4}.input-hint{font-size:.85rem;color:var(--gray-500);margin-top:var(--spacing-xs)}.input-error{font-size:.85rem;color:var(--error);margin-top:var(--spacing-xs)}.grid{display:grid;gap:var(--spacing-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--accent)}.text-muted{color:var(--gray-500)}.text-error{color:var(--error)}.text-success{color:var(--success)}.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)}.spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){body{font-size:14px}.container{padding:0 var(--spacing-md)}}
