:root {
    --comparison-table-border-radius: 0.25rem;
}

.comparison-table__button {
    background: #fbaf37;
    border-radius: var(--comparison-table-border-radius);
    cursor: pointer;
    font-size: 80%;
    font-weight: 700;
    padding: .5rem 1rem;
    text-align: center;
    width: max-content;
    border: none;
    margin: 0.5rem;

    &::hover, &::focus {
        background-color: #000;
        color: #fff;
        transition: all 0.3s ease-in-out;
    }
}

.comparison-table__company-logo {
    object-fit: contain;
    object-position: center;
    aspect-ratio: 3 / 2;
    width: 100%;
}

.comparison-table__company-name {
    display:block;
    padding: 1rem 0;
}

.comparison-table__wrapper {
    container-type: inline-size;
    container-name: comparison-table;
    position: relative;
}

.comparison-table-container {
    border-radius: var(--comparison-table-border-radius);
    container-type:scroll-state;
    container-name:comparison-table-scroller;

    &.alignContent {
        width: var(--wp--style--global--content-size);
    }
}

.comparison-table__table {
    width: 100%;
    border-spacing: 2px;
    border-collapse: collapse;
    table-layout: fixed;

    th, td {
        font-size: 70%;
        padding: 1rem 0.5rem;
        text-align: center;
    }

    a {
        text-decoration-style: dotted;
    }

    .narrow-visible {
        display: none;
        visibility: hidden;
    }
}

.comparison-table__header {
    background-color: var(--wp--preset--color--custom-clever-blue);
    border-right: 2px solid rgba(221,222,223);
    color: #fff;
    padding: 0.875rem 1.25rem;

    &:first-child {
       border-top-left-radius: var(--comparison-table-border-radius); 
    }

    &:last-child {
       border-top-right-radius: var(--comparison-table-border-radius); 
       border-right: none;
    }
}

.comparison-table__row {
    border-bottom: 1px solid rgba(0,0,0,0.3);

    &:last-child {
        border-bottom: none;
    }
}

.comparison-table__cell {

    .as-block {
        display:block;
    }
}

.comparison-table__review-stars {
    --review-stars: 5;
    mask-image: url(https://y3j5t.listwithclever.dev/wp-content/uploads/2026/01/review-stars.svg);
    mask-repeat: no-repeat;
    width: 127px;
    height: 24px;
    position: relative;
    mask-size: contain;
    margin: 0 auto;

    &:after {
        content: '';
        position: absolute;
        left: 0;
        top: 0;
        width: calc(var(--review-stars) / 5 * 100%);
        display: block;
        background-color: #f6d43e;
        height: 100%;
        mask-size: contain;
    }
}

.comparison-table_review-link,
.comparison-table__review-score {
    font-size: clamp(8px, 50%, 1rem);
    margin-top: 0.5rem;
}

.comparison-table__link--external{
    display: flex;
    gap: 0.25rem;
    align-items: center;
    justify-content: center;
    font-size: clamp(10px, 70%, 1rem);

    .external-site-icon {
        width:12px;
        height: auto;
    }
}

.comparison-table__shade {
        display: none; 
    }

/*
* Container Query
*/
@container comparison-table (width < 800px) {
    .comparison-table-container {
        position: relative;
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-snap-type: x proximity;
    }

    .comparison-table__shade {
        background: linear-gradient(90deg,rgba(255, 255, 255, 0) 30%, rgba(255, 255, 255, 1) 90%);
        display: block;
        height: 100%;
        width: 20vw;
        position: absolute;
        top: 0;
        right:-3px;
        z-index: 2;
    }

    .comparison-table_review-link,
    .comparison-table__link--external,
    .comparison-table__review-score {
        justify-content: flex-start;
        font-size:clamp(16px, 5vw, 2rem);
    }

    .external-site-icon {
        width: 24px;
    }

    .comparison-table__review-stars {
        margin: unset;
    }

    .comparison-table__table {
    position: relative;

    .narrow-visible {
        display: revert;
        visibility: visible;
    }

        th, td {
            font-size: clamp(0.875rem, 5vw, 1.5rem);
            scroll-snap-align: start;
            scroll-snap-type: x mandatory;
            text-align: left;
            padding: 1.25rem 1.5rem 1.25rem 1.25rem;
            width: 50vw;
        }
    }

    .comparison-table__table th,
    .comparison-table__table td {
        width: 50vw;
    }

    .comparison-table__company-logo {
        object-position: left;
    }

    .comparison-table__button {
        padding: 1.3rem;
    }
}

@container comparison-table-scroller not scroll-state(scrollable: right) {
  .comparison-table__shade {
    display:none;
  }
}