﻿/* =========================================
   Wizard Context Strip
   ========================================= */

.wizard-context-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-4);
    margin-top: var(--s-4);
    padding: var(--s-3) var(--s-4);
    border: var(--border-w) solid var(--border);
    border-radius: var(--r-2);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.wizard-context-strip__main {
    min-width: 0;
}

.wizard-context-strip__eyebrow {
    color: var(--text-2);
    font-size: var(--text-xs);
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.wizard-context-strip__title {
    margin-top: var(--s-1);
    color: var(--text);
    font-size: var(--text-sm);
    font-weight: 700;
}

.wizard-context-strip__steps {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--s-2);
    flex-wrap: wrap;
}

.wizard-context-strip__step {
    display: inline-flex;
    align-items: center;
    gap: var(--s-2);
    padding: 0.3rem 0.65rem;
    border: var(--border-w) solid var(--border);
    border-radius: var(--r-pill);
    background: var(--surface-2);
    color: var(--text-2);
    font-size: var(--text-xs);
    font-weight: 700;
    white-space: nowrap;
}

.wizard-context-strip__step--active {
    border-color: color-mix(in srgb, var(--primary) 42%, var(--border));
    background: color-mix(in srgb, var(--primary) 12%, var(--surface));
    color: var(--primary);
}

.wizard-context-strip__step--complete {
    background: var(--success-soft);
    color: var(--success);
}

.wizard-context-strip__step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.2rem;
    height: 1.2rem;
    border-radius: var(--r-pill);
    background: color-mix(in srgb, currentColor 12%, transparent);
}

/* =========================================
   Onboarding / Configuration Layouts
   ========================================= */

.onboarding-page,
.configuration-entity-page {
    height: calc(100dvh - 245px);
    min-height: 24rem;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: var(--s-5);
    overflow: hidden;
    box-sizing: border-box;
}

.onboarding-scroll-frame,
.configuration-entity-scroll-frame {
    width: 100%;
    height: 100%;
    min-height: 0;
    overflow: auto;
    padding-right: var(--s-2);
    padding-bottom: var(--s-3);
    box-sizing: border-box;
    scrollbar-gutter: auto;
}

.onboarding-hero .wizard-hero__content,
.configuration-entity-hero .wizard-hero__content {
    max-width: 64rem;
}

.configuration-entity-content,
.onboarding-summary-panel {
    margin-top: var(--s-5);
}

/* =========================================
   Onboarding Step Cards
   ========================================= */

.onboarding-step-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--s-4);
    margin-top: var(--s-5);
}

.onboarding-step-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--s-3);
    padding: var(--s-4);
    border: var(--border-w) solid var(--border);
    border-radius: var(--r-2);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.onboarding-step-card--active {
    border-color: color-mix(in srgb, var(--primary) 42%, var(--border));
    box-shadow: var(--shadow-md);
}

.onboarding-step-card--complete {
    border-color: color-mix(in srgb, var(--success) 36%, var(--border));
}

.onboarding-step-card__number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: var(--r-pill);
    background: var(--surface-2);
    color: var(--text-2);
    font-weight: 800;
}

.onboarding-step-card--active .onboarding-step-card__number {
    background: color-mix(in srgb, var(--primary) 12%, var(--surface));
    color: var(--primary);
}

.onboarding-step-card__title {
    margin: 0;
    color: var(--text);
    font-size: var(--text-base);
    line-height: var(--line-tight);
}

.onboarding-step-card__text {
    margin: var(--s-2) 0 0;
    color: var(--text-2);
    font-size: var(--text-sm);
    line-height: var(--line-normal);
}

.onboarding-step-card__status {
    margin-top: var(--s-3);
    color: var(--text-2);
    font-size: var(--text-xs);
    font-weight: 700;
}

/* =========================================
   Onboarding Summary
   ========================================= */

.onboarding-summary-panel {
    padding: var(--s-4);
    border: var(--border-w) solid var(--border);
    border-radius: var(--r-2);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.onboarding-summary-panel__title {
    margin: 0 0 var(--s-4);
    color: var(--text);
    font-size: var(--text-base);
}

.onboarding-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--s-4);
}

    .onboarding-summary-grid div {
        display: grid;
        gap: var(--s-1);
    }

    .onboarding-summary-grid span {
        color: var(--text-2);
        font-size: var(--text-xs);
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }

    .onboarding-summary-grid strong {
        color: var(--text);
        font-size: var(--text-sm);
    }

/* =========================================
   Generic Data Card
   ========================================= */

.data-card {
    width: 100%;
    max-width: none;
    overflow: hidden;
    border: var(--border-w) solid var(--border);
    border-radius: var(--r-2);
    background: color-mix(in srgb, var(--surface) 96%, transparent);
    box-shadow: var(--shadow-sm);
}

.data-card--fill {
    inline-size: 100%;
}

.data-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-4);
    padding: var(--s-4) var(--s-5);
    border-bottom: var(--border-w) solid var(--border);
    background: color-mix(in srgb, var(--surface) 92%, var(--surface-2));
}

