@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-primary: #00214A;--color-accent: #FF5200;--color-tab-active: #FFD9BF;--color-border: #E6E6E6;--radius-card: 12px;--color-background: #FFFFFF;--color-text: #213547;--color-text-secondary: #666666;--color-error: #DC3545;--color-success: #28A745;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--primary-color: #00214A;--primary-dark: #001a3a;--black: #1a1a1a;--light-gray: #f5f7fa;--medium-gray: #6b7280;--dark-gray: #4b5563;--hermasa-orange: #ff6b35;--hermasa-blue: #004e89;--sidebar-width-expanded: 280px;--sidebar-width-collapsed: 64px;--header-height: 64px;--transition-sidebar: .3s ease;--transition-normal: .2s ease;--transition-fast: .15s ease;--spacing-xs: 8px;--spacing-sm: 16px;--spacing-md: 24px;--spacing-lg: 32px;--z-sidebar: 1500;--z-header: 1400;--z-modal: 1600;font-family:var(--font-family);line-height:1.5;font-weight:400;color-scheme:light;color:var(--color-text);background-color:var(--color-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{margin:0;min-width:320px;min-height:100vh;font-size:var(--font-size-sm);color:var(--color-text);background:var(--light-gray);line-height:1.4}#root{height:100%}h1,h2,h3,h4,h5,h6{margin:0;color:var(--color-primary)}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--color-primary);color:#fff;cursor:pointer;transition:all .25s;border:none;outline:none}button:hover{opacity:.9}button:focus,button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}button:disabled{opacity:.5;cursor:not-allowed}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--light-gray)}::-webkit-scrollbar-thumb{background:var(--medium-gray);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--dark-gray)}a{color:var(--primary-color);text-decoration:none;transition:var(--transition-fast)}a:hover{color:var(--primary-dark)}input,textarea,select{font-family:inherit;font-size:inherit}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.fade-in{animation:fadeIn var(--transition-normal)}.language-selector{position:relative;width:100%}.language-selector-trigger{width:100%;display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-lg);background:transparent;border:none;color:#ffffffd9;font-size:var(--font-size-xs);letter-spacing:.2px;cursor:pointer;transition:background-color .2s ease,color .2s ease;text-align:left;line-height:1.2}.language-selector-trigger:hover{background-color:#ffffff0d;color:#fff}.language-selector-trigger.collapsed{justify-content:center;padding:var(--spacing-xs)}.language-selector-icon{font-size:20px;flex-shrink:0;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.2);border-radius:var(--border-radius-sm);line-height:1;font-style:normal;overflow:hidden;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}.language-selector-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.language-selector-dropdown{position:absolute;bottom:100%;left:0;right:0;margin-bottom:var(--spacing-xs);background-color:#1e4a6e;border:1px solid rgba(255,255,255,.3);border-radius:var(--border-radius-sm);box-shadow:0 4px 12px #0000004d;z-index:1000;max-height:300px;overflow-y:auto;display:flex;flex-direction:column}.language-selector-option{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;color:#ffffffd9;font-size:var(--font-size-xs);cursor:pointer;transition:background-color .2s ease,color .2s ease;text-align:left;width:100%}.language-selector-option:first-child{border-top-left-radius:var(--border-radius-sm);border-top-right-radius:var(--border-radius-sm)}.language-selector-option:last-child{border-bottom-left-radius:var(--border-radius-sm);border-bottom-right-radius:var(--border-radius-sm)}.language-selector-option:hover{background-color:#ffffff1a;color:#fff}.language-selector-option.active{background-color:#3498db33;color:#fff;font-weight:600}.language-selector-option-flag{font-size:20px;flex-shrink:0;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;margin-right:var(--spacing-sm);font-style:normal;overflow:hidden;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;line-height:1}.language-selector-option-name{flex:1}.language-selector-option-check{margin-left:var(--spacing-sm);color:#fff;font-weight:700}.language-selector-dropdown::-webkit-scrollbar{width:8px}.language-selector-dropdown::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px;margin:4px 0}.language-selector-dropdown::-webkit-scrollbar-thumb{background:#ffffff80;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.language-selector-dropdown::-webkit-scrollbar-thumb:hover{background:#ffffffb3}.sidebar{position:fixed;left:0;top:0;height:100vh;width:var(--sidebar-width-expanded);background-color:#01082a;color:#fff;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;transition:all .3s ease;z-index:var(--z-sidebar);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-width-collapsed)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1);min-height:var(--header-height);overflow:hidden}.sidebar.collapsed .sidebar-header{justify-content:flex-start;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);align-items:center;overflow:visible;min-height:auto}.sidebar-brand{display:flex;align-items:center;gap:var(--spacing-md);flex:1;overflow:hidden;justify-content:flex-start}.sidebar.collapsed .sidebar-brand{justify-content:center;flex:0 0 auto;width:100%;overflow:visible}.sidebar-logo{width:32px;height:32px;object-fit:contain;flex-shrink:0;cursor:pointer;transition:all .3s ease;display:block;opacity:1}.sidebar.collapsed .sidebar-logo{width:40px;height:40px;margin:0 auto;position:relative;z-index:10;visibility:visible}.sidebar-logo:hover{opacity:.8}.sidebar-title{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:1.2px;opacity:.9;color:#ffffffe6;white-space:nowrap;transition:opacity .3s ease;cursor:pointer}.sidebar-title:hover{opacity:.8}.sidebar.collapsed .sidebar-title{opacity:0;pointer-events:none}.sidebar-nav{flex:1;padding:var(--spacing-md) 0;overflow-y:auto;overflow-x:hidden}.sidebar-footer-container{flex-shrink:0;display:flex;flex-direction:column;border-top:1px solid rgba(255,255,255,.1)}.sidebar-footer{flex-shrink:0;display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-lg);color:#ffffffd9;font-size:var(--font-size-xs);letter-spacing:.2px;-webkit-user-select:none;user-select:none;min-height:auto;line-height:1.2}.sidebar-footer.collapsed{justify-content:center;padding:var(--spacing-xs)}.sidebar-footer-icon{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.2);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);line-height:1;flex-shrink:0}.sidebar-footer-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-root-title{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:1.2px;opacity:.9;color:#ffffffe6;padding:0 var(--spacing-lg) var(--spacing-md)}.sidebar-tree{display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-group{margin-top:var(--spacing-sm)}.sidebar-group-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:.5rem 1rem;color:#ffffffd9;font-weight:600;letter-spacing:.5px;background:transparent;border:none;cursor:pointer;text-align:left}.sidebar.collapsed .sidebar-group-header{justify-content:center;padding:var(--spacing-md)}.sidebar-group-children{display:none;flex-direction:column;border-left:1px solid rgba(255,255,255,.1);margin-left:1.25rem}.sidebar-group-children.expanded{display:flex}.sidebar-subitem{padding-left:2.5rem;font-size:var(--font-size-sm)}.sidebar-group-chevron{margin-left:auto;font-size:var(--font-size-sm);opacity:.8}.sidebar-item{width:100%;display:flex;align-items:center;gap:var(--spacing-md);padding:.5rem 1rem;background:transparent;border:none;color:#fffffff2;text-decoration:none;font-size:var(--font-size-sm);cursor:pointer;transition:background-color .2s ease,color .2s ease;text-align:left;position:relative;font-weight:500;border-radius:0}.sidebar-item:hover{background-color:#34495e;text-decoration:none;color:#fff}.sidebar-item:focus{outline:2px solid #3498db;outline-offset:-2px}.sidebar-item.active{background-color:#3498db33;color:#fff;font-weight:600}.sidebar-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#3498db}.sidebar-item-icon{font-size:var(--font-size-lg);flex-shrink:0;width:28px;text-align:center;display:flex;align-items:center;justify-content:center}.sidebar-item-icon-img{width:28px;height:28px;object-fit:contain;border:1px solid white;border-radius:20px;padding:0;background:#fff}.sidebar-item-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:1;transition:opacity var(--transition-normal)}.sidebar.collapsed .sidebar-item-label{opacity:0;width:0}.sidebar.collapsed .sidebar-item{justify-content:center;padding:var(--spacing-md)}.sidebar.collapsed .sidebar-subitem{padding-left:var(--spacing-md)}.sidebar.collapsed .sidebar-group-children{display:none}.sidebar-toggle{width:28px;height:28px;padding:0;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:var(--border-radius-sm);color:#fff;font-size:var(--font-size-md);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-toggle:hover{background:#ffffff1a;border-color:#fff6;color:#fff}.sidebar-toggle:focus{outline:2px solid #3498db;outline-offset:2px}.sidebar-toggle-icon{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);transition:transform .2s ease;line-height:1}.sidebar-toggle:active .sidebar-toggle-icon{transform:scale(.9)}.sidebar.collapsed .sidebar-toggle{width:32px;height:32px}@media(max-width:768px){.sidebar{width:var(--sidebar-width-collapsed);transition:transform var(--transition-sidebar),width var(--transition-sidebar)}.sidebar:not(.collapsed){width:var(--sidebar-width-expanded)}.sidebar.collapsed{transform:translate(-100%)}}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.header{position:fixed;top:0;left:var(--sidebar-width-expanded);right:0;height:var(--header-height);background-color:#01082a;color:#fff;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:var(--z-header);transition:left .3s ease,all .3s ease}body.sidebar-collapsed .header{left:var(--sidebar-width-collapsed)}.header-left{display:flex;align-items:center;gap:1rem;flex:0 0 auto}.header-hamburger{display:none;background:transparent;border:none;font-size:var(--font-size-lg);color:#fff;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--border-radius-sm);transition:all .2s ease}.header-hamburger:hover{background-color:#ffffff1a;opacity:.8}.hamburger-icon{display:block;line-height:1}.header-logo{height:40px;width:auto;cursor:pointer;transition:opacity .2s ease,transform .2s ease}.header-logo:hover{opacity:.8;transform:scale(1.05)}.header-title{cursor:pointer;margin:0;font-weight:300;font-size:1.5rem;color:#fff;transition:opacity .2s ease,transform .2s ease;-webkit-user-select:none;user-select:none}.header-title:hover{opacity:.8;transform:scale(1.05)}.header-title:active{transform:scale(.95)}.header-right{display:flex;align-items:center;gap:.75rem;flex:0 0 auto}.view-mode-toggle{display:flex;align-items:center;gap:.5rem;padding:0 .5rem;border-right:1px solid rgba(255,255,255,.1);margin-right:.25rem}.toggle-label{font-size:var(--font-size-xs);color:#ffffffb3;font-weight:500;font-family:Courier New,monospace;text-transform:uppercase;letter-spacing:.5px}.toggle-switch{position:relative;display:flex;align-items:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:4px 12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:80px;justify-content:center}.toggle-switch:hover{background:#ffffff26;border-color:#fff6;transform:translateY(-1px)}.toggle-switch.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 8px #667eea66}.toggle-option{font-size:var(--font-size-xs);font-weight:700;color:#fff;font-family:Courier New,monospace;letter-spacing:.5px;text-transform:uppercase;position:relative;z-index:2}.toggle-slider{position:absolute;inset:2px;background:#ffffff1a;border-radius:18px;transition:all .3s ease;z-index:1;pointer-events:none}.header-action-btn{position:relative;display:flex;align-items:center;gap:var(--spacing-xs);background:transparent;border:none;color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background-color .2s ease;font-weight:500;height:32px}.header-action-btn:hover{background-color:#34495e;text-decoration:none;color:#fff}.header-action-btn:focus{outline:2px solid #3498db;outline-offset:2px}.action-icon{font-size:var(--font-size-2xl);line-height:1;color:#fff;filter:grayscale(100%) brightness(200%)}.notification-badge{position:absolute;top:2px;right:2px;min-width:14px;height:14px;display:flex;align-items:center;justify-content:center;background:#e74c3c;color:#fff;font-size:9px;font-weight:var(--font-weight-bold);border-radius:50%;padding:0 3px}.header-user-btn{border:1px solid rgba(255,255,255,.2)}.header-user-btn:hover{border-color:#ffffff80;background-color:#34495e}.user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:#fff}.user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.2);background-color:#ffffff1a}@media(max-width:768px){.header{left:0!important;padding:.75rem;flex-direction:row;height:56px}.header-hamburger{display:block}.header-left{gap:.5rem;justify-content:flex-start}.header-logo{height:28px}.header-title{font-size:1rem}.view-mode-toggle,.user-name{display:none}.header-right{gap:.25rem}.header-action-btn{padding:.3rem .5rem;font-size:.85rem;height:28px;min-width:28px}.action-icon{font-size:var(--font-size-lg)}.user-avatar{width:20px;height:20px}.notification-badge{min-width:12px;height:12px;font-size:8px}}@media(max-width:480px){.header{padding:.5rem;height:52px}.header-logo{height:24px}.header-title{display:none}.header-action-btn{padding:.25rem .4rem;font-size:.75rem;height:24px;min-width:24px}.action-icon{font-size:var(--font-size-md)}.user-avatar{width:18px;height:18px}}.app-footer{background:linear-gradient(135deg,var(--hermasa-orange) 0%,var(--hermasa-blue) 100%);color:#fff;margin-top:auto;position:relative;overflow:hidden;flex-shrink:0}.app-footer:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.03) 10px,rgba(255,255,255,.03) 20px);pointer-events:none}.footer-content{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:40px 60px 20px}.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-bottom:40px}.footer-column{display:flex;flex-direction:column;gap:16px}.footer-logo-section{display:flex;align-items:center;justify-content:flex-start;margin-bottom:16px}.footer-logo-large{width:120px;height:auto;object-fit:contain;filter:brightness(0) invert(1)}.footer-tagline{font-size:14px;font-weight:600;color:#fffffff2;margin:0;font-style:italic}.footer-description{font-size:13px;line-height:1.6;color:#ffffffd9;margin:0}.footer-heading{font-size:16px;font-weight:700;color:#fff;margin:0 0 12px;text-transform:uppercase;letter-spacing:1.5px;border-bottom:2px solid rgba(255,255,255,.3);padding-bottom:8px}.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.footer-link{background:none;border:none;padding:0;font:inherit;color:#ffffffe6;text-decoration:none;font-size:14px;transition:all .2s ease;cursor:pointer;text-align:left;display:inline-block;position:relative}.footer-link:before{content:"→";position:absolute;left:-20px;opacity:0;transition:all .2s ease}.footer-link:hover{color:#fff;transform:translate(5px);opacity:1}.footer-link:hover:before{opacity:1;left:-15px}.footer-contact{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.contact-item{display:flex;align-items:center;gap:10px;font-size:14px;color:#ffffffe6}.contact-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.contact-text{color:#ffffffe6}.footer-social{display:flex;flex-direction:column;gap:12px}.social-link{display:flex;align-items:center;gap:12px;color:#fff;text-decoration:none;font-size:14px;padding:8px 12px;border-radius:4px;background:#ffffff1a;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.social-link:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.social-icon{font-size:20px;width:24px;text-align:center}.social-label{font-weight:500}.footer-bottom{border-top:1px solid rgba(255,255,255,.2);padding-top:24px;margin-top:20px}.footer-bottom-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:13px}.footer-copyright{color:#fffc}.footer-version{color:#ffffffb3;font-family:Courier New,monospace;font-weight:600;background:#ffffff1a;padding:4px 12px;border-radius:4px}.footer-legal{display:flex;align-items:center;gap:12px}.legal-link{color:#fffc;text-decoration:none;transition:color .2s ease}.legal-link:hover{color:#fff;text-decoration:underline}.legal-separator{color:#fff6}@media(max-width:768px){.footer-content{padding:30px 40px 20px}.footer-grid{grid-template-columns:repeat(2,1fr);gap:30px;margin-bottom:30px}.footer-logo-large{width:100px}.social-label{display:none}.social-link{padding:8px;justify-content:center}.footer-bottom-content{flex-direction:column;text-align:center;gap:12px}}@media(max-width:480px){.footer-content{padding:20px 20px 16px}.footer-grid{grid-template-columns:1fr;gap:24px;margin-bottom:24px}.footer-column{text-align:center}.footer-logo-section{justify-content:center}.footer-logo-large{width:100px}.footer-description{text-align:center}.footer-links,.footer-contact{align-items:center}.footer-link{text-align:center}.footer-link:before{display:none}.footer-link:hover{transform:scale(1.05)}.contact-item{justify-content:center}.footer-social{flex-direction:row;justify-content:center;flex-wrap:wrap}.social-link{flex:0 0 auto;min-width:48px}.footer-heading{text-align:center}.footer-bottom-content{font-size:12px}.footer-legal{flex-wrap:wrap;justify-content:center}}.btn{border-radius:8px;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .25s;border:1px solid transparent}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){opacity:.9}.btn-secondary{background-color:var(--color-accent);color:#fff}.btn-secondary:hover:not(:disabled){opacity:.9}.btn-outline{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary);color:#fff}.multi-select{position:relative;width:100%}.multi-select-trigger{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:6px;background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:.9rem;transition:border-color .25s;color:var(--color-text)}.multi-select-trigger:hover{border-color:var(--color-primary)}.multi-select-trigger:focus{outline:2px solid var(--color-accent);outline-offset:2px}.multi-select-placeholder{color:var(--color-text-secondary)}.multi-select-arrow{color:var(--color-text-secondary);font-size:.8rem;margin-left:.5rem}.multi-select-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background-color:#fff;border:1px solid var(--color-border);border-radius:6px;box-shadow:0 4px 6px #0000001a;z-index:1000;max-height:300px;display:flex;flex-direction:column}.multi-select-search{padding:.5rem;border-bottom:1px solid var(--color-border)}.multi-select-search input{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;font-size:.9rem}.multi-select-search input:focus{outline:2px solid var(--color-accent);outline-offset:2px}.multi-select-options{overflow-y:auto;max-height:250px}.multi-select-option{display:flex;align-items:center;padding:.5rem;cursor:pointer;transition:background-color .25s;border:none;background:none;width:100%;text-align:left;font-size:.9rem}.multi-select-option:hover{background-color:#f5f5f5}.multi-select-option-selected{background-color:var(--color-tab-active);color:var(--color-primary);font-weight:500}.multi-select-option input[type=checkbox]{margin-right:.5rem;cursor:pointer}.multi-select-all{font-weight:600;border-bottom:1px solid var(--color-border);color:var(--color-primary)}.multi-select-no-results{padding:1rem;text-align:center;color:var(--color-text-secondary);font-style:italic}.filters-panel{width:300px;background-color:#fff;padding:1.5rem;overflow-y:auto;height:100%;transition:width .3s ease,transform .3s ease;border-right:2px solid #CCCCCC}.filters-panel-collapsed{width:60px;padding:1rem .5rem;overflow:visible;border-right:none!important}.filters-panel-backdrop{display:none}.filters-panel-header{display:flex;justify-content:space-between;align-items:center;margin:0;padding:0;border-bottom:1px solid var(--color-border)}.filters-panel-collapsed .filters-panel-header{margin-bottom:0;padding-bottom:0;border-bottom:none;justify-content:center}.filters-panel-header h3{font-size:1.25rem;font-weight:600;color:var(--color-primary);margin:0;transition:opacity .3s ease}.filters-panel-collapsed .filters-panel-header h3{display:none}.filters-panel-actions{display:flex;align-items:center;gap:.5rem}.filters-panel-reset{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.reset-button{font-size:.875rem;padding:.4rem .8rem;width:100%}.collapse-button{background:none;border:1px solid var(--color-border);border-radius:4px;min-width:32px;width:auto;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-primary);font-size:1rem;transition:all .25s;padding:0 .75rem}.collapse-button-text{font-size:.875rem;opacity:.4;color:var(--color-text);white-space:nowrap;transition:opacity .25s}.collapse-button:hover .collapse-button-text{opacity:.7}.collapse-button:hover{background-color:#f5f5f5;border-color:var(--color-primary)}.filters-panel-collapsed .collapse-button{width:40px;height:40px;border:1px solid var(--color-primary);box-shadow:0 2px 4px #0000001a;color:var(--color-primary)}.filters-icon{width:18px;height:18px;display:block;flex-shrink:0;color:inherit}.filters-list{display:flex;flex-direction:column;gap:1.5rem;transition:opacity .3s ease}.filters-panel-collapsed .filters-list{display:none}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-label{font-size:.9rem;font-weight:500;color:var(--color-text)}.filters-panel-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--color-border);transition:opacity .3s ease}.filters-panel-collapsed .filters-panel-footer{display:none}.drilldown-link{display:inline-block;color:var(--color-accent);text-decoration:none;font-weight:500;transition:color .25s}.drilldown-link:hover{color:var(--color-primary);text-decoration:underline}@media(max-width:768px){.filters-panel-backdrop{display:block;position:fixed;inset:0;background-color:#00000080;z-index:200;opacity:1;transition:opacity .3s ease}.filters-panel{position:fixed;top:0;right:0;height:100vh;width:90%;max-width:400px;transform:translate(100%);z-index:210;border-right:none;box-shadow:-2px 0 8px #00000026;padding:1.5rem;display:none}.filters-panel-mobile-open{transform:translate(0);display:flex;flex-direction:column}.filters-panel-collapsed{width:90%;max-width:400px;padding:1.5rem;display:none}.collapse-button{min-width:44px;min-height:44px}}.main-layout{display:flex;height:100%}.main-layout-content{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-width-expanded);transition:margin-left var(--transition-sidebar);height:100vh;overflow:hidden}.main-layout.sidebar-collapsed .main-layout-content{margin-left:var(--sidebar-width-collapsed)}.main-content-wrapper{flex:1;display:flex;flex-direction:column;margin-top:var(--header-height);min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.main-content{flex:1 0 auto;padding:0;background:#f5f7fa;background-image:linear-gradient(180deg,#f8f9fc,#f5f7fa);display:flex;flex-direction:row;color:var(--color-text)}.main-content>.filters-panel{flex-shrink:0}.main-content>:not(.filters-panel){flex:1;min-width:0;padding:var(--spacing-lg);color:var(--color-text)}.main-content>:not(.filters-panel) *{color:inherit}.main-content>:not(.filters-panel) h1,.main-content>:not(.filters-panel) h2,.main-content>:not(.filters-panel) h3,.main-content>:not(.filters-panel) h4,.main-content>:not(.filters-panel) h5,.main-content>:not(.filters-panel) h6{color:var(--color-primary)}.main-content:not(:has(.filters-panel)){padding:var(--spacing-lg)}.main-content:has(>.tunacheck-view)>.tunacheck-view{padding:0}.main-content-wrapper .app-footer{flex-shrink:0}@media(max-width:768px){.main-layout-content{margin-left:0;width:100%}.main-layout.sidebar-collapsed .main-layout-content{margin-left:0}.main-content-wrapper{margin-top:56px}.main-content{padding:var(--spacing-sm)}}@media(max-width:480px){.main-content-wrapper{margin-top:52px}.main-content{padding:var(--spacing-xs)}}:root{--auth-bg: #030712;--auth-surface: linear-gradient(140deg, rgba(13, 18, 32, .95), rgba(6, 10, 22, .95));--auth-panel: rgba(17, 22, 36, .85);--auth-panel-strong: rgba(24, 29, 44, .9);--auth-border: rgba(255, 255, 255, .08);--auth-primary: #5c7cfa;--auth-primary-dark: #4c6ef5;--auth-success: #63e6be;--auth-warning: #fcc419;--auth-danger: #ff6b6b;--auth-text: #f8fafc;--auth-text-muted: rgba(248, 250, 252, .75)}.auth-wrapper{position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;background:radial-gradient(circle at 15% 20%,rgba(92,124,250,.25),transparent 45%),radial-gradient(circle at 80% 0%,rgba(99,230,190,.18),transparent 40%),var(--auth-bg)}.auth-content{display:flex;flex-direction:column;align-items:center;margin-top:-120px}.auth-bg-hermasa{flex-shrink:0}.auth-card{position:relative;z-index:1;width:100%;max-width:440px;background:#080c18e6;border:1px solid var(--auth-border);border-radius:32px;padding:48px;box-shadow:0 30px 50px #050a1499}.auth-card h1{color:#fff;font-weight:700;font-size:1.75rem;text-shadow:0 0 30px rgba(92,124,250,.3);margin:0 0 8px}.eyebrow{display:flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:.2em;font-size:1rem;color:var(--auth-text-muted);margin-top:12px;margin-bottom:24px}.eyebrow-logo{width:28px;height:28px;padding:4px;object-fit:contain;background-color:#fff;border-radius:50%}.stat-sub{color:var(--auth-text-muted);font-size:.95rem;margin:0}.input{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--auth-border);background:#03070e99;color:var(--auth-text);font-size:.95rem}.input::placeholder{color:#f8fafc80}.btn{border:none;border-radius:14px;padding:12px 16px;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 12px 18px #0003}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary{background:var(--auth-primary);color:#fff}.btn-ghost{background:transparent;border:1px solid var(--auth-border);color:var(--auth-text)}.btn-ghost:hover:not(:disabled){background:#5c7cfa26;border-color:#5c7cfa4d}.error-text{color:var(--auth-danger);margin:0}.link{color:var(--auth-primary);font-weight:600}@keyframes explodeCenter{0%{transform:translate(-50%,-50%) scale(.2);opacity:0}60%{opacity:.12}to{transform:translate(-50%,-50%) scale(1);opacity:.08}}@keyframes pulse{0%,to{opacity:.08;transform:translate(-50%,-50%) scale(1)}50%{opacity:.12;transform:translate(-50%,-50%) scale(1.02)}}.auth-bg-element{position:absolute;pointer-events:none;z-index:0;background-repeat:no-repeat;background-position:center;background-size:contain}.auth-bg-hermasa{width:250px;height:100px;z-index:1;background-image:url(/Logo_Hermasa.png);background-size:contain;background-repeat:no-repeat;background-position:center;animation:fadeInScale .8s ease-out forwards}@keyframes fadeInScale{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.email-form{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.splash-screen{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;z-index:9999;overflow:hidden}.splash-screen:before{content:"";position:absolute;top:-100%;left:-100%;width:300%;height:300%;background:linear-gradient(0deg,var(--hermasa-orange, #ff6b35) 0%,var(--hermasa-blue, #004e89) 100%);animation:rotateGradient 1s linear forwards}.splash-screen.fade-out{animation:fadeOut .3s ease-out forwards}@keyframes rotateGradient{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.splash-logo{max-width:300px;max-height:200px;animation:logoFade 1s ease-in-out;filter:drop-shadow(0 10px 20px rgba(0,0,0,.3));position:relative;z-index:10}@keyframes logoFade{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}.loading-spinner{display:inline-flex;align-items:center;justify-content:center}.spinner-image{animation:spin 1s linear infinite;object-fit:contain}.spinner-small .spinner-image{width:16px;height:16px}.spinner-medium .spinner-image{width:32px;height:32px}.spinner-large .spinner-image{width:48px;height:48px}.loading-spinner-centered{display:flex;width:100%;height:100%;min-height:200px;align-items:center;justify-content:center}.modal-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal, 1100);padding:var(--spacing-lg);animation:fadeIn .2s ease}.modal-content{background:var(--color-background, #fff);border-radius:8px;box-shadow:0 8px 32px #00000029,0 4px 16px #0000001f;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.modal-small{width:400px;max-width:90%}.modal-medium{width:600px;max-width:90%}.modal-large{width:800px;max-width:95%}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg, 24px) var(--spacing-xl, 32px);background:linear-gradient(135deg,var(--color-primary, #00214A) 0%,var(--hermasa-blue, #004e89) 100%);position:relative;overflow:hidden}.modal-header:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(255,255,255,.03) 2px,rgba(255,255,255,.03) 4px);pointer-events:none}.modal-header-content{display:flex;align-items:center;gap:var(--spacing-md, 16px);position:relative;z-index:1;color:#fff}.modal-icon{font-size:1.5rem;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fff3;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.modal-title{font-size:1.125rem;font-weight:700;color:#fff;margin:0;letter-spacing:.5px;text-transform:uppercase}.modal-close-btn{width:36px;height:36px;border-radius:4px;border:1px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1;position:relative;z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-close-btn:hover{background:#fff3;border-color:#ffffff80;transform:scale(1.05)}.modal-close-btn:active{transform:scale(.95)}.modal-close-btn:focus-visible{outline:2px solid white;outline-offset:2px}.modal-body{padding:var(--spacing-xl, 32px);overflow-y:auto;flex:1;color:var(--color-text, #213547)}.modal-footer{padding:var(--spacing-lg, 24px) var(--spacing-xl, 32px);border-top:1px solid var(--color-border, #E6E6E6);background:#f8f9fa;display:flex;gap:var(--spacing-md, 16px);justify-content:flex-end}.btn{padding:12px 24px;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;text-transform:uppercase;letter-spacing:.5px;min-width:100px}.btn-primary{background:linear-gradient(135deg,var(--color-primary, #00214A) 0%,var(--hermasa-blue, #004e89) 100%);color:#fff;box-shadow:0 2px 4px #00214a4d}.btn-primary:hover{box-shadow:0 4px 12px #00214a66;transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--color-text, #213547);border:1px solid var(--color-border, #E6E6E6)}.btn-secondary:hover{background:#f5f7fa;border-color:#ccc}.btn-danger{background:var(--color-error, #DC3545);color:#fff}.btn-danger:hover{background:#c82333}.btn-warning{background:#ffc107;color:#212529}.btn-warning:hover{background:#e0a800}@media(max-width:768px){.modal-backdrop{padding:var(--spacing-sm, 12px);padding-top:56px}.modal-content{max-height:calc(100vh - 72px);width:100%;max-width:100%}.modal-small,.modal-medium,.modal-large{width:100%;max-width:100%}.modal-header{padding:16px 20px}.modal-body{padding:20px}.modal-footer{padding:16px 20px;gap:12px}}@media(max-width:480px){.modal-footer{flex-direction:column}.modal-footer .btn{width:100%}}.toast-container{position:fixed;top:calc(var(--header-height, 64px) + var(--spacing-lg, 24px));right:var(--spacing-lg, 24px);z-index:2000;display:flex;flex-direction:column;gap:var(--spacing-md, 16px);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--spacing-md, 16px);min-width:300px;max-width:400px;padding:16px 20px;background:var(--color-background, #fff);border-radius:8px;box-shadow:0 4px 12px #00000026,0 2px 6px #0000001a;pointer-events:auto;animation:slideInRight .3s cubic-bezier(.4,0,.2,1);border-left:4px solid}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:var(--color-success, #28A745)}.toast-error{border-left-color:var(--color-error, #DC3545)}.toast-warning{border-left-color:#ffc107}.toast-info{border-left-color:#17a2b8}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;flex-shrink:0}.toast-success .toast-icon{background:var(--color-success, #28A745);color:#fff}.toast-error .toast-icon{background:var(--color-error, #DC3545);color:#fff}.toast-warning .toast-icon{background:#ffc107;color:#212529}.toast-info .toast-icon{background:#17a2b8;color:#fff}.toast-content{flex:1;overflow:hidden}.toast-message{margin:0;font-size:.875rem;color:var(--color-text, #213547);line-height:1.4}.toast-close{width:24px;height:24px;border:none;background:transparent;color:#6b7280;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0;line-height:1}.toast-close:hover{background:#f5f7fa;color:var(--color-text, #213547)}@media(max-width:768px){.toast-container{left:16px;right:16px}.toast{min-width:auto;max-width:none}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:1000px 100%;animation:shimmer 2s infinite linear;display:inline-block}.confirm-dialog{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 0}.confirm-message{font-size:1rem;color:#6b7280;margin:0;line-height:1.6;max-width:100%}.breadcrumbs{padding:8px 0;font-size:.875rem}.breadcrumbs-list{display:flex;align-items:center;flex-wrap:wrap;gap:4px;list-style:none;margin:0;padding:0}.breadcrumbs-item{display:flex;align-items:center;gap:4px}.breadcrumbs-link{color:var(--color-text-secondary, #666);text-decoration:none;transition:color .2s ease}.breadcrumbs-link:hover{color:var(--color-primary, #00214A);text-decoration:underline}.breadcrumbs-separator{color:var(--color-text-secondary, #999);margin:0 4px}.breadcrumbs-current{color:var(--color-text, #213547);font-weight:500}.kpi-gauge-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem;height:100%}.kpi-gauge-label{font-size:.9rem;font-weight:500;color:var(--color-primary);margin-bottom:.5rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:.25rem}.kpi-gauge-info-icon{flex-shrink:0;cursor:pointer;opacity:.7;transition:opacity .2s}.kpi-gauge-info-icon:hover{opacity:1}.kpi-gauge-chart{width:100%;height:110px}.kpi-list-card{padding:1.5rem}.kpi-list-title{font-size:1.25rem;font-weight:600;color:var(--color-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.kpi-list-items{display:flex;flex-direction:column;gap:1rem}.kpi-list-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f9f9f9;border-radius:6px}.kpi-list-label{font-size:.9rem;color:var(--color-text-secondary)}.kpi-list-value{font-size:1.1rem;font-weight:600;color:var(--color-primary)}.scatter-card{width:100%;height:400px}.scatter-card-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f9f9fb;border-radius:8px;border:1px dashed #e0e0e0}.scatter-card-empty-title{color:#00214a;font-size:16px;font-weight:600;margin:0 0 12px;text-align:center}.scatter-card-empty-message{color:#666;font-size:14px;margin:0;text-align:center;padding:0 20px}.estado-general-kpis{display:flex;flex-direction:column;gap:2rem}.gauges-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;align-items:center;background-color:#fff;padding:.75rem;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a}.kpis-bottom-row{display:grid;grid-template-columns:1fr 2fr;gap:1.5rem}.kpi-list-wrapper{min-height:400px;background-color:#fff;padding:1.5rem;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a}.scatter-plots{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;background-color:#fff;padding:1.5rem;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a}.scatter-wrapper{min-height:400px}.dashboard-loading,.dashboard-error,.dashboard-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background-color:#fff;border-radius:var(--radius-card);border:1px solid var(--color-border);padding:2rem}@media(max-width:1400px){.gauges-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media(max-width:1024px){.gauges-row{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.kpis-bottom-row,.scatter-plots{grid-template-columns:1fr}}.tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--color-border);margin-bottom:1rem;flex-wrap:nowrap;overflow-x:visible}.tab{background:none;border:none;padding:.75rem 1.5rem;font-size:1em;font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .25s}.tab:hover{color:var(--color-primary)}.tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);background-color:var(--color-tab-active)}.tab[style*="background-color: #00214A"],.tab[style*="background-color: #004e89"],.tab[style*="background-color: #003366"],.tab[style*="background-color: #001a3d"],.tab[style*="background: #00214A"],.tab[style*="background: #004e89"],.tab[style*="background: #003366"],.tab[style*="background: #001a3d"],.tab[style*="background-color: #00214A"] *,.tab[style*="background-color: #004e89"] *,.tab[style*="background-color: #003366"] *,.tab[style*="background-color: #001a3d"] *{color:#fff!important}@media(max-width:768px){.tabs{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;padding-bottom:.5rem;margin-bottom:.5rem}.tabs::-webkit-scrollbar{height:4px}.tabs::-webkit-scrollbar-track{background:transparent}.tabs::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:2px}.tabs::-webkit-scrollbar-thumb:hover{background-color:var(--color-primary)}.tab{flex-shrink:0;white-space:nowrap;padding:.75rem 1rem;font-size:.875rem}}.segmented-control{display:inline-flex;background-color:#f5f5f5;border-radius:8px;padding:.25rem;gap:.25rem}.segmented-option{background:transparent;border:none;padding:.5rem 1rem;font-size:.9em;font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-radius:6px;transition:all .25s}.segmented-option:hover{color:var(--color-primary)}.segmented-option-active{background-color:#fff;color:var(--color-primary);box-shadow:0 1px 3px #0000001a}.tiempos-card{padding:1rem}.tiempos-kpi{display:flex;flex-direction:column;gap:1rem}.tiempos-kpi-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f9f9f9;border-radius:6px}.tiempos-kpi-label{font-size:.9rem;color:var(--color-text-secondary)}.tiempos-kpi-value{font-size:1.1rem;font-weight:600;color:var(--color-primary)}.alarmas-chart{width:100%;height:300px}.rechazos-card{padding:1rem}.rechazos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.rechazos-total{display:flex;flex-direction:column;gap:.25rem}.rechazos-total-label{font-size:.9rem;color:var(--color-text-secondary)}.rechazos-total-value{font-size:1.5rem;font-weight:600;color:var(--color-primary)}.rechazos-percent{font-size:1.25rem;font-weight:600;color:var(--color-accent)}.rechazos-breakdown{display:flex;flex-direction:column;gap:1rem}.rechazos-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:6px}.rechazos-exceso{background-color:#fff4e6}.rechazos-defecto{background-color:#e6f3ff}.rechazos-item-label{font-size:.9rem;color:var(--color-text-secondary)}.rechazos-item-value{font-size:1.1rem;font-weight:600;color:var(--color-primary)}.rechazos-mensual-chart{width:100%;height:300px}.serie-temporal-chart{width:100%;height:400px}.estado-general-tiempos-rechazos{display:flex;flex-direction:column;gap:2rem}.tiempos-rechazos-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.tiempos-card-wrapper,.rechazos-card-wrapper{min-height:600px;background-color:#fff;padding:1.5rem;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a}.alarm-metric-toggle{margin-bottom:1rem}.placeholder-content{padding:2rem;text-align:center;color:var(--color-text-secondary)}.evolucion-tiempos-chart{height:350px;margin-top:1rem}.no-data-message{display:flex;align-items:center;justify-content:center;height:100%;min-height:200px;background:#f9f9fb;border-radius:8px;border:1px dashed #e0e0e0}.no-data-message p{color:#666;font-size:14px;text-align:center}.rechazos-chart-section{margin-top:2rem}.rechazos-chart-title{font-size:1.1rem;font-weight:600;color:var(--color-primary);margin-bottom:1rem}@media(max-width:1024px){.tiempos-rechazos-grid{grid-template-columns:1fr;max-width:100%;overflow-x:hidden}}@media(max-width:768px){.estado-general-tiempos-rechazos{gap:1rem;overflow-x:hidden;max-width:100%}.tiempos-card-wrapper,.rechazos-card-wrapper{padding:1rem;min-height:auto;overflow-x:hidden;max-width:100%}}.card{background:var(--color-background);border:1px solid rgba(0,0,0,.2);border-radius:var(--radius-card);padding:1.5rem;box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a}.card-title{font-size:1.25rem;font-weight:600;color:var(--color-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.card-content{width:100%}.comparativa-bar-chart{width:100%;height:300px;min-width:0;max-width:100%;box-sizing:border-box}.comparativas{display:flex;flex-direction:column;gap:2rem;width:100%;min-width:0;max-width:100%;box-sizing:border-box}.metric-selector-card{padding:.5rem 1rem;background-color:#fff;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a;overflow-x:auto;overflow-y:hidden}.metric-selector-card .tabs{margin-bottom:0;border-bottom:none;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.metric-selector-card .tabs::-webkit-scrollbar{height:4px}.metric-selector-card .tabs::-webkit-scrollbar-track{background:transparent}.metric-selector-card .tabs::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:2px}.metric-selector-card .tab{padding:.5rem 1rem;font-size:.875rem;flex-shrink:0;white-space:nowrap}@media(max-width:768px){.metric-selector-card{padding:.5rem 0;overflow-x:visible}.metric-selector-card .tabs{padding-left:1rem;padding-right:1rem}}.comparativas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;width:100%;min-width:0;max-width:100%;box-sizing:border-box}.comparativa-panel{min-height:350px;background-color:#fff;padding:1.5rem;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a;width:100%;min-width:0;max-width:100%;box-sizing:border-box;overflow:hidden}.dashboard-loading,.dashboard-error,.dashboard-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background-color:#fff;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a;padding:2rem}.dashboard-error button{margin-top:1rem;padding:.5rem 1rem;background-color:var(--color-accent);color:#fff;border:none;border-radius:6px;cursor:pointer}.dashboard-error button:hover{opacity:.9}@media(max-width:1400px){.comparativas-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.comparativas-grid{grid-template-columns:1fr}}.analisis-historico{display:flex;flex-direction:column;gap:2rem}.serie-temporal-card{min-height:500px;background-color:#fff;padding:1.5rem;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a}.producciones-table-card{min-height:600px;background-color:#fff;padding:1.5rem;border-radius:var(--radius-card);border:1px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #00000026,0 4px 8px #0000001a}.table-title{font-size:1.25rem;font-weight:600;color:var(--color-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.producciones-table{width:100%;height:500px;margin-bottom:1rem}.table-footer{padding-top:1rem;border-top:1px solid var(--color-border);color:var(--color-text-secondary);font-size:.9rem}.chart-loading,.chart-error,.table-loading,.table-error,.table-empty{padding:2rem;text-align:center;color:var(--color-text-secondary)}.chart-error,.table-error{color:var(--color-error)}.ag-theme-alpine{--ag-header-background-color: #001a3d;--ag-header-foreground-color: white;--ag-border-color: var(--color-border);--ag-row-hover-color: #e8e8f0;--ag-row-border-color: var(--color-border)}.ag-theme-alpine .ag-header-cell{font-weight:600;background-color:#001a3d!important;color:#fff!important}.ag-theme-alpine .ag-header-cell-text,.ag-theme-alpine .ag-header-cell-label{color:#fff!important}.ag-theme-alpine .ag-row{border-bottom:1px solid var(--color-border)}.ag-theme-alpine .ag-row-odd{background-color:#fff!important}.ag-theme-alpine .ag-row-even{background-color:#f5f0f8!important}.producciones-table .ag-theme-alpine .ag-row:nth-child(2n){background-color:#f5f0f8!important}.producciones-table .ag-theme-alpine .ag-row:nth-child(odd){background-color:#fff!important}@media(max-width:768px){.analisis-historico{gap:1rem}.serie-temporal-card,.producciones-table-card{padding:1rem;min-height:auto}.producciones-table{height:400px}}.status-indicator{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.status-indicator-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600}.status-indicator-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-indicator-description{font-size:14px;color:#666;text-align:left}.traceability-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.traceability-modal-container{background:#fff;border-radius:8px;box-shadow:0 8px 32px #0000003d,0 4px 16px #00000029;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease;border:1px solid rgba(0,0,0,.12)}.traceability-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(0,0,0,.12);background:#fff;border-radius:8px 8px 0 0}.traceability-modal-title{font-size:20px;font-weight:500;color:#000000de;margin:0;letter-spacing:.15px}.traceability-modal-close{background:transparent;border:none;font-size:32px;line-height:1;color:#0000008a;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease,color .2s ease}.traceability-modal-close:hover{background-color:#00000014;color:#000000de}.traceability-modal-close:active{background-color:#0000001f}.traceability-modal-summary{position:sticky;top:0;z-index:10;background:#e0e0e0;border-bottom:1px solid rgba(0,0,0,.12);padding:16px 24px;display:flex;flex-direction:column;gap:8px;box-shadow:0 2px 4px #0000000d}.traceability-modal-summary-with-chart{flex-direction:row;gap:16px;align-items:flex-start}.traceability-summary-content{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.traceability-summary-chart{flex-shrink:0;width:300px;height:150px;background:#fff;border-radius:4px;padding:8px;box-shadow:0 1px 2px #0000001a}@media(max-width:768px){.traceability-modal-overlay{padding:10px}.traceability-modal-container{max-height:95vh}.traceability-modal-header{padding:16px}.traceability-modal-title{font-size:18px}.traceability-modal-summary{padding:12px 16px}.traceability-modal-summary-with-chart{flex-direction:column;gap:12px}.traceability-summary-content{order:1;width:100%}.traceability-summary-chart{order:2;width:100%;height:120px}.traceability-summary-item{font-size:12px;padding:6px 10px}.traceability-modal-content{padding:16px;font-size:13px}}.traceability-mini-chart{width:100%;height:100%}.traceability-summary-item{font-size:13px;color:#000000b3;line-height:1.5;padding:8px 12px;background:#fff;border-radius:4px;border-left:3px solid #1976D2;box-shadow:0 1px 2px #0000000d;display:flex;flex-direction:column;gap:4px}.traceability-summary-line{line-height:1.5}.traceability-modal-content{padding:24px;overflow-y:auto;font-size:14px;line-height:1.5;color:#000000de;flex:1}.traceability-section{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(0,0,0,.12)}.traceability-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.traceability-section-title{font-size:16px;font-weight:500;color:#000000de;margin:0 0 12px;padding:0 0 8px;border-bottom:1px solid rgba(0,0,0,.12);letter-spacing:.15px}.traceability-item{margin-bottom:16px;padding:16px;background:#fff;border-radius:4px;border-left:4px solid #FF9800;box-shadow:0 1px 3px #0000001f,0 1px 2px #0000003d;transition:box-shadow .2s ease}.traceability-item:hover{box-shadow:0 2px 6px #00000029,0 2px 4px #0000001f}.traceability-item:last-child{margin-bottom:0}.traceability-item-header{margin-bottom:8px;color:#000000de;font-size:14px;font-weight:500;letter-spacing:.15px}.traceability-item-description{color:#0009;font-size:13px;margin-top:8px;line-height:1.5}.traceability-item-detail{margin-top:12px;display:flex;flex-direction:column;gap:8px}.traceability-label{font-weight:500;color:#0009;font-size:12px;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}.traceability-code,.traceability-formula,.traceability-result{display:inline-block;padding:6px 12px;background:#e3f2fd;border-radius:16px;font-family:Roboto Mono,Courier New,monospace;font-size:12px;color:#1976d2;margin-top:4px;border:1px solid rgba(25,118,210,.2)}.traceability-query{margin-top:8px;padding:16px;background:#263238;border-radius:4px;font-family:Roboto Mono,Courier New,monospace;font-size:12px;color:#a5d6a7;overflow-x:auto;white-space:pre-wrap;word-break:break-all;line-height:1.6;border:1px solid rgba(0,0,0,.12)}.traceability-filters{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.traceability-filter-item{padding:8px 16px;background:#e8eaf6;border-radius:16px;font-size:13px;border:none;box-shadow:0 1px 2px #0000001a}.traceability-filter-field{font-weight:500;color:#3f51b5;margin-right:8px}.traceability-filter-value{color:#000000de}.traceability-notes{margin:0;padding-left:24px;color:#0009;list-style-type:disc}.traceability-notes li{margin-bottom:12px;line-height:1.5;padding-left:4px}.traceability-notes li:last-child{margin-bottom:0}.hero-kpi-card{padding:24px 32px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.hero-kpi-card-clickable{cursor:pointer;position:relative;transition:box-shadow .3s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.hero-kpi-card-clickable:before{content:"";position:absolute;inset:0;border-radius:12px;background:#00214a00;transition:background .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.hero-kpi-card-clickable:hover{box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;transform:translateY(-1px)}.hero-kpi-card-clickable:hover:before{background:#00214a0a}.hero-kpi-card-clickable:active{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;transform:translateY(0)}.hero-kpi-card-clickable:active:before{background:#00214a14}.hero-kpi-card-clickable:focus{outline:2px solid rgba(0,33,74,.4);outline-offset:2px}.hero-kpi-card-clickable:focus:not(:focus-visible){outline:none}.hero-kpi-main{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center;width:100%;max-width:100%;box-sizing:border-box}.hero-kpi-left{text-align:left}.hero-kpi-right{text-align:left;display:flex;flex-direction:column;gap:12px}.hero-kpi-label{font-size:14px;color:#666;margin-bottom:8px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.hero-kpi-value{font-size:52px;font-weight:700;color:#00214a;margin-bottom:12px;line-height:1}.hero-kpi-target{font-size:14px;color:#666;margin-top:0}.hero-kpi-latas-section{padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid #e0e0e0;text-align:left}.hero-kpi-latas-section-clickable{cursor:pointer;position:relative;transition:background-color .2s cubic-bezier(.4,0,.2,1);border-radius:8px;padding:12px;margin:-12px -12px 12px}.hero-kpi-latas-section-clickable:hover{background-color:#00214a0a}.hero-kpi-latas-section-clickable:active{background-color:#00214a14}.hero-kpi-latas-label{font-size:14px;color:#666;margin-bottom:8px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.hero-kpi-latas-value{font-size:52px;font-weight:700;color:#00214a;line-height:1}.hero-kpi-comparison{font-size:15px;color:#333;line-height:1.4;margin-top:0}.hero-kpi-difference{font-size:14px;color:#ff5200;font-weight:500;margin-top:0}@media(max-width:768px){.hero-kpi-main{grid-template-columns:1fr;gap:20px;text-align:center}.hero-kpi-left,.hero-kpi-right{text-align:center}.hero-kpi-value{font-size:42px}.hero-kpi-latas-section{text-align:center;padding-bottom:20px;margin-bottom:20px}.hero-kpi-latas-value{font-size:42px}.hero-kpi-card{padding:20px 24px}}.positive-metrics-section{padding:0;background:transparent;border-radius:0;box-shadow:none}.positive-metrics-title{font-size:24px;font-weight:700;color:#00214a;margin-bottom:16px}.positive-metrics-summary{font-size:18px;color:#333;margin-bottom:32px;line-height:1.5}.positive-metrics-list{display:flex;flex-direction:column;gap:20px}.positive-metric-item-wrapper{display:flex;flex-direction:column}.positive-metric-item{display:flex;align-items:center;gap:16px;padding:20px;background:#f5f9ff;border-radius:8px;border-left:4px solid #50C878;width:100%;max-width:100%;box-sizing:border-box;min-width:0}.positive-metric-item-clickable{cursor:pointer;position:relative;transition:box-shadow .3s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1),background-color .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.positive-metric-item-clickable:before{content:"";position:absolute;inset:0;border-radius:8px;background:#50c87800;transition:background .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.positive-metric-item-clickable:after{content:"→";position:absolute;right:20px;top:50%;transform:translateY(-50%);opacity:0;color:#50c878;font-size:18px;font-weight:700;transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);pointer-events:none}.positive-metric-item-clickable:hover{box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f;transform:translateY(-1px);background:#f0fdf4}.positive-metric-item-clickable:hover:before{background:#50c87814}.positive-metric-item-clickable:hover:after{opacity:1;transform:translateY(-50%) translate(-4px)}.positive-metric-item-clickable:active{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;transform:translateY(0)}.positive-metric-item-clickable:active:before{background:#50c8781f}.positive-metric-item-clickable:focus{outline:2px solid rgba(80,200,120,.5);outline-offset:2px}.positive-metric-item-clickable:focus:not(:focus-visible){outline:none}.positive-metric-check{font-size:24px;color:#50c878;font-weight:700;flex-shrink:0}.positive-metric-content{flex:1}.positive-metric-name-wrapper{display:flex;align-items:baseline;gap:8px;margin-bottom:4px;flex-wrap:wrap;min-width:0}.positive-metric-name{font-size:18px;font-weight:600;color:#00214a;word-wrap:break-word;overflow-wrap:break-word;min-width:0}.positive-metric-definition{font-size:12px;color:#666666b7;font-weight:400;font-style:italic;word-wrap:break-word;overflow-wrap:break-word;min-width:0}.positive-metric-value{font-size:16px;color:#666}.positive-metrics-empty{padding:0;text-align:center;color:#666;font-size:16px;background:transparent;border-radius:0;box-shadow:none}.critical-issue-card{padding:24px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #FFA500;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.critical-issue-card-clickable{cursor:pointer;position:relative;transition:box-shadow .3s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.critical-issue-card-clickable:before{content:"";position:absolute;inset:0;border-radius:12px;background:#f440;transition:background .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.critical-issue-card-clickable:after{content:"→";position:absolute;right:24px;top:24px;opacity:0;color:#f44;font-size:20px;font-weight:700;transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);pointer-events:none}.critical-issue-card-clickable:hover{box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;transform:translateY(-1px)}.critical-issue-card-clickable:hover:before{background:#ff44440a}.critical-issue-card-clickable:hover:after{opacity:1;transform:translate(-4px)}.critical-issue-card-clickable:active{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;transform:translateY(0)}.critical-issue-card-clickable:active:before{background:#ff444414}.critical-issue-card-clickable:focus{outline:2px solid rgba(255,68,68,.5);outline-offset:2px}.critical-issue-card-clickable:focus:not(:focus-visible){outline:none}.critical-issue-card-high{border-left-color:#f44}.critical-issue-card-medium{border-left-color:orange}.critical-issue-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.critical-issue-icon{font-size:24px;flex-shrink:0}.critical-issue-title{font-size:20px;font-weight:700;color:#00214a;margin:0}.critical-issue-metrics{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;padding:16px;background:#fff5f5;border-radius:8px}.critical-issue-metric{display:flex;justify-content:space-between;align-items:center}.critical-issue-metric-label{font-size:14px;color:#666}.critical-issue-metric-value{font-size:18px;font-weight:700;color:#00214a}.critical-issue-difference{font-size:14px;color:#f44;font-weight:600;text-align:right;margin-top:4px}.critical-issue-impact{font-size:16px;color:#333;line-height:1.5;margin-bottom:16px;padding:12px;background:#fff9e6;border-radius:8px}.critical-issue-action{font-size:16px;color:#333;line-height:1.5;padding:12px;background:#f0f7ff;border-radius:8px}.critical-issue-action strong,.critical-issue-impact strong{color:#00214a}.critical-issue-alarm-details{margin-bottom:20px;padding:16px;background:#fff0f0;border-radius:8px;border:1px solid #FFCCCC}.critical-issue-alarm-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:16px;color:#00214a}.critical-issue-alarm-icon{font-size:20px}.critical-issue-alarm-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.critical-issue-alarm-item{display:flex;flex-direction:column;gap:4px}.critical-issue-alarm-label{font-size:12px;color:#666;text-transform:uppercase;letter-spacing:.5px}.critical-issue-alarm-value{font-size:18px;font-weight:600;color:#00214a}.critical-issue-alarm-value-highlight{color:#f44;font-size:20px;font-weight:700}.trend-chart-wrapper{width:100%}.trend-chart{width:100%;height:300px}.trend-chart-conclusion{margin-top:1rem;padding:1rem;background-color:#f5f5f5;border-radius:6px;text-align:center}.trend-chart-conclusion p{margin:0;font-size:1rem;color:var(--color-text);font-weight:500}.trend-indicator{padding:20px;background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000001a}.trend-indicator-clickable{cursor:pointer;position:relative;transition:box-shadow .3s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.trend-indicator-clickable:before{content:"";position:absolute;inset:0;border-radius:8px;background:#00214a00;transition:background .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.trend-indicator-clickable:after{content:"→";position:absolute;right:20px;top:50%;transform:translateY(-50%);opacity:0;color:#00214a;font-size:16px;font-weight:700;transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}.trend-indicator-clickable:hover{box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f;transform:translateY(-1px)}.trend-indicator-clickable:hover:before{background:#00214a0a}.trend-indicator-clickable:hover:after{opacity:1;transform:translateY(-50%) translate(-4px)}.trend-indicator-clickable:active{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;transform:translateY(0)}.trend-indicator-clickable:active:before{background:#00214a14}.trend-indicator-clickable:focus{outline:2px solid rgba(0,33,74,.4);outline-offset:2px}.trend-indicator-clickable:focus:not(:focus-visible){outline:none}.trend-indicator-metric{font-size:14px;color:#666;margin-bottom:8px;font-weight:500}.trend-indicator-values{display:flex;align-items:baseline;gap:12px;margin-bottom:8px}.trend-indicator-current{font-size:24px;font-weight:700;color:#00214a}.trend-indicator-change{font-size:16px;font-weight:600}.trend-indicator-previous{font-size:12px;color:#999}.daily-insight-card{padding:32px;background:linear-gradient(135deg,#f0f7ff,#e8f4fd);border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #00214A;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.daily-insight-card-clickable{cursor:pointer;position:relative;transition:box-shadow .3s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.daily-insight-card-clickable:before{content:"";position:absolute;inset:0;border-radius:12px;background:#00214a00;transition:background .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.daily-insight-card-clickable:after{content:"→";position:absolute;right:32px;top:32px;opacity:0;color:#00214a;font-size:20px;font-weight:700;transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);pointer-events:none}.daily-insight-card-clickable:hover{box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;transform:translateY(-1px)}.daily-insight-card-clickable:hover:before{background:#00214a0a}.daily-insight-card-clickable:hover:after{opacity:1;transform:translate(-4px)}.daily-insight-card-clickable:active{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;transform:translateY(0)}.daily-insight-card-clickable:active:before{background:#00214a14}.daily-insight-card-clickable:focus{outline:2px solid rgba(0,33,74,.4);outline-offset:2px}.daily-insight-card-clickable:focus:not(:focus-visible){outline:none}.daily-insight-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.daily-insight-icon{font-size:28px}.daily-insight-title{font-size:20px;font-weight:700;color:#00214a;margin:0}.daily-insight-content{display:flex;flex-direction:column;gap:16px}.daily-insight-subtitle{font-size:22px;font-weight:600;color:#00214a;margin:0;line-height:1.4}.daily-insight-description{font-size:16px;color:#333;line-height:1.6;margin:0}.daily-insight-visualization{margin-top:16px;padding:20px;background:#fff;border-radius:8px}.insight-alarm-details{display:flex;flex-direction:column;gap:12px}.insight-alarm-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f5f9ff;border-radius:6px}.insight-alarm-label{font-size:14px;color:#666;font-weight:500}.insight-alarm-value{font-size:16px;color:#00214a;font-weight:600}.recommendation-card{padding:24px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #00214A;display:flex;flex-direction:column;gap:16px;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.recommendation-card-clickable{cursor:pointer;position:relative;transition:box-shadow .3s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.recommendation-card-clickable:before{content:"";position:absolute;inset:0;border-radius:12px;background:#00214a00;transition:background .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.recommendation-card-clickable:after{content:"→";position:absolute;right:24px;top:24px;opacity:0;color:#00214a;font-size:20px;font-weight:700;transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);pointer-events:none}.recommendation-card-clickable:hover{box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;transform:translateY(-1px)}.recommendation-card-clickable:hover:before{background:#00214a0a}.recommendation-card-clickable:hover:after{opacity:1;transform:translate(-4px)}.recommendation-card-clickable:active{box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f;transform:translateY(0)}.recommendation-card-clickable:active:before{background:#00214a14}.recommendation-card-clickable:focus{outline:2px solid rgba(0,33,74,.4);outline-offset:2px}.recommendation-card-clickable:focus:not(:focus-visible){outline:none}.recommendation-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.recommendation-priority{padding:4px 12px;border-radius:12px;color:#fff;font-size:12px;font-weight:600}.recommendation-metric{font-size:12px;color:#666;font-style:italic}.recommendation-action{font-size:16px;color:#333;line-height:1.5}.recommendation-action strong{color:#00214a}.recommendation-impact{font-size:15px;color:#666;line-height:1.5;padding:12px;background:#f0f7ff;border-radius:8px}.recommendation-impact strong{color:#00214a}.storytelling-dashboard{max-width:1400px;margin:0 auto;padding:40px 20px;position:relative;width:100%;box-sizing:border-box;overflow-x:hidden}.storytelling-period-selector-container{display:flex;justify-content:flex-start;align-items:center;margin-bottom:24px;padding:0 4px}.storytelling-period-selector{max-width:400px}.storytelling-toc{background:#fff;border-radius:12px;padding:20px;margin-bottom:32px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 4px -1px #0000001f,0 4px 5px #00000024,0 1px 10px #0003}.storytelling-toc-title{font-size:16px;font-weight:600;color:#00214a;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.storytelling-toc-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px}.storytelling-toc-link{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:transparent;border:1px solid rgba(0,33,74,.1);border-radius:6px;color:#00214a;font-size:14px;text-align:left;cursor:pointer;transition:all .2s ease}.storytelling-toc-link:hover{background:#00214a0d;border-color:#00214a4d;transform:translate(2px)}.storytelling-toc-number{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;background:#00214a1a;color:#00214a;border-radius:4px;font-size:12px;font-weight:600;flex-shrink:0}.storytelling-back-to-top{position:fixed;bottom:30px;right:30px;width:50px;height:50px;border-radius:50%;background:#00214a;color:#fff;border:none;font-size:24px;cursor:pointer;box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:999;display:flex;align-items:center;justify-content:center}.storytelling-back-to-top:hover{background:#036;transform:translateY(-2px);box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f}.storytelling-back-to-top:active{transform:translateY(0)}.storytelling-section{margin-bottom:32px;background:#fff;border-radius:16px;padding:24px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 4px -1px #0000001f,0 4px 5px #00000024,0 1px 10px #0003;transition:box-shadow .3s cubic-bezier(.4,0,.2,1);width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.storytelling-section:hover{box-shadow:0 3px 5px -1px #0000001f,0 6px 10px #00000024,0 1px 18px #0003}.storytelling-hero{margin-bottom:32px;box-shadow:0 2px 4px -1px #0000001f,0 4px 5px #00000024,0 1px 10px #0003;padding:0}.storytelling-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}.storytelling-content-grid .storytelling-section{margin-bottom:0}.storytelling-section-title{font-size:28px;font-weight:700;color:#00214a;margin-bottom:24px;line-height:1.3;display:flex;align-items:center;gap:12px}.storytelling-section-number{display:inline-flex;align-items:center;justify-content:center;min-width:48px;height:32px;background:#00214a1a;color:#00214a;border-radius:6px;font-size:14px;font-weight:600;padding:0 8px;flex-shrink:0}.critical-issues-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.trends-container{display:grid;grid-template-columns:2fr 1fr;gap:24px;background:transparent;padding:0;border-radius:0;box-shadow:none;border:none}.trends-chart{min-height:300px}.trend-traceability-button{margin-top:16px;padding:12px 24px;background:transparent;border:1px solid rgba(0,33,74,.2);border-radius:6px;color:#00214ab3;font-size:14px;font-weight:500;cursor:pointer;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:center;width:100%;box-shadow:none}.trend-traceability-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#00214a1a;transform:translate(-50%,-50%);transition:width .6s cubic-bezier(.4,0,.2,1),height .6s cubic-bezier(.4,0,.2,1)}.trend-traceability-button:hover{background:#00214a0d;border-color:#00214a66;color:#00214ae6;transform:translateY(-1px);box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.trend-traceability-button:hover:before{width:300px;height:300px}.trend-traceability-button:active{transform:translateY(0);box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.trend-traceability-button:active:before{background:#00214a26}.trend-traceability-button:focus{outline:2px solid rgba(0,33,74,.4);outline-offset:2px}.trend-traceability-button:focus:not(:focus-visible){outline:none}.trends-indicators{display:flex;flex-direction:column;gap:16px}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.storytelling-loading,.storytelling-error,.storytelling-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;font-size:18px;color:#666}.storytelling-error button{margin-top:16px;padding:12px 24px;background:#00214a;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:16px}.storytelling-error button:hover{background:#036}@media(max-width:1024px){.storytelling-content-grid{grid-template-columns:1fr;gap:24px}.trends-container,.critical-issues-grid,.recommendations-grid{grid-template-columns:1fr}}@media(max-width:768px){.storytelling-dashboard{padding:16px 12px;overflow-x:hidden}.storytelling-content-grid{gap:16px;margin-bottom:20px}.storytelling-section{margin-bottom:20px;padding:16px;border-radius:12px;overflow-x:hidden}.storytelling-hero{margin-bottom:20px;padding:0;overflow-x:hidden}.storytelling-section-title{font-size:20px;margin-bottom:16px;word-wrap:break-word;overflow-wrap:break-word;flex-wrap:wrap}.storytelling-section-number{min-width:40px;height:28px;font-size:12px}.critical-issues-grid{grid-template-columns:1fr;gap:16px}.trends-container{gap:16px;overflow-x:hidden}.trends-chart{min-height:250px;max-width:100%;overflow-x:hidden}.storytelling-toc{padding:16px;margin-bottom:20px}.storytelling-toc-list{grid-template-columns:1fr;gap:6px}.storytelling-toc-link{padding:8px 10px;font-size:13px}.storytelling-back-to-top{bottom:20px;right:20px;width:44px;height:44px;font-size:20px}}.storytelling-export-pdf-button{position:fixed;top:100px;right:20px;z-index:1000;display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fff;border:1px solid rgba(0,33,74,.2);border-radius:8px;color:#00214a;font-size:14px;font-weight:500;cursor:pointer;box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f;transition:all .3s cubic-bezier(.4,0,.2,1)}.storytelling-export-pdf-button:hover:not(:disabled){background:#f5f9ff;border-color:#00214a66;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;transform:translateY(-1px)}.storytelling-export-pdf-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.storytelling-export-pdf-button:disabled{opacity:.6;cursor:not-allowed}.storytelling-export-pdf-button-text{font-size:14px}@media(max-width:768px){.storytelling-export-pdf-button{top:80px;right:16px;padding:10px 16px}.storytelling-export-pdf-button-text{display:none}}@media print{.sidebar-nav,.filters-panel,.storytelling-export-pdf-button,.collapse-button,.trend-traceability-button{display:none!important}.app-header{display:block!important;position:fixed!important;bottom:0!important;left:0!important;right:0!important;width:100%!important;height:40px!important;page-break-inside:avoid;background:#fff!important;z-index:1000!important;box-shadow:none!important;padding-bottom:.25rem!important;padding-top:.25rem!important;border-top:1px solid #ddd!important}.app-header-content{padding:.25rem 1rem!important}.logo-image{height:24px!important}.app-header-title{font-size:.9rem!important}.app-header-border{height:1px!important}.app-shell{display:block!important}.main-content{display:block!important;width:100%!important;margin:0!important;padding:0!important}.app-body{display:block!important;width:100%!important}.app-main{width:100%!important;padding:1rem!important;padding-bottom:50px!important;margin:0!important;overflow:visible!important}@page{margin-bottom:45px}.storytelling-dashboard{max-width:100%!important;margin:0!important;padding:.5rem 1rem 1rem!important;page-break-inside:avoid}.storytelling-section{page-break-inside:avoid;page-break-after:auto;margin-bottom:1.5rem!important;box-shadow:none!important;border:1px solid #ddd!important}.storytelling-content-grid,.critical-issues-grid,.recommendations-grid,.trends-container{grid-template-columns:1fr!important;gap:1rem!important}.storytelling-section-title{font-size:1.5rem!important;margin-bottom:1rem!important}.trends-chart,.daily-insight-visualization{max-width:100%!important;overflow:visible!important}.hero-kpi-card,.critical-issue-card,.recommendation-card,.daily-insight-card{page-break-inside:avoid}*{box-shadow:none!important}body{width:100%!important;margin:0!important;padding:0!important}::-webkit-scrollbar{display:none!important}img{max-width:100%!important;height:auto!important}}body.printing-pdf .sidebar-nav,body.printing-pdf .filters-panel,body.printing-pdf .storytelling-export-pdf-button{display:none!important}body.printing-pdf .main-content{margin-left:0!important;width:100%!important}body.printing-pdf .app-main{width:100%!important;padding:1rem!important}.kpi-card{background:#fff;border-radius:12px;padding:20px;display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border:2px solid transparent}.kpi-card-clickable{cursor:pointer;border:none;width:100%;text-align:center}.kpi-card-clickable:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.kpi-card-clickable:active{transform:translateY(-2px)}.kpi-icon{font-size:1.75rem;line-height:1}.kpi-value{font-size:2rem;font-weight:700;color:#004e89;line-height:1}.kpi-label{font-size:.95rem;color:#6c757d;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.kpi-card-success{border-color:#28a745}.kpi-card-success .kpi-value{color:#28a745}.kpi-card-warning{border-color:#b45309}.kpi-card-warning .kpi-value{color:#b45309}.kpi-card-danger{border-color:#dc3545}.kpi-card-danger .kpi-value{color:#dc3545}@media(max-width:768px){.kpi-card{padding:14px}.kpi-icon{font-size:1.5rem}.kpi-value{font-size:1.75rem}.kpi-label{font-size:.85rem}}.line-status-card{background:#fff;border-radius:8px;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:0 1px 4px #00000014;transition:all .3s ease;border:2px solid transparent;cursor:pointer;width:100%;text-align:left;border-left:4px solid}.line-status-card:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001f}.line-status-card:active{transform:translate(2px)}.line-status-header{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.line-status-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}@keyframes pulse-slow{0%,to{opacity:1}50%{opacity:.1}}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.1}}@keyframes pulse-error{0%,to{opacity:1}50%{opacity:0}}.status-pulse-active{animation:pulse-slow 5.5s ease-in-out infinite}.status-pulse-warning{animation:pulse-warning 1.2s ease-in-out infinite}.status-pulse-error{animation:pulse-error .3s ease-in-out infinite}.status-pulse-inactive{opacity:.5}.line-status-name{font-size:1rem;font-weight:600;color:#004e89;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.line-status-info{display:flex;align-items:center;gap:20px;font-size:.9rem;flex-shrink:0}.line-machine-count{color:#6c757d;font-weight:500}.line-status-text{font-weight:500;padding:2px 8px;border-radius:4px;font-size:.85rem}.line-status-active{border-left-color:#28a745}.line-status-active .line-status-text{color:#28a745;background:#28a7451a}.line-status-warning{border-left-color:#b45309}.line-status-warning .line-status-text{color:#b45309;background:#b453091a}.line-status-error{border-left-color:#dc3545}.line-status-error .line-status-text{color:#dc3545;background:#dc35451a}.line-status-inactive{border-left-color:#6c757d}.line-status-inactive .line-status-text{color:#6c757d;background:#6c757d1a}@media(max-width:768px){.line-status-card{padding:10px 16px;flex-wrap:wrap}.line-status-icon svg{width:16px;height:16px}.line-status-name{font-size:.95rem}.line-status-info{gap:12px;font-size:.85rem;flex-basis:100%;justify-content:flex-end;padding-left:28px}}.quick-access-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border:2px solid transparent;cursor:pointer;width:100%;text-align:left}.quick-access-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026;border-color:#007bff}.quick-access-card:active{transform:translateY(-2px)}.quick-access-icon{font-size:3rem;line-height:1;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:80px;height:80px}.quick-access-icon-img{max-width:100%;max-height:100%;object-fit:contain}.quick-access-content{flex:1;min-width:0}.quick-access-title{font-size:1.2rem;font-weight:600;color:#004e89;margin:0 0 4px}.quick-access-description{font-size:.9rem;color:#6c757d;margin:0;line-height:1.4}@media(max-width:768px){.quick-access-card{padding:16px;flex-direction:column;text-align:center}.quick-access-icon{font-size:2.5rem;width:64px;height:64px}.quick-access-title{font-size:1.1rem}.quick-access-description{font-size:.85rem}}.home-view{padding:24px;max-width:1400px;margin:0 auto;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid #e9ecef}.home-title-section{flex:1}.home-title{font-size:2.25rem;font-weight:700;color:#004e89;margin:0 0 8px;letter-spacing:1px}.home-subtitle{font-size:1rem;color:#6c757d;margin:0;font-weight:500}.home-timestamp{font-size:.9rem;color:#6c757d;white-space:nowrap}.kpi-section{margin-bottom:32px}.kpi-subtitle{font-size:.85rem;color:#6b7280;margin:0 0 16px;font-weight:400;text-align:left;letter-spacing:.3px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.home-section{margin-bottom:32px}.section-title{font-size:1.5rem;font-weight:600;color:#004e89;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #e9ecef}.line-status-grid{display:flex;flex-direction:column;gap:8px}.quick-access-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.home-empty-state{text-align:center;padding:64px 24px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.home-empty-state .empty-state-icon{font-size:4rem;display:block;margin-bottom:16px}.home-empty-state h3{font-size:1.5rem;color:#004e89;margin:0 0 8px}.home-empty-state p{font-size:1rem;color:#6c757d;margin:0}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.line-status-grid{gap:8px}.quick-access-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.home-view{padding:16px}.home-header{flex-direction:column;align-items:flex-start;gap:12px}.home-title{font-size:1.5rem}.home-subtitle{font-size:.9rem}.home-timestamp{font-size:.85rem}.kpi-subtitle{font-size:.8rem;margin-bottom:12px}.kpi-grid{grid-template-columns:1fr;gap:16px}.section-title{font-size:1.25rem}.line-status-grid{gap:6px}.quick-access-grid{grid-template-columns:1fr;gap:16px}.home-empty-state{padding:48px 16px}.home-empty-state .empty-state-icon{font-size:3rem}.home-empty-state h3{font-size:1.25rem}.home-empty-state p{font-size:.9rem}}@media(max-width:480px){.home-title{font-size:1.25rem}.section-title{font-size:1.1rem}}.wizard-container{display:flex;flex-direction:column;gap:24px}.wizard-steps{display:flex;justify-content:center;gap:8px;padding-bottom:24px;border-bottom:1px solid #e9ecef}.wizard-step-indicator{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;max-width:120px;position:relative}.wizard-step-indicator:not(:last-child):after{content:"";position:absolute;top:16px;left:calc(50% + 20px);width:calc(100% - 40px);height:2px;background:#e9ecef}.wizard-step-indicator.completed:not(:last-child):after{background:#28a745}.wizard-step-number{width:32px;height:32px;border-radius:50%;background:#e9ecef;color:#6c757d;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;transition:all .3s ease;position:relative;z-index:1}.wizard-step-indicator.active .wizard-step-number{background:linear-gradient(135deg,#00214a,#004e89);color:#fff;box-shadow:0 2px 8px #00214a4d}.wizard-step-indicator.completed .wizard-step-number{background:#28a745;color:#fff}.wizard-step-title{font-size:.75rem;color:#6c757d;text-align:center;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.wizard-step-indicator.active .wizard-step-title{color:#004e89;font-weight:600}.wizard-step-indicator.completed .wizard-step-title{color:#28a745}.wizard-content{min-height:200px}.wizard-footer{display:flex;justify-content:space-between;width:100%}.wizard-footer-left,.wizard-footer-right{display:flex;gap:12px}.wizard-form-group{margin-bottom:20px}.wizard-form-group label{display:block;font-size:.875rem;font-weight:600;color:#333;margin-bottom:8px}.wizard-form-group input,.wizard-form-group select,.wizard-form-group textarea{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:.9375rem;transition:all .2s ease;background:#fff}.wizard-form-group input:focus,.wizard-form-group select:focus,.wizard-form-group textarea:focus{outline:none;border-color:#004e89;box-shadow:0 0 0 3px #004e891a}.wizard-form-group input::placeholder{color:#adb5bd}.wizard-form-group .form-hint{font-size:.75rem;color:#6c757d;margin-top:6px}.wizard-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.wizard-type-option{padding:16px;border:2px solid #e9ecef;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:center}.wizard-type-option:hover{border-color:#004e89;background:#f8f9ff}.wizard-type-option.selected{border-color:#004e89;background:linear-gradient(135deg,#00214a0d,#004e891a)}.wizard-type-option-icon{font-size:2rem;margin-bottom:8px;filter:grayscale(1)}.wizard-type-option.selected .wizard-type-option-icon{filter:none}.wizard-type-option-label{font-size:.8125rem;font-weight:600;color:#333}.wizard-summary{background:#f8f9fa;border-radius:8px;padding:20px}.wizard-summary-title{font-size:.875rem;font-weight:600;color:#004e89;margin:0 0 16px;text-transform:uppercase;letter-spacing:.5px}.wizard-summary-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e9ecef}.wizard-summary-item:last-child{border-bottom:none}.wizard-summary-label{color:#6c757d;font-size:.875rem}.wizard-summary-value{color:#333;font-weight:600;font-size:.875rem}@media(max-width:768px){.wizard-steps{gap:4px}.wizard-step-indicator{max-width:80px}.wizard-step-title{font-size:.625rem}.wizard-type-grid{grid-template-columns:repeat(2,1fr)}}.production-lines-view{width:100%;max-width:1400px;margin:0 auto;padding:24px;display:flex;flex-direction:column;gap:24px}.lines-top-header{display:flex;align-items:center;gap:1.25rem;background:#01082ad9;border-radius:16px;padding:.9rem 1.25rem;border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 30px #00000040;color:#fff}.lines-top-header-logo{width:56px;height:56px;border-radius:16px;border:1px solid rgba(255,255,255,.2);background:#fff;padding:.35rem}.lines-top-header-label{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin:0;opacity:.75;color:#fff!important}.lines-top-header-title{margin:0;font-size:clamp(1.35rem,2vw,1.9rem);font-weight:600;color:#fff!important}.factory-container{border:2px solid #007bff;border-radius:8px;padding:24px;background:#007bff05;box-shadow:0 4px 12px #007bff1a;transition:all .3s cubic-bezier(.4,0,.2,1)}.factory-container:hover{box-shadow:0 6px 20px #007bff26}.factory-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid rgba(0,123,255,.2)}.factory-title-section{display:flex;align-items:center;gap:8px}.factory-icon{font-size:1.125rem;line-height:1}.factory-title{font-size:1rem;font-weight:600;color:#007bff;margin:0;letter-spacing:.5px}.add-line-btn{width:100%;padding:8px 12px;margin-bottom:24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:2px;font-size:.75rem;font-weight:700;font-family:Courier New,monospace;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #667eea66;height:40px;text-transform:uppercase;letter-spacing:2px}.add-line-btn:hover{background:linear-gradient(135deg,#5568d3,#6538a0);box-shadow:0 4px 12px #667eea80;transform:translateY(-2px)}.add-line-icon{font-size:24px;font-weight:300;line-height:1;color:#fff!important}.add-line-text{font-size:.75rem;font-weight:700;letter-spacing:2px;color:#fff!important}.production-lines-list{display:flex;flex-direction:column;gap:24px}.production-line{background:#fff;border-radius:8px;box-shadow:0 2px 4px #00000014;padding:16px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);border:2px solid #f5f5f5}.production-line:hover{border-color:#007bff;box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.line-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.line-title-section{display:flex;align-items:center;gap:8px}.line-icon{font-size:.875rem;color:#007bff;font-weight:900}.line-title{font-size:.875rem;font-weight:600;color:#333;margin:0;cursor:pointer;letter-spacing:.3px}.line-title:hover{color:#007bff}.line-actions{display:flex;gap:2px;opacity:0;transition:opacity .2s ease}.production-line:hover .line-actions{opacity:1}.line-action-btn{padding:2px 4px;background:#fff;color:#333;border:1px solid #e0e0e0;border-radius:4px;font-size:.8125rem;cursor:pointer;transition:all .3s;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center}.line-action-delete:hover{background:#dc3545;border-color:#dc3545;color:#fff}.line-separator{height:1px;background:#e0e0e0;margin-bottom:12px}.machines-container{position:relative;display:flex;align-items:center;gap:16px;overflow-x:auto;padding:16px 0;margin:8px 0}.machines-container:before{content:"";position:absolute;top:50%;left:0;right:0;height:3px;background:linear-gradient(to right,#007bff 0% 100%);transform:translateY(-50%);z-index:0;box-shadow:0 1px 2px #007bff33}.machines-container::-webkit-scrollbar{height:4px}.machines-container::-webkit-scrollbar-track{background:#f5f5f5;border-radius:2px}.machines-container::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.machine-card{flex-shrink:0;width:90px;min-height:80px;background:#fff;border:1px solid #e0e0e0;border-radius:4px;padding:4px 8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 2px 4px #0000001f;z-index:2}.machine-card:hover{border-color:#007bff;box-shadow:0 6px 12px #007bff33;transform:translateY(-3px)}.machine-clickable:hover{transform:translateY(-4px)!important;box-shadow:0 8px 16px #007bff40!important;border-color:#0056b3!important}.machine-editable:hover{transform:translateY(-3px)!important;box-shadow:0 6px 12px #667eea33!important;border-color:#667eea!important;background:#fafbff!important}.machine-icon-placeholder{width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #667eea4d}.machine-icon-emoji{font-size:12px;font-weight:700;color:#fff;font-family:Courier New,monospace}.machine-icon-img{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));border:2px solid white;border-radius:2px;padding:1px;background:#fff}.machine-name{font-size:.625rem;font-weight:600;color:#333;text-align:center;margin:0;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.machine-status{display:flex;align-items:center;gap:2px;font-size:9px;width:100%;justify-content:center}.status-dot{font-size:10px;line-height:1}.status-active{color:#28a745}.status-warning{color:#b45309}.status-error{color:#dc3545}.status-inactive{color:#ccc}.status-text{color:#666;font-weight:700;font-size:9px;font-family:Courier New,monospace}.add-machine-btn-wrapper{display:flex;align-items:center;flex-shrink:0;margin-left:8px}.add-machine-btn{width:90px;min-height:80px;background:#fff;border:2px dashed rgba(0,123,255,.4);border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:all .3s;color:#007bff;z-index:2}.add-machine-btn:hover{border-color:#007bff;border-style:solid;color:#fff;background:#007bff;transform:translateY(-2px)}.add-machine-btn:hover .add-machine-icon,.add-machine-btn:hover .add-machine-text{color:#fff}.add-machine-icon{font-size:28px;font-weight:300;line-height:1;color:#007bff}.add-machine-text{font-size:9px;font-weight:700;text-align:center;letter-spacing:1px;font-family:Courier New,monospace;color:#007bff}.empty-state{padding:24px;text-align:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.empty-state-icon{font-size:64px;display:block;margin-bottom:12px}.empty-state h3{font-size:1rem;margin-bottom:8px;color:#333}.empty-state p{color:#666;margin-bottom:16px}.empty-state-btn{padding:8px 16px;background:#007bff;color:#fff;border:none;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .3s}.empty-state-btn:hover{background:#0056b3}@media(max-width:768px){.production-lines-view,.factory-container,.production-line{padding:8px}.machine-card,.add-machine-btn{width:80px;min-height:75px}}.hierarchy-view{padding:24px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 164px)}.hierarchy-header{margin-bottom:24px}.hierarchy-header-content{display:flex;align-items:center;gap:20px}.hierarchy-logo{width:80px;height:80px;object-fit:contain}.hierarchy-header-text{flex:1}.hierarchy-header h2{font-size:28px;font-weight:700;color:#333;margin:0 0 8px}.hierarchy-subtitle{color:#6c757d;font-size:16px;margin:0}.hierarchy-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .3s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card-active{background:linear-gradient(135deg,#d4edda,#c3e6cb);border-color:#28a745}.stat-icon{font-size:32px}.stat-content{flex:1}.stat-value{font-size:32px;font-weight:700;color:#333;line-height:1;margin-bottom:4px}.stat-label{font-size:14px;color:#6c757d;font-weight:500}.hierarchy-tree{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:32px;margin-bottom:32px;overflow-x:auto}.hierarchy-level{display:flex;flex-direction:column;align-items:flex-start}.hierarchy-node{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:12px;margin-bottom:16px;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;min-width:280px}.hierarchy-node:hover{transform:translate(4px);box-shadow:0 4px 12px #00000026}.enterprise-node{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.site-node{background:linear-gradient(135deg,#764ba2,#9f7aea);color:#fff}.area-node{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.line-node{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.line-node-clickable{cursor:pointer;transition:all .3s ease}.line-node-clickable:hover{transform:translate(8px) scale(1.02);box-shadow:0 6px 16px #0003}.line-node-clickable:active{transform:translate(8px) scale(.98)}.node-icon{font-size:28px;min-width:40px;text-align:center}.node-content{flex:1}.node-title{font-size:18px;font-weight:600;margin-bottom:4px}.node-subtitle{font-size:12px;opacity:.9;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.node-equipment-id{font-family:Courier New,monospace;font-size:11px;opacity:.8;margin-top:4px}.node-metrics{margin-top:8px}.metric-badge{display:inline-block;background:#fff3;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600}.hierarchy-children{margin-left:40px;padding-left:20px;border-left:3px solid #e0e0e0;position:relative}.hierarchy-level-enterprise>.hierarchy-children{border-left-color:#764ba2}.hierarchy-level-site>.hierarchy-children{border-left-color:#9f7aea}.hierarchy-level-area>.hierarchy-children{border-left-color:#f5576c}.hierarchy-legend{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:24px}.hierarchy-legend h3{font-size:18px;font-weight:600;color:#333;margin:0 0 16px}.legend-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-bottom:20px}.legend-item{display:flex;align-items:center;gap:12px}.legend-color{width:32px;height:32px;border-radius:6px;display:inline-block;box-shadow:0 2px 4px #0000001a}.legend-label{font-size:14px;color:#495057;font-weight:500}.hierarchy-info{padding:16px;background:#f8f9fa;border-radius:8px;margin-top:16px}.hierarchy-info p{margin:0 0 12px;font-size:14px;color:#495057;line-height:1.6}.hierarchy-info p:last-child{margin-bottom:0}.hierarchy-info strong{color:#333;font-weight:600}@media(max-width:768px){.hierarchy-view{padding:12px}.hierarchy-logo{width:50px;height:50px}.hierarchy-header h2{font-size:20px}.hierarchy-stats{grid-template-columns:repeat(2,1fr)}.hierarchy-tree{padding:12px}.hierarchy-node{min-width:180px;padding:10px 12px}.node-title{font-size:14px}.hierarchy-children{margin-left:12px;padding-left:8px}}.sim-graph-container{padding:24px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;flex:2}.sim-graph-header{display:flex;justify-content:flex-end;margin-bottom:16px}.sim-graph-label-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9375rem;font-weight:500;color:#374151;-webkit-user-select:none;user-select:none}.sim-graph-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary, #00214A)}.sim-graph-chart{width:100%;height:400px;min-height:400px}.sim-graph-stats{margin-top:24px;padding:16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.sim-graph-stat-main{text-align:center;margin-bottom:16px}.sim-graph-stat-main h4{font-size:1.125rem;font-weight:700;color:#111827;margin:0}.sim-graph-stat-details{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-bottom:16px}.sim-graph-stat-item{padding:8px 16px;border-radius:6px;min-width:150px;text-align:center;font-weight:500}.sim-graph-stat-rejected{color:#b60505;background:#b605051a}.sim-graph-stat-params{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:16px}.sim-graph-stat-param{padding:8px;border-radius:6px;text-align:center;font-weight:500;background:#fff;font-size:.875rem;color:#374151}.sim-parameter-controls{padding:24px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;height:fit-content}.sim-parameter-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 24px}.sim-preset-buttons{display:flex;gap:12px;margin-bottom:24px;justify-content:center}.sim-preset-btn{display:flex;align-items:center;gap:8px;flex:1;justify-content:center}.sim-preset-btn:disabled{opacity:.5;cursor:not-allowed}.sim-params-list{display:flex;flex-direction:column;gap:16px}.sim-param-input{border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb;overflow:hidden;transition:all .2s}.sim-param-input:hover{border-color:#d1d5db}.sim-param-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.sim-param-label{font-size:.9375rem;font-weight:600;color:#374151}.sim-param-toggle{background:none;border:none;cursor:pointer;color:#6b7280;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.sim-param-toggle:hover{color:#111827}.sim-param-content{padding:16px;display:flex;flex-direction:column;gap:12px;border-top:1px solid #e5e7eb;background:#fff}.sim-param-slider{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;-webkit-appearance:none;appearance:none}.sim-param-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary, #00214A);cursor:pointer;transition:all .2s}.sim-param-slider::-webkit-slider-thumb:hover{background:var(--primary-dark, #001a3a);transform:scale(1.1)}.sim-param-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-primary, #00214A);cursor:pointer;border:none;transition:all .2s}.sim-param-slider::-moz-range-thumb:hover{background:var(--primary-dark, #001a3a);transform:scale(1.1)}.sim-param-number{padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:.9375rem;width:100%;box-sizing:border-box}.sim-param-number:focus{outline:none;border-color:var(--color-primary, #00214A);box-shadow:0 0 0 3px #00214a1a}.sim-param-unit{font-size:.875rem;color:#6b7280;align-self:flex-end;margin-top:-32px;margin-right:12px;pointer-events:none}.gaussian-sim-modal-backdrop{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:2.5vh 2.5vw;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gaussian-sim-modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000003d,0 4px 16px #00000029;width:95vw;height:95vh;max-width:100%;max-height:100%;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.4,0,.2,1);overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.gaussian-sim-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;background:linear-gradient(135deg,var(--color-primary, #00214A) 0%,var(--hermasa-blue, #004e89) 100%);border-bottom:1px solid rgba(255,255,255,.1);position:relative;overflow:hidden}.gaussian-sim-modal-header:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(255,255,255,.03) 2px,rgba(255,255,255,.03) 4px);pointer-events:none}.gaussian-sim-modal-header-content{display:flex;align-items:center;gap:16px;position:relative;z-index:1;color:#fff}.gaussian-sim-modal-logo{height:50px;width:auto;object-fit:contain;background:#fff;padding:8px;border-radius:8px}.gaussian-sim-modal-title{font-size:1.5rem;font-weight:700;color:#fff!important;margin:0;letter-spacing:.5px}.gaussian-sim-modal-close{width:40px;height:40px;border-radius:6px;border:1px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative;z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gaussian-sim-modal-close:hover{background:#fff3;border-color:#ffffff80;transform:scale(1.05)}.gaussian-sim-modal-close:active{transform:scale(.95)}.gaussian-sim-modal-body{flex:1;overflow-y:auto;padding:24px;background:linear-gradient(to bottom,#1a1a1a,#2d2d2d);color:#fff}.gaussian-sim-modal-layout{display:flex;gap:24px;height:100%;align-items:flex-start}.sim-preset-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .2s ease}.sim-preset-dialog{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000003d;width:90%;max-width:400px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.sim-preset-dialog-large{max-width:600px}.sim-preset-dialog h3{padding:24px 24px 16px;margin:0;font-size:1.25rem;font-weight:700;color:#111827;border-bottom:1px solid #e5e7eb}.sim-preset-dialog-content{padding:24px;flex:1;overflow-y:auto}.sim-preset-dialog-input{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:1rem;box-sizing:border-box}.sim-preset-dialog-input:focus{outline:none;border-color:var(--color-primary, #00214A);box-shadow:0 0 0 3px #00214a1a}.sim-preset-dialog-warning{margin-top:8px;font-size:.875rem;color:#dc2626}.sim-preset-dialog-empty{text-align:center;color:#6b7280;padding:32px 0}.sim-preset-list{display:flex;flex-direction:column;gap:8px}.sim-preset-item{display:flex;align-items:center;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:all .2s}.sim-preset-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.sim-preset-item-content{flex:1;padding:16px;cursor:pointer}.sim-preset-item-name{font-size:1rem;font-weight:600;color:#111827;margin-bottom:4px}.sim-preset-item-details{font-size:.875rem;color:#6b7280;margin-bottom:4px}.sim-preset-item-timestamp{font-size:.75rem;color:#9ca3af;font-style:italic}.sim-preset-item-delete{padding:12px;background:transparent;border:none;border-left:1px solid #e5e7eb;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.sim-preset-item-delete:hover{background:#fee2e2;color:#dc2626}.sim-preset-dialog-actions{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;background:#f9fafb}.sim-preset-dialog-actions .tunacheck-btn.btn-secondary{background:#fff;color:#213547;border:1px solid #E6E6E6}.sim-preset-dialog-actions .tunacheck-btn.btn-secondary:hover{background:#f5f7fa;border-color:#ccc}@media(max-width:1024px){.gaussian-sim-modal-layout{flex-direction:column}.gaussian-sim-modal-content{width:98vw;height:98vh}}@media(max-width:768px){.gaussian-sim-modal-header{padding:16px 20px}.gaussian-sim-modal-title{font-size:1.125rem}.gaussian-sim-modal-logo{height:40px}.gaussian-sim-modal-body{padding:16px}.gaussian-sim-modal-layout{gap:16px}}.tunacheck-view{min-height:100%;background:linear-gradient(to bottom,#f9fafb,#f3f4f6)}.tunacheck-header-section{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;padding:16px 24px;margin-bottom:24px;border-radius:12px}.tunacheck-header-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.tunacheck-logo-section{display:flex;align-items:center;gap:16px}.tunacheck-logo{height:60px;width:auto}.tunacheck-title{font-size:1.5rem;font-weight:700;color:#333;margin:0}.tunacheck-subtitle{font-size:.875rem;color:#6c757d;margin:0}.tunacheck-actions{display:flex;align-items:center;gap:12px}.tunacheck-time-range{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:10px;border:1px solid #e5e7eb;background:#ffffffbf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tunacheck-time-range-label{font-size:.8125rem;font-weight:700;color:#fff}.tunacheck-time-range-select{padding:6px 10px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;font-size:.875rem;color:#111827}.status-badge{padding:6px 12px;border-radius:20px;font-size:.875rem;font-weight:500}.status-active{background:#d1fae5;color:#065f46}.status-inactive{background:#fee2e2;color:#991b1b}.tunacheck-btn{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid #e5e7eb;background:#fff;color:#333}.tunacheck-btn:hover{background:#f3f4f6}.tunacheck-btn.btn-primary{background:var(--color-primary, #00214A);color:#fff;border-color:var(--color-primary, #00214A)}.tunacheck-btn.btn-primary:hover{background:var(--primary-dark, #001a3a);color:#fff}.tunacheck-btn.btn-outline{background:#fff;color:var(--color-accent, #FF5200);border-color:var(--color-accent, #FF5200)}.tunacheck-btn.btn-outline:hover{background:#ff52000d}.tunacheck-content{padding:0 24px 24px}.tunacheck-sticky-controls{position:sticky;top:12px;z-index:5;margin-bottom:16px}.tunacheck-filter-label{font-size:.875rem;font-weight:600;color:#fff}.tunacheck-sticky-toggle{display:none}.tunacheck-sticky-panel{display:flex;align-items:center;gap:12px;padding:12px 16px;box-sizing:border-box;width:calc(100% + 24px);margin:0 -12px;background:#00214a26;background-image:linear-gradient(135deg,#00214a40,#00214a1f);-webkit-backdrop-filter:blur(14px) saturate(160%);backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(0,33,74,.3);border-radius:12px;box-shadow:0 2px 8px #00000014,inset 0 1px #00214a33}.tunacheck-sticky-panel-header{display:none}.tunacheck-sticky-panel-title{font-size:.875rem;font-weight:700;color:#fff}.tunacheck-sticky-panel-close{display:none}.tunacheck-filter-select{min-width:220px;padding:8px 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;font-size:.875rem;color:#111827}.tunacheck-filter-select:disabled{background:#f9fafb;color:#6b7280}.tunacheck-filter-hint{font-size:.8125rem;color:#ffffffe6}.tunacheck-filter-hint-error{color:#b91c1c}.tunacheck-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:24px}.tunacheck-stat-card{background:#fff;border-radius:12px;padding:24px;text-align:center;box-shadow:0 2px 8px #00000014;transition:all .3s}.tunacheck-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.stat-icon-container{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 12px}.stat-icon-system,.stat-icon-weight,.stat-icon-savings{background:#f3f4f6;color:#374151}.stat-title{font-size:.875rem;font-weight:500;color:#6c757d;margin:0 0 8px}.stat-value{font-size:2rem;font-weight:700;color:#333;margin-bottom:4px}.stat-value-savings{color:#059669}.stat-label{font-size:.875rem;color:#6b7280;margin:0}.stat-switch-container{display:flex;align-items:center;justify-content:center;gap:8px}.switch-btn{padding:8px 20px;border-radius:20px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.switch-on{background:#10b981;color:#fff}.switch-off{background:#e5e7eb;color:#6b7280}.switch-label{font-size:.875rem;color:#6b7280}.tunacheck-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:24px;overflow:hidden}.tunacheck-card.tunacheck-card-chart{overflow:visible}.echarts-tooltip,.echarts-tooltip *{z-index:2147483647!important}.card-header{padding:16px 24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;gap:12px}.card-header h2{font-size:1.125rem;font-weight:600;color:#333;margin:0}.card-content{padding:24px}.tc-chart-wrap{width:100%}.tc-chart-canvas{width:100%;height:100%}.tc-chart-menu{position:relative;z-index:6}.tc-chart-menu-button{width:30px;height:30px;border-radius:10px;border:1px solid rgba(17,24,39,.12);background:#ffffffd9;color:#111827cc;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:18px;line-height:1;opacity:.22;transition:opacity .16s ease,background-color .16s ease}.tunacheck-card-chart:hover .tc-chart-menu-button,.tc-chart-menu-button:focus-visible{opacity:.85}.tc-chart-menu-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:220px;padding:6px;border-radius:12px;border:1px solid rgba(17,24,39,.12);background:#fff;box-shadow:0 12px 30px #00000024}.tc-chart-menu-item{width:100%;border:0;background:transparent;text-align:left;padding:10px;border-radius:10px;cursor:pointer;font-size:.875rem;color:#111827}.tc-chart-menu-item:hover{background:#f3f4f6}.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.config-label{font-size:.875rem;font-weight:500;color:#6b7280;margin:0 0 4px}.config-value{font-size:.875rem;color:#333;margin:0}.corrections-list{list-style:disc;padding-left:20px;margin:0;font-size:.875rem;color:#6b7280}.tunacheck-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;margin-bottom:24px}.tunacheck-charts-grid .card-content{min-height:280px;padding:16px}.tunacheck-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:24px}.info-box{padding:16px;border-radius:8px;margin-bottom:16px}.info-box p{margin:0;font-size:.875rem}.info-box-blue{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.info-box-purple{background:#f5f3ff;border:1px solid #ddd6fe;color:#5b21b6}.info-highlight{font-weight:600;margin-top:8px!important}.connectivity-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.connectivity-item{display:flex;align-items:center;gap:12px;padding:16px;border-radius:8px}.connectivity-ok{background:#ecfdf5}.connectivity-warning{background:#fffbeb}.connectivity-error{background:#fef2f2}.connectivity-icon{font-size:24px}.connectivity-item h4{font-size:.875rem;font-weight:500;color:#333;margin:0 0 4px}.connectivity-item p{font-size:.875rem;margin:0}.connectivity-ok p{color:#065f46}.connectivity-warning p{color:#92400e}.connectivity-error p{color:#991b1b}.tunacheck-loading,.tunacheck-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:#6b7280}.tunacheck-loading p,.tunacheck-error p{margin:0;font-size:1rem}.tunacheck-error{color:#ef4444}.tunacheck-error .error-detail{font-size:.875rem;color:#6b7280}.spin{animation:spin 1s linear infinite}.chart-empty{display:flex;align-items:center;justify-content:center;height:250px;color:#6b7280;font-size:.875rem}@media(max-width:768px){.tunacheck-header-content{flex-direction:column;align-items:flex-start}.tunacheck-content{padding:0 12px 12px}.tunacheck-sticky-controls{position:fixed;top:72px;right:12px;left:auto;margin:0;z-index:50}.tunacheck-sticky-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid rgba(0,33,74,.3);background:#00214a33;background-image:linear-gradient(135deg,#00214a40,#00214a26);-webkit-backdrop-filter:blur(14px) saturate(160%);backdrop-filter:blur(14px) saturate(160%);box-shadow:0 2px 8px #0000001a;color:#fff;font-size:.875rem;font-weight:700;cursor:pointer}.tunacheck-sticky-toggle-text{display:none}.tunacheck-sticky-panel{display:none;width:min(280px,calc(100vw - 24px));margin:0;flex-direction:column;align-items:stretch;gap:10px;padding:12px;border-radius:14px}.tunacheck-time-range{width:100%;justify-content:space-between}.tunacheck-time-range-select{width:100%;max-width:170px}.tunacheck-sticky-controls[data-open=true] .tunacheck-sticky-panel{display:flex}.tunacheck-sticky-controls[data-open=true] .tunacheck-sticky-toggle{display:none}.tunacheck-sticky-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.tunacheck-sticky-panel-close{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:1px solid rgba(0,33,74,.3);background:#00214a33;background-image:linear-gradient(135deg,#00214a40,#00214a26);-webkit-backdrop-filter:blur(12px) saturate(160%);backdrop-filter:blur(12px) saturate(160%);cursor:pointer;color:#fff;font-size:22px;line-height:1}.tunacheck-sticky-panel-close svg{display:none}.tunacheck-filter-select{min-width:0;width:100%}.tunacheck-charts-grid,.config-grid{grid-template-columns:1fr}}@media(max-width:420px){.tunacheck-header-section{padding:8px 4px;margin-bottom:16px}.tunacheck-header-content{align-items:center;text-align:center}.tunacheck-logo-section{flex-direction:column;gap:10px}.tunacheck-actions{width:100%;justify-content:center;flex-wrap:wrap}.tunacheck-content{padding:0 4px 12px}.tunacheck-stats-grid{grid-template-columns:1fr;gap:12px;margin-bottom:16px}.tunacheck-stat-card{padding:10px 6px}.card-header{padding:8px 6px}.card-content{padding:10px 6px}.tunacheck-charts-grid .card-content{padding:12px}.tunacheck-actions-grid{grid-template-columns:1fr;gap:16px}}.main-content:has(>.tunacheck-view){padding:0!important}.main-content>.tunacheck-view{padding:0!important}.tunacheck-reporting-controls{margin:16px 0}.tunacheck-reporting-controls .tunacheck-filter-label{color:#333;margin-bottom:8px;display:block}.tunacheck-reporting-controls .tunacheck-filter-select{width:100%;background:#fff;color:#111827}.tunacheck-last-sent{margin:16px 0;padding:12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.tunacheck-last-sent .config-label{margin-bottom:4px}.tunacheck-last-sent .config-value{font-weight:600}.config-value-small{font-size:.8125rem;color:#6b7280;margin:0}.tunacheck-error-message,.tunacheck-success-message{padding:8px 12px;border-radius:6px;margin-top:8px}.tunacheck-error-message{background:#fee2e2;border:1px solid #fecaca}.tunacheck-success-message{background:#d1fae5;border:1px solid #a7f3d0}.tunacheck-btn:disabled{opacity:.6;cursor:not-allowed}.tunacheck-btn .spin{animation:spin 1s linear infinite}@media(max-width:480px){.main-content:has(>.tunacheck-view){padding:0!important}.main-content>.tunacheck-view{padding:0!important}}.password-prompt{padding:1rem 0}.password-prompt-message{margin-bottom:1.5rem;color:var(--text-secondary, #666);line-height:1.5}.password-prompt-form{display:flex;flex-direction:column;gap:1.5rem}.password-prompt-field{display:flex;flex-direction:column;gap:.5rem}.password-prompt-field label{font-weight:500;color:var(--text-primary, #333)}.password-prompt-field input{padding:.75rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:1rem;transition:border-color .2s}.password-prompt-field input:focus{outline:none;border-color:var(--primary-color, #007bff)}.password-prompt-field input.error{border-color:var(--error-color, #dc3545)}.password-prompt-field input:disabled{background-color:var(--bg-disabled, #f5f5f5);cursor:not-allowed}.error-message{color:var(--error-color, #dc3545);font-size:.875rem;margin-top:.25rem}.password-prompt-actions{display:flex;gap:.75rem;justify-content:flex-end}.password-prompt-actions .btn{min-width:100px}.table-data-viewer{display:flex;flex-direction:column;height:100%;gap:1rem}.table-data-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #ddd);flex-wrap:wrap;gap:1rem}.table-data-header h3{margin:0;font-size:1.25rem;color:var(--text-primary, #333)}.table-data-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.search-column-select,.search-input,.limit-select{padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:.9rem}.search-column-select{min-width:150px}.search-input{min-width:200px}.limit-select{min-width:120px}.table-data-container{flex:1;overflow:auto;border:1px solid var(--border-color, #ddd);border-radius:4px}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table thead{background-color:var(--primary-color, #007bff);color:#fff;position:sticky;top:0;z-index:10}.data-table thead *{color:#fff}.data-table th{padding:.75rem;text-align:left;font-weight:600;color:#fff;border-right:1px solid rgba(255,255,255,.2)}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.data-table th.sortable:hover{background-color:#ffffff1a}.data-table th:last-child{border-right:none}.data-table tbody tr{border-bottom:1px solid var(--border-color, #ddd)}.data-table tbody tr:nth-child(2n){background-color:var(--bg-hover, #f5f5f5)}.data-table tbody tr:hover{background-color:var(--bg-active, #e8e8f0)}.data-table td{padding:.75rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-right:1px solid var(--border-color, #ddd)}.data-table td:last-child{border-right:none}.null-value{color:var(--text-secondary, #999);font-style:italic}.table-data-pagination{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border-color, #ddd);flex-wrap:wrap;gap:1rem}.pagination-info{color:var(--text-secondary, #666);font-size:.9rem}.pagination-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.page-info{padding:0 .5rem;color:var(--text-secondary, #666);font-size:.9rem}.table-data-loading,.table-data-error,.table-data-empty{padding:2rem;text-align:center;color:var(--text-secondary, #666)}.table-data-error{color:var(--error-color, #dc3545)}.table-data-empty button{margin-top:1rem}.btn{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color, #007bff);color:#fff}.btn-primary *{color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-color-dark, #0056b3);color:#fff}.btn-primary:hover:not(:disabled) *{color:#fff}.btn-secondary{background-color:var(--bg-secondary, #6c757d);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--bg-secondary-dark, #5a6268)}.database-viewer{padding:2rem;height:100%;display:flex;flex-direction:column}.database-viewer-header{margin-bottom:2rem}.database-viewer-header h2{margin:0 0 .5rem;font-size:1.75rem;color:var(--text-primary, #333)}.database-viewer-header p{margin:0;color:var(--text-secondary, #666)}.database-viewer-content{display:flex;gap:2rem;flex:1;min-height:0}.tables-sidebar{width:300px;background:#fff;border:1px solid var(--border-color, #ddd);border-radius:8px;padding:1rem;overflow-y:auto}.tables-sidebar h3{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary, #333);padding-bottom:.5rem;border-bottom:1px solid var(--border-color, #ddd)}.tables-list{list-style:none;padding:0;margin:0}.tables-list li{padding:.75rem;margin-bottom:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.25rem}.tables-list li:hover{background-color:var(--bg-hover, #f5f5f5);border-color:var(--primary-color, #007bff)}.tables-list li.active{background-color:var(--primary-color, #007bff);border-color:var(--primary-color, #007bff);color:#fff}.tables-list li.active *{color:#fff}.table-name{font-weight:500;font-size:.95rem}.table-column-count{font-size:.8rem;opacity:.7}.table-viewer-main{flex:1;min-width:0;background:#fff;border:1px solid var(--border-color, #ddd);border-radius:8px;padding:1.5rem;overflow:auto}.no-table-selected{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary, #666);font-size:1.1rem}.loading,.error{padding:2rem;text-align:center;color:var(--text-secondary, #666)}.error{color:var(--error-color, #dc3545)}.user-management{padding:2rem}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.user-management-header h2{margin:0;font-size:1.75rem;color:var(--text-primary, #333)}.search-controls{display:flex;gap:.5rem}.search-input{padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;min-width:200px}.edit-user-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.edit-user-content{background:#fff;padding:2rem;border-radius:8px;max-width:500px;width:90%}.edit-user-content h3{margin:0 0 1.5rem}.edit-user-form{display:flex;flex-direction:column;gap:1rem}.form-field input[type=text],.form-field input[type=email]{padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px}.users-table-container{overflow-x:auto;border:1px solid var(--border-color, #ddd);border-radius:4px}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:var(--primary-color, #007bff)!important;color:#fff!important}.users-table thead *{color:#fff!important}.users-table th{padding:.75rem;text-align:left;font-weight:600;color:#fff!important;border-right:1px solid rgba(255,255,255,.2)}.users-table th:last-child{border-right:none}.users-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.users-table th.sortable:hover{background-color:#ffffff1a}.users-table td{padding:.75rem;border-bottom:1px solid var(--border-color, #ddd);border-right:1px solid var(--border-color, #ddd)}.users-table td:last-child{border-right:none}.users-table tbody tr:nth-child(2n){background-color:var(--bg-hover, #f5f5f5)}.users-table tbody tr:hover{background-color:var(--bg-active, #e8e8f0)}.btn-small{padding:.25rem .5rem;font-size:.85rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem}.user-management-loading,.user-management-error{padding:2rem;text-align:center}.user-management-error{color:var(--error-color, #dc3545)}.user-management .btn-primary,.user-management .btn.btn-primary{background-color:var(--primary-color, #007bff)!important;color:#fff!important}.user-management .btn-primary *,.user-management .btn.btn-primary *{color:#fff!important}.user-management .btn-primary:hover:not(:disabled),.user-management .btn.btn-primary:hover:not(:disabled){background-color:var(--primary-color-dark, #0056b3)!important;color:#fff!important}.user-management .btn-primary:hover:not(:disabled) *,.user-management .btn.btn-primary:hover:not(:disabled) *{color:#fff!important}.client-management{padding:2rem}.client-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.client-management-header h2{margin:0;font-size:1.75rem;color:var(--text-primary, #333)}.client-form-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.client-form-content{background:#fff;padding:2rem;border-radius:8px;max-width:500px;width:90%}.client-form-content h3{margin:0 0 1.5rem}.client-form{display:flex;flex-direction:column;gap:1rem}.form-field input[type=text],.form-field textarea{padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px}.clients-table-container{overflow-x:auto;border:1px solid var(--border-color, #ddd);border-radius:4px}.clients-table{width:100%;border-collapse:collapse}.clients-table thead{background-color:var(--primary-color, #007bff)!important;color:#fff!important}.clients-table thead *{color:#fff!important}.clients-table th{padding:.75rem;text-align:left;font-weight:600;color:#fff!important;border-right:1px solid rgba(255,255,255,.2)}.clients-table th:last-child{border-right:none}.clients-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.clients-table th.sortable:hover{background-color:#ffffff1a}.clients-table td{padding:.75rem;border-bottom:1px solid var(--border-color, #ddd);border-right:1px solid var(--border-color, #ddd)}.clients-table td:last-child{border-right:none}.clients-table tbody tr:nth-child(2n){background-color:var(--bg-hover, #f5f5f5)}.clients-table tbody tr:hover{background-color:var(--bg-active, #e8e8f0)}.client-management-loading,.client-management-error{padding:2rem;text-align:center}.client-management-error{color:var(--error-color, #dc3545)}.client-management .btn-primary,.client-management .btn.btn-primary{background-color:var(--primary-color, #007bff)!important;color:#fff!important}.client-management .btn-primary *,.client-management .btn.btn-primary *{color:#fff!important}.client-management .btn-primary:hover:not(:disabled),.client-management .btn.btn-primary:hover:not(:disabled){background-color:var(--primary-color-dark, #0056b3)!important;color:#fff!important}.client-management .btn-primary:hover:not(:disabled) *,.client-management .btn.btn-primary:hover:not(:disabled) *{color:#fff!important}.searchable-select{position:relative;width:100%}.searchable-select-trigger{width:100%;padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:.9rem;transition:border-color .25s;color:var(--text-primary, #333);text-align:left}.searchable-select-trigger:hover:not(.searchable-select-disabled){border-color:var(--primary-color, #007bff)}.searchable-select-trigger:focus:not(.searchable-select-disabled){outline:2px solid var(--primary-color, #007bff);outline-offset:2px}.searchable-select-trigger.searchable-select-disabled{background-color:var(--bg-disabled, #f5f5f5);cursor:not-allowed;opacity:.6}.searchable-select-trigger.searchable-select-error{border-color:var(--error-color, #dc3545)}.searchable-select-placeholder{color:var(--text-secondary, #666)}.searchable-select-arrow{color:var(--text-secondary, #666);font-size:.8rem;margin-left:.5rem;flex-shrink:0}.searchable-select-error-message{margin-top:.25rem;font-size:.75rem;color:var(--error-color, #dc3545)}.searchable-select-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background-color:#fff;border:1px solid var(--border-color, #ddd);border-radius:6px;box-shadow:0 4px 6px #0000001a;z-index:1000;max-height:300px;display:flex;flex-direction:column}.searchable-select-search{padding:.5rem;border-bottom:1px solid var(--border-color, #ddd);position:relative}.searchable-select-search input{width:100%;padding:.5rem 2rem .5rem .5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:.9rem}.searchable-select-search input:focus{outline:2px solid var(--primary-color, #007bff);outline-offset:2px}.searchable-select-loading{position:absolute;right:1rem;top:50%;transform:translateY(-50%);display:flex;align-items:center}.searchable-select-spinner{display:inline-block;animation:spin 1s linear infinite;font-size:1rem;color:var(--primary-color, #007bff)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.searchable-select-options{overflow-y:auto;max-height:250px}.searchable-select-option{display:flex;flex-direction:column;align-items:flex-start;padding:.75rem;cursor:pointer;transition:background-color .25s;border:none;background:none;width:100%;text-align:left;font-size:.9rem;gap:.25rem}.searchable-select-option:hover,.searchable-select-option-highlighted{background-color:var(--bg-hover, #f5f5f5)}.searchable-select-option-selected{background-color:var(--primary-color-light, #e7f3ff);color:var(--primary-color, #007bff);font-weight:500}.searchable-select-option-label{font-weight:500}.searchable-select-option-description{font-size:.8rem;color:var(--text-secondary, #666);font-style:italic}.searchable-select-no-results{padding:1rem;text-align:center;color:var(--text-secondary, #666);font-style:italic}.searchable-select-footer{padding:.5rem;border-top:1px solid var(--border-color, #ddd);font-size:.75rem;color:var(--text-secondary, #666);text-align:center;background-color:var(--bg-hover, #f5f5f5)}.route-multi-select{position:relative;width:100%}.route-multi-select-trigger{width:100%;padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:.9rem;transition:border-color .25s;color:var(--text-primary, #333);text-align:left}.route-multi-select-trigger:hover{border-color:var(--primary-color, #007bff)}.route-multi-select-trigger:focus{outline:2px solid var(--primary-color, #007bff);outline-offset:2px}.route-multi-select-placeholder{color:var(--text-secondary, #666)}.route-multi-select-arrow{color:var(--text-secondary, #666);font-size:.8rem;margin-left:.5rem;flex-shrink:0}.route-multi-select-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.route-multi-select-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .5rem;background-color:var(--primary-color-light, #e7f3ff);color:var(--primary-color, #007bff);border-radius:4px;font-size:.85rem;border:1px solid var(--primary-color, #007bff)}.route-multi-select-chip-label{font-weight:500}.route-multi-select-chip-remove{background:none;border:none;color:var(--primary-color, #007bff);cursor:pointer;font-size:1.2rem;line-height:1;padding:0;width:1.2rem;height:1.2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.route-multi-select-chip-remove:hover{background-color:var(--primary-color, #007bff);color:#fff}.route-multi-select-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background-color:#fff;border:1px solid var(--border-color, #ddd);border-radius:6px;box-shadow:0 4px 6px #0000001a;z-index:1000;max-height:400px;display:flex;flex-direction:column}.route-multi-select-search{padding:.5rem;border-bottom:1px solid var(--border-color, #ddd)}.route-multi-select-search input{width:100%;padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:.9rem}.route-multi-select-search input:focus{outline:2px solid var(--primary-color, #007bff);outline-offset:2px}.route-multi-select-options{overflow-y:auto;max-height:350px}.route-multi-select-category{border-bottom:1px solid var(--border-color, #ddd)}.route-multi-select-category:last-child{border-bottom:none}.route-multi-select-category-header{width:100%;display:flex;align-items:center;gap:.5rem;padding:.75rem;background-color:var(--bg-hover, #f5f5f5);border:none;cursor:pointer;text-align:left;font-weight:600;font-size:.85rem;transition:background-color .2s}.route-multi-select-category-header:hover{background-color:var(--bg-active, #e8e8f0)}.route-multi-select-category-header.route-multi-select-category-all-selected{background-color:var(--primary-color-light, #e7f3ff);color:var(--primary-color, #007bff)}.route-multi-select-category-header.route-multi-select-category-some-selected{background-color:var(--primary-color-light, #e7f3ff);color:var(--primary-color, #007bff);opacity:.8}.route-multi-select-category-checkbox{font-size:1rem;width:1.2rem;text-align:center}.route-multi-select-category-label{flex:1;text-transform:uppercase;letter-spacing:.5px}.route-multi-select-category-count{font-size:.75rem;opacity:.7}.route-multi-select-category-routes{padding:.25rem 0}.route-multi-select-option{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem .5rem 2rem;cursor:pointer;transition:background-color .25s;border:none;background:none;width:100%;text-align:left;font-size:.9rem}.route-multi-select-option:hover:not(.route-multi-select-option-disabled){background-color:var(--bg-hover, #f5f5f5)}.route-multi-select-option-selected{background-color:var(--primary-color-light, #e7f3ff);color:var(--primary-color, #007bff)}.route-multi-select-option-disabled{opacity:.5;cursor:not-allowed}.route-multi-select-option-already-granted{position:relative}.route-multi-select-option-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.route-multi-select-option-label{font-weight:500}.route-multi-select-option-path{font-size:.75rem;color:var(--text-secondary, #666);font-family:monospace}.route-multi-select-option input[type=checkbox]{margin-right:0;cursor:pointer;flex-shrink:0}.route-multi-select-option-badge{font-size:.7rem;padding:.125rem .375rem;background-color:#ffc107;color:#212529;border-radius:3px;font-weight:600;white-space:nowrap}.route-multi-select-no-results{padding:1rem;text-align:center;color:var(--text-secondary, #666);font-style:italic}.existing-permissions-panel{margin-top:1rem;padding:1rem;background-color:var(--bg-hover, #f5f5f5);border-radius:6px;border:1px solid var(--border-color, #ddd)}.existing-permissions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.existing-permissions-title{font-weight:600;font-size:.9rem;color:var(--text-primary, #333);margin-right:.5rem}.existing-permissions-count{font-size:.85rem;color:var(--text-secondary, #666)}.existing-permissions-toggle{padding:.25rem .75rem;background-color:var(--primary-color, #007bff);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .2s}.existing-permissions-toggle:hover{background-color:var(--primary-color-dark, #0056b3)}.existing-permissions-content{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color, #ddd)}.existing-permissions-empty{padding:1rem;text-align:center;color:var(--text-secondary, #666);font-style:italic}.existing-permissions-category{margin-bottom:1rem}.existing-permissions-category:last-child{margin-bottom:0}.existing-permissions-category-title{font-size:.85rem;font-weight:600;color:var(--text-primary, #333);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.existing-permissions-list{display:flex;flex-direction:column;gap:.5rem}.existing-permission-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background-color:#fff;border-radius:4px;border:1px solid var(--border-color, #ddd);font-size:.85rem}.existing-permission-path{flex:1;font-weight:500;color:var(--text-primary, #333)}.existing-permission-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.existing-permission-badge-granted{background-color:#d4edda;color:#155724}.existing-permission-badge-denied{background-color:#f8d7da;color:#721c24}.existing-permission-date{font-size:.75rem;color:var(--text-secondary, #666);white-space:nowrap}.existing-permissions-view-all{margin-top:1rem;padding:.5rem 1rem;background-color:transparent;color:var(--primary-color, #007bff);border:1px solid var(--primary-color, #007bff);border-radius:4px;cursor:pointer;font-size:.85rem;width:100%;transition:all .2s}.existing-permissions-view-all:hover{background-color:var(--primary-color, #007bff);color:#fff}.page-permission-management{padding:2rem}.page-permission-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-permission-header h2{margin:0;font-size:1.75rem;color:var(--text-primary, #333)}.filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filters select{padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;min-width:200px}.permission-form-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.permission-form-content{background:#fff;padding:2rem;border-radius:8px;max-width:700px;width:90%;max-height:90vh;overflow-y:auto;position:relative}.permission-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.permission-form-header h3{margin:0;font-size:1.5rem}.permission-form-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:var(--text-secondary, #666);padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.permission-form-close:hover{background-color:var(--bg-hover, #f5f5f5);color:var(--text-primary, #333)}.permission-form{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-weight:500}.form-field input[type=text],.form-field select{padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px}.form-field select[multiple]{min-height:120px;padding:.5rem}.form-field select[multiple] option{padding:.5rem;border-bottom:1px solid rgba(0,0,0,.05)}.form-field select[multiple] option:checked{background-color:var(--primary-color, #007bff);color:#fff}.page-paths-select{width:100%}.page-paths-select[multiple]{min-height:150px;max-height:250px;overflow-y:auto}.form-hint{font-size:.75rem;color:var(--text-secondary, #666);margin-top:.25rem;font-style:italic}.form-field input[type=checkbox]{margin-right:.5rem}.form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.permissions-table-container{overflow-x:auto;border:1px solid var(--border-color, #ddd);border-radius:4px}.permissions-table{width:100%;border-collapse:collapse}.permissions-table thead{background-color:var(--primary-color, #007bff)!important;color:#fff!important}.permissions-table thead *{color:#fff!important}.permissions-table th{padding:.75rem;text-align:left;font-weight:600;color:#fff!important;border-right:1px solid rgba(255,255,255,.2)}.permissions-table th:last-child{border-right:none}.permissions-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.permissions-table th.sortable:hover{background-color:#ffffff1a}.permissions-table td{padding:.75rem;border-bottom:1px solid var(--border-color, #ddd);border-right:1px solid var(--border-color, #ddd)}.permissions-table td:last-child{border-right:none}.permissions-table tbody tr:nth-child(2n){background-color:var(--bg-hover, #f5f5f5)}.permissions-table tbody tr:hover{background-color:var(--bg-active, #e8e8f0)}.btn-small{padding:.25rem .5rem;font-size:.85rem;margin-right:.5rem}.btn-danger{background-color:var(--error-color, #dc3545);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--error-color-dark, #c82333)}.empty-state{padding:2rem;text-align:center;color:var(--text-secondary, #666)}.page-permission-loading,.page-permission-error{padding:2rem;text-align:center}.page-permission-error{color:var(--error-color, #dc3545)}.page-permission-management .btn-primary,.page-permission-management .btn.btn-primary{background-color:var(--primary-color, #007bff)!important;color:#fff!important}.page-permission-management .btn-primary *,.page-permission-management .btn.btn-primary *{color:#fff!important}.page-permission-management .btn-primary:hover:not(:disabled),.page-permission-management .btn.btn-primary:hover:not(:disabled){background-color:var(--primary-color-dark, #0056b3)!important;color:#fff!important}.page-permission-management .btn-primary:hover:not(:disabled) *,.page-permission-management .btn.btn-primary:hover:not(:disabled) *{color:#fff!important}.contextual-info-card{margin-top:1rem;padding:1rem;background-color:var(--bg-hover, #f5f5f5);border-radius:6px;border:1px solid var(--border-color, #ddd)}.contextual-info-card h4{margin:0 0 .75rem;font-size:.9rem;font-weight:600;color:var(--text-primary, #333)}.contextual-info-content{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem}.contextual-info-content div{display:flex;gap:.5rem}.contextual-info-content strong{min-width:120px;color:var(--text-secondary, #666)}.preview-summary{margin-top:1rem;padding:1rem;background-color:#e7f3ff;border-radius:6px;border:1px solid var(--primary-color, #007bff)}.preview-summary h4{margin:0 0 .75rem;font-size:.9rem;font-weight:600;color:var(--primary-color, #007bff)}.preview-summary-content{font-size:.85rem;color:var(--text-primary, #333)}.preview-summary-content p{margin:0 0 .75rem}.preview-routes-list{margin-top:.75rem}.preview-routes-list ul{margin:.5rem 0 0;padding-left:1.5rem}.preview-routes-list li{margin:.25rem 0}.form-error-message{margin-top:.25rem;font-size:.75rem;color:var(--error-color, #dc3545)}@media(max-width:768px){.page-permission-management{padding:1rem}.page-permission-header{flex-direction:column;align-items:flex-start;gap:1rem}.page-permission-header h2{font-size:1.5rem}.permission-form-content{max-width:90vw;padding:1.5rem;max-height:95vh}.permission-form-header h3{font-size:1.25rem}.filters{flex-direction:column}.filters select{width:100%;min-width:unset}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.permissions-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.permissions-table{font-size:.85rem}.permissions-table th,.permissions-table td{padding:.5rem}.contextual-info-content{font-size:.8rem}.contextual-info-content div{flex-direction:column;gap:.25rem}.contextual-info-content strong{min-width:unset}}@media(max-width:480px){.permission-form-content{padding:1rem}.permission-form-header h3{font-size:1.1rem}}.admin-view{display:flex;flex-direction:column;height:100%;padding:2rem}.admin-view-header{margin-bottom:2rem}.admin-view-header h1{margin:0 0 .5rem;font-size:2rem;color:var(--text-primary, #333)}.admin-view-header p{margin:0;color:var(--text-secondary, #666)}.admin-view-content{flex:1;overflow:auto}.admin-view .tab[style*=background][style*="#00214A"],.admin-view .tab[style*=background][style*="#004e89"],.admin-view .tab[style*=background][style*="#003366"],.admin-view .tab[style*=background][style*="00214A"],.admin-view .tab[style*=background][style*="#00214A"] *,.admin-view .tab[style*=background][style*="#004e89"] *,.admin-view .tab[style*=background][style*="#003366"] *{color:#fff!important}.admin-view .btn-primary,.admin-view .btn.btn-primary{background-color:var(--primary-color, #007bff)!important;color:#fff!important}.admin-view .btn-primary *,.admin-view .btn.btn-primary *{color:#fff!important}.admin-view .btn-primary:hover:not(:disabled),.admin-view .btn.btn-primary:hover:not(:disabled){background-color:var(--primary-color-dark, #0056b3)!important;color:#fff!important}.admin-view .btn-primary:hover:not(:disabled) *,.admin-view .btn.btn-primary:hover:not(:disabled) *{color:#fff!important}.admin-view thead{background-color:var(--primary-color, #007bff)!important;color:#fff!important}.admin-view thead *,.admin-view th{color:#fff!important}.access-denied-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.access-denied-content{background:#fff;border-radius:12px;padding:3rem 2rem;max-width:500px;width:100%;text-align:center;box-shadow:0 10px 40px #0003}.access-denied-icon{font-size:4rem;margin-bottom:1rem}.access-denied-content h1{font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:1rem}.access-denied-message{font-size:1.1rem;color:#4a5568;margin-bottom:1.5rem;line-height:1.6}.attempted-path{background:#f7fafc;border-radius:8px;padding:1rem;margin-bottom:2rem;font-size:.9rem;color:#718096}.attempted-path code{display:block;margin-top:.5rem;font-family:Courier New,Courier,monospace;color:#2d3748;font-weight:600;word-break:break-all}.access-denied-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.access-denied-actions button{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.access-denied-actions .btn-primary{background:#667eea;color:#fff}.access-denied-actions .btn-primary:hover{background:#5a67d8;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.access-denied-actions .btn-secondary{background:#e2e8f0;color:#2d3748}.access-denied-actions .btn-secondary:hover{background:#cbd5e0;transform:translateY(-2px)}
