*{margin:0;padding:0;box-sizing:border-box}:root[data-theme=dark]{--bg-primary: #0a0e27;--bg-secondary: rgba(15, 23, 42, .95);--bg-tertiary: rgba(30, 41, 59, .6);--bg-card: rgba(15, 23, 42, .8);--bg-hover: rgba(30, 41, 59, .4);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-tertiary: #64748b;--border-primary: rgba(148, 163, 184, .1);--border-secondary: rgba(148, 163, 184, .2);--border-hover: rgba(96, 165, 250, .3);--accent-primary: #60a5fa;--accent-secondary: #a78bfa;--accent-gradient: linear-gradient(135deg, #60a5fa 0%, #a78bfa 100%);--success: #10b981;--error: #ef4444;--warning: #f59e0b;--info: #3b82f6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4);--bg-gradient-1: radial-gradient(at 0% 0%, rgba(30, 58, 138, .15) 0px, transparent 50%);--bg-gradient-2: radial-gradient(at 100% 100%, rgba(139, 92, 246, .15) 0px, transparent 50%)}:root[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-tertiary: #e2e8f0;--bg-card: #f1f5f9;--bg-hover: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-tertiary: #64748b;--border-primary: rgba(148, 163, 184, .2);--border-secondary: rgba(148, 163, 184, .3);--border-hover: rgba(59, 130, 246, .4);--accent-primary: #3b82f6;--accent-secondary: #8b5cf6;--accent-gradient: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--success: #059669;--error: #dc2626;--warning: #d97706;--info: #2563eb;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .15);--bg-gradient-1: radial-gradient(at 0% 0%, rgba(59, 130, 246, .1) 0px, transparent 50%);--bg-gradient-2: radial-gradient(at 100% 100%, rgba(139, 92, 246, .1) 0px, transparent 50%)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);background-image:var(--bg-gradient-1),var(--bg-gradient-2);min-height:100vh;margin:0;padding:0;color:var(--text-primary);overflow-x:hidden;transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}.navbar{position:sticky;top:0;z-index:1000;background:var(--bg-secondary);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-primary);box-shadow:var(--shadow-md);transition:background-color .3s ease,border-color .3s ease}.navbar-container{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.navbar-left{display:flex;align-items:center}.navbar-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text-primary);transition:opacity .2s ease}.navbar-logo:hover{opacity:.8}.logo-icon{width:32px;height:32px;color:var(--accent-primary);display:flex;align-items:center;justify-content:center}.logo-icon svg{width:100%;height:100%}.navbar-title{font-size:1.5em;font-weight:700;letter-spacing:-.02em;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-right{display:flex;align-items:center}.navbar-actions{position:relative;display:flex;align-items:center;gap:12px}.theme-toggle-button{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:10px;padding:10px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.theme-toggle-button:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--accent-primary);transform:scale(1.05)}.theme-toggle-button svg{width:20px;height:20px}.config-button{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:10px;padding:10px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.config-button:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--accent-primary);transform:rotate(90deg)}.config-button svg{width:20px;height:20px}.config-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-secondary);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-primary);border-radius:12px;box-shadow:var(--shadow-lg);min-width:220px;padding:8px;animation:slideDown .2s ease;transition:background-color .3s ease,border-color .3s ease}.config-menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-primary);cursor:pointer;border-radius:8px;transition:all .2s ease;font-size:.95em;text-decoration:none}.config-menu-item:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.config-menu-item svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none}.config-menu-divider{height:1px;background:var(--border-primary);margin:8px 0}.service-container{margin:0;border-bottom:1px solid var(--border-primary)}.service-container:last-child{border-bottom:none}.service-item{display:flex;align-items:center;padding:12px 16px;background:transparent;transition:all .2s ease;position:relative;min-height:48px}.service-item:hover{background:var(--bg-hover)}.status-indicator{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-right:14px;flex-shrink:0;position:relative;transition:all .3s ease}.status-indicator.success{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 0 #10b98166,0 4px 6px -1px #10b98133}.status-indicator.success:before{content:"";position:absolute;width:100%;height:100%;border-radius:8px;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%)}.status-indicator.error{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 0 #ef444466,0 4px 6px -1px #ef444433;animation:pulse-error 2s infinite}@keyframes pulse-error{0%,to{box-shadow:0 0 #ef444466,0 4px 6px -1px #ef444433}50%{box-shadow:0 0 0 4px #ef444400,0 4px 6px -1px #ef444433}}.status-indicator.error:before{content:"";position:absolute;width:100%;height:100%;border-radius:8px;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%)}.status-icon{width:18px;height:18px;position:relative;z-index:1}.status-icon svg{width:100%;height:100%;stroke:#fff;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round}.service-name-container{flex:1;display:flex;align-items:center;gap:8px}.service-name{flex:1;font-size:.95em;color:var(--text-primary);font-weight:500;letter-spacing:-.01em}.service-system-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75em;font-weight:600;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-primary);white-space:nowrap}.chevron-button{background:transparent;border:none;cursor:pointer;margin-left:10px;padding:4px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease;color:var(--text-secondary)}.chevron-button:hover{color:var(--text-primary)}.chevron-button.active{transform:rotate(180deg)}.chevron-icon{width:18px;height:18px}.chevron-icon svg{width:100%;height:100%;stroke:currentColor;stroke-width:2.5;fill:none;stroke-linecap:round;stroke-linejoin:round}.alert{display:flex;gap:10px;align-items:flex-start;border-radius:8px;border:1px solid;padding:10px 14px;margin:0;animation:slideDown .3s ease}.alert-success{background:#10b9811a;border-color:#10b9814d}.alert-error{background:#ef44441a;border-color:#ef44444d}.alert-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px}.alert-icon svg{width:100%;height:100%;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}.alert-success .alert-icon{color:var(--success)}.alert-error .alert-icon{color:var(--error)}.alert-content{flex:1;min-width:0}.alert-title{font-weight:600;font-size:.95em;margin-bottom:2px;line-height:1.3;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.alert-success .alert-title{color:var(--success)}.alert-error .alert-title{color:var(--error)}.alert-description{font-size:.875em;line-height:1.4;margin-top:2px}.alert-success .alert-description,.alert-error .alert-description{color:var(--text-primary);opacity:.9}.alert-info-item{margin-top:4px}.alert-info-item:first-child{margin-top:0}.alert-info-item strong{font-weight:600;margin-right:6px}.alert-info-item small{font-size:.85em;opacity:.9}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.system-card{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:var(--shadow-md);border:1px solid var(--border-primary);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%;height:214px;display:flex;flex-direction:column;cursor:pointer}.system-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--border-hover)}.system-header{background:var(--accent-gradient);color:#fff;padding:22px;font-size:1.4em;font-weight:600;text-align:center;border-bottom:1px solid var(--border-primary);position:relative;overflow:hidden}.system-header-content{display:flex;justify-content:space-between;align-items:center;gap:12px}.system-header-content span{color:#fff!important}.system-stats{display:flex;gap:8px;align-items:center}.stat-badge{padding:4px 10px;border-radius:12px;font-size:.65em;font-weight:700;min-width:28px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff}.stat-badge.stat-ok{background:var(--success);color:#fff;border:1px solid var(--success);box-shadow:0 2px 4px #10b9814d;cursor:pointer;transition:opacity .2s ease,transform .15s ease}.stat-badge.stat-ok:hover{opacity:.85;transform:scale(1.08)}.stat-badge.stat-ok.stat-badge-active{outline:2px solid white;outline-offset:1px}.stat-badge.stat-error{background:var(--error);color:#fff;border:1px solid var(--error);box-shadow:0 2px 4px #ef44444d}.system-header:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.system-card:hover .system-header:before{left:100%}.services-table{padding:0;background:transparent;display:flex;flex-direction:column;border-top:1px solid var(--border-primary);overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.services-table::-webkit-scrollbar{width:8px}.services-table::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.services-table::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px;transition:background .2s ease}.services-table::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.empty-state{text-align:center;padding:50px;color:var(--text-secondary)}.empty-state p{font-size:1.1em}.all-ok-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;color:var(--success);opacity:.7}.all-ok-state svg{width:36px;height:36px}.all-ok-state span{font-size:.9em;font-weight:500}.view-more-indicator{display:block;text-align:center;margin-top:18px;padding:12px;color:var(--accent-primary);font-weight:500;font-size:.9em;opacity:.8;pointer-events:none}.sentry-card{border-left:4px solid #f87171}.system-card.sentry-card{height:600px;max-height:80vh}.sentry-header{background:linear-gradient(135deg,#1e293b,#334155)}.sentry-stats-bar{display:flex;gap:16px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap}.sentry-stat-item{font-size:12px;display:flex;align-items:center;gap:4px}.sentry-stat-item strong{font-weight:600;font-size:14px}.sentry-issue-item{border-left:3px solid transparent;transition:all .2s ease}.sentry-issue-item:hover{background-color:var(--bg-hover, rgba(148, 163, 184, .05));border-left-color:#f87171}.sentry-issue-item .service-main{display:flex;flex-direction:column;gap:6px;width:100%}.sentry-issue-item .service-name-container{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.sentry-issue-item .service-name{flex:1;min-width:0;font-weight:500;color:var(--text-primary, #f1f5f9);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sentry-issue-item .service-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--text-secondary, #94a3b8)}.sentry-issue-item .service-value{font-family:Courier New,monospace;background:#94a3b81a;padding:2px 6px;border-radius:4px}.sentry-issue-item .service-date{color:var(--text-secondary, #94a3b8)}.sentry-issue-item .service-comment{font-size:12px;color:var(--text-secondary, #94a3b8);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;white-space:nowrap}.status-unresolved{background-color:#f8717133;color:#f87171;border:1px solid rgba(248,113,113,.3)}.status-resolved{background-color:#22c55e33;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.dashboard-container{max-width:1400px;margin:0 auto;padding:30px 20px}.retry-button{margin-top:10px;padding:12px 24px;background:var(--bg-tertiary);color:var(--accent-primary);border:1px solid var(--border-hover);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.header-section{margin-bottom:24px;position:relative}.last-update{color:var(--text-tertiary);font-size:.85em;font-weight:400}.last-update-corner{position:absolute;top:0;right:0;margin:0}.stats-bar{display:flex;justify-content:center;gap:20px;margin-top:30px;flex-wrap:wrap}.stat-item{background:var(--bg-tertiary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-primary);border-radius:12px;padding:20px 30px;color:var(--text-primary);min-width:140px;text-align:center;transition:all .3s ease}.stat-item:hover{transform:translateY(-4px);border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.stat-item.stat-success{border-left:3px solid var(--success)}.stat-item.stat-error{border-left:3px solid var(--error)}.stat-item.stat-systems{border-left:3px solid var(--accent-primary)}.stat-value{font-size:2em;font-weight:700;color:var(--accent-primary);margin-bottom:5px}.stat-item.stat-success .stat-value{color:var(--success)}.stat-item.stat-error .stat-value{color:var(--error)}.stat-label{font-size:.85em;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:25px;max-width:100%}.dashboard-card-wrapper{cursor:grab;min-height:0}.dashboard-card-wrapper:active{cursor:grabbing}.dashboard-card-wrapper.dashboard-card-drag-over{outline:2px dashed var(--accent-primary);outline-offset:4px;border-radius:16px;background:var(--bg-hover)}@media(max-width:1200px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}}.sentry-project-block{margin-bottom:24px}.sentry-issues-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-primary, #334155)}.sentry-issues-list{display:flex;flex-direction:column;gap:16px;margin-top:16px}.sentry-issue-card{background:var(--bg-card, #1e293b);border:1px solid var(--border-primary, #334155);border-radius:8px;padding:16px;transition:all .2s ease}.sentry-issue-card:hover{border-color:var(--accent-primary, #3b82f6);box-shadow:0 2px 8px #3b82f61a}.sentry-issue-header{margin-bottom:12px}.sentry-issue-title-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.sentry-issue-level-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;border:1px solid}.sentry-issue-short-id{font-family:Courier New,monospace;font-size:12px;color:var(--text-secondary, #94a3b8);background:#94a3b81a;padding:2px 6px;border-radius:4px}.sentry-issue-title{font-size:16px;font-weight:600;color:var(--text-primary, #f1f5f9);margin:0;line-height:1.4;word-break:break-word}.sentry-issue-details{display:flex;flex-direction:column;gap:10px}.sentry-issue-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--text-secondary, #94a3b8)}.sentry-issue-stat{display:flex;align-items:center;gap:4px}.sentry-issue-stat strong{color:var(--text-primary, #f1f5f9);font-weight:600}.sentry-issue-culprit{font-size:13px;color:var(--text-secondary, #94a3b8);font-family:Courier New,monospace;background:#94a3b81a;padding:8px 12px;border-radius:4px;word-break:break-all}.sentry-issue-culprit strong{color:var(--text-primary, #f1f5f9);margin-right:8px}.sentry-issue-dates{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary, #94a3b8)}.sentry-issue-dates span{display:flex;gap:8px}.sentry-issue-dates strong{color:var(--text-primary, #f1f5f9);min-width:100px}.sentry-issue-actions{margin-top:8px;padding-top:12px;border-top:1px solid var(--border-secondary, #475569)}.sentry-issue-link{color:var(--accent-primary, #3b82f6);text-decoration:none;font-size:13px;font-weight:500;transition:color .2s ease}.sentry-issue-link:hover{color:var(--accent-hover, #60a5fa);text-decoration:underline}.sentry-no-issues{text-align:center;padding:32px;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:8px}.sentry-no-issues p{margin:0;color:#22c55e;font-size:14px;font-weight:500}@media(max-width:768px){.sentry-issue-meta{flex-direction:column;gap:8px}.sentry-issue-dates{font-size:11px}.sentry-issue-dates span{flex-direction:column;gap:2px}.sentry-issue-dates strong{min-width:auto}}.detalle-container{max-width:1200px;margin:0 auto;padding:30px 20px;min-height:calc(100vh - 80px)}.header{margin-bottom:30px}.back-link{display:inline-flex;align-items:center;gap:8px;margin-bottom:25px;padding:12px 20px;background:var(--bg-tertiary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--accent-primary);text-decoration:none;border-radius:10px;transition:all .2s ease;border:1px solid var(--border-hover);font-weight:500}.back-link:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translate(-4px)}.detalle-title{color:var(--text-primary);text-align:center;margin-bottom:8px;font-size:2.2em;font-weight:700;letter-spacing:-.02em;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-container p{color:var(--text-secondary);font-size:1.1em}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;text-align:center;padding:40px}.error-icon{width:64px;height:64px;color:var(--error);margin-bottom:10px}.error-icon svg{width:100%;height:100%}.error-container h3{color:var(--text-primary);font-size:1.5em;margin:0}.error-container p{color:var(--text-secondary);font-size:1em}.retry-button{margin-top:10px;padding:12px 24px;background:var(--bg-tertiary);color:var(--accent-primary);border:1px solid var(--border-hover);border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease;text-decoration:none;display:inline-block}.retry-button:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translateY(-2px)}.header .subtitle{color:var(--text-secondary);text-align:center;font-size:1em;margin-bottom:20px;font-weight:400}.stats{text-align:center;color:var(--text-primary);margin-bottom:20px;padding:16px 20px;background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:1px solid var(--border-primary);box-shadow:var(--shadow-md)}.stats strong{color:var(--accent-primary);font-size:1.1em}.stats-value{font-size:1.5em;font-weight:700;color:var(--accent-primary);margin-left:8px}.system-card{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:var(--shadow-md);border:1px solid var(--border-primary);overflow:hidden;display:flex;flex-direction:column;min-height:400px;transition:background-color .3s ease,border-color .3s ease}.system-header{background:var(--accent-gradient);color:#fff;padding:22px;font-size:1.4em;font-weight:600;text-align:center;border-bottom:1px solid var(--border-primary);position:relative;overflow:hidden;flex-shrink:0}.system-header span,.system-header div{color:#fff!important}.services-list{display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;padding:0;background:transparent}.services-list::-webkit-scrollbar{width:8px}.services-list::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.services-list::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px;transition:background .2s ease}.services-list::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.servicio-detalle-block{border-bottom:1px solid var(--border-primary);padding:20px;background:var(--bg-tertiary);margin:0 12px 12px;border-radius:12px}.servicio-detalle-block:last-child{border-bottom:none;margin-bottom:0}.historial-section{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:20px;align-items:start}@media(max-width:900px){.historial-section{grid-template-columns:1fr}}.historial-subtitle{color:var(--text-secondary);font-size:.95em;font-weight:600;margin:0 0 12px}.historial-chart-wrap,.historial-table-wrap{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:12px;padding:16px;min-height:180px}.historial-empty{color:var(--text-tertiary);font-size:.9em;margin:20px 0;text-align:center}.historial-table-scroll{overflow-x:auto;max-height:280px;overflow-y:auto}.historial-table{width:100%;border-collapse:collapse;font-size:.9em}.historial-table th,.historial-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-primary)}.historial-table th{color:var(--text-secondary);font-weight:600;background:var(--bg-tertiary);position:sticky;top:0}.historial-table td{color:var(--text-primary)}.cell-comentario{max-width:320px;word-break:break-word;color:var(--text-secondary)}.status-ok{color:var(--success, #22c55e);font-weight:600}.status-error{color:var(--error, #ef4444);font-weight:600}.mantenedor-container{max-width:1400px;margin:0 auto;padding:30px 20px}.mantenedor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.mantenedor-header h1{color:var(--text-primary);font-size:2em;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-primary{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#60a5fa,#4f46e5);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #60a5fa4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 12px #60a5fa66}.btn-primary svg{width:20px;height:20px;stroke:currentColor;stroke-width:2.5;fill:none}.error-message{background:#ef444433;border:1px solid rgba(239,68,68,.5);color:#fca5a5;padding:12px 16px;border-radius:8px;margin-bottom:20px}.servicios-table-container{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid var(--border-primary);overflow:hidden;overflow-x:auto;transition:background-color .3s ease,border-color .3s ease}.servicios-table{width:100%;border-collapse:collapse}.servicios-table thead{background:var(--bg-tertiary)}.servicios-table th{padding:16px;text-align:left;color:var(--text-primary);font-weight:600;font-size:.9em;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-primary)}.servicios-table td{padding:16px;color:var(--text-primary);border-bottom:1px solid var(--border-primary)}.servicios-table tbody tr{transition:background .2s ease}.servicios-table tbody tr:hover{background:var(--bg-hover)}.empty-row{text-align:center;color:var(--text-secondary);padding:40px!important}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.85em;font-weight:600}.status-badge.success{background:#10b98133;color:var(--success);border:1px solid rgba(16,185,129,.3)}.status-badge.error{background:#ef444433;color:var(--error);border:1px solid rgba(239,68,68,.3)}.url-indicator,.query-indicator{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.8em;font-weight:500}.url-indicator{background:#8b5cf633;color:#a78bfa;border:1px solid rgba(139,92,246,.3)}.query-indicator{background:#60a5fa33;color:#93c5fd;border:1px solid rgba(96,165,250,.3)}.no-config{color:#64748b;font-style:italic}.action-buttons{display:flex;gap:8px}.btn-edit,.btn-delete{background:transparent;border:1px solid var(--border-primary);border-radius:6px;padding:6px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-edit:hover{background:#60a5fa33;border-color:var(--border-hover);color:var(--accent-primary)}.btn-delete:hover{background:#ef444433;border-color:#ef444466;color:var(--error)}.btn-edit svg,.btn-delete svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none}.modal-overlay{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:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:1px solid var(--border-primary);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease;transition:background-color .3s ease,border-color .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-primary)}.modal-header h2{color:var(--text-primary);font-size:1.5em;font-weight:600;margin:0}.modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#ef444433;color:var(--error)}.modal-close svg{width:20px;height:20px;stroke:currentColor;stroke-width:2.5;fill:none}.servicio-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;color:var(--text-primary);font-weight:500;margin-bottom:8px;font-size:.95em}.form-group label[for=estado]{display:flex;align-items:center;gap:8px;cursor:pointer}.form-group input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#60a5fa}.form-group input[type=text],.form-group input[type=url],.form-group select,.form-group textarea{width:100%;padding:12px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:.95em;font-family:inherit;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #60a5fa1a}.form-group textarea{resize:vertical;min-height:80px}.form-group small{display:block;margin-top:6px;color:var(--text-secondary);font-size:.85em}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:30px;padding-top:20px;border-top:1px solid var(--border-primary)}.btn-cancel,.btn-save{padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-cancel{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-primary)}.btn-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-save{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 6px #10b9814d}.btn-save:hover{transform:translateY(-2px);box-shadow:0 6px 12px #10b98166}.query-cell{display:flex;align-items:center;gap:8px}.btn-test-query{background:#60a5fa33;color:#60a5fa;border:1px solid rgba(96,165,250,.4);border-radius:6px;padding:4px 10px;cursor:pointer;font-size:.8em;font-weight:500;transition:all .2s ease;white-space:nowrap}.btn-test-query:hover{background:#60a5fa4d;border-color:#60a5fa99;color:#93c5fd;transform:translateY(-1px)}.test-modal-content{max-width:1000px;max-height:90vh}.test-modal-body{padding:24px;max-height:calc(90vh - 140px);overflow-y:auto}.test-info-section{margin-bottom:24px;padding:16px;background:#1e293b99;border-radius:10px;border:1px solid rgba(148,163,184,.1)}.info-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.info-item:last-child{margin-bottom:0}.query-item{flex-direction:column;align-items:stretch}.info-label{color:#94a3b8;font-weight:500;font-size:.9em;min-width:100px;flex-shrink:0}.info-value{color:#e2e8f0;font-weight:500}.query-container{width:100%;margin-top:8px}.query-display{background:#0f172ae6;padding:14px;border-radius:8px;color:#d4d4d4;font-family:Courier New,monospace;font-size:13px;line-height:1.6;overflow-x:auto;border:1px solid rgba(148,163,184,.2);white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.status-banner{display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:10px;font-weight:600;margin-bottom:20px}.status-banner svg{width:20px;height:20px;stroke:currentColor;stroke-width:2.5;fill:none}.success-banner{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.error-banner{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.test-stats{display:flex;gap:20px;margin-bottom:24px;padding:16px;background:#1e293b66;border-radius:8px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{color:#94a3b8;font-size:.85em}.stat-value{color:#60a5fa;font-size:1.5em;font-weight:700}.test-columns-section,.test-results-section,.test-error-section{margin-top:24px}.section-title{display:flex;align-items:center;gap:8px;color:#f8fafc;margin-bottom:12px;font-size:1.05em;font-weight:600}.section-title svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none;color:#60a5fa}.columns-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.column-badge{background:#60a5fa33;color:#93c5fd;padding:6px 12px;border-radius:6px;font-size:.85em;font-weight:500;border:1px solid rgba(96,165,250,.3);transition:all .2s ease}.column-badge:hover{background:#60a5fa4d;border-color:#60a5fa80}.table-wrapper{overflow-x:auto;border-radius:10px;border:1px solid rgba(148,163,184,.1);background:#0f172a99;margin-top:12px;max-height:400px;overflow-y:auto}.results-table{width:100%;border-collapse:collapse;min-width:600px}.results-table thead{position:sticky;top:0;z-index:10;background:#1e3a8acc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.results-table th{padding:12px 14px;text-align:left;color:#e2e8f0;font-weight:600;font-size:.9em;border-bottom:2px solid rgba(148,163,184,.2);white-space:nowrap}.results-table td{padding:10px 14px;color:#ccc;border-bottom:1px solid rgba(148,163,184,.05);font-size:.9em;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.results-table tbody tr{transition:background .2s ease}.results-table tbody tr:hover{background:#1e293bcc}.null-value{color:#64748b;font-style:italic}.no-results-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:30px;background:#1e293b66;border-radius:10px;border:1px dashed rgba(148,163,184,.2);color:#94a3b8;font-style:italic}.no-results-banner svg{width:24px;height:24px;stroke:currentColor;stroke-width:2;fill:none}.error-details{margin-top:20px}.error-message{background:#ef44441a;padding:14px;border-radius:8px;color:#fca5a5;font-family:Courier New,monospace;font-size:13px;line-height:1.6;overflow-x:auto;border:1px solid rgba(239,68,68,.3);white-space:pre-wrap;word-break:break-word;margin-top:12px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;color:#60a5fa}.loading-container p{margin-top:20px;color:#94a3b8;font-size:1em}.loading-spinner{width:50px;height:50px;border:4px solid rgba(96,165,250,.2);border-top-color:#60a5fa;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-container{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:0}
