:root{--primary-color: #3b82f6;--primary-color-dark: #2563eb;--border-color: #e5e7eb;--text-color: #374151;--background-color: #f9fafb}.analytics-auth-wrapper{border:1px solid var(--border-color);border-radius:12px;padding:32px;display:flex;flex-direction:column;align-items:center;gap:16px;background:#ffffffe6;margin-bottom:32px;box-shadow:0 10px 30px #3b82f61f}.analytics-auth-wrapper.hidden{display:none}.auth-description{color:var(--text-color);text-align:center;max-width:420px;line-height:1.5}.auth-error{text-align:center;max-width:480px}.auth-spinner{margin-top:12px}.google-signin-button{display:inline-flex;justify-content:center;width:100%;max-width:280px}.google-signin-button.disabled{opacity:.6;pointer-events:none}.analytics-secondary-button{background:transparent;border:1px solid var(--primary-color);color:var(--primary-color);border-radius:24px;padding:8px 20px;font-weight:600;cursor:pointer;transition:background .2s ease,color .2s ease}.analytics-secondary-button:hover{background:var(--primary-color);color:#fff}.analytics-user-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding:12px 20px;border:1px solid var(--border-color);border-radius:12px;background-color:#fff}.analytics-user-info{display:flex;align-items:center;gap:12px}.analytics-user-avatar{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:1px solid var(--border-color)}.analytics-user-name{font-weight:600;color:var(--text-color)}.analytics-user-email{font-size:.85rem;color:#6b7280}.top-purchased-items,.login-counts-chart,.location-entries-chart,.players-in-location-form,.event-types-viewer,.player-playtime-list,.average-playtime-container,.dictionary-viewer,.player-telemetry-container{width:100%}.data-table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:10px;text-align:left;border-bottom:1px solid #e1e5ea}.data-table th{background-color:#93c0fc4d;font-weight:700}.data-table tr:nth-child(2n){background-color:#ffffff80}.data-table tr:nth-child(odd){background-color:#f7fafc80}.data-table tr:hover{background-color:#93c0fc33}.percentage-bar-container{width:100%;height:20px;background-color:#e5e7eb80;border-radius:10px;overflow:hidden}.percentage-bar{height:100%;background:linear-gradient(to right,#7aa8fdcc,#999bffcc);border-radius:10px;transition:width .5s ease-out}.percentage-bar-relative{background:linear-gradient(to right,#f97316cc,#ea580ccc)}.loading-spinner{display:inline-block;width:50px;height:50px;border:4px solid rgba(147,192,252,.3);border-radius:50%;border-top-color:#93c0fc;animation:spin 1s ease-in-out infinite;margin:2rem auto}.loading-spinner.small{width:24px;height:24px;border-width:2px;margin:1rem auto}.error-message{color:#b91c1c;text-align:center;padding:1rem;background-color:#fee2e280;border-radius:.375rem;margin:1rem 0}.no-data{text-align:center;padding:2rem;color:#6b7280;font-style:italic}.api-source-toggle{display:flex;flex-direction:column;align-items:center;margin-bottom:1.5rem;gap:.5rem}.toggle-api-button{background:linear-gradient(to right,#7aa8fdcc,#999bffcc);color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.toggle-api-button:hover{background:linear-gradient(to right,#7aa8fde6,#999bffe6);transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.toggle-api-button:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.current-api-source{font-size:.875rem;color:#6b7280}.api-source{font-weight:600;color:#4b5563}.players-in-location-form form{background-color:#ffffffb3;padding:1.5rem;border-radius:.5rem;box-shadow:0 2px 4px #0000000d;margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#4b5563}.form-group select,.form-group input{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff}.query-button{background:linear-gradient(to right,#7aa8fdcc,#999bffcc);color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;width:100%;margin-top:.5rem}.query-button:hover:not(:disabled){background:linear-gradient(to right,#7aa8fde6,#999bffe6);transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.query-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000001a}.query-button:disabled{opacity:.6;cursor:not-allowed}.result-card{background-color:#fffc;padding:1.5rem;border-radius:.5rem;box-shadow:0 2px 8px #0000001a}.result-card h3{margin-top:0;margin-bottom:1rem;color:#374151;font-size:1.25rem}.result-details p{margin:.5rem 0;font-size:1rem;color:#4b5563}.analytics-tabs{display:flex;border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem;margin-top:1rem;overflow-x:auto;flex-wrap:wrap}.analytics-tab,.tab-button{padding:.75rem 1.25rem;cursor:pointer;font-weight:500;color:#6b7280;border-bottom:2px solid transparent;transition:all .2s ease;white-space:nowrap;background:none;border:none;font-size:inherit;font-family:inherit;text-align:center}.analytics-tab:hover,.tab-button:hover{color:#4b5563}.analytics-tab.active,.tab-button.active{color:#3b82f6;border-bottom-color:#3b82f6}.tab-content{width:100%}.analytics-panel{padding:1rem 0}.panel-title{margin-top:0;margin-bottom:1.5rem;font-size:1.25rem;color:#374151}.event-types-viewer{padding:.5rem 0}.search-container{margin-bottom:1.5rem}.search-input{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff;font-size:1rem}.search-input:focus{outline:none;border-color:#93c0fc;box-shadow:0 0 0 3px #93c0fc33}.event-types-list{margin-bottom:1.5rem}.event-types-summary{display:flex;justify-content:space-between;padding:1rem;background-color:#ffffffb3;border-radius:.375rem;margin-top:1rem}.event-types-summary p{margin:0;color:#4b5563}.player-playtime-list{padding:.5rem 0}.player-playtime-list tr td:nth-child(3){font-weight:500}.player-playtime-list tr td:first-child{font-weight:700;text-align:center}.average-playtime-container{display:flex;justify-content:center;padding:1rem 0}.stat-card{background-color:#fffc;border-radius:.75rem;box-shadow:0 4px 12px #0000001a;padding:2rem;width:100%;max-width:600px;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #00000026}.stat-header{font-size:1.25rem;font-weight:600;color:#4b5563;margin-bottom:1rem}.stat-value{font-size:2.5rem;font-weight:700;color:#3b82f6;margin-bottom:.5rem;background:linear-gradient(to right,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-subtitle{font-size:.875rem;color:#6b7280;margin-bottom:2rem}.stat-details{background-color:#f7fafcb3;padding:1rem;border-radius:.5rem;text-align:left}.stat-detail-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #e5e7eb}.stat-detail-row:last-child{border-bottom:none}.detail-label{font-weight:500;color:#4b5563}.detail-value{font-weight:600;color:#3b82f6}.dictionary-viewer{background-color:#ffffffb3;padding:1.5rem;border-radius:.5rem;box-shadow:0 2px 4px #0000000d}.selector-container{display:flex;flex-direction:column;gap:1.5rem}@media (min-width: 768px){.selector-container{flex-direction:row;align-items:flex-start}}.event-selector,.value-selector{flex:1}.dictionary-viewer label{display:block;margin-bottom:.5rem;font-weight:500;color:#4b5563}.dictionary-viewer select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff;font-size:1rem}.dictionary-viewer select:focus{outline:none;border-color:#93c0fc;box-shadow:0 0 0 3px #93c0fc4d}.dictionary-viewer select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.7}.value-dropdown{min-height:150px;max-height:250px;overflow-y:auto}.value-filter-container{position:relative;margin-bottom:.5rem}.value-filter-input{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background-color:#fff}.value-filter-input:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.7}.clear-filter-button{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.25rem;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%}.clear-filter-button:hover{background-color:#f3f4f6;color:#6b7280}.dropdown-helper-text{font-size:.75rem;color:#6b7280;margin-top:.5rem;font-style:italic}.values-count{background-color:#f3f4f6;padding:.75rem;border-radius:.375rem;font-size:.875rem;color:#4b5563;font-weight:500;margin-top:.5rem}.loading-indicator{display:flex;justify-content:center;padding:1.5rem;color:#6b7280}.no-data-message{text-align:center;padding:1.5rem;color:#6b7280;font-style:italic;background-color:#f7fafc80;border-radius:.375rem;margin-top:1rem}.dictionary-counts-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;clear:both}.section-title{font-size:1.125rem;color:#4b5563;margin-bottom:1rem}.date-range-container{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;background-color:#f7fafcb3;padding:1rem;border-radius:.5rem}@media (min-width: 768px){.date-range-container{flex-direction:row;align-items:flex-end}}.date-field{flex:1}.date-field label{display:block;margin-bottom:.5rem;font-weight:500;color:#4b5563}.date-field input{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff}.count-button{background:linear-gradient(to right,#7aa8fdcc,#999bffcc);color:#fff;border:none;padding:.75rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;min-width:120px;display:flex;align-items:center;justify-content:center;gap:.5rem}.count-icon:before{content:"📊";font-size:1rem}.loading-icon{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.count-button:hover:not(:disabled){background:linear-gradient(to right,#7aa8fde6,#999bffe6);transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.count-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000001a}.count-button:disabled{opacity:.6;cursor:not-allowed}.counts-result{margin-top:1.5rem}.result-title{font-size:1rem;color:#4b5563;margin-bottom:1rem;font-weight:600}.counts-summary{display:flex;flex-wrap:wrap;margin-bottom:1.5rem;gap:1rem;background-color:#f3f4f6b3;padding:1rem;border-radius:.5rem}.summary-item{display:flex;flex-direction:column;min-width:150px}.summary-label{font-size:.75rem;color:#6b7280;margin-bottom:.25rem}.summary-value{font-size:1rem;font-weight:600;color:#4b5563}.summary-action{margin-left:auto;align-self:center}.export-button{display:flex;align-items:center;gap:.5rem;background-color:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000001a}.export-button:hover{background-color:#059669;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.export-button:active{transform:translateY(0)}.export-icon:before{content:"📥";font-size:1rem}.loading-icon-small{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}.total-row{background-color:#f3f4f6cc!important}.help-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background-color:#9ca3af4d;color:#4b5563;font-size:10px;font-weight:700;margin-left:5px;cursor:help}.help-icon:hover{background-color:#9ca3af80}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:.5rem;background-color:#f3f4f680;border-radius:.375rem}.pagination-button{background-color:#fff;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;color:#4b5563;cursor:pointer;transition:all .2s ease}.pagination-button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.875rem;color:#4b5563}.pagination-details{margin-left:.5rem;font-size:.75rem;color:#6b7280}.player-telemetry-container{display:flex;flex-direction:column;gap:1.5rem}.player-telemetry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.player-telemetry-title{font-size:1.25rem;font-weight:600;color:#111827}.telemetry-form,.player-telemetry-form{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;align-items:flex-end}.telemetry-form .form-group,.player-telemetry-form .form-group{flex:1;min-width:200px}.telemetry-form input,.player-telemetry-form input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px}.telemetry-form label,.player-telemetry-form label{display:block;margin-bottom:6px;font-weight:500;color:#4b5563}.player-telemetry-results{margin-top:1.5rem}.player-telemetry-no-data{text-align:center;padding:2rem;color:#6b7280;font-style:italic}.player-telemetry-chart-container{height:400px;margin-bottom:2rem}.player-telemetry-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.player-telemetry-stat-card{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;text-align:center}.player-telemetry-stat-value{font-size:1.5rem;font-weight:600;color:#3b82f6;margin-bottom:.25rem}.player-telemetry-stat-label{font-size:.875rem;color:#6b7280}.event-filter{background-color:#f7fafcb3;padding:1rem;border-radius:.375rem;margin-bottom:1.5rem}.event-filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.event-filter-header label{font-weight:500;color:#4b5563}.event-filter-actions{display:flex;gap:.5rem}.filter-button{background-color:#e5e7eb;border:none;padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;cursor:pointer;transition:background-color .2s ease}.filter-button:hover{background-color:#d1d5db}.event-type-checkboxes{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.event-type-checkbox label{display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#4b5563;cursor:pointer}.filter-info{font-size:.75rem;color:#6b7280;text-align:right}.no-data-message{text-align:center;padding:2rem;background-color:#ffffffb3;border-radius:.5rem;color:#6b7280;font-size:1rem}.page-info{font-size:.875rem;color:#4b5563}.custom-query-container{display:flex;flex-direction:column;gap:1.5rem;width:100%}.query-input-section{background-color:#ffffffb3;padding:1.5rem;border-radius:.5rem;box-shadow:0 2px 4px #0000000d}.query-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff;resize:vertical;min-height:100px;font-family:inherit;font-size:.95rem}.query-textarea:focus{outline:none;border-color:#93c0fc;box-shadow:0 0 0 3px #93c0fc33}.execute-query-button{background:linear-gradient(to right,#7aa8fdcc,#999bffcc);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;margin-top:1rem;width:200px}.execute-query-button:hover:not(:disabled){background:linear-gradient(to right,#7aa8fde6,#999bffe6);transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.execute-query-button:disabled{opacity:.6;cursor:not-allowed}.generated-query-container{background-color:#ffffffb3;padding:1.5rem;border-radius:.5rem;box-shadow:0 2px 4px #0000000d}.generated-query-container h4{margin-top:0;margin-bottom:.75rem;color:#4b5563}.generated-query-code{background-color:#f3f4f6b3;padding:1rem;border-radius:.375rem;border:1px solid #e5e7eb;overflow-x:auto;white-space:pre-wrap;font-family:Courier New,monospace;font-size:.9rem;color:#374151}.query-results-container{background-color:#ffffffb3;padding:1.5rem;border-radius:.5rem;box-shadow:0 2px 4px #0000000d}.query-results-container h4{margin-top:0;margin-bottom:.75rem;color:#4b5563}.active-panel{display:block}.hidden-panel{display:none}.player-telemetry-container .fetch-button,.fetch-button{background-color:var(--primary-color);color:#fff;padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s ease;margin-top:15px}.player-telemetry-container .fetch-button:hover,.fetch-button:hover{background-color:var(--primary-color-dark)}.player-telemetry-container .fetch-button:disabled,.fetch-button:disabled{background-color:#9ca3af;cursor:not-allowed}.telemetry-table{width:100%;border-collapse:collapse;margin-top:15px;font-size:14px}.telemetry-table th{background-color:#f5f5f5;color:#333;font-weight:600;text-align:left;padding:10px;border-bottom:2px solid #d1d5db}.telemetry-table td{padding:8px 10px;border-bottom:1px solid #d1d5db}.telemetry-table tr:nth-child(2n){background-color:#f9f9f9}.telemetry-table tr:hover{background-color:#f0f0f0}.telemetry-table-container{max-height:500px;overflow-y:auto;margin-top:15px;border:1px solid #d1d5db;border-radius:4px}.filter-button{background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;padding:4px 8px;margin-left:5px;cursor:pointer;font-size:12px}.filter-button:hover{background-color:#e0e0e0}.event-filter{margin:15px 0;padding:10px;border:1px solid #d1d5db;border-radius:4px;background-color:#f9f9f9}.event-filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.event-type-checkboxes{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}.event-type-checkbox{display:flex;align-items:center}.event-type-checkbox label{display:flex;align-items:center;cursor:pointer}.event-type-checkbox input{margin-right:5px}.filter-info{font-size:12px;color:#666;margin-top:5px}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:15px;gap:10px}.pagination-controls button{background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;padding:5px 10px;cursor:pointer;font-size:14px;transition:all .2s ease}.pagination-controls button:hover:not(:disabled){background-color:#e0e0e0}.pagination-controls button:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:14px;color:#666}.no-data-message{text-align:center;padding:30px;font-size:16px;color:#666;font-style:italic}.loading-spinner{display:flex;justify-content:center;align-items:center;height:100px}.input-group{margin-bottom:15px}.input-group label{display:block;margin-bottom:5px;font-weight:500}.input-group input,.input-group select{width:100%;padding:8px;border:1px solid #d1d5db;border-radius:4px;font-size:14px}.date-range-picker{display:flex;gap:10px;margin-bottom:15px}.date-range-picker>div{flex:1}