.data-card__title {
    color: var(--text);
    font-size: var(--text-base);
    font-weight: 800;
    line-height: var(--line-tight);
}

.data-card__subtitle {
    margin-top: var(--s-1);
    color: var(--text-2);
    font-size: var(--text-sm);
}

.data-card__footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--s-2);
    padding: var(--s-3) var(--s-5);
    border-top: var(--border-w) solid var(--border);
    background: color-mix(in srgb, var(--surface) 92%, var(--surface-2));
}

/* =========================================
   Generic Data Table
   ========================================= */

.data-table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
}

.data-table {
    width: 100%;
    min-width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    table-layout: fixed;
}

    .data-table th {
        padding: var(--s-3) var(--s-4);
        color: var(--text-2);
        font-size: var(--text-xs);
        font-weight: 800;
        letter-spacing: 0.04em;
        text-align: left;
        text-transform: uppercase;
        background: var(--surface-2);
        border-bottom: var(--border-w) solid var(--border);
        white-space: nowrap;
    }

    .data-table td {
        padding: var(--s-4);
        color: var(--text);
        font-size: var(--text-sm);
        line-height: var(--line-normal);
        vertical-align: top;
        border-bottom: var(--border-w) solid color-mix(in srgb, var(--border) 72%, transparent);
    }

    .data-table tbody tr:last-child td {
        border-bottom: 0;
    }

.data-table--interactive .data-table__row {
    cursor: pointer;
    transition: background-color 140ms ease, box-shadow 140ms ease;
}

    .data-table--interactive .data-table__row:hover {
        background: color-mix(in srgb, var(--primary) 7%, var(--surface));
        box-shadow: inset 0.25rem 0 0 var(--primary);
    }

.data-table__primary {
    color: var(--text);
    font-weight: 800;
}

.data-table__secondary {
    margin-top: var(--s-1);
    color: var(--text-2);
    font-size: var(--text-xs);
    line-height: var(--line-normal);
}

.data-table__value,
.data-table__wrap {
    display: block;
    max-width: 100%;
    overflow-wrap: anywhere;
}

.data-table__actions {
    white-space: nowrap;
    text-align: right;
}

.data-table__col--enterprise {
    width: 17%;
}

.data-table__col--registration {
    width: 16%;
}

.data-table__col--contact {
    width: 20%;
}

.data-table__col--website {
    width: 16%;
}

.data-table__col--address {
    width: 19%;
}

.data-table__col--gps {
    width: 12%;
}

.data-table__col--actions {
    width: 7rem;
}

.form-button-small {
    padding: 0.45rem 0.7rem;
    font-size: var(--text-xs);
}

/* =========================================
   Platform Loyalty Page Layout
   ========================================= */

#main:has(.platform-lp-page) {
    height: 100dvh;
    min-height: 0;
    overflow: hidden;
}

    #main:has(.platform-lp-page) .page-content {
        flex: 1 1 auto;
        min-height: 0;
        overflow: hidden;
        display: flex;
        flex-direction: column;
    }

.platform-lp-page {
    width: 100%;
    max-width: none;
    flex: 1 1 auto;
    min-height: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: var(--s-5);
    overflow: hidden;
    box-sizing: border-box;
}

.platform-lp-scroll-frame {
    width: 100%;
    max-width: none;
    height: 100%;
    min-height: 0;
    overflow: auto;
    padding: 0;
    box-sizing: border-box;
    /* Keep card width aligned with footer actions outside the scroll frame. */
    scrollbar-gutter: auto;
}

.platform-lp-hero .wizard-hero__content {
    max-width: 64rem;
}

.platform-lp-content {
    width: 100%;
    max-width: none;
    min-width: 0;
    min-height: 0;
    margin-top: var(--s-5);
    box-sizing: border-box;
}

    .platform-lp-content > .data-card {
        width: 100%;
        max-width: none;
        box-sizing: border-box;
    }

    .platform-lp-content .data-table-wrap,
    .platform-lp-content .data-table {
        width: 100%;
        max-width: none;
    }

.platform-lp-floating-actions {
    justify-self: end;
    align-self: end;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--s-2);
    flex-wrap: wrap;
    max-width: 100%;
    padding: var(--s-3);
    border: var(--border-w) solid var(--border);
    border-radius: var(--r-2);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(10px);
}

.platform-lp-page-size {
    width: 8.5rem;
    min-width: 8.5rem;
    max-width: 8.5rem;
    flex: 0 0 8.5rem;
}

.platform-lp-page-button {
    width: 2.75rem;
    min-width: 2.75rem;
    flex: 0 0 2.75rem;
    font-size: 1.2rem;
    line-height: 1;
}

.platform-lp-page-summary {
    padding-inline: var(--s-2);
    white-space: nowrap;
}

/* =========================================
   Platform Forms / Details
   ========================================= */

