/* ==========================================================================
   pages.css — page-specific tweaks
   --------------------------------------------------------------------------
   Reserved for the rare case where a one-off rule genuinely doesn't fit a
   component or layout primitive. If a rule shows up for 3+ pages, promote
   it to components.css.

   Sections:
     1. Auth (login / register / invite) — added in session 5
     2. Lists / dashboard — uploads.html, campaigns.html, index.html
     3. Accounts — accounts.html
     4. Detail pages — upload_detail.html, campaign_detail.html
     5. Settings — settings.html
   ========================================================================== */

/* -------------------------------------------------------------------------- */
/* 1. Auth — login.html, register.html, invite.html                           */
/* -------------------------------------------------------------------------- */

.auth-card {
    background: var(--neutral-2);
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-2xl);
    padding: var(--space-10);
    width: 100%;
    max-width: 440px;
    box-shadow: var(--shadow-3);
}

.auth-card-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-1);
    margin-bottom: var(--space-8);
    text-align: center;
}

.auth-brand-logo {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, var(--accent-9), var(--accent-10));
    display: grid;
    place-items: center;
    font-weight: var(--weight-bold);
    color: white;
    font-size: var(--text-xl);
    letter-spacing: var(--tracking-tight);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08), var(--shadow-2);
    margin-bottom: var(--space-3);
}

.auth-icon {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-lg);
    display: grid;
    place-items: center;
    margin-bottom: var(--space-3);
}

.auth-icon svg {
    width: 28px;
    height: 28px;
    stroke-width: 1.75;
    stroke: currentColor;
    fill: none;
}

.auth-icon--accent {
    background: var(--accent-3);
    color: var(--accent-11);
    box-shadow: 0 0 0 1px var(--accent-6);
}

.auth-icon--danger {
    background: var(--danger-3);
    color: var(--danger-11);
    box-shadow: 0 0 0 1px var(--danger-6);
}

.auth-title {
    font-size: var(--text-2xl);
    line-height: var(--leading-2xl);
    font-weight: var(--weight-semibold);
    color: var(--neutral-12);
    letter-spacing: var(--tracking-tight);
    margin: 0;
}

.auth-subtitle {
    color: var(--neutral-11);
    font-size: var(--text-sm);
    line-height: var(--leading-sm);
    margin: 0;
}

.auth-subtitle--centered {
    margin-top: var(--space-2);
    text-align: center;
    font-size: var(--text-base);
    line-height: var(--leading-base);
}

.auth-workspace-name {
    font-size: var(--text-xl);
    font-weight: var(--weight-semibold);
    color: var(--accent-11);
    letter-spacing: var(--tracking-tight);
    margin-top: var(--space-2);
}

.auth-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}

.auth-actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    margin-top: var(--space-6);
}

.auth-alert-slot:not(:empty) {
    margin-bottom: var(--space-5);
}

.auth-footer {
    margin-top: var(--space-6);
    text-align: center;
    color: var(--neutral-11);
    font-size: var(--text-sm);
}

.auth-footer a {
    color: var(--accent-11);
    font-weight: var(--weight-medium);
}

.auth-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-8) 0;
    color: var(--neutral-11);
    font-size: var(--text-sm);
    text-align: center;
}

.auth-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--neutral-6);
    border-top-color: var(--accent-9);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

@media (max-width: 480px) {
    .auth-card {
        padding: var(--space-6);
        border-radius: var(--radius-xl);
    }
    .auth-card-header {
        margin-bottom: var(--space-6);
    }
}

/* -------------------------------------------------------------------------- */
/* 2. Lists / dashboard — uploads.html, campaigns.html, index.html            */
/* -------------------------------------------------------------------------- */

.list-table-card .card-content {
    padding: 0;
    overflow-x: auto;
}

.list-table-shell[hidden],
.list-table-state[hidden] {
    display: none !important;
}

.upload-row-name {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    min-width: 0;
}

