/* App-level overrides on top of Pico.css 2.
   Keeps the dashboard dense and mobile-friendly. */

:root {
    --pico-font-size: 95%;
    --pico-spacing: 0.75rem;
}

body > header {
    padding-block: 0.5rem;
    border-bottom: 1px solid var(--pico-muted-border-color);
    margin-bottom: 1rem;
}

body > header nav strong {
    font-size: 1.05rem;
}

body > header nav a {
    text-decoration: none;
}

body > header nav .user-email {
    color: var(--pico-muted-color);
    font-size: 0.9rem;
}

main.container {
    padding-block: 0.5rem 2rem;
}

/* Tighten data tables. */
.data-table-wrapper {
    overflow-x: auto;
    border: 1px solid var(--pico-muted-border-color);
    border-radius: var(--pico-border-radius);
}

.data-table-wrapper table {
    margin: 0;
    font-size: 0.875rem;
}

.data-table-wrapper th,
.data-table-wrapper td {
    padding: 0.4rem 0.6rem;
    white-space: nowrap;
}

.data-table-wrapper td a {
    text-decoration: none;
}

.data-table-wrapper tbody tr:hover {
    background: var(--pico-secondary-background);
}

/* Scrollable list section: h2 stays put, only the data scrolls. */
.list-section {
    margin-bottom: 1.5rem;
}

.list-section > h2 {
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
}

.list-section .scroll-area {
    max-height: 360px;
    overflow: auto;
    border-radius: var(--pico-border-radius);
}

@media (max-width: 768px) {
    .list-section .scroll-area {
        max-height: 280px;
    }
}

/* Toggle button groups for resolution + host-group filters. */
.toggle-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-bottom: 1rem;
}

.toggle-row label {
    margin: 0;
}

[role="group"].toggle-group {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0;
}

[role="group"].toggle-group > button {
    padding: 0.25rem 0.75rem;
    font-size: 0.85rem;
    margin: 0;
    border-radius: 0;
    background: transparent;
    border: 1px solid var(--pico-primary);
    color: var(--pico-primary);
    cursor: pointer;
}

[role="group"].toggle-group > button:not(:first-child) {
    border-left: none;
}

[role="group"].toggle-group > button:first-child {
    border-top-left-radius: var(--pico-border-radius);
    border-bottom-left-radius: var(--pico-border-radius);
}

[role="group"].toggle-group > button:last-child {
    border-top-right-radius: var(--pico-border-radius);
    border-bottom-right-radius: var(--pico-border-radius);
}

[role="group"].toggle-group > button.active,
[role="group"].toggle-group > button[aria-pressed="true"] {
    background: var(--pico-primary);
    color: var(--pico-primary-inverse);
}

/* Chart layout. */
.caddy-group-section {
    margin-block: 1rem;
    padding: 0.75rem 0.9rem;
    border: 1px solid var(--pico-muted-border-color);
    border-radius: var(--pico-border-radius);
}

.caddy-group-section > header {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-bottom: 0.5rem;
    padding: 0;
    border: none;
}

.caddy-group-section > header h3 {
    margin: 0;
    font-size: 1.05rem;
}

.caddy-group-section > header select {
    margin: 0;
    width: auto;
    min-width: 12rem;
    font-size: 0.9rem;
    padding-block: 0.25rem;
}

.caddy-charts-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 0.75rem;
}

.caddy-chart {
    width: 100%;
    min-height: 220px;
}

.caddy-chart .u-title {
    font-size: 0.95rem;
}

/* Headings spacing. */
h1 {
    font-size: 1.6rem;
    margin-bottom: 0.5rem;
}

h2 {
    font-size: 1.2rem;
}

h3 {
    font-size: 1rem;
}

/* Compact buttons & forms in the page-level Fastly etc. block. */
.inline-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin-block: 0.5rem;
}

.inline-actions button {
    padding: 0.25rem 0.75rem;
    font-size: 0.85rem;
    margin: 0;
    width: auto;
}

/* Loading hint under list scroll areas. */
.loading-hint {
    color: var(--pico-muted-color);
    font-size: 0.85rem;
    padding: 0.25rem 0.6rem;
}

.loading-hint:empty {
    display: none;
}

/* Hide lower-priority columns on narrow screens for readability. */
@media (max-width: 600px) {
    .data-table-wrapper .col-id,
    .data-table-wrapper .col-host,
    .data-table-wrapper .col-group,
    .data-table-wrapper .col-app {
        display: none;
    }
}