.platform-lp-field {
    display: grid;
    gap: var(--s-2);
}

    .platform-lp-field span {
        color: var(--text-2);
        font-size: var(--text-sm);
        font-weight: 700;
    }

.platform-lp-field__hint {
    color: var(--text-2);
    font-size: var(--text-xs);
    line-height: var(--line-normal);
}

.platform-lp-details {
    display: grid;
    gap: var(--s-4);
    margin: 0;
}

    .platform-lp-details div {
        display: grid;
        gap: var(--s-1);
    }

    .platform-lp-details dt {
        color: var(--text-2);
        font-size: var(--text-xs);
        font-weight: 700;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }

    .platform-lp-details dd {
        margin: 0;
        color: var(--text);
    }

.platform-lp-drawer-note {
    padding: var(--s-4);
    border: var(--border-w) solid var(--border);
    border-radius: var(--r-2);
    background: var(--surface-2);
    color: var(--text-2);
    font-size: var(--text-sm);
    line-height: var(--line-normal);
}

/* =========================================
   Legacy LP Grid Support
   ========================================= */

.lp-grid-wrap {
    max-width: 100%;
}

.lp-grid--interactive .lp-grid__row {
    cursor: pointer;
}

.lp-grid__row--selected {
    outline: 2px solid color-mix(in srgb, var(--primary) 36%, transparent);
    outline-offset: -2px;
}

.lp-grid__sort-button {
    display: inline-flex;
    align-items: center;
    gap: var(--s-2);
    border: 0;
    background: transparent;
    padding: 0;
    color: inherit;
    font: inherit;
    font-weight: 700;
    text-transform: inherit;
    letter-spacing: inherit;
    cursor: pointer;
}

.lp-grid__sort-indicator {
    font-size: var(--text-xs);
    color: var(--text-2);
    text-transform: none;
    letter-spacing: 0;
}

.lp-grid__actions-column {
    width: 1%;
    white-space: nowrap;
    text-align: right;
}

/* =========================================
   Responsive Rules
   ========================================= */

@media (max-width: 1199.98px) {
    .onboarding-page,
    .configuration-entity-page {
        height: calc(100dvh - 225px);
    }

    .onboarding-step-grid,
    .onboarding-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .data-table {
        min-width: 72rem;
    }
}

@media (max-width: 720px) {
    .wizard-context-strip {
        align-items: stretch;
        flex-direction: column;
    }

    .wizard-context-strip__steps {
        justify-content: flex-start;
    }

    .onboarding-page,
    .configuration-entity-page {
        height: calc(100dvh - 190px);
        gap: var(--s-3);
    }

    .onboarding-step-grid,
    .onboarding-summary-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .data-card__header,
    .data-card__footer {
        padding-inline: var(--s-3);
    }

    .data-card__footer {
        justify-content: center;
        flex-wrap: wrap;
    }

    .platform-lp-page {
        gap: var(--s-3);
    }

    .platform-lp-floating-actions {
        justify-self: stretch;
    }

        .platform-lp-floating-actions .form-button,
        .platform-lp-floating-actions .form-input {
            flex: 1 1 auto;
        }

    .platform-lp-page-summary {
        flex: 1 1 100%;
        text-align: center;
    }
}

/* =========================================
   Generic Empty State
   ========================================= */

.empty-state {
    min-height: 22rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--s-3);
    padding: clamp(var(--s-5), 5vw, 4.5rem) var(--s-5);
    border: var(--border-w) solid var(--border);
    border-radius: var(--r-2);
    background: color-mix(in srgb, var(--surface) 96%, transparent);
    box-shadow: var(--shadow-sm);
    text-align: center;
}

.empty-state--compact {
    min-height: 16rem;
}

.empty-state--danger {
    border-color: color-mix(in srgb, var(--danger, #dc2626) 18%, var(--border));
}

.empty-state__image {
    display: block;
    width: min(18rem, 58vw);
    height: auto;
    margin: 0 0 var(--s-2);
    user-select: none;
}

.empty-state__content {
    max-width: 30rem;
}

.empty-state__eyebrow {
    color: var(--text-2);
    font-size: var(--text-xs);
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.empty-state__title {
    margin: 0;
    color: var(--text);
    font-size: clamp(1.35rem, 2vw, 1.75rem);
    font-weight: 850;
    line-height: var(--line-tight);
}

.empty-state__text {
    max-width: 34rem;
    margin: var(--s-2) 0 0;
    color: var(--text-2);
    font-size: var(--text-sm);
    line-height: var(--line-normal);
}

.empty-state__actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-2);
    flex-wrap: wrap;
    margin-top: var(--s-2);
}

@media (max-width: 720px) {
    .empty-state {
        min-height: 18rem;
        padding: var(--s-5) var(--s-3);
    }

    .empty-state__image {
        width: min(14rem, 70vw);
    }

    .empty-state__actions {
        align-self: stretch;
    }

        .empty-state__actions .form-button {
            flex: 1 1 auto;
        }
}