.upload-row-title {
    font-weight: var(--weight-medium);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.upload-row-error {
    margin-top: var(--space-1);
    padding-left: var(--space-4);
    color: var(--danger-11);
    font-size: var(--text-xs);
    line-height: var(--leading-xs);
}

.upload-progress {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    min-width: 128px;
}

.upload-progress .progress-bar {
    flex: 1;
}

.upload-progress-pct {
    min-width: 36px;
    color: var(--neutral-11);
    font-size: var(--text-xs);
    line-height: var(--leading-xs);
    text-align: right;
}

.row-action {
    min-height: 32px;
}

.scroll-sentinel {
    height: 1px;
}

.dashboard-metrics {
    margin-bottom: var(--space-6);
}

.dashboard-list-state {
    min-height: 160px;
    padding: var(--space-8) var(--space-4);
}

.list-item--summary .list-item-content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    column-gap: var(--space-3);
    row-gap: var(--space-1);
}

.list-item--summary .list-item-title {
    grid-column: 1;
    grid-row: 1;
}

.list-item--summary .list-item-trailing {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
}

.list-item--summary .list-item-meta {
    grid-column: 1 / -1;
    margin-top: 0;
}

/* -------------------------------------------------------------------------- */
/* 3. Accounts — accounts.html                                                */
/* -------------------------------------------------------------------------- */

.account-trigger-main {
    flex: 1;
    min-width: 0;
}

.account-name {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.account-badges {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1-5);
    margin-left: auto;
}

.account-id-line {
    margin-bottom: var(--space-4);
    color: var(--neutral-11);
}

.account-config-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
}

.account-config-field--wide {
    grid-column: 1 / -1;
}

.account-geo-button {
    justify-content: flex-start;
    width: 100%;
    min-width: 0;
    padding: var(--space-3) var(--space-4);
    overflow: hidden;
    text-overflow: ellipsis;
    font-family: var(--font-mono);
    font-size: var(--text-md);
    line-height: var(--leading-md);
}

.account-panel-footer {
    display: flex;
    justify-content: flex-end;
    margin-top: var(--space-5);
    padding-top: var(--space-4);
    border-top: 1px solid var(--border-hairline);
}

.selected-countries {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    min-height: 32px;
}

.geo-tag {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    background: var(--accent-3);
    border: 1px solid var(--accent-6);
    color: var(--accent-11);
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
}

.geo-tag button {
    display: grid;
    place-items: center;
    width: 18px;
    height: 18px;
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: var(--radius-xs);
    color: currentColor;
    cursor: pointer;
    font: inherit;
    line-height: 1;
}

.country-list {
    display: flex;
    flex-direction: column;
    max-height: 260px;
    overflow-y: auto;
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-md);
}

.country-option {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    width: 100%;
    padding: var(--space-2) var(--space-3);
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--border-hairline);
    color: var(--neutral-12);
    font: inherit;
    font-size: var(--text-sm);
    text-align: left;
    cursor: pointer;
}

.country-option:last-child {
    border-bottom: 0;
}

.country-option.is-selected {
    background: var(--accent-3);
    color: var(--accent-11);
}

.country-code {
    min-width: 32px;
    color: inherit;
    font-family: var(--font-mono);
    font-weight: var(--weight-semibold);
}

.country-empty {
    padding: var(--space-4);
    color: var(--neutral-11);
    font-size: var(--text-sm);
}

@media (max-width: 767.98px) {
    .account-config-grid {
        grid-template-columns: 1fr;
    }

    .account-badges {
        width: 100%;
        margin-left: 0;
    }

    .account-panel-footer {
        position: sticky;
        bottom: 0;
        margin-inline: calc(var(--space-4) * -1);
        margin-bottom: calc(var(--space-5) * -1);
        padding: var(--space-3) var(--space-4) calc(var(--space-3) + var(--safe-bottom));
        background: var(--neutral-2);
    }

    .account-panel-footer .btn {
        width: 100%;
    }
}

/* -------------------------------------------------------------------------- */
/* 4. Detail pages — upload_detail.html, campaign_detail.html                 */
/* -------------------------------------------------------------------------- */

.detail-title-row {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    min-width: 0;
}

.detail-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.detail-section-grid {
    margin-bottom: var(--space-6);
}

.detail-card-spaced {
    margin-bottom: var(--space-6);
}

