body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.time-range-selector{display:flex;flex-direction:column;gap:10px}.quick-ranges{display:flex;gap:8px}.quick-ranges button{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.quick-ranges button:hover{background:#f5f5f5}.quick-ranges button.active{background:#667eea;border-color:#667eea;color:#fff}.custom-range-picker{align-items:flex-end;background:#f9f9f9;border:1px solid #ddd;border-radius:4px;display:flex;gap:10px;padding:10px}.date-input-group{display:flex;flex-direction:column;gap:4px}.date-input-group label{color:#666;font-size:12px;font-weight:500}.date-input-group input{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:6px 10px}.apply-button{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 20px;transition:background .2s}.apply-button:hover{background:#5568d3}.apply-button:active{background:#4757b8}.dashboard{display:flex;flex-direction:column;gap:2rem}.summary-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.card-label{color:#666;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.card-value{color:#667eea;font-size:2rem;font-weight:700}.top-slow-section{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(500px,1fr))}.top-slow-panel{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem}.top-slow-panel h2{color:#333;font-size:1.2rem;margin-bottom:1rem}.slow-queries-table{border-collapse:collapse;width:100%}.slow-queries-table thead{background:#f5f7fa}.slow-queries-table th{border-bottom:2px solid #e0e0e0;color:#555;font-size:.9rem;font-weight:600;padding:.75rem;text-align:left}.slow-queries-table th.sortable{cursor:pointer;transition:background-color .2s;-webkit-user-select:none;user-select:none}.slow-queries-table th.sortable:hover{background-color:#e8eaf0}.slow-queries-table td{border-bottom:1px solid #f0f0f0;font-size:.9rem;padding:.75rem}.slow-queries-table tbody tr:hover{background:#f9f9f9}.query-cell{color:#555;font-family:Courier New,monospace;font-size:.85rem;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:1200px){.top-slow-section{grid-template-columns:1fr}}.timeline{display:flex;flex-direction:column;gap:2rem}.timeline h2{color:#333;font-size:1.5rem;margin-bottom:1rem}.timeline-list{display:flex;flex-direction:column;gap:1.5rem;max-height:80vh;overflow-y:auto;padding-right:.5rem}.timeline-list::-webkit-scrollbar{width:8px}.timeline-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.timeline-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.timeline-list::-webkit-scrollbar-thumb:hover{background:#555}.timeline-bucket{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow:visible}.bucket-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1rem 1.5rem}.bucket-time{font-size:1rem;font-weight:600}.bucket-count{font-size:.9rem;opacity:.9}.bucket-queries{gap:.75rem;min-height:50px;padding:1rem}.bucket-queries,.query-row{display:flex;flex-direction:column}.query-row{background:#f9f9f9;border-left:3px solid #667eea;border-radius:4px;gap:.5rem;min-height:60px;padding:.75rem;transition:background .2s}.query-row:hover{background:#f0f0f0}.query-stats{align-items:center;display:flex;font-size:.85rem;gap:1rem}.query-count{background:#667eea;border-radius:12px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.query-timing{color:#666}.query-text,.query-timing{font-family:Courier New,monospace}.query-text{color:#333;font-size:.85rem;line-height:1.4;word-break:break-all}.more-queries{color:#999;font-size:.9rem;font-style:italic;padding:.5rem;text-align:center}.system-metrics{display:flex;flex-direction:column;gap:2rem}.system-metrics .summary-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.system-metrics .card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;transition:transform .2s,box-shadow .2s}.system-metrics .card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.system-metrics .card.cpu .card-value{color:#ff6384}.system-metrics .card.memory .card-value{color:#36a2eb}.system-metrics .card-label{color:#666;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.system-metrics .card-value{color:#667eea;font-size:2rem;font-weight:700}.system-metrics .chart-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:2rem}.system-metrics .no-data{color:#999;font-size:1.1rem;padding:3rem;text-align:center}.admin-queries{display:flex;flex-direction:column;gap:2rem}.admin-queries .summary-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.admin-queries .card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;transition:transform .2s,box-shadow .2s}.admin-queries .card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.admin-queries .card.slow .card-value{color:#e74c3c}.admin-queries .card.fast .card-value{color:#27ae60}.admin-queries .card-label{color:#666;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.admin-queries .card-value{color:#667eea;font-size:2rem;font-weight:700}.queries-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem}.queries-section h2{color:#333;font-size:1.2rem;margin-bottom:.5rem}.section-description{color:#666;font-size:.9rem;margin-bottom:1.5rem}.queries-table{border-collapse:collapse;width:100%}.queries-table thead{background:#f5f7fa}.queries-table th{border-bottom:2px solid #e0e0e0;color:#555;font-size:.9rem;font-weight:600;padding:.75rem;text-align:left}.queries-table td{border-bottom:1px solid #f0f0f0;font-size:.9rem;padding:.75rem}.queries-table tbody tr:hover{background:#f9f9f9}.queries-table .slow-row{background:#e74c3c0d}.queries-table .slow-row:hover{background:#e74c3c1a}.operation-link{color:#667eea;font-weight:500;text-decoration:none}.operation-link:hover{text-decoration:underline}.type-badge{padding:.2rem .5rem}.admin-query-detail{display:flex;flex-direction:column;gap:2rem}.breadcrumb{color:#666;font-size:.9rem}.breadcrumb a{color:#667eea;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.operation-header{align-items:center;display:flex;gap:1rem}.operation-header h1{color:#333;font-size:1.8rem;margin:0}.admin-query-detail .summary-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.admin-query-detail .card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;transition:transform .2s,box-shadow .2s}.admin-query-detail .card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.admin-query-detail .card.slow .card-value{color:#e74c3c}.admin-query-detail .card.fast .card-value{color:#27ae60}.admin-query-detail .card-label{color:#666;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.admin-query-detail .card-value{color:#667eea;font-size:1.8rem;font-weight:700}.chart-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:2rem}.threshold-indicator{align-items:center;color:#e74c3c;display:flex;font-size:.85rem;gap:.5rem;margin-bottom:1rem}.threshold-line{background:#e74c3cb3;border-top:2px dashed #e74c3cb3;display:inline-block;height:2px;width:30px}.timeline-table-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem}.timeline-table-section h2{color:#333;font-size:1.2rem;margin-bottom:1rem}.timeline-table{border-collapse:collapse;width:100%}.timeline-table thead{background:#f5f7fa}.timeline-table th{border-bottom:2px solid #e0e0e0;color:#555;font-size:.9rem;font-weight:600;padding:.75rem;text-align:left}.timeline-table td{border-bottom:1px solid #f0f0f0;font-size:.9rem;padding:.75rem}.timeline-table tbody tr:hover{background:#f9f9f9}.timeline-table .slow-row{background:#e74c3c0d}.timeline-table .slow-row:hover{background:#e74c3c1a}.type-badge{border-radius:4px;font-size:.8rem;padding:.3rem .6rem}.p95-slow{color:#e74c3c;font-weight:600}.p95-fast{color:#27ae60}.status-badge{border-radius:4px;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .5rem}.status-badge.slow{background:#e74c3c;color:#fff}.status-badge.fast{background:#27ae60;color:#fff}.no-data{font-size:1.1rem;padding:3rem}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:450px;overflow:hidden;width:100%}.login-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 30px;text-align:center}.login-header h1{font-size:28px;font-weight:600;margin:0 0 10px}.login-header p{font-size:14px;margin:0;opacity:.9}.login-content{padding:40px 30px}.login-content h2{color:#1a202c;font-size:24px;margin:0 0 10px}.login-subtitle{color:#718096;font-size:14px;margin:0 0 30px}.error-message{align-items:center;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c00;display:flex;font-size:14px;gap:10px;margin-bottom:20px;padding:12px 16px}.error-message svg{flex-shrink:0}.google-login-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#1a202c;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:12px;justify-content:center;margin-bottom:20px;padding:12px 24px;transition:all .2s ease;width:100%}.google-login-btn:hover{background:#f7fafc;border-color:#cbd5e0;box-shadow:0 4px 12px #0000001a}.google-login-btn:active{transform:translateY(1px)}.login-notice{align-items:center;background:#f0f9ff;border-radius:6px;color:#0369a1;display:flex;font-size:13px;gap:8px;padding:12px 16px}.login-notice svg{flex-shrink:0}@media (max-width:480px){.login-box{border-radius:0}.login-content,.login-header{padding:30px 20px}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 4px #0000001a;color:#fff;padding:0}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:1rem 2rem}.nav-title{font-size:1.5rem;font-weight:600}.nav-links{align-items:center;display:flex;gap:2rem}.nav-link{border-radius:4px;color:#fff;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:background .2s}.nav-link:hover{background:#ffffff1a}.user-menu{align-items:center;border-left:1px solid #ffffff4d;display:flex;gap:1rem;margin-left:1rem;padding-left:1rem}.user-email{font-size:.9rem;opacity:.9}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .2s}.logout-btn:hover{background:#ffffff4d;border-color:#ffffff80}.main-content{margin:0 auto;max-width:1400px;padding:2rem}.loading{color:#666;font-size:1.2rem;padding:4rem;text-align:center}.no-data{color:#999;font-style:italic;padding:2rem;text-align:center}.controls{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem;padding:1.5rem}.controls,.selector{align-items:center;display:flex}.selector{gap:.5rem}.selector label{color:#555;font-weight:600}.refresh-btn,.selector select{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.95rem;padding:.5rem 1rem;transition:border-color .2s}.selector select:focus,.selector select:hover{border-color:#667eea;outline:none}.refresh-btn{background:#667eea;border:none;color:#fff;font-weight:500}.refresh-btn:hover{background:#5568d3}.auto-refresh{align-items:center;color:#555;display:flex;font-weight:500;gap:.5rem}.auto-refresh,.auto-refresh input{cursor:pointer}.type-badge{border-radius:3px;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .5rem;text-transform:uppercase}.type-badge.query{background:#e3f2fd;color:#1976d2}.type-badge.mutation{background:#fce4ec;color:#c2185b}
/*# sourceMappingURL=main.cc16a4d4.css.map*/