*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6,li,ol,p,ul{margin:0;padding:0}ol,ul{list-style:none}a{color:inherit;text-decoration:none}button{border:none;cursor:pointer;font-family:inherit;font-size:inherit}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #667eea;outline-offset:2px}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.app-header{background:#374151;border-bottom:1px solid #4b5563;box-shadow:0 2px 4px #0000001a;color:#fff;height:64px;position:sticky;top:0;z-index:1000}.header-content{height:100%;justify-content:space-between;padding:0 20px;width:100%}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:12px}.app-logo{align-items:center;display:flex;justify-content:center}.logo-image{display:block;height:40px;width:auto}.app-title{color:#fff;font-size:24px;font-weight:600;margin:0}.header-center{display:flex;flex:1 1;justify-content:center}.header-nav{display:flex;gap:16px}.nav-button{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .3s ease}.nav-button:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-1px)}.header-right,.user-info{align-items:center;display:flex}.user-info{cursor:pointer;gap:12px;position:relative}.user-details{align-items:flex-end;display:flex;flex-direction:column;gap:2px}.user-name{font-size:14px;font-weight:500;line-height:1.2}.user-email-header{color:#ffffffb3;font-size:12px;line-height:1.2}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #ffffff4d;border-radius:50%;cursor:pointer;display:flex;font-size:16px;font-weight:600;height:40px;justify-content:center;transition:all .2s ease;width:40px}.user-avatar:hover{border-color:#ffffff80;transform:scale(1.05)}.user-dropdown{animation:dropdownSlideIn .2s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:280px;overflow:hidden;position:absolute;right:0;top:60px;z-index:1001}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:12px;padding:16px}.dropdown-user-avatar{align-items:center;background:#fff3;border:2px solid #ffffff80;border-radius:50%;display:flex;font-size:20px;font-weight:600;height:48px;justify-content:center;width:48px}.dropdown-user-info{flex:1 1;overflow:hidden}.dropdown-user-name{font-size:16px;font-weight:600;margin-bottom:4px}.dropdown-user-email,.dropdown-user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-user-email{font-size:13px;opacity:.9}.dropdown-divider{background:#e5e7eb;height:1px;margin:4px 0}.dropdown-item{align-items:center;background:#fff;border:none;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-align:left;transition:background-color .15s ease;width:100%}.dropdown-item:hover{background-color:#f3f4f6}.dropdown-item.signout{color:#dc2626}.dropdown-item.signout:hover{background-color:#fef2f2}.dropdown-icon{align-items:center;display:flex;font-size:18px;justify-content:center;width:24px}.dropdown-user-badge{margin-top:4px}.badge-superadmin{background:#fff3;border:1px solid #fff6;border-radius:4px;display:inline-block;font-size:10px;font-weight:700;letter-spacing:.5px;padding:2px 8px}.impersonation-banner{align-items:center;animation:pulseGlow 2s ease-in-out infinite;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:6px;box-shadow:0 2px 4px #0003;color:#fff;display:flex;font-size:13px;font-weight:500;gap:8px;margin-right:16px;padding:6px 12px}@keyframes pulseGlow{0%,to{box-shadow:0 2px 4px #0003}50%{box-shadow:0 2px 8px #f59e0b99}}.impersonation-icon{font-size:16px}.impersonation-text{align-items:center;display:flex;gap:4px}.stop-impersonation-btn{background:#fff3;border:1px solid #fff6;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:4px 12px;transition:all .2s ease}.stop-impersonation-btn:hover{background:#ffffff4d;border-color:#fff9}.user-avatar.impersonating{animation:avatarPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#fbbf24}@keyframes avatarPulse{0%,to{border-color:#fbbf24}50%{border-color:#f59e0b}}.dropdown-item.impersonate-item{color:#f59e0b;font-weight:600}.dropdown-item.impersonate-item:hover{background-color:#fffbeb}.impersonate-modal{max-width:500px}.impersonate-warning{background:#fffbeb;border:1px solid #fbbf24;border-radius:6px;color:#92400e;font-size:13px;line-height:1.5;margin-bottom:20px;padding:12px}.impersonate-warning strong{color:#78350f}.left-sidebar{background:#f8fafc;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;height:calc(100vh - 64px);overflow-y:auto;position:sticky;top:64px;transition:width .3s ease;width:260px}.left-sidebar.collapsed{width:60px}.sidebar-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:20px 16px 16px;transition:padding .3s ease}.left-sidebar.collapsed .sidebar-header{padding:20px 8px 16px}.sidebar-title{color:#374151;font-size:16px;font-weight:600;margin:0;overflow:hidden;white-space:nowrap}.sidebar-nav{flex:1 1;overflow-y:auto;padding:16px 0}.nav-list{list-style:none;margin:0;padding:0}.nav-item{margin-bottom:2px}.nav-link{align-items:center;border-left:3px solid #0000;color:#64748b;display:flex;padding:12px 16px;text-decoration:none;transition:all .2s ease;white-space:nowrap}.left-sidebar.collapsed .nav-link{justify-content:center;padding:12px 8px}.nav-link:hover{background:#e2e8f0;border-left-color:#cbd5e1;color:#475569}.nav-link.active{background:#374151;border-left-color:#4b5563;color:#fff;font-weight:600}.nav-link.active:hover{background:#4b5563}.nav-icon{align-items:center;display:flex;flex-shrink:0;height:24px;justify-content:center;margin-right:12px;width:24px}.nav-icon svg{height:100%;width:100%}.left-sidebar.collapsed .nav-icon{margin-right:0}.nav-label{font-size:14px;font-weight:500;overflow:hidden;transition:opacity .2s ease}.left-sidebar.collapsed .nav-label{opacity:0;width:0}.sidebar-footer{background:#fff;border-top:1px solid #e2e8f0;margin-top:auto;padding:16px;transition:padding .3s ease}.left-sidebar.collapsed .sidebar-footer{padding:12px 8px}.footer-title{color:#374151;font-size:13px;font-weight:600;letter-spacing:.05em;margin:0 0 12px;text-transform:uppercase}.health-indicators{display:flex;flex-direction:column;gap:8px}.health-item{align-items:center;background:#f9fafb;border-radius:4px;display:flex;justify-content:space-between;padding:6px 8px;transition:background .2s ease}.health-item:hover{background:#f3f4f6}.left-sidebar.collapsed .health-item{justify-content:center;padding:8px 4px}.health-label-with-icon{align-items:center;display:flex;gap:8px}.health-icon{font-size:14px}.health-label{color:#374151;font-size:12px;font-weight:500}.health-status{flex-shrink:0;font-size:14px}.health-status-dot.healthy,.health-status.healthy{color:#10b981}.health-status-dot.warning,.health-status.warning{color:#f59e0b}.health-status-dot.error,.health-status.error{color:#ef4444}.health-icon-only{display:flex;justify-content:center;width:100%}.health-status-dot{font-size:16px}.left-sidebar::-webkit-scrollbar{width:4px}.left-sidebar::-webkit-scrollbar-track{background:#f1f5f9}.left-sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.left-sidebar::-webkit-scrollbar-thumb:hover{background:#94a3b8}.right-sidebar{background:#f8fafc;border-left:1px solid #e2e8f0;box-sizing:border-box;display:flex;flex-direction:column;height:calc(100vh - 64px);overflow-x:hidden;overflow-y:auto;padding:10px;position:sticky;top:64px;transition:width .3s ease,padding .3s ease;width:300px}.right-sidebar.collapsed{border:none;overflow:hidden;padding:0;width:0}.sidebar-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;box-sizing:border-box;display:flex;flex-direction:column;margin-bottom:12px;padding:12px;width:100%}.sidebar-section:last-child{display:flex;flex:1 1;flex-direction:column;margin-bottom:0}.section-title{color:#374151;font-size:13px;letter-spacing:.3px;margin:0 0 10px}.stats-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.stat-card,.stats-grid{box-sizing:border-box;width:100%}.stat-card{align-items:center;background:#f9fafb;border-radius:6px;display:flex;flex-direction:column;justify-content:center;min-height:95px;overflow:hidden;padding:12px 8px}.stat-value{color:#1f2937;font-size:20px;font-weight:600;line-height:1.1;margin-bottom:6px;white-space:nowrap}.stat-label{-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;font-size:9.5px;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;margin-bottom:6px;max-height:38px;overflow:hidden;padding:0 4px;width:100%;word-break:break-word}.stat-change{font-size:13px;font-weight:700;line-height:1.1;margin-top:0;white-space:nowrap}.stat-change.positive{color:#10b981}.stat-change.negative{color:#ef4444}.sidebar-section:first-child{max-width:100%;overflow:hidden}.sidebar-section:first-child .stats-grid{margin:0;padding:0}.sidebar-section:first-child .stat-card{min-width:0}.activity-list{flex:1 1;max-height:none;min-height:400px;overflow-y:auto}.activity-item{align-items:flex-start;border-left:3px solid #0000;border-radius:6px;display:flex;margin-bottom:6px;padding:10px}.activity-item.error{background:#fef2f2;border-left-color:#ef4444}.activity-item.warning{background:#fffbeb;border-left-color:#f59e0b}.activity-item.success{background:#f0fdf4;border-left-color:#10b981}.activity-item.info{background:#eff6ff;border-left-color:#3b82f6}.activity-icon{flex-shrink:0;font-size:13px;margin-right:6px}.activity-content{flex:1 1;min-width:0}.activity-message{color:#374151;font-size:12px;line-height:1.3;margin-bottom:3px}.activity-time{color:#9ca3af;font-size:10px}.activity-list::-webkit-scrollbar,.right-sidebar::-webkit-scrollbar{width:4px}.activity-list::-webkit-scrollbar-track,.right-sidebar::-webkit-scrollbar-track{background:#f1f5f9}.activity-list::-webkit-scrollbar-thumb,.right-sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.activity-list::-webkit-scrollbar-thumb:hover,.right-sidebar::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app-footer{background:#374151;border-top:1px solid #4b5563;color:#e5e7eb;min-height:60px}.app-footer,.footer-content{align-items:center;display:flex}.footer-content{justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 24px;width:100%}.footer-left{align-items:center;display:flex}.footer-text{color:#d1d5db;font-size:13px}.footer-center{display:flex;flex:1 1;justify-content:center}.footer-links{display:flex;gap:24px}.footer-link{color:#d1d5db;font-size:13px;text-decoration:none;transition:color .2s ease}.footer-link:hover{color:#fff}.footer-right{align-items:center;display:flex;gap:16px}.footer-version{color:#9ca3af;font-size:12px;font-weight:500}.footer-status{align-items:center;display:flex;gap:6px}.status-indicator{animation:pulse 2s infinite;background:#10b981;height:8px;width:8px}@media (max-width:768px){.footer-content{flex-direction:column;gap:12px;padding:16px 24px}.footer-center{order:-1}.footer-links{gap:16px}}.master-page{display:flex;flex-direction:column;min-height:100vh}.main-layout{display:flex;flex:1 1;position:relative}.main-content{background:#fff;flex:1 1;min-height:calc(100vh - 124px);overflow-y:auto;transition:margin .3s ease}.content-wrapper{margin:0 auto;max-width:1400px;min-height:calc(100vh - 172px);padding:24px;width:100%}.sidebar-toggle{align-items:center;background:#374151;border:1px solid #4b5563;border-radius:0 8px 8px 0;box-shadow:2px 0 8px #0000001a;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:60px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:28px;z-index:100}.sidebar-toggle:hover{background:#4b5563;box-shadow:2px 0 12px #00000026}.sidebar-toggle.left-toggle{border-radius:0 8px 8px 0;left:260px;transition:left .3s ease}.left-sidebar.collapsed~.sidebar-toggle.left-toggle{left:60px}.sidebar-toggle.right-toggle{border-radius:8px 0 0 8px;box-shadow:-2px 0 8px #0000001a;right:320px;transition:right .3s ease}.sidebar-toggle.right-toggle:hover{box-shadow:-2px 0 12px #00000026}.right-sidebar.collapsed~.sidebar-toggle.right-toggle,.sidebar-toggle.right-toggle:has(~.right-sidebar.collapsed){right:0}@media (max-width:1024px){.main-layout{position:relative}.left-sidebar{left:-260px;position:absolute;transition:left .3s ease;z-index:999}.left-sidebar.mobile-open{left:0}.main-content{margin-left:0}.right-sidebar{display:none}}@media (max-width:768px){.content-wrapper{padding:16px}.right-sidebar{display:none}}.content-loading{color:#6b7280}.content-error,.content-loading{align-items:center;display:flex;height:200px;justify-content:center}.content-error{color:#ef4444;flex-direction:column;gap:8px}.main-content::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-track{background:#f1f5f9}.main-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.main-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dashboard{min-height:100%}.dashboard-header{margin-bottom:32px}.dashboard-header h1{color:#111827;font-size:32px;font-weight:700;margin:0 0 8px}.dashboard-header p{color:#6b7280;font-size:16px;margin:0}.dashboard-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.dashboard-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:24px}.stat-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.stat-header h3{color:#6b7280;font-size:14px;font-weight:500;letter-spacing:.5px;margin:0;text-transform:uppercase}.stat-trend{border-radius:4px;font-weight:600;padding:2px 6px}.stat-trend.up{background:#d1fae5;color:#059669}.stat-trend.down{background:#fee2e2;color:#dc2626}.dashboard-content{grid-gap:32px;display:grid;gap:32px;grid-template-columns:1fr 300px}.dashboard-main{space-y:32px}.dashboard-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:24px}.dashboard-section h2{color:#111827;font-size:20px;font-weight:600;margin:0 0 20px}.overview-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.overview-card{border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .2s ease}.overview-card:hover{border-color:#667eea;box-shadow:0 4px 8px #0000001a}.overview-card h3{color:#111827;font-size:16px;font-weight:600;margin:0 0 8px}.overview-card p{color:#6b7280;font-size:14px;line-height:1.5;margin:0 0 16px}.card-action-button{background:none;border:1px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.card-action-button:hover{background:#667eea;color:#fff}.performance-chart{align-items:center;background:#f9fafb;border:1px dashed #d1d5db;border-radius:8px;display:flex;height:300px;justify-content:center}.chart-placeholder{color:#9ca3af;text-align:center}.chart-placeholder p{font-size:14px;margin:4px 0}.dashboard-sidebar{space-y:24px}.events-list{space-y:12px}.event-item{align-items:flex-start;border-left:3px solid #0000;border-radius:8px;display:flex;padding:12px}.event-item.warning{background:#fffbeb;border-left-color:#f59e0b}.event-item.success{background:#f0fdf4;border-left-color:#10b981}.event-item.info{background:#eff6ff;border-left-color:#3b82f6}.event-item.error{background:#fef2f2;border-left-color:#ef4444}.event-icon{font-size:16px;margin-right:12px}.event-content{flex:1 1}.event-content h4{color:#111827;font-size:14px;font-weight:600;margin:0 0 4px}.event-content p{color:#6b7280;font-size:13px;line-height:1.4;margin:0 0 4px}.event-time{color:#9ca3af;font-size:11px;font-weight:500}.quick-actions{display:flex;flex-direction:column;gap:8px}.quick-action-button{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:12px 16px;text-align:left;transition:all .2s ease}.quick-action-button:hover{border-color:#667eea;color:#667eea}.quick-action-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.quick-action-button.primary:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}@media (max-width:1024px){.dashboard-content{grid-template-columns:1fr}.dashboard-sidebar{order:-1}}@media (max-width:768px){.dashboard-stats{grid-template-columns:1fr 1fr}.overview-grid{grid-template-columns:1fr}.dashboard-header h1{font-size:24px}}.configure-monitor-tab{padding:24px}.form-sections-container{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr 1fr}.form-section{margin-bottom:0}.form-section h3{border-bottom:2px solid #e5e7eb;color:#111827;margin:0 0 20px;padding-bottom:8px}.form-row{display:block;gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-label{color:#374151;font-size:14px;font-weight:500;margin-bottom:6px}.required{color:#ef4444}.form-input,.form-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:10px 12px;transition:all .2s ease}.form-input:focus,.form-select:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.form-input.error{background:#fef2f2;border-color:#ef4444}.error-message{color:#ef4444;font-weight:500}.tags-input-container{background:#fff;border:1px solid #d1d5db;border-radius:6px;min-height:80px;padding:8px}.tags-display{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.tag{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:inline-flex;font-size:12px;font-weight:500;gap:4px}.tag-remove{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:16px;justify-content:center;line-height:1;padding:0;transition:background-color .2s ease;width:16px}.tag-remove:hover{background:#fff3}.tag-input-wrapper{display:flex;gap:8px}.tag-input{border:1px solid #e5e7eb;border-radius:4px;flex:1 1;font-size:13px;padding:6px 8px}.tag-input:focus{border-color:#667eea;outline:none}.add-tag-button{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .2s ease}.add-tag-button:hover:not(:disabled){background:#5a67d8}.add-tag-button:disabled{background:#d1d5db;cursor:not-allowed}.checkbox-group{display:flex;flex-direction:column;gap:12px}.checkbox-item{align-items:center;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s ease}.checkbox-item:hover{background:#f8fafc;border-color:#667eea}.checkbox-custom{border-radius:3px;flex-shrink:0;height:18px;width:18px}.checkbox-input:checked+.checkbox-custom:after{font-size:12px;position:absolute}.checkbox-icon{font-size:16px}.device-item{align-items:flex-start;padding:16px 12px}.device-info{display:flex;flex-direction:column;gap:2px}.device-description{color:#6b7280;font-size:12px}@media (max-width:1024px){.form-sections-container{gap:24px;grid-template-columns:1fr}.form-section{margin-bottom:24px}}@media (max-width:768px){.form-row{display:block;gap:16px;grid-template-columns:1fr}.configure-monitor-tab{padding:16px}.tags-display{margin-bottom:12px}.tag-input-wrapper{flex-direction:column;gap:8px}.add-tag-button{align-self:flex-start}}.select-location-tab{padding:24px}.tab-content{margin:0 auto;max-width:1400px}.location-header{margin-bottom:32px;text-align:center}.location-header h3{color:#111827;font-size:20px;font-weight:600;margin:0 0 8px}.location-header p{color:#6b7280;font-size:14px;line-height:1.5;margin:0}.location-controls{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:24px;padding:16px}.select-all-button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s ease}.select-all-button:hover{background:#5a67d8;transform:translateY(-1px)}.selection-summary{color:#374151;font-size:13px;font-weight:500}.locations-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:24px}.location-card{background:#fff;border:2px solid #e5e7eb;padding:20px;position:relative;transition:all .2s ease}.location-card:hover{border-color:#667eea;box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.location-card.selected{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-color:#667eea;box-shadow:0 2px 4px #667eea1a}.location-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.location-icon{font-size:32px}.location-checkbox{position:relative}.checkbox-input{display:none}.checkbox-custom{background:#fff;border:2px solid #d1d5db;border-radius:4px;height:20px;position:relative;transition:all .2s ease;width:20px}.checkbox-input:checked+.checkbox-custom{background:#667eea;border-color:#667eea}.checkbox-input:checked+.checkbox-custom:after{color:#fff;content:"✓";font-size:18px;font-weight:700;left:50%;top:50%;transform:translate(-50%,-50%)}.location-info{margin-bottom:16px}.location-name{font-size:16px;margin:0 0 6px}.location-description{color:#6b7280;font-size:13px;line-height:1.4;margin:0 0 8px}.location-meta{align-items:center;display:flex;gap:8px}.location-timezone{background:#f3f4f6;border-radius:4px;color:#9ca3af;font-size:12px;padding:2px 6px}.location-status{align-items:center;display:flex;min-height:20px}.status-indicator{align-items:center;display:flex;gap:6px}.status-dot{animation:pulse 2s infinite;background:#10b981;border-radius:50%;height:8px;width:8px}.status-text{color:#10b981;font-size:12px;font-weight:500}.location-error{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#ef4444;font-size:14px;font-weight:500;padding:12px 16px;text-align:center}.location-info-panel{background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;margin-top:24px;padding:20px}.location-info-panel h4{color:#1e40af;font-size:16px;font-weight:600;margin:0 0 12px}.location-info-panel ul{list-style:none;margin:0;padding-left:0}.location-info-panel li{color:#374151;font-size:13px;line-height:1.5;margin-bottom:8px;padding-left:16px;position:relative}.location-info-panel li:before{color:#3b82f6;content:"•";font-weight:700;left:0;position:absolute}.location-info-panel strong{color:#1e40af;font-weight:600}@media (max-width:768px){.select-location-tab{padding:16px}.locations-grid{grid-template-columns:1fr}.location-controls{align-items:stretch;flex-direction:column;gap:12px;text-align:center}.select-all-button{width:100%}}.write-script-tab{padding:0}.script-tabs{background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex}.script-tab{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-weight:500;gap:8px;justify-content:center;padding:14px 20px;position:relative;transition:all .2s ease}.script-tab:hover{background:#f3f4f6;color:#374151}.script-tab.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.tab-icon{font-size:16px}.validation-indicator{font-size:12px;font-weight:700;margin-left:4px}.validation-indicator.success{color:#10b981}.validation-indicator.error{color:#ef4444}.script-content{background:#fff;min-height:500px}.script-editor-container{padding:24px}.editor-toolbar{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.editor-info h4{color:#111827;font-size:18px;font-weight:600;margin:0 0 4px}.editor-info p{color:#6b7280;font-size:14px;margin:0}.editor-actions{display:flex;gap:8px}.editor-action-button{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 12px;transition:all .2s ease}.editor-action-button.primary{background:#667eea;color:#fff}.editor-action-button.primary:hover:not(:disabled){background:#5a67d8;transform:translateY(-1px)}.editor-action-button.primary:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;transform:none}.editor-action-button.secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.editor-action-button.secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.editor-action-button.secondary:disabled{color:#9ca3af;cursor:not-allowed}.script-editor-wrapper{margin-bottom:24px}.script-editor{background:#fafafa;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;line-height:1.5;padding:16px;resize:vertical;transition:all .2s ease;width:100%}.script-editor:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.script-editor.error{background:#fef2f2;border-color:#ef4444}.editor-footer{align-items:center;display:flex;justify-content:space-between;margin-top:8px}.editor-stats{color:#9ca3af;font-family:monospace;font-size:12px}.editor-error{color:#ef4444;font-size:12px;font-weight:500}.script-guidelines{background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;padding:16px}.script-guidelines h5{color:#1e40af;font-size:14px;font-weight:600;margin:0 0 12px}.script-guidelines ul{list-style-type:disc;margin:0;padding-left:16px}.script-guidelines li{color:#374151;font-size:13px;line-height:1.4;margin-bottom:4px}.validation-empty{align-items:center;color:#9ca3af;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{font-size:48px}.validation-empty h4{color:#6b7280;font-size:18px;margin:0 0 8px}.validation-empty p{font-size:14px;margin:0}.validation-results{padding:24px}.validation-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.validation-status{align-items:center;display:flex;gap:8px}.validation-status.success .status-icon{color:#10b981}.validation-status.error .status-icon{color:#ef4444}.status-text{font-size:18px;font-weight:600}.validation-status.success .status-text{color:#10b981}.validation-status.error .status-text{color:#ef4444}.validation-timestamp{color:#9ca3af;font-size:12px}.validation-section{border-radius:8px;margin-bottom:20px;overflow:hidden}.validation-section h5{font-size:14px;font-weight:600;margin:0;padding:12px 16px}.validation-section ul{list-style:none;margin:0;padding:0}.validation-section li{border-bottom:1px solid #ffffff1a;font-size:14px;line-height:1.4;padding:10px 16px}.validation-section li:last-child{border-bottom:none}.validation-section.errors h5{background:#ef4444;color:#fff}.validation-section.errors li{background:#fef2f2;border-color:#fecaca;color:#991b1b}.validation-section.warnings h5{background:#f59e0b;color:#fff}.validation-section.warnings li{background:#fffbeb;border-color:#fed7aa;color:#92400e}.validation-section.suggestions h5{background:#3b82f6;color:#fff}.validation-section.suggestions li{background:#eff6ff;border-color:#dbeafe;color:#1e40af}.validation-success{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:40px 20px;text-align:center}.success-icon{font-size:48px;margin-bottom:16px}.validation-success h4{color:#065f46;font-size:20px;font-weight:600;margin:0 0 8px}.validation-success p{color:#047857;font-size:14px;margin:0}@media (max-width:768px){.script-editor-container{padding:16px}.editor-toolbar{align-items:stretch;flex-direction:column;gap:16px}.editor-actions{flex-wrap:wrap;justify-content:center}.validation-header{align-items:center;gap:12px;text-align:center}.script-tabs,.validation-header{flex-direction:column}.script-tab{border-bottom:1px solid #e5e7eb}.script-tab.active{border-bottom-color:#e5e7eb;border-left:3px solid #667eea}}.browser-monitor-form{margin:0 auto;max-width:1400px}.form-header{margin-bottom:32px;text-align:center}.form-header h2{color:#111827;font-size:28px;font-weight:600;margin:0 0 8px}.form-header p{color:#6b7280;font-size:16px;margin:0}.form-tabs{background:#fff;border-bottom:2px solid #e5e7eb;border-radius:8px 8px 0 0;box-shadow:0 2px 4px #0000000d;display:flex;overflow:hidden}.form-tab{align-items:center;background:#f9fafb;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-weight:500;gap:8px;justify-content:center;padding:16px 20px;position:relative;transition:all .2s ease}.form-tab:hover{background:#f3f4f6;color:#374151}.form-tab.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.tab-icon{font-size:18px}.tab-label{font-size:14px}.tab-error-indicator{color:#ef4444;font-size:12px;position:absolute;right:8px;top:8px}.form-content{border-radius:0 0 8px 8px;min-height:400px}.form-actions,.form-content{background:#fff;box-shadow:0 2px 4px #0000000d}.form-actions{align-items:center;border-radius:8px;justify-content:space-between;margin-top:32px;padding:20px}.form-actions-right{align-items:center;display:flex;gap:16px}.form-status{font-size:14px}.form-warning{color:#f59e0b;font-weight:500}.form-button{font-size:14px}.form-button.primary{background:linear-gradient(135deg,#667eea,#764ba2)}.form-button.primary:hover:not(.disabled){box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.form-button.primary.disabled{background:#d1d5db;box-shadow:none;color:#9ca3af;cursor:not-allowed;transform:none}.form-button.secondary:hover{background:#f9fafb;border-color:#9ca3af}@media (max-width:768px){.form-tabs{flex-direction:column}.form-tab{border-bottom:1px solid #e5e7eb;border-radius:0}.form-tab.active{border-bottom-color:#e5e7eb;border-left:3px solid #667eea}.form-actions{gap:16px}.form-actions,.form-actions-right{align-items:stretch;flex-direction:column}.form-actions-right{gap:12px}}.ping-monitor-form{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:800px;padding:24px}.form-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.form-header h2{color:#333;font-size:24px;margin:0}.form-section{margin-bottom:32px}.form-section h3{color:#333;font-size:18px;font-weight:600}.form-section h3,.section-header{margin-bottom:16px}.select-all-btn{background:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 12px;transition:all .2s}.select-all-btn:hover{background:#e0e0e0}.form-group input[type=number],.form-group input[type=text],.form-group select{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#4a90e2;outline:none}.form-group input.error{border-color:#e74c3c}.error-message{color:#e74c3c;display:block;font-size:12px;margin-top:4px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.locations-grid{grid-gap:12px;display:grid;gap:12px;margin-top:12px}.location-card{align-items:center;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;gap:12px;padding:16px;transition:all .2s}.location-card:hover{background:#f8f9fa;border-color:#4a90e2}.location-card.selected{background:#e3f2fd;border-color:#4a90e2}.location-checkbox input[type=checkbox]{cursor:pointer;height:18px;width:18px}.location-info{flex:1 1}.location-name{color:#333;margin-bottom:4px}.location-code{color:#777;font-size:12px}.loading-locations,.no-locations{background:#f8f9fa;border-radius:8px;color:#777;padding:32px;text-align:center}.tags-input-wrapper{border:1px solid #ddd;border-radius:4px;min-height:42px;padding:8px}.tags-list{flex-wrap:wrap;margin-bottom:8px}.tag,.tags-list{display:flex;gap:6px}.tag{align-items:center;background:#e3f2fd;border-radius:4px;color:#1976d2;font-size:13px;padding:4px 8px}.tag button{background:none;border:none;color:#1976d2;cursor:pointer;font-size:18px;line-height:1;padding:0}.tags-input-wrapper input{border:none;font-size:14px;outline:none;padding:4px;width:100%}.error-banner{background:#ffebee;border:1px solid #ef5350;border-radius:4px;color:#c62828;margin-bottom:16px;padding:12px 16px}.form-actions{border-top:1px solid #e0e0e0;justify-content:flex-end;padding-top:24px}.btn-primary,.btn-secondary{border-radius:4px;padding:10px 24px;transition:all .2s}@media (max-width:768px){.form-row,.locations-grid{grid-template-columns:1fr}.ping-monitor-form{padding:16px}}.synthetic-monitors{background-color:#f9fafb;min-height:100%}.error-state,.loading-state{padding:80px 20px}.loading-spinner{border:4px solid #e5e7eb;display:inline-block;margin-bottom:16px}.loading-state p{color:#6b7280;font-size:16px;margin:0}.error-state .error-icon{font-size:48px;margin-bottom:16px}.error-state h3{color:#ef4444;font-size:24px;margin:0 0 8px}.error-state p{color:#6b7280;font-size:16px;margin:0 0 24px}.error-state button{background:#374151;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:background .2s ease}.error-state button:hover{background:#4b5563}.tabs{border-bottom:2px solid #e5e7eb;display:flex;margin-bottom:24px}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .2s ease}.tab.active,.tab:hover{color:#374151}.tab.active{border-bottom-color:#374151}.page-header{align-items:flex-end}.page-header h1{font-weight:700}.page-header p{font-size:16px}.create-button{background:#374151;border:none;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .3s ease}.create-button:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-1px)}.stats-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.stat-card{box-shadow:0 2px 4px #0000001a;padding:10px}.stat-card h3{color:#6b7280;font-size:14px;font-weight:500;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.stat-value{font-size:28px;margin-bottom:4px}.stat-trend{font-size:12px;font-weight:500}.stat-trend.positive{color:#10b981}.stat-trend.negative{color:#ef4444}.stat-trend.neutral{color:#6b7280}.monitors-list{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.list-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:24px}.filter-indicator{color:#6b7280;font-size:16px;font-weight:400}.filter-select,.search-input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px}.search-input{width:200px}.filter-select{width:120px}.monitors-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));padding:24px}.monitor-card{background:#fff}.monitor-card:hover{box-shadow:0 4px 8px #0000001a}.monitor-header{justify-content:space-between;margin-bottom:12px}.monitor-header,.monitor-type{align-items:center;display:flex}.monitor-type{color:#6b7280;font-size:12px;font-weight:500;gap:6px}.status-badge{padding:4px 8px}.status-badge.active{background:#d1fae5}.monitor-name{color:#111827;font-size:16px;font-weight:600;margin:0 0 4px}.monitor-url{color:#6b7280;font-size:14px;margin:0 0 16px}.monitor-metrics{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:16px}.metric{display:flex;flex-direction:column;gap:2px}.metric-label{color:#9ca3af;font-size:11px;text-transform:uppercase}.metric-value{font-size:14px;font-weight:600}.monitor-actions{display:flex;gap:8px}.action-button{background:#fff;border:1px solid #d1d5db;color:#374151;font-size:12px;font-weight:500;padding:8px 12px}.action-button:hover{border-color:#374151;color:#374151}.action-button.secondary{background:#f9fafb}.close-button,.modal-header h2{font-size:24px}.close-button{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;padding:4px}.close-button:hover{background:#f3f4f6;color:#374151}.monitor-types-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px}.monitor-type-card{border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;padding:24px;text-align:center;transition:all .2s ease}.monitor-type-card:hover{border-color:#374151;box-shadow:0 4px 8px #0000001a}.type-icon{font-size:48px;margin-bottom:16px}.monitor-type-card h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 8px}.monitor-type-card p{color:#6b7280;font-size:14px;margin:0 0 16px}.feature-list{list-style:none;margin:0 0 20px;padding:0;text-align:left}.feature-list li{color:#374151;font-size:13px;margin-bottom:4px}.select-type-button{background:#374151;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s ease}.select-type-button:hover{transform:translateY(-1px)}.form-header{align-items:center;display:flex;gap:12px;margin-bottom:10px}.back-button{border-radius:4px;padding:4px 8px}.back-button:hover{background:#eff6ff}.form-content{color:#6b7280;text-align:left}.form-actions{display:flex;gap:12px;justify-content:center;margin-top:24px}.form-button{border-radius:6px;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .2s ease}.form-button.primary{background:#374151;border:none;color:#fff}.form-button.secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.form-button:hover{transform:translateY(-1px)}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:16px}.stats-cards{grid-template-columns:1fr 1fr}.monitors-grid{grid-template-columns:1fr}.list-header{align-items:flex-start;flex-direction:column;gap:16px}.list-controls{flex-direction:column;width:100%}.filter-select,.search-input{width:100%}.monitor-types-grid{grid-template-columns:1fr}}.view-toggle{background:#fff;color:#374151;font-weight:500;gap:6px;padding:8px 12px}.view-toggle:hover{background:#f8fafc;color:#374151}.view-toggle.card,.view-toggle.list{background:#374151;border-color:#0000;color:#fff}.toggle-text{font-size:12px}.pagination{gap:8px}.pagination-button{background:#fff;color:#374151;font-weight:500}.pagination-button:hover:not(:disabled){background:#f8fafc;color:#374151}.pagination-button:disabled{background:#f9fafb;color:#9ca3af}.pagination-numbers{display:flex;gap:4px}.pagination-number{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;height:36px;justify-content:center;transition:all .2s ease;width:36px}.pagination-number:hover{background:#f8fafc;border-color:#374151;color:#374151}.pagination-number.active{background:#374151;border-color:#0000;color:#fff}.monitors-table{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.table-header{color:#374151}.table-header,.table-row{grid-template-columns:2fr 1fr 1fr 1fr 1.2fr 1.2fr 1.5fr}.table-row{transition:all .2s ease}.table-cell{align-items:center;display:flex;font-size:14px;padding:12px 16px}.header-cell{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.name-cell{padding:16px}.monitor-name-with-icon{align-items:center;display:flex;gap:10px}.monitor-icon{font-size:16px}.type-badge{background:#f3f4f6;border-radius:4px;color:#374151;font-size:11px;font-weight:600;padding:4px 8px}.uptime-value.high{color:#059669;font-weight:600}.uptime-value.medium{color:#d97706;font-weight:600}.uptime-value.low{color:#dc2626;font-weight:600}.response-time{background:#f3f4f6;border-radius:4px;font-family:monospace;font-size:12px;padding:2px 6px}.last-check{color:#6b7280;font-size:12px}.actions-cell{gap:6px}.table-action-button{border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;padding:4px 8px;transition:all .2s ease}.table-action-button.primary{background:#374151;color:#fff}.table-action-button.primary:hover{background:#5a67d8}.table-action-button.secondary{background:#f3f4f6;color:#374151}.table-action-button.secondary:hover{background:#e5e7eb}@media (max-width:1200px){.table-header,.table-row{grid-template-columns:2fr 1fr 1fr 1fr 1fr 2fr}.response-time-cell{display:none}}@media (max-width:768px){.list-controls{align-items:stretch;flex-direction:column;gap:12px}.filter-select,.search-input,.view-toggle{width:100%}.monitors-table{overflow-x:auto}.table-header,.table-row{grid-template-columns:200px 80px 100px 80px 120px;min-width:580px}.last-check-cell,.type-cell{display:none}.pagination{flex-direction:column;gap:16px}.pagination-numbers{order:-1}.pagination-button{width:100%}}@media (max-width:480px){.table-header,.table-row{grid-template-columns:1fr 80px 100px;min-width:320px}.last-check-cell,.response-time-cell,.status-cell{display:none}.actions-cell{flex-direction:column;gap:4px}.table-action-button{padding:6px 8px;width:100%}}.no-results{align-items:center;background:#fff;border-radius:8px;display:flex;flex-direction:column;justify-content:center;margin:24px 0;padding:60px 20px;text-align:center}.no-results-icon{font-size:48px;margin-bottom:16px;opacity:.6}.no-results h3{color:#374151;font-size:20px;font-weight:600;margin:0 0 8px}.no-results p{color:#6b7280;font-size:14px;line-height:1.5;margin:0;max-width:300px}.clear-filters-button{background:#374151;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;margin-top:16px;padding:8px 16px;transition:all .2s ease}.clear-filters-button:hover{background:#5a67d8;transform:translateY(-1px)}.entities-table-container{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;max-width:100%;overflow-x:hidden}.entities-table{background-color:#fff;border-collapse:collapse;table-layout:fixed;width:100%}.entities-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.entities-table thead tr th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:11px;font-weight:700;letter-spacing:.5px;line-height:1.3;padding:12px 0;text-align:left;text-transform:uppercase;white-space:normal}.entities-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .15s ease}.entities-table tbody tr:hover{background-color:#f9fafb}.entities-table tbody tr td{color:#111827;font-size:12px;padding:12px 0;vertical-align:middle}.col-star,.col-status{text-align:center;width:4%}.col-status{vertical-align:middle}.col-status .status-indicator{margin:0 auto}.col-name{width:25%}.col-name button{max-width:100%}.col-monitor-status{width:12%}.col-success-rate{text-align:center;width:9%}.col-locations{text-align:center;width:12%}.col-period{width:5%}.col-monitor-type{width:10%}.col-monitor-type .monitor-type-text{display:block}.col-actions{text-align:center;width:10%}.action-buttons{align-items:center;justify-content:center}.action-btn:hover{opacity:1;transform:scale(1.1)}.mute-btn:hover{background-color:#fef3c7}.mute-btn.unmute:hover{background-color:#dcfce7}.edit-btn:hover{background-color:#dbeafe}.delete-btn:hover{background-color:#fee2e2}.action-btn:active{transform:scale(.95)}.star-button{background:none;border:none;color:#d1d5db;cursor:pointer;font-size:20px;line-height:1;padding:0;transition:all .2s ease}.star-button:hover{color:#f59e0b;transform:scale(1.2)}.star-button.active{color:#f59e0b}.status-indicator{border:2px solid #0000;border-radius:50%;display:contents;height:12px;width:12px}.status-indicator.success{background-color:#10b981;border-color:#d1fae5;box-shadow:0 0 8px #10b98180}.status-indicator.warning{background-color:#f59e0b;border-color:#fef3c7;box-shadow:0 0 8px #f59e0b80}.status-indicator.error{background-color:#ef4444;border-color:#fee2e2;box-shadow:0 0 8px #ef444480}.status-indicator.unknown{background-color:#6b7280;border-color:#e5e7eb}.monitor-name-link{word-wrap:break-word;background:none;border:none;color:#374151;cursor:pointer;display:block;font-size:12px;font-weight:500;line-height:1.4;padding:0;text-align:left;text-decoration:none;transition:color .2s ease;white-space:normal;width:100%}.monitor-name-link:hover{color:#4b5563;text-decoration:underline}.account-text{color:#6b7280;font-size:13px}.status-badge{border-radius:4px;font-size:11px;padding:3px 10px;white-space:nowrap}.status-badge.active{background-color:#d1fae5;border:1px solid #6ee7b7;color:#065f46}.status-badge.disabled,.status-badge.inactive{background-color:#f3f4f6;border:1px solid #d1d5db;color:#6b7280}.success-rate-text{font-weight:500}.locations-text,.success-rate-text{color:#111827;font-size:12px}.period-text{color:#111827;font-size:12px}.monitor-type-text,.period-text{word-wrap:break-word;line-height:1.4;white-space:normal}.monitor-type-text{color:#6b7280;font-size:11px}.create-button.primary{background:#374151;border:none;border-radius:6px;box-shadow:0 4px 6px #37415140;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.create-button.primary:hover{box-shadow:0 6px 12px #37415166;transform:translateY(-2px)}.list-controls-wrapper{margin-bottom:24px}.list-controls{align-items:center;display:flex;gap:12px}.search-input{background-color:#fff;color:#111827;min-width:300px;padding:8px 16px}.filter-controls{align-items:center;display:flex;gap:12px}.search-input:focus{box-shadow:0 0 0 3px #667eea1a}.filter-select{cursor:pointer;padding:8px 16px;transition:all .2s ease}.filter-select,.filter-select option,.view-toggle{background-color:#fff;color:#111827}.view-toggle{align-items:center;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:8px 16px;transition:all .2s ease}.view-toggle:hover{background-color:#f9fafb;border-color:#374151}.toggle-text{font-size:13px}.list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.list-header h2{color:#111827;font-size:20px;font-weight:600;margin:0}.monitors-list{margin-top:32px}.monitors-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:24px}.monitor-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:20px;transition:all .2s ease}.monitor-card:hover{border-color:#374151;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.monitor-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.monitor-card-name{color:#374151;cursor:pointer;font-size:16px;font-weight:600;margin:0 0 16px;transition:color .2s ease}.monitor-card-name:hover{color:#4b5563}.monitor-card-details{margin:16px 0}.detail-row{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:8px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#6b7280;font-size:13px;font-weight:500}.detail-value{color:#111827;font-size:14px;font-weight:500}.monitor-card-actions{display:flex;gap:8px;margin-top:16px}.action-button{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px;transition:all .2s ease}.action-button.primary{background:#374151;color:#fff}.action-button.primary:hover{box-shadow:0 4px 8px #667eea4d;transform:translateY(-2px)}.pagination{margin-top:32px;padding:20px 0}.pagination-button{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#111827;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.pagination-button:hover:not(:disabled){background-color:#374151;border-color:#374151;color:#fff}.pagination-button:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.5}@media (max-width:1400px){.col-name{width:25%}}@media (max-width:1200px){.col-name{width:22%}}@media (max-width:768px){.entities-table-container{overflow-x:auto}.entities-table{min-width:900px;table-layout:auto}.col-name{min-width:180px}.page-header{align-items:flex-start;flex-direction:column;gap:16px}.list-controls{flex-direction:column;width:100%}.search-input{min-width:100%;width:100%}.filter-controls{justify-content:space-between;width:100%}.filter-select,.view-toggle{flex:1 1}.monitors-grid{grid-template-columns:1fr}}.execution-details{min-height:100%;padding:0}.execution-details.error-state,.execution-details.loading,.execution-details.not-found{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#374151;height:50px;margin-bottom:20px;width:50px}.error-icon,.not-found-icon{font-size:64px;margin-bottom:20px}.execution-header{background:#fff;margin-bottom:0;padding:0 0 20px}.execution-page-title{color:#111827;font-size:32px;font-weight:700;line-height:1.2;margin:0}.execution-subtitle{color:#6b7280;font-size:14px;font-weight:400;margin:0}.back-button{background:none;border:none;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:8px 0;transition:all .2s ease}.back-button:hover{color:#5a67d8;transform:translateX(-2px)}.execution-title-section{margin-bottom:0;margin-top:0}.execution-title{align-items:center;display:flex;gap:16px;margin-bottom:0}.execution-title h1{color:#111827;font-size:28px;font-weight:700;margin:0}.execution-meta{color:#6b7280;display:flex;flex-wrap:wrap;font-size:14px;gap:24px}.meta-item strong{color:#374151;font-weight:600}.execution-actions{display:flex;gap:12px}.action-btn{align-items:center;display:flex;font-size:14px;gap:8px;padding:10px 16px}.action-btn.primary{border:none}.action-btn.secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.action-btn:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.status-badge{border-radius:6px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.status-badge.success{background:#d1fae5;color:#065f46}.status-badge.warning{background:#fef3c7;color:#92400e}.status-badge.error{background:#fee2e2;color:#991b1b}.status-badge.neutral{background:#f3f4f6;color:#6b7280}.status-badge.info{background:#dbeafe;color:#1e40af}.execution-tabs{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;gap:8px;margin-bottom:0;padding:8px}.execution-tab{background:#0000;border:none;border-radius:8px;color:#6b7280;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s ease}.execution-tab:hover{background:#f9fafb;color:#374151}.execution-tab.active{background:#374151;box-shadow:0 2px 4px #667eea4d;color:#fff}.execution-content{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:0 24px 24px}.execution-summary-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.summary-card{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:16px;padding:20px}.summary-icon{font-size:32px}.summary-content{flex:1 1}.summary-label{color:#6b7280;font-size:12px;font-weight:500;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.summary-value{color:#111827;font-size:24px;font-weight:700}.summary-value.success{color:#059669}.summary-value.error{color:#dc2626}.execution-timeline{margin-bottom:32px}.execution-timeline h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 20px}.timeline{position:relative}.timeline:before{background:#e5e7eb;bottom:0;content:"";left:20px;position:absolute;top:0;width:2px}.timeline-item{display:flex;gap:16px;padding-bottom:24px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-marker{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:40px;justify-content:center;position:relative;width:40px;z-index:1}.timeline-marker.success{background:#d1fae5;border:3px solid #10b981;color:#065f46}.timeline-marker.error{background:#fee2e2;border:3px solid #ef4444;color:#991b1b}.timeline-marker.neutral{background:#f3f4f6;border:3px solid #9ca3af;color:#6b7280}.timeline-content{flex:1 1;padding-top:8px}.timeline-step-name{color:#111827;font-size:16px;font-weight:600;margin-bottom:4px}.timeline-step-meta{display:flex;font-size:14px;gap:16px}.step-status{border-radius:4px;font-size:11px;font-weight:600;padding:2px 8px}.step-status.success{background:#d1fae5;color:#065f46}.step-status.error{background:#fee2e2;color:#991b1b}.step-status.neutral{background:#f3f4f6;color:#6b7280}.step-duration{color:#6b7280;font-family:monospace}.performance-metrics h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 20px}.metrics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metric-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.metric-label{color:#6b7280;font-size:12px;font-weight:500;margin-bottom:8px}.metric-value{color:#111827;font-family:monospace;font-size:20px;font-weight:700}.results-tab h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 20px}.results-summary{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;padding:20px}.results-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:16px}.stat-row{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;justify-content:space-between;padding:12px}.stat-label{color:#374151}.stat-value{font-size:18px}.stat-row.success .stat-value{color:#059669}.stat-row.error .stat-value{color:#dc2626}.stat-row.neutral .stat-value{color:#6b7280}.results-table{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.table-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.table-header,.table-row{display:grid;grid-template-columns:3fr 1fr 1fr;padding:12px 16px}.table-row{border-bottom:1px solid #f3f4f6;transition:background .2s ease}.table-row:hover{background:#f8fafc}.table-row:last-child{border-bottom:none}.col-step{color:#111827;font-weight:500}.col-status{align-items:center;display:flex}.col-duration{color:#6b7280;font-family:monospace;font-size:14px}.screenshots-tab h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 20px}.screenshots-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.screenshot-card{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:all .2s ease}.screenshot-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.screenshot-image{align-items:center;background:#f3f4f6;display:flex;height:200px;justify-content:center;overflow:hidden;width:100%}.screenshot-image img{height:100%;object-fit:cover;width:100%}.screenshot-info{background:#fff;padding:16px}.screenshot-name{color:#111827;font-weight:600;margin-bottom:4px}.screenshot-time{color:#6b7280;font-size:12px}.logs-tab h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 20px}.logs-container{background:#1e293b;border-radius:8px;font-family:Courier New,monospace;font-size:13px;max-height:600px}.log-entry{grid-gap:12px;border-bottom:1px solid #ffffff1a;display:grid;gap:12px;grid-template-columns:80px 80px 1fr;padding:8px 0}.log-entry:last-child{border-bottom:none}.log-timestamp{color:#94a3b8;font-weight:500}.log-level{border-radius:4px;font-size:11px;font-weight:700;padding:2px 8px;text-align:center}.log-level.info{background:#3b82f6;color:#fff}.log-level.success{background:#10b981;color:#fff}.log-level.warning{background:#f59e0b;color:#fff}.log-level.error{background:#ef4444;color:#fff}.log-message{color:#e2e8f0;line-height:1.5}@media (max-width:1024px){.execution-summary-cards,.metrics-grid,.screenshots-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.execution-details,.execution-header{padding:16px}.execution-page-title{font-size:24px}.execution-subtitle{font-size:12px}.execution-title{align-items:flex-start}.execution-meta,.execution-title{flex-direction:column;gap:8px}.execution-tabs{flex-direction:column}.execution-content{padding:16px}.execution-summary-cards,.metrics-grid,.results-stats,.screenshots-grid{grid-template-columns:1fr}.table-header,.table-row{font-size:12px;grid-template-columns:2fr 1fr 1fr;padding:8px 12px}.log-entry,.logs-container{font-size:11px}.log-entry{gap:8px;grid-template-columns:60px 60px 1fr}}@media (max-width:480px){.execution-actions{flex-direction:column}.action-btn{width:100%}.timeline:before{left:15px}.timeline-marker{font-size:14px;height:30px;width:30px}.table-header,.table-row{grid-template-columns:1fr}.col-duration,.col-status{display:none}}.execution-history-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:2rem 0}.stat-card{border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:1.5rem}.stat-value{color:#374151;font-size:1.5rem;margin-bottom:.5rem}.stat-label{font-size:.6rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.subtitle{color:#6b7280;font-size:.875rem;margin:0}.no-executions{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:4rem 2rem}.no-data-icon{font-size:4rem;margin-bottom:1rem}.no-executions h3{color:#1e3a8a;font-size:1.5rem;margin-bottom:.5rem}.no-executions p{max-width:600px}.execution-history-table{border-radius:12px;box-shadow:0 2px 4px #0000000d}.execution-history-table .table-header{grid-gap:1rem;background:#f8fafc;border-bottom:2px solid #e5e7eb;color:#1e3a8a;font-size:.875rem;gap:1rem;padding:1.25rem}.execution-history-table .table-header .sortable{cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.execution-history-table .table-header .sortable:hover{background:#eff6ff;border-radius:4px;color:#3b82f6;margin:-4px -8px;padding:4px 8px}.execution-history-table .table-row{grid-gap:1rem;border-bottom:1px solid #e5e7eb;font-size:.9rem;gap:1rem;padding:1.25rem;transition:all .2s}.execution-history-table .table-row:hover{background-color:#f8fafc;transform:translateX(4px)}.col-actions,.col-duration,.col-status,.col-time,.col-workers{align-items:center;display:flex}.col-time{color:#4b5563;font-size:.85rem}.col-duration{color:#1e3a8a;font-weight:600}.worker-status-group{flex-wrap:wrap;gap:.5rem}.worker-badge{background:#e5e7eb;font-size:.75rem;font-weight:700;gap:.25rem;padding:.35rem .6rem;transition:all .2s}.worker-badge:hover{background:#d1d5db;transform:scale(1.05)}.location-circles-group{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.location-circle{border:2px solid #0000;border-radius:50%;cursor:pointer;display:inline-block;height:14px;transition:all .2s;width:14px}.location-circle.success{background-color:#10b981;border-color:#059669}.location-circle.failed{background-color:#ef4444;border-color:#dc2626}.location-circle.partial{background:linear-gradient(135deg,#10b981 50%,#ef4444 0);border-color:#6b7280}.location-circle.unknown{background-color:#9ca3af;border-color:#6b7280}.location-circle:hover{box-shadow:0 2px 4px #0003;transform:scale(1.3)}.action-btn{border-radius:8px;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:.6rem 1.2rem;text-transform:uppercase}.action-btn.primary{box-shadow:0 4px 6px #667eea40}.action-btn.primary:hover{box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.workers-tab{padding:1rem 0}.workers-tab h3{color:#1e3a8a;font-size:1.5rem;margin-bottom:1.5rem}.workers-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));margin-top:1rem}.worker-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000000d;overflow:hidden;transition:all .3s}.worker-card:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-4px)}.worker-card-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.25rem}.worker-title{align-items:center;display:flex;gap:1rem}.worker-icon{font-size:1.75rem}.worker-title h4{color:#1e3a8a;font-size:1.2rem;font-weight:700;margin:0}.worker-id{color:#6b7280;font-family:Courier New,monospace;font-size:.75rem;margin:.25rem 0 0}.worker-card-body{padding:1.25rem}.worker-info-row{border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.75rem 0}.worker-info-row:last-child{border-bottom:none}.info-label{color:#6b7280}.info-label,.info-value{font-size:.875rem;font-weight:600}.info-value{color:#1e3a8a}.worker-error{background:#fee2e2;border-left:4px solid #ef4444;border-radius:6px;color:#991b1b;font-size:.875rem;line-height:1.5;margin-top:1rem;padding:1rem}.worker-error strong{color:#7f1d1d;display:block;margin-bottom:.5rem}.worker-card-footer{background:#f8fafc;border-top:2px solid #e5e7eb;padding:1.25rem}.worker-card-footer h5{color:#1e3a8a;font-size:.875rem;font-weight:700;letter-spacing:.5px;margin:0 0 1rem;text-transform:uppercase}.artifact-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.artifact-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:.35rem;padding:.6rem 1rem;transition:all .2s}.artifact-btn:hover{background:#374151;border-color:#374151;box-shadow:0 4px 8px #667eea40;color:#fff;transform:translateY(-2px)}@media (max-width:768px){.execution-history-stats{grid-template-columns:1fr}.execution-history-table .table-header,.execution-history-table .table-row{gap:.5rem;grid-template-columns:1fr}.col-duration,.col-time,.col-workers{font-size:.8rem}.workers-grid{grid-template-columns:1fr}.worker-card-header{align-items:flex-start;gap:1rem}.artifact-buttons,.worker-card-header{flex-direction:column}.artifact-btn{justify-content:center;width:100%}}.summary-view{background:#f9fafb}.summary-top-stats{grid-gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 1px 3px #0000001a;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);margin-bottom:16px;padding:10px}.summary-stat-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;display:flex;flex-direction:column;justify-content:center;min-height:56px;padding:8px 10px}.summary-stat-card.status-ok{background:#f0fdf4;border-color:#bbf7d0}.summary-stat-card.status-failed{background:#fef2f2;border-color:#fecaca}.summary-stat-value{color:#111827;font-size:20px;font-weight:700;line-height:1.1;margin-bottom:4px}.summary-stat-label{color:#6b7280;font-size:10px;font-weight:600;margin-bottom:2px;text-transform:capitalize}.summary-stat-meta{color:#9ca3af;font-size:9px}.summary-status-title{color:#16a34a;font-size:13px;font-weight:600;margin-bottom:3px}.summary-status-subtitle{color:#4d7c0f;font-size:10px;line-height:1.3}.summary-status-title-failed{color:#dc2626;font-size:13px;font-weight:600;margin-bottom:3px}.summary-status-subtitle-failed{color:#991b1b;font-size:10px;line-height:1.3}.duration-availability-section{background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 1px 2px #0000000d;padding:16px}.section-heading{color:#111827;font-size:14px;font-weight:600;margin:0 0 16px}.location-check-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:14px;padding:14px}.location-check-card:last-child{margin-bottom:0}.location-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:-15px}.location-info{align-items:center;display:inherit;gap:6px}.location-icon{font-size:18px}.location-name{color:#111827;font-size:14px;font-weight:600}.location-stats-inline{align-items:center;display:flex;gap:12px}.stat-text{color:#6b7280;font-size:12px}.more-options-btn{background:none;border:none;border-radius:3px;color:#9ca3af;cursor:pointer;font-size:16px;padding:2px 6px;transition:all .2s}.more-options-btn:hover{background:#e5e7eb;color:#374151}.location-graph-container{align-items:center;display:flex;gap:10px;margin-bottom:8px}.location-graph-area{background:#fff;border:1px solid #e5e7eb;border-radius:4px;flex:1 1;padding:8px 12px;position:relative}.response-time-graph{display:block;height:35px;width:100%}.graph-stats{align-items:flex-end;display:flex;flex-direction:column;gap:3px;position:absolute;right:12px;top:8px}.graph-stat-value{background:#ffffffe6;border:1px solid #e5e7eb;border-radius:3px;color:#6b7280;font-size:10px;padding:3px 6px}.location-footer{align-items:center;display:flex;justify-content:space-between}.time-range{color:#9ca3af;font-size:11px}.run-check-btn-side{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;height:fit-content;padding:8px 12px;transition:all .2s;white-space:nowrap}.run-check-btn-side:hover{background:#374151;border-color:#374151;box-shadow:0 2px 4px #0000001a;color:#fff;transform:translateY(-1px)}.execution-history-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px #0000000d;margin-top:24px;padding:24px}.execution-history-header{align-items:center;display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.execution-history-header .section-heading{margin:0}.table-search-bar{flex:1 1;max-width:400px;position:relative}.table-search-input{background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-size:14px;padding:10px 40px 10px 16px;transition:all .2s;width:100%}.table-search-input:focus{background:#fff;border-color:#374151;box-shadow:0 0 0 3px #3741511a;outline:none}.search-icon,.table-search-input::placeholder{color:#9ca3af}.search-icon{font-size:16px;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.execution-history-table{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.execution-history-table .table-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:700;letter-spacing:.5px;padding:12px 16px;text-transform:uppercase}.execution-history-table .table-header,.execution-history-table .table-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1.5fr 1.5fr 1fr 1fr 1fr}.execution-history-table .table-row{align-items:center;border-bottom:1px solid #f3f4f6;padding:16px;transition:background-color .15s ease}.execution-history-table .table-row.clickable{cursor:pointer}.execution-history-table .table-row:last-child{border-bottom:none}.execution-history-table .table-row:hover{background-color:#f3f4f6}.execution-history-table .col-time{color:#374151;font-size:13px}.execution-history-table .col-duration{color:#374151;font-size:13px;font-weight:500}.execution-history-table .col-status{align-items:center;display:flex}.execution-history-table .col-workers{display:flex;gap:8px}.worker-status-group{display:flex;gap:6px}.worker-badge{align-items:center;background:#f3f4f6;border-radius:6px;color:#374151;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:4px 8px}.action-btn{border-radius:6px;font-size:13px;font-weight:500;padding:6px 14px;transition:all .2s}.action-btn.primary{background:#374151;color:#fff}.action-btn.primary:hover{background:#4b5563;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.no-executions{padding:60px 20px;text-align:center}.no-executions h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 8px}.no-executions p{color:#6b7280;font-size:14px;margin:0 auto;max-width:400px}.worker-detail-tab{background:#f9fafb;min-height:400px;padding:0}.worker-execution-header{background:#fff;border-bottom:1px solid #e5e7eb;margin-bottom:0;padding:20px 24px}.execution-date-location{color:#111827;font-size:13px;font-weight:500;letter-spacing:.2px}.execution-meta-inline{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.meta-item-inline{color:#374151;font-size:13px}.meta-item-inline strong{color:#111827;font-weight:600;margin-right:6px}.meta-separator{color:#d1d5db;font-size:13px}.worker-summary-section{align-items:stretch;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;flex-wrap:nowrap;gap:0;margin-bottom:0;padding:24px}.worker-summary-item{flex:1 1;min-width:0;padding:0 20px;position:relative;text-align:left}.worker-summary-item:not(:last-child):after{background:#e5e7eb;content:"";height:40px;position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px}.worker-summary-item:first-child{padding-left:0}.worker-summary-item:last-child{padding-right:0}.summary-item-value{color:#111827;font-size:20px;font-weight:600;line-height:1.2;margin-bottom:8px}.summary-item-label,.summary-item-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-item-label{color:#6b7280;font-size:11px;font-weight:500;line-height:1.4;text-transform:capitalize}.worker-section{background:#fff;border-bottom:1px solid #e5e7eb;padding:0 24px 32px}.section-title,.worker-section:last-child{border-bottom:none}.section-title{color:#111827;font-size:15px;font-weight:600;margin:0 0 20px;padding-bottom:0}.logs-container{background:#1f2937;border:1px solid #374151;border-radius:6px;max-height:500px;overflow-y:auto;padding:20px}.logs-content{word-wrap:break-word;color:#f3f4f6;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;font-size:12px;line-height:1.7;margin:0;white-space:pre-wrap}.logs-empty,.logs-loading,.logs-placeholder{color:#9ca3af;font-size:13px;padding:40px 20px;text-align:center}.logs-empty{background:#111827}.logs-empty p{color:#d1d5db;margin:0 0 8px}.logs-empty pre{background:#1f2937;border-radius:4px;color:#9ca3af;font-size:11px;overflow-x:auto;padding:12px;text-align:left}.load-logs-btn{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;margin-top:12px;padding:10px 20px;transition:all .2s}.load-logs-btn:hover{background:#2563eb;box-shadow:0 2px 8px #3b82f64d;transform:translateY(-1px)}.screenshots-container{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:20px;text-align:center}.screenshot-image{border:1px solid #d1d5db;border-radius:6px;box-shadow:0 2px 8px #00000014;height:auto;max-width:100%}.image-error{color:#6b7280;font-size:13px;padding:40px 20px}.video-container{background:#000;border:1px solid #374151;border-radius:6px;overflow:hidden}.execution-video{display:block;max-height:600px;width:100%}.video-error{background:#1f2937;color:#9ca3af;font-size:13px;padding:40px 20px;text-align:center}.error-details{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:20px}.error-details pre{word-wrap:break-word;color:#dc2626;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;font-size:12px;line-height:1.7;margin:0;white-space:pre-wrap}.tab-status-indicator{border-radius:4px;display:inline-block;font-size:12px;font-weight:600;margin-left:8px;padding:2px 6px}.tab-status-indicator.success{background:#d1fae5;color:#065f46}.tab-status-indicator.error{background:#fee2e2;color:#991b1b}.no-data-message{padding:60px 20px;text-align:center}.no-data-icon{font-size:48px;margin-bottom:16px}.no-data-message p{color:#6b7280;font-size:16px}.pagination-container{align-items:center;background:#f9fafb;border-radius:0 0 8px 8px;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-top:-1px;padding:16px}.pagination-info{font-size:13px}.pagination-controls{align-items:center;display:flex;gap:4px}.pagination-btn{font-size:13px;min-width:36px;padding:6px 12px;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f3f4f6}.pagination-btn.active{background:#374151;border-color:#374151;color:#fff}.pagination-ellipsis{color:#9ca3af;font-size:13px;padding:0 8px}@media (max-width:1024px){.summary-top-stats{grid-template-columns:repeat(2,1fr)}.execution-history-header{align-items:flex-start;flex-direction:column}.table-search-bar{max-width:100%;width:100%}.summary-stat-card{min-height:49px}.summary-stat-value{font-size:18px}}@media (max-width:768px){.execution-history-table .table-header,.execution-history-table .table-row{gap:8px;grid-template-columns:1fr}.execution-history-table .table-header{display:none}.execution-history-table .table-row{padding:16px;position:relative}.execution-history-table .col-duration:before,.execution-history-table .col-status:before,.execution-history-table .col-time:before,.execution-history-table .col-workers:before{color:#6b7280;content:attr(data-label);display:block;font-size:11px;font-weight:600;margin-bottom:4px;text-transform:uppercase}.pagination-container{flex-direction:column;gap:12px}.pagination-controls{flex-wrap:wrap;justify-content:center}.location-graph-container{flex-direction:column}.run-check-btn-side{justify-content:center;width:100%}}@media (max-width:640px){.summary-top-stats{grid-template-columns:1fr;padding:12px}.summary-stat-card{min-height:46px;padding:7px 8px}.summary-stat-value{font-size:16px}.summary-stat-label{font-size:9px}.location-footer,.location-header{align-items:flex-start;flex-direction:column;gap:12px}.worker-summary-section{flex-direction:column;gap:20px;padding:20px 16px}.worker-summary-item{min-width:100%;padding:0!important}.worker-summary-item:not(:last-child):after{display:none}.summary-item-value{font-size:18px}.summary-item-label{font-size:11px}.worker-section{padding:24px 16px}.worker-execution-header{padding:16px}.execution-meta-inline{align-items:flex-start;flex-direction:column;gap:8px}.meta-separator{display:none}.meta-item-inline{font-size:12px}.section-title{font-size:14px}.logs-container{max-height:400px;padding:12px}.logs-content{font-size:12px}.execution-video{max-height:300px}.execution-tabs{overflow-x:auto}.execution-tab{font-size:13px;padding:10px 16px}}.infrastructure-page{background-color:#f9fafb;min-height:100%}.overview-section{padding:0}.page-header{align-items:center}.page-header h1{color:#111827}.dashboard-section{height:calc(100vh - 180px);margin-bottom:24px}.dashboard-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;height:100%;overflow:hidden}.dashboard-card-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px 20px}.dashboard-card-title{color:#fff;font-size:16px;font-weight:600;margin:0}.dashboard-actions{display:flex;gap:12px}.btn-open-grafana{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 14px;text-decoration:none;transition:all .2s ease}.btn-open-grafana:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.btn-open-grafana svg{height:14px;width:14px}.dashboard-embed-container{align-items:center;background:#f9fafb;border-radius:8px;display:flex;height:calc(100vh - 200px);justify-content:center;min-height:700px;overflow:hidden;position:relative;width:100%}.grafana-iframe{border:none;height:100%;width:100%}.info-section{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:24px}.info-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:16px;padding:16px 20px;transition:all .2s ease}.info-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.info-icon{flex-shrink:0;font-size:28px}.info-content h3{color:#111827;font-size:15px;font-weight:600;margin:0 0 6px}.info-content p{color:#6b7280;font-size:13px;line-height:1.5;margin:0}@media (max-width:1024px){.page-header h1{font-size:24px}.dashboard-card-header{align-items:flex-start;flex-direction:column;gap:10px}.dashboard-embed-container{height:calc(100vh - 240px);min-height:600px}.dashboard-section{height:calc(100vh - 220px)}.info-section{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width:768px){.page-header{margin-bottom:24px}.page-header h1{font-size:22px}.page-header p{font-size:13px}.dashboard-card-title{font-size:15px}.btn-open-grafana{font-size:12px;padding:5px 12px}.info-section{gap:12px;grid-template-columns:1fr}.dashboard-embed-container{height:calc(100vh - 280px);min-height:500px}.dashboard-section{height:calc(100vh - 260px)}.dashboard-error{padding:40px 24px}}.dashboard-loading{align-items:center;background:#f9fafb;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%;z-index:1}.dashboard-loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:12px;width:40px}.dashboard-loading p{color:#6b7280;font-size:14px;margin:0}.dashboard-error{align-items:center;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;color:#92400e;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:60px 40px;text-align:center}.dashboard-error-icon{font-size:48px;margin-bottom:16px}.dashboard-error h3{color:#92400e;font-size:18px;font-weight:600;margin:0 0 8px}.dashboard-error p{color:#78350f;font-size:14px;line-height:1.5;margin:0 0 16px;max-width:600px}.dashboard-error ol{color:#78350f;font-size:13px;line-height:1.6;text-align:left}.dashboard-error a{color:#667eea;font-weight:500;text-decoration:underline}.dashboard-error a:hover{color:#764ba2}.dashboard-error code{background:#0000000d;border-radius:4px;display:inline-block;font-family:Courier New,monospace;font-size:12px;padding:6px 10px}.user-management-container{background-color:#f9fafb;min-height:100%;padding:0}.user-management-header{margin-bottom:32px}.user-management-header h1{color:#111827;font-size:28px;font-weight:600;margin:0 0 8px}.user-management-header .subtitle{color:#6b7280;font-size:14px;margin:0}.org-selector-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;justify-content:space-between;margin-bottom:24px;padding:16px}.org-selector-group,.org-selector-section{align-items:center;display:flex;gap:1rem}.org-selector-section label{color:#374151;font-size:14px;font-weight:600}.org-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:14px;min-width:250px;padding:8px 12px;transition:border-color .2s ease}.org-select:focus{border-color:#374151;box-shadow:0 0 0 3px #3741511a;outline:none}.error-message,.info-message,.success-message{align-items:center;border-radius:8px;display:flex;font-size:14px;justify-content:space-between;margin-bottom:24px;padding:12px 16px}.info-message{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.info-banner{align-items:center;display:flex;gap:8px;padding:12px 14px}.form-helper-text{color:#6b7280;display:block;font-size:12px;font-style:italic;margin-top:6px}.action-buttons{gap:12px}.btn-secondary:hover:not(:disabled){box-shadow:0 4px 6px #0000001a}.btn-icon-only{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:24px!important;justify-content:center;min-height:40px;min-width:40px;transition:all .2s ease}.btn-icon-only:hover:not(:disabled){background:#f3f4f6;color:#374151;transform:scale(1.1)}.btn-icon-only:active:not(:disabled){background:#e5e7eb;transform:scale(.95)}.btn-icon-only:disabled{cursor:not-allowed;opacity:.3}.btn-superadmin{background:linear-gradient(135deg,#374151,#1f2937);border:none;border-radius:8px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.btn-superadmin:hover:not(:disabled){background:linear-gradient(135deg,#1f2937,#111827);box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.btn-superadmin:active:not(:disabled){box-shadow:0 2px 4px #0003;transform:translateY(0)}.btn-superadmin:disabled{cursor:not-allowed;opacity:.5;transform:none}.action-buttons-row{align-items:center;display:flex;gap:8px}.action-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:18px;opacity:.7;padding:4px 8px;transition:all .2s ease}.action-btn:hover:not(:disabled){opacity:1;transform:scale(1.1)}.action-btn:disabled{cursor:not-allowed;opacity:.3}.action-btn:active:not(:disabled){transform:scale(.95)}.edit-btn:hover:not(:disabled){background-color:#e5e7eb}.delete-btn:hover:not(:disabled){background-color:#d1d5db}.users-section-with-sidebar{grid-gap:24px;display:grid;gap:24px;grid-template-columns:280px 1fr;margin-top:24px}.category-sidebar{background:#fff;border:1px solid #e5e7eb;border-radius:8px;height:fit-content;padding:20px;position:sticky;top:20px}.category-sidebar h3{border-bottom:1px solid #e5e7eb;color:#111827;font-size:16px;font-weight:600;margin:0 0 16px;padding-bottom:12px}.category-item{align-items:center;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;margin-bottom:4px;padding:10px 12px;transition:all .2s ease}.category-item:hover{background:#f3f4f6}.category-item.active{background:#374151;color:#fff;font-weight:500}.category-label{align-items:center;display:flex;gap:6px}.category-count{background:#e5e7eb;border-radius:12px;color:#374151;font-size:12px;font-weight:600;min-width:24px;padding:2px 8px;text-align:center}.category-item.active .category-count{background:#fff3;color:#fff}.group-drilldown{border-left:2px solid #e5e7eb;margin-bottom:8px;margin-left:12px;margin-top:4px;padding-left:12px}.group-item{border-radius:4px;color:#6b7280;cursor:pointer;font-size:13px;margin-bottom:2px;padding:8px 10px}.group-item:hover{background:#f3f4f6;color:#374151}.group-item.active{background:#374151;color:#fff;font-weight:500}.group-label{text-transform:capitalize}.group-count{background:#e5e7eb;border-radius:10px;color:#374151;font-size:11px;font-weight:600;min-width:20px;padding:1px 6px;text-align:center}.group-item.active .group-count{background:#ffffff4d;color:#fff}.no-groups-message{color:#9ca3af;font-size:12px;font-style:italic;padding:8px 10px}.search-bar-container{margin-bottom:20px;position:relative}.search-input{background:#f9fafb;border-radius:8px;padding:12px 40px 12px 16px;transition:all .2s ease;width:100%}.search-input:focus{background:#fff}.search-input::placeholder{color:#9ca3af}.clear-search-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:all .2s ease;width:24px}.clear-search-btn:hover{background:#e5e7eb;color:#374151}.users-table-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000000d;padding:24px}.users-table-section h2{color:#111827;font-size:18px;font-weight:600;margin-bottom:20px}.users-table{border-collapse:initial;border-spacing:0;width:100%}.users-table thead{background:#f9fafb}.users-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.users-table td{border-bottom:1px solid #e5e7eb;color:#1f2937;font-size:14px;padding:16px}.users-table tbody tr{transition:background-color .15s ease}.users-table tbody tr:hover{background:#f9fafb}.users-table tbody tr:last-child td{border-bottom:none}.loading-spinner,.no-users-message{color:#6b7280;font-size:14px;padding:48px;text-align:center}.roles-badges{display:flex;flex-wrap:wrap;gap:8px}.role-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:capitalize}.role-badge.role-superadmin{background:linear-gradient(135deg,#1f2937,#111827);box-shadow:0 2px 4px #0000004d;color:#fff;font-weight:700}.role-badge.role-admin{background:#d1d5db;color:#1f2937;font-weight:600}.role-badge.role-member{background:#e5e7eb;color:#374151}.role-badge.role-customer{background:#f3f4f6;color:#4b5563}.user-form{padding:24px}.form-group input,.form-group select,.role-select{border:1px solid #d1d5db;border-radius:6px;color:#1f2937;font-size:14px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.role-select:focus{border-color:#374151;box-shadow:0 0 0 3px #3741511a;outline:none}.form-group input.disabled-input{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed}.superadmin-indicator{cursor:help;font-size:16px;margin-left:8px}.superadmin-note{color:#6b7280;font-size:13px;font-style:italic}.form-group small{color:#6b7280;font-size:13px;margin-top:6px}@media (max-width:768px){.user-management-container{padding:16px}.user-management-header h1{font-size:24px}.action-buttons{flex-direction:column}.users-table{font-size:13px}.users-table td,.users-table th{padding:12px 8px}.modal-content{max-width:none;width:95%}.org-selector-section{align-items:flex-start;flex-direction:column}.org-select{width:100%}}.org-management-container{background-color:#f9fafb;min-height:100%;padding:0}.org-management-header{margin-bottom:32px}.org-management-header h1{color:#111827;font-size:28px;font-weight:600;margin:0 0 8px}.org-management-header .subtitle{color:#6b7280;font-size:14px;margin:0}.close-btn{line-height:1}.section{margin-bottom:32px}.org-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.org-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000000d;overflow:hidden;transition:all .2s ease}.org-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.org-card-header{background:linear-gradient(135deg,#374151,#1f2937);color:#fff;padding:20px}.org-card-header h3{font-size:18px;font-weight:600;margin:0}.org-card-body{padding:20px}.org-card-body p{color:#6b7280;font-size:14px;margin:0 0 16px}.org-card-body strong{color:#374151;font-weight:600}.org-card-body .btn{margin-bottom:8px;margin-right:8px}.empty-state{background:#fff;border:2px dashed #e5e7eb;padding:48px}.empty-state p{margin-bottom:20px}.btn{border:none;border-radius:8px;box-shadow:0 1px 3px #0000001a;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#374151}.btn-primary:hover:not(:disabled){box-shadow:0 4px 6px #0000001a}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-sm{box-shadow:none}.groups-list{display:flex;flex-direction:column;gap:12px}.group-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000000d;display:flex;justify-content:space-between;padding:16px 20px;transition:all .2s ease}.group-item:hover{box-shadow:0 2px 4px #0000001a}.group-info h4{color:#111827;font-size:16px;font-weight:600;margin:0 0 6px}.group-org{background:#dbeafe;border-radius:12px;color:#1e40af;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-close{color:#9ca3af;font-size:28px;line-height:1;transition:color .2s ease}.org-form{padding:24px}.org-form .form-group{margin-bottom:20px}.org-form .form-group label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.org-form .form-group input,.org-form .form-group select{border:1px solid #d1d5db;border-radius:6px;color:#1f2937;font-size:14px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.org-form .form-group input:focus,.org-form .form-group select:focus{border-color:#374151;box-shadow:0 0 0 3px #3741511a;outline:none}.org-form .form-group small{color:#6b7280;display:block;font-size:13px;margin-top:6px}.modal-footer{background:#f9fafb;border-radius:0 0 12px 12px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:24px}@media (max-width:768px){.org-management-container{padding:16px}.org-management-header h1{font-size:24px}.section-header{align-items:flex-start;flex-direction:column;gap:12px}.org-grid{grid-template-columns:1fr}.group-item{align-items:flex-start;flex-direction:column;gap:12px}.modal-content{width:95%}}.permissions-management-container{background-color:#f9fafb;min-height:100%;padding:0}.permissions-management-header{margin-bottom:32px}.permissions-management-header h1{color:#111827;font-size:28px;font-weight:600;margin:0 0 8px}.permissions-management-header .subtitle{color:#6b7280;font-size:14px;margin:0}.error-message,.success-message{align-items:center;border-radius:8px;display:flex;font-size:14px;justify-content:space-between;margin-bottom:24px;padding:12px 16px}.error-message{background:#fef2f2;border:1px solid #fecaca}.success-message{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.close-btn{color:inherit;font-size:20px;margin-left:12px;opacity:.7;transition:opacity .2s ease}.close-btn:hover{opacity:1}.permissions-controls{background:#fff;border:1px solid #e5e7eb;border-radius:8px;gap:1rem;justify-content:space-between;margin-bottom:24px;padding:16px}.control-actions,.permissions-controls{align-items:center;display:flex;flex-wrap:wrap}.control-actions{gap:12px}.export-buttons{display:flex;gap:8px}.search-filter-group{display:flex;flex:1 1;gap:12px;max-width:600px}.search-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;flex:1 1;font-size:14px;padding:8px 12px;transition:border-color .2s ease}.search-input:focus{border-color:#374151;box-shadow:0 0 0 3px #3741511a;outline:none}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:14px;min-width:150px;padding:8px 12px;transition:border-color .2s ease}.filter-select:focus{border-color:#374151;box-shadow:0 0 0 3px #3741511a;outline:none}.btn-primary,.btn-secondary{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.btn-primary{background:#111827}.btn-primary:hover:not(:disabled){background:#1f2937}.btn-primary:disabled{background:#9ca3af}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.permissions-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;text-align:center}.stat-value{color:#111827;font-size:32px;font-weight:700;margin-bottom:8px}.stat-label{color:#6b7280;font-size:14px;font-weight:500}.permissions-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.loading-state{color:#6b7280;padding:60px 20px;text-align:center}.spinner{animation:spin .8s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#111827;height:40px;margin:0 auto 16px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{color:#6b7280;padding:60px 20px}.empty-state p{margin-bottom:16px}.permissions-table{border-collapse:collapse;width:100%}.permissions-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.permissions-table th{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.05em;padding:12px 16px;text-align:left;text-transform:uppercase}.permissions-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .15s ease}.permissions-table tbody tr:hover{background:#f9fafb}.permissions-table td{color:#374151;font-size:14px;padding:16px;vertical-align:middle}.tuple-cell{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.tuple-type-badge{border-radius:4px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.05em;padding:2px 8px;text-transform:uppercase}.tuple-type-badge.type-user{background:#dbeafe;color:#1e40af}.tuple-type-badge.type-group{background:#fce7f3;color:#9f1239}.tuple-type-badge.type-org{background:#dcfce7;color:#166534}.tuple-type-badge.type-route{background:#fef3c7;color:#92400e}.tuple-value{color:#111827;font-family:Monaco,Courier New,monospace;font-size:13px;word-break:break-all}.relation-badge{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;display:inline-block;font-size:13px;font-weight:600;padding:4px 12px}.action-buttons{justify-content:flex-start}.btn-icon{border:1px solid #d1d5db;border-radius:6px}.btn-icon:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-icon.btn-danger:hover:not(:disabled){background:#fef2f2;border-color:#fecaca}.btn-icon:disabled{cursor:not-allowed;opacity:.5}.btn-icon .icon{display:block}.pagination{align-items:center;border-top:1px solid #e5e7eb;display:flex;gap:16px;justify-content:center;padding:20px}.pagination-btn{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#6b7280;font-size:14px;font-weight:500}.modal-content{border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{padding:24px 24px 16px}.modal-header h2{color:#111827}.modal-form{padding:24px}.form-group label{font-weight:600}.form-input{color:#374151;transition:border-color .2s ease}.form-input:focus{border-color:#374151;box-shadow:0 0 0 3px #3741511a}.form-hint{font-style:italic}.info-banner{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#1e40af;font-size:13px;margin-bottom:20px;padding:12px}.info-banner strong{display:block;font-weight:600;margin-bottom:8px}.info-banner ul{margin:0;padding-left:20px}.info-banner li{font-family:Monaco,Courier New,monospace;font-size:12px;margin-bottom:4px}.modal-actions{padding-top:16px}@media (max-width:768px){.permissions-controls{align-items:stretch;flex-direction:column}.search-filter-group{flex-direction:column;max-width:100%}.permissions-stats{grid-template-columns:repeat(2,1fr)}.permissions-table{font-size:12px}.permissions-table td,.permissions-table th{padding:8px}.tuple-cell{align-items:flex-start;flex-direction:column}}@media (max-width:480px){.permissions-stats{grid-template-columns:1fr}.modal-content{border-radius:0;max-height:100vh;max-width:100%}}.tabs-container{border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;font-size:14px;font-weight:600;margin-bottom:-2px;padding:12px 20px;transition:all .2s ease}.tab-button:hover{background:#f9fafb;color:#111827}.tab-button.active{border-bottom-color:#111827;color:#111827}.tab-content{animation:fadeIn .3s ease}.model-management-container{display:flex;flex-direction:column;gap:24px}.model-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:24px}.section-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.section-header h2{color:#111827;font-size:18px;font-weight:600;margin:0}.section-actions{display:flex;gap:12px}.model-info-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:20px;padding:16px}.model-info-row{align-items:center;display:flex;font-size:14px;gap:12px;padding:8px 0}.model-info-row:not(:last-child){border-bottom:1px solid #e5e7eb}.model-info-label{color:#6b7280;font-weight:600;min-width:150px}.model-id-display{align-items:center;display:flex;flex:1 1;gap:8px}.model-id{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#111827;flex:1 1;font-family:Monaco,Courier New,monospace;font-size:13px;padding:6px 12px;word-break:break-all}.model-viewer{margin-top:20px}.model-viewer-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:12px}.model-viewer h3{color:#111827;font-size:16px;font-weight:600;margin:0}.model-viewer-controls{align-items:center;display:flex;gap:12px}.view-mode-toggle{background:#f3f4f6;border-radius:6px;display:flex;gap:2px;padding:2px}.toggle-btn{background:#0000;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.toggle-btn:hover{background:#e5e7eb;color:#111827}.toggle-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#111827}.model-code{background:#1f2937;border-radius:8px;color:#f3f4f6;font-family:Monaco,Courier New,monospace;font-size:13px;line-height:1.6;margin:0;max-height:500px;overflow-x:auto;overflow-y:auto;padding:20px;white-space:pre-wrap;word-break:break-word}.model-history-list{display:flex;flex-direction:column;gap:12px}.model-history-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;padding:16px;transition:all .2s ease}.model-history-item:hover{background:#f3f4f6;border-color:#d1d5db}.model-history-item.current{background:#eff6ff;border-color:#bfdbfe}.model-history-info{display:flex;flex:1 1;flex-direction:column;gap:8px}.model-history-id{align-items:center;display:flex;gap:12px}.model-history-id code{background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#111827;font-family:Monaco,Courier New,monospace;font-size:13px;padding:4px 8px}.badge-current{background:#1e40af;border-radius:4px;color:#fff;font-size:10px;font-weight:700;letter-spacing:.05em;padding:3px 8px;text-transform:uppercase}.model-history-date{color:#6b7280;font-size:13px}.model-history-actions{display:flex;gap:8px}.btn-sm{font-size:13px;padding:6px 12px}.modal-large{max-width:900px}.model-editor-textarea{background:#1f2937;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;color:#f3f4f6;font-family:Monaco,Courier New,monospace;font-size:13px;line-height:1.6;padding:16px;resize:vertical;width:100%}.model-editor-textarea:focus{border-color:#374151;box-shadow:0 0 0 3px #3741511a;outline:none}.model-id-display-large{background:#fff;border:2px solid #111827;border-radius:8px;display:flex;flex-direction:column;gap:12px;margin:16px 0;padding:16px}.model-id-display-large code{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#111827;font-family:Monaco,Courier New,monospace;font-size:14px;padding:12px;word-break:break-all}.success-banner{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#166534;margin-bottom:16px;padding:16px}.success-banner p{margin:0 0 8px}.success-banner p:last-child{margin:0}.info-banner ol{margin:8px 0 0;padding-left:24px}.info-banner li{margin-bottom:6px}@media (max-width:768px){.section-header{align-items:flex-start;flex-direction:column;gap:16px}.section-actions{width:100%}.section-actions button{flex:1 1}.model-history-item{align-items:flex-start;flex-direction:column;gap:12px}.model-history-actions{width:100%}.model-history-actions button{flex:1 1}.model-info-row{align-items:flex-start;flex-direction:column;gap:8px}.model-info-label{min-width:0}.modal-large{max-width:100%}.model-viewer-header{align-items:flex-start;flex-direction:column}.model-viewer-controls{flex-direction:column;width:100%}.view-mode-toggle{width:100%}.toggle-btn{flex:1 1}.model-viewer-controls .btn-secondary{width:100%}.permissions-controls{align-items:stretch;flex-direction:column}.control-actions{flex-direction:column;width:100%}.export-buttons{width:100%}.export-buttons button{flex:1 1}}.export-modal .modal-body{padding:24px}.export-preview{margin-top:16px}.export-preview-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.export-preview-header h3{color:#111827;font-size:16px;font-weight:600;margin:0}.export-code{background:#1f2937;border-radius:8px;color:#f3f4f6;font-family:Monaco,Courier New,monospace;font-size:12px;line-height:1.6;margin:0;max-height:500px;overflow-x:auto;overflow-y:auto;padding:20px;white-space:pre;word-break:normal}.export-modal .info-banner{margin-bottom:20px}.export-modal .info-banner ul{margin:8px 0 0;padding-left:24px}.export-modal .info-banner li{font-size:13px;margin-bottom:4px}@media (max-width:768px){.export-preview-header{align-items:flex-start;flex-direction:column;gap:12px}.export-preview-header button{width:100%}.export-code{font-size:11px;padding:16px}}.synthetic-locations-management{margin:0 auto;max-width:1400px;padding:24px}.page-header{display:flex;justify-content:space-between}.page-header h1{color:#333;font-size:28px}.page-description{color:#666}.btn-primary{background:#4a90e2;transition:background .2s}.btn-primary:hover{background:#357abd}.btn-secondary{background:#f5f5f5;border:1px solid #ddd;color:#333;transition:all .2s}.btn-secondary:hover{background:#e0e0e0}.error-state,.loading-state{background:#f8f9fa;border-radius:8px;color:#666;padding:48px;text-align:center}.error-state{background:#ffebee;color:#e74c3c}.empty-state{background:#f8f9fa;border-radius:8px;padding:64px 24px}.empty-state p{color:#666;font-size:16px;margin-bottom:24px}.locations-table{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.locations-table table{border-collapse:collapse;width:100%}.locations-table thead{background:#f8f9fa}.locations-table th{border-bottom:2px solid #e0e0e0;color:#555;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.locations-table td{border-bottom:1px solid #f0f0f0;color:#333;padding:16px}.locations-table tbody tr:hover{background:#f8f9fa}.locations-table code{background:#f5f5f5;border-radius:4px;color:#e74c3c;font-family:Monaco,Courier New,monospace;font-size:13px;padding:4px 8px}.function-name{color:#2196f3}.status-badge.enabled{background:#d4edda;color:#155724}.status-badge.disabled{background:#f8d7da;color:#721c24}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-icon{border:none;font-size:18px;padding:4px 8px;transition:background .2s}.btn-icon:hover{background:#f0f0f0}.btn-icon.btn-danger:hover{background:#ffebee}.modal-overlay{background:#00000080}.modal-content{box-shadow:0 4px 20px #0000004d;width:90%}.modal-header{border-bottom:1px solid #e0e0e0;padding:24px}.modal-header h2{color:#333}.close-btn{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;padding:0;transition:color .2s;width:32px}.close-btn:hover{color:#333}.modal-content form{padding:24px}.form-group label{color:#555;display:block;margin-bottom:8px}.required{color:#e74c3c}.form-group input[type=number],.form-group input[type=text],.form-group textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#4a90e2;outline:none}.form-group input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-group small{color:#777;display:block;font-size:12px;margin-top:4px}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:8px}.checkbox-group input[type=checkbox]{cursor:pointer;height:18px;width:18px}.modal-actions{border-top:1px solid #e0e0e0}@media (max-width:768px){.synthetic-locations-management{padding:16px}.page-header{flex-direction:column;gap:16px}.locations-table{overflow-x:auto}.locations-table table{min-width:800px}.modal-content{margin:16px;width:95%}}.api-keys-page{margin:0 auto;max-width:1400px;padding:24px}.page-header p{color:#6b7280;font-size:14px;margin:0}.alert-success{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.api-keys-actions{display:flex;justify-content:flex-end;margin-bottom:24px}.btn-primary{align-items:center;display:flex;gap:8px}.btn-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.loading-container{color:#6b7280;padding:60px 20px}.api-keys-list{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.empty-state{padding:80px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{color:#1f2937;font-size:20px;font-weight:600;margin:0 0 8px}.empty-state p{color:#6b7280;margin:0 0 24px}.api-keys-table{border-collapse:collapse;width:100%}.api-keys-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.api-keys-table th{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.api-keys-table td{border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;padding:16px}.api-keys-table tbody tr:hover{background-color:#f9fafb}.api-keys-table tbody tr:last-child td{border-bottom:none}.key-identifier{background-color:#f3f4f6;border-radius:4px;color:#1f2937;font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;font-weight:500;padding:4px 8px}.status-badge{font-size:12px;padding:4px 12px;text-transform:capitalize}.status-active{background-color:#d1fae5;color:#065f46}.status-revoked{background-color:#fee2e2;color:#991b1b}.action-buttons{display:flex;gap:8px}.btn-icon{align-items:center;background:none;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer;display:flex;font-size:16px;justify-content:center;padding:6px 10px;transition:all .2s ease}.btn-icon:hover{background-color:#f3f4f6;border-color:#d1d5db}.btn-icon.btn-danger:hover{background-color:#fef2f2;border-color:#fecaca;color:#dc2626}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;max-width:1400px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#1f2937;font-size:20px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.modal-close:hover{background-color:#f3f4f6;color:#374151}.modal-body{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#374151;font-size:14px;font-weight:500;margin-bottom:6px}.form-input{border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:all .2s ease;width:100%}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-hint{margin-top:4px}.checkbox-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px}.checkbox-label input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.key-display-modal{max-width:600px}.key-warning{background-color:#fef3c7;border:1px solid #fde68a;border-radius:6px;color:#92400e;font-size:14px;padding:12px 16px}.key-display,.key-warning{margin-bottom:24px}.key-display label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.key-value-container{align-items:center;display:flex;gap:8px}.key-value{background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;color:#1f2937;flex:1 1;font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;padding:12px;word-break:break-all}.btn-copy-key{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:10px 16px;transition:all .2s ease;white-space:nowrap}.btn-copy-key:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.key-details{background-color:#f9fafb;border-radius:6px;margin-top:16px;padding:16px}.key-details p{color:#374151;font-size:14px;margin:8px 0}.key-details strong{color:#1f2937;margin-right:8px}@media (max-width:768px){.api-keys-page{padding:16px}.api-keys-table{font-size:12px}.api-keys-table td,.api-keys-table th{padding:8px}.key-value-container{align-items:stretch;flex-direction:column}.btn-copy-key{width:100%}}.api-documentation-page{box-sizing:border-box;margin:0;max-width:100%;padding:0;width:100%}.page-header{margin-bottom:32px}.page-header h1{color:#1f2937;font-size:32px;font-weight:600;margin:0 0 8px}.page-description{color:#6b7280;font-size:14px;line-height:1.6;margin:0}.api-keys-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;padding:20px}.api-keys-section label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.api-key-selector-wrapper{margin-bottom:12px}.api-key-select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-size:14px;max-width:600px;padding:10px 12px;transition:all .2s ease;width:100%}.api-key-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.no-keys-hint{color:#6b7280;display:block;font-size:12px;margin-top:6px}.no-keys-hint a{color:#667eea;text-decoration:none}.no-keys-hint a:hover{text-decoration:underline}.api-key-input-wrapper{align-items:center;display:flex;gap:8px;max-width:600px}.api-key-input{box-sizing:border-box;flex:1 1;font-family:Monaco,Menlo,Courier New,monospace;font-size:14px}.api-key-input,.btn-toggle-visibility{border:1px solid #d1d5db;border-radius:6px;padding:10px 12px;transition:all .2s ease}.btn-toggle-visibility{background-color:#f3f4f6;cursor:pointer;font-size:16px}.btn-toggle-visibility:hover{background-color:#e5e7eb}.api-key-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-hint{color:#6b7280;display:block;font-size:12px;margin-top:6px}.form-hint a{color:#667eea;text-decoration:none}.form-hint a:hover{text-decoration:underline}.alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:12px;margin-bottom:24px;padding:12px 16px}.alert-error{background-color:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert button{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;font-size:20px;height:24px;justify-content:center;margin-left:auto;opacity:.7;padding:0;width:24px}.alert button:hover{opacity:1}.api-documentation-layout{align-items:flex-start;box-sizing:border-box;display:flex;gap:24px;width:100%}.api-list-sidebar{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;flex:0 0 280px;padding:20px;position:sticky;top:24px}.api-list-sidebar h2{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 20px}.api-category{margin-bottom:24px}.api-category:last-child{margin-bottom:0}.category-header{border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:13px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;padding-bottom:8px;text-transform:uppercase}.api-list{list-style:none;margin:0;padding:0}.api-list li{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:8px;margin-bottom:4px;padding:12px;transition:all .2s ease}.api-list li:hover{background-color:#f3f4f6}.api-list li.active{background-color:#eef2ff;border-left:3px solid #667eea}.api-method{border-radius:4px;font-size:11px;font-weight:600;min-width:40px;padding:2px 6px;text-align:center;text-transform:uppercase}.api-list li .api-method{background-color:#667eea;color:#fff}.api-name{color:#374151;font-size:14px;font-weight:500}.api-details-panel{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;box-sizing:border-box;flex:1 1;min-width:0;overflow:hidden;padding:32px}.no-selection{color:#6b7280;padding:80px 20px;text-align:center}.api-details{box-sizing:border-box;max-width:100%;width:100%}.api-tabs{margin-top:24px}.tab-headers{border-bottom:2px solid #e5e7eb;display:flex;gap:0;margin-bottom:24px}.tab-header{background:none;border:none;border-bottom:3px solid #0000;bottom:-2px;color:#6b7280;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;position:relative;transition:all .2s ease}.tab-header:hover{background-color:#f9fafb;color:#374151}.tab-header.active{border-bottom-color:#667eea;color:#667eea;font-weight:600}.tab-content{min-height:400px}.tab-panel{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.export-note{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#1e40af;margin-bottom:20px;padding:12px 16px}.export-note small{font-size:13px;line-height:1.5}.api-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.api-header h2{color:#1f2937;font-size:24px;font-weight:600;margin:0}.api-method-badge{background-color:#667eea;border-radius:4px;color:#fff;font-size:12px;font-weight:600;padding:4px 10px;text-transform:uppercase}.api-path{background-color:#f3f4f6;border-radius:4px;color:#374151;font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;padding:4px 8px}.api-description{color:#6b7280;font-size:16px;line-height:1.6;margin-bottom:32px}.api-section{border-bottom:1px solid #e5e7eb;margin-bottom:32px;padding-bottom:32px}.api-section:last-child{border-bottom:none}.api-section h3{color:#1f2937;font-size:20px;font-weight:600;margin:0 0 16px}.parameters-table{border-collapse:collapse;margin-top:12px;width:100%}.parameters-table thead{background-color:#f9fafb}.parameters-table th{border-bottom:2px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.parameters-table td{border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;padding:12px 16px}.parameters-table tbody tr:hover{background-color:#f9fafb}.parameters-table code{background-color:#f3f4f6;border-radius:4px;color:#1f2937;padding:2px 6px}.code-block,.parameters-table code{font-family:Monaco,Menlo,Courier New,monospace;font-size:13px}.code-block{background-color:#1f2937;border-radius:6px;color:#f9fafb;line-height:1.6;margin:12px 0;overflow-x:auto;padding:16px}.code-block code{background:none;color:#f9fafb;padding:0}.api-tester{margin-top:16px}.tester-form{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.tester-form .form-group{display:flex;flex-direction:column;gap:6px}.tester-form label{color:#374151;font-size:14px;font-weight:500}.tester-form input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:10px 12px;transition:all .2s ease}.tester-form input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.array-input-group{align-items:center;display:flex;gap:8px;margin-bottom:8px}.array-input-group input{flex:1 1}.array-input-group button{background-color:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#991b1b;cursor:pointer;font-size:12px;padding:8px 12px;transition:all .2s ease}.array-input-group button:hover{background-color:#fecaca}.tester-form button[type=button]{align-self:flex-start;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .2s ease}.tester-form button[type=button]:hover{background-color:#e5e7eb}.tester-actions{display:flex;gap:12px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-secondary:hover{background-color:#f9fafb;border-color:#9ca3af}.test-results{margin-top:16px}.result-status{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:12px}.status-badge{border-radius:12px;display:inline-block;font-size:13px;font-weight:500;padding:6px 12px}.status-success{background-color:#d1fae5;color:#065f46}.status-error{background-color:#fee2e2;color:#991b1b}.result-timestamp{color:#6b7280;font-size:12px}.copy-results-btn{background-color:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.copy-results-btn:hover{background-color:#5568d3}.copy-results-btn:active{transform:scale(.98)}.result-error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:16px}.error-message{color:#991b1b;line-height:1.6;margin-top:12px}.error-message strong{color:#7f1d1d}.error-details,.error-status{color:#6b7280;font-size:13px;margin-top:8px}.error-response{background-color:#1f2937;border:1px solid #dc2626;margin-top:12px}.result-success{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;padding:16px}.code-exporter{margin-top:16px}.format-selector{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.format-selector button{background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s ease}.format-selector button:hover{background-color:#e5e7eb}.format-selector button.active{background-color:#667eea;border-color:#667eea;color:#fff}.code-output{border:1px solid #e5e7eb;border-radius:6px;overflow:hidden}.code-header{align-items:center;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:12px 16px}.code-header span{color:#374151;font-size:13px;font-weight:500}.btn-copy{background-color:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .2s ease}.btn-copy:hover{background-color:#5568d3}@media (max-width:1024px){.api-documentation-layout{flex-direction:column}.api-list-sidebar{flex:1 1;position:static;width:100%}.api-list{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.api-details-panel{width:100%}}@media (max-width:768px){.api-documentation-page{padding:0}.api-details-panel{padding:20px}.tab-headers{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab-header{font-size:13px;padding:10px 16px;white-space:nowrap}.api-documentation-page{padding:16px}.api-details-panel{padding:20px}.parameters-table{font-size:12px}.parameters-table td,.parameters-table th{padding:8px}.format-selector{flex-direction:column}.format-selector button{width:100%}}.App,.coming-soon{min-height:100vh}.coming-soon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:center;text-align:center}.coming-soon h1{font-size:48px;font-weight:700;margin:0 0 16px}.coming-soon p{font-size:18px;margin:0;max-width:400px;opacity:.9}.sign-in-button,.sign-out-button,.sign-up-button{border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:600;margin:8px;padding:12px 24px;transition:all .3s ease}.sign-up-button{background-color:#0d66d0;color:#fff}.sign-up-button:hover{background-color:#095aba}.sign-in-button{background-color:#2680eb;color:#fff}.sign-in-button:hover{background-color:#1473e6}.sign-out-button{background-color:#e34850;color:#fff}.sign-out-button:hover{background-color:#d7373f}.not-signed-in-container,.signed-in-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;text-align:center}.not-signed-in-container h3,.signed-in-container h3{color:#333;font-size:32px;margin-bottom:24px}.signed-in-container p{color:#666;font-size:18px;margin-bottom:16px}.signed-in-container .user-email{color:#888;font-size:16px;font-style:italic;margin-bottom:24px;margin-top:-16px}.auth-buttons{display:flex;gap:16px}.loading-container{align-items:center;background:#f3f4f6;display:flex;flex-direction:column;justify-content:center;min-height:100vh;text-align:center}.loading-container p{animation:pulse 1.5s ease-in-out infinite;color:#666;font-size:18px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}
/*# sourceMappingURL=main.3a56167e.css.map*/