.detail-stack {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.detail-field {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    min-width: 0;
}

.detail-label {
    color: var(--neutral-11);
    font-size: var(--text-sm);
    line-height: var(--leading-sm);
}

.detail-value {
    color: var(--neutral-12);
    font-size: var(--text-base);
    line-height: var(--leading-base);
    font-weight: var(--weight-medium);
    overflow-wrap: anywhere;
}

.detail-value--large {
    font-size: var(--text-2xl);
    line-height: var(--leading-2xl);
    font-weight: var(--weight-semibold);
}

.detail-value--danger,
.detail-label--danger {
    color: var(--danger-11);
}

.detail-progress {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.detail-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
}

.detail-form-field--wide {
    grid-column: 1 / -1;
}

.media-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.media-cell,
.asset-list-item {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
}

.media-cell {
    min-width: 0;
    padding: var(--space-4);
}

.media-header,
.asset-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    min-width: 0;
}

.media-title {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.media-trailing {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}

.media-chips,
.asset-files {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.media-chip,
.asset-file-chip {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    padding: var(--space-0-5) var(--space-2);
    border-radius: var(--radius-sm);
    background: var(--neutral-4);
    color: var(--neutral-11);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    line-height: var(--leading-xs);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.media-meta,
.asset-meta {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    color: var(--neutral-11);
    min-width: 0;
    overflow-wrap: anywhere;
}

.media-meta-row {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    min-width: 0;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-sm);
    background: var(--neutral-3);
    overflow-wrap: anywhere;
}

.media-meta-label {
    display: block;
    min-width: 0;
    padding: 0;
    color: var(--neutral-11);
    font-family: var(--font-sans);
    font-size: var(--text-xs);
    line-height: var(--leading-xs);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
}

.media-meta-value {
    display: block;
    min-width: 0;
    color: var(--neutral-12);
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    line-height: var(--leading-sm);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.media-meta-value--danger {
    color: var(--danger-11);
}

@media (max-width: 767.98px) {
    .detail-form-grid {
        grid-template-columns: 1fr;
    }

    .detail-title-row {
        width: 100%;
    }

    .media-header,
    .asset-header {
        align-items: flex-start;
    }

    .media-title {
        white-space: normal;
        overflow-wrap: anywhere;
    }

    .media-trailing {
        justify-content: flex-end;
    }

    .media-meta-label {
        justify-self: start;
    }
}

/* -------------------------------------------------------------------------- */
/* 5. Settings — settings.html                                                */
/* -------------------------------------------------------------------------- */

.settings-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.settings-card-body {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.settings-help {
    display: block;
    margin-top: var(--space-1);
    color: var(--neutral-11);
    font-size: var(--text-xs);
    line-height: var(--leading-xs);
}

.credentials-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-3);
}

.credentials-actions .field-file {
    flex: 1;
    min-width: 220px;
}

.credentials-status {
    align-items: center;
    gap: var(--space-3);
}

.credentials-status-icon {
    display: grid;
    place-items: center;
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: color-mix(in srgb, currentColor 12%, transparent);
}

.credentials-status-icon svg {
    width: 16px;
    height: 16px;
    stroke: currentColor;
    fill: none;
}

.credentials-status-copy {
    display: flex;
    flex: 1;
    min-width: 0;
    flex-direction: column;
    justify-content: center;
    gap: 2px;
}

.credentials-status-title {
    color: var(--neutral-12);
    font-weight: var(--weight-medium);
    line-height: var(--leading-sm);
}

.credentials-status-detail {
    min-width: 0;
    color: currentColor;
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    line-height: var(--leading-xs);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.danger-action {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-4);
    background: var(--danger-3);
    border: 1px solid var(--danger-6);
    border-radius: var(--radius-md);
}

.danger-action-copy {
    flex: 1;
    min-width: 220px;
}

.danger-action-title {
    color: var(--neutral-12);
    font-weight: var(--weight-medium);
    margin-bottom: var(--space-1);
}

.danger-action-description {
    color: var(--neutral-11);
    font-size: var(--text-sm);
    line-height: var(--leading-sm);
}
