/* Styles for all reviews page */

/* ---------- Scoped design tokens (instead of :root) ---------- */
.page--reviews {
    --ics-bg: #0f0b07;
    /* deep cocoa */
    --ics-panel: rgba(255, 255, 255, 0.08);
    /* glass layer */
    --ics-ink: #f7f3ee;
    /* cream text */
    --ics-muted: #c9c1b7;
    /* soft cream */
    --ics-border: rgba(255, 255, 255, 0.14);
    --ics-accent: #e1b26b;
    /* caramel gold */
    --ics-accent-ink: #1d130c;
    --ics-focus: #ffe7b4;
    /* warm highlight */
    --ics-shadow: 0 8px 24px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, .06);
}

/* Light-scheme adjustments without touching global :root */
@media (prefers-color-scheme: light) {
    .page--reviews {
        --ics-bg: #f6f4f1;
        --ics-panel: rgba(255, 255, 255, .72);
        --ics-ink: #1e160f;
        --ics-muted: #6f6356;
        --ics-border: rgba(0, 0, 0, .1);
        --ics-accent: #b3722a;
        --ics-accent-ink: #fffef9;
        --ics-focus: #c98a33;
        --ics-shadow: 0 10px 26px rgba(0, 0, 0, .08), inset 0 1px 0 rgba(255, 255, 255, .6);
    }
}

/* ---------- Page backdrop + section spacing ---------- */
.page--reviews .ics-reviews {
    background:
        radial-gradient(1200px 800px at 50% -10%, rgba(225, 178, 107, 0.14), transparent 60%) var(--ics-bg);
    color: var(--ics-ink);
}

.page--reviews .ics-reviews>.container {
    padding-top: 2rem;
    padding-bottom: 3rem;
    padding-inline: 2rem;
}

/* Title */
.page--reviews .ics-reviews__title {
    font-size: 2rem;
    line-height: 1.1;
    letter-spacing: .3px;
    color: var(--ics-ink);
    text-shadow: 0 1px 0 rgba(255, 255, 255, .06);
    margin: 0 0 .85rem;
}

/* ---------- Filters: container + sticky ---------- */
.page--reviews .ics-filters {
    position: sticky;
    top: .5rem;
    z-index: 30;
    margin-block: .75rem 1rem;
}

.page--reviews .ics-filterbar {
    background: var(--ics-panel);
    border: 1px solid var(--ics-border);
    border-radius: 16px;
    box-shadow: var(--ics-shadow);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    overflow: hidden;
}

.page--reviews .ics-filterbar__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
        "search"
        "cat"
        "brand"
        "flavor";
    gap: .5rem;
    align-items: center;
    padding: .6rem .6rem .75rem .6rem;
}

/* Map fields to areas (IDs optional; class-based works too) */
.page--reviews .ics-filterbar__search {
    grid-area: search;
}

.page--reviews #cat {
    grid-area: cat;
}

.page--reviews #brand {
    grid-area: brand;
}

.page--reviews #flavor {
    grid-area: flavor;
}

/* ---------- Shared control styles ---------- */
.page--reviews .ics-filterbar__control,
.page--reviews .ics-filters input[type="search"],
.page--reviews .ics-filters select {
    width: 100%;
    height: 44px;
    border-radius: 12px;
    border: 1px solid var(--ics-border);
    background-color: rgba(20, 14, 9, .5);
    color: var(--ics-ink);
    font-size: .95rem;
    line-height: 1;
    padding: 0 14px;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .02);
    transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease, transform .08s ease;
}

.page--reviews .ics-filterbar__control::placeholder {
    color: #bfb6aa;
    opacity: .9;
}

.page--reviews .ics-filterbar__control:hover {
    background-color: rgba(20, 14, 9, .64);
    border-color: rgba(255, 255, 255, .22);
}

.page--reviews .ics-filterbar__control:focus,
.page--reviews .ics-filterbar__control:focus-visible {
    outline: none;
    border-color: var(--ics-focus);
    box-shadow: 0 0 0 4px rgba(255, 231, 180, .15), inset 0 0 0 1px rgba(255, 255, 255, .06);
}

/* Custom select caret (best-effort) */
.page--reviews select.ics-filterbar__control {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 42px;
    background-image:
        linear-gradient(to bottom, rgba(255, 255, 255, .06), rgba(255, 255, 255, 0)),
        url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.75 9l5.25 6 5.25-6' stroke='%23c9c1b7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat, no-repeat;
    background-position: left 0 top 0, right 14px center;
    background-size: auto, 18px 18px;
    cursor: pointer;
}

@media (prefers-color-scheme: light) {
    .page--reviews select.ics-filterbar__control option {
        color: #1e160f;
        background: #fffef9;
    }
}

/* Search icon as background (simpler, reliable) */
.page--reviews .ics-filterbar__search {
    padding-inline-start: 42px;
    background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21 21l-4.3-4.3M10.5 18a7.5 7.5 0 1 1 0-15 7.5 7.5 0 0 1 0 15Z' stroke='%23c9c1b7' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: 14px center;
    background-size: 18px 18px;
}

.page--reviews .ics-filterbar__search:focus {
    background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21 21l-4.3-4.3M10.5 18a7.5 7.5 0 1 1 0-15 7.5 7.5 0 0 1 0 15Z' stroke='rgba(201,193,183,0.35)' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");
}

/* Use background icon on the input; hide the separate icon span */
.page--reviews .ics-filterbar__icon {
    display: none;
}

/* SEARCH: icon + hover/focus animation on the input itself */
.page--reviews input[type="search"]#q,
.page--reviews .ics-filterbar__search {
    padding-inline-start: 42px;
    /* room for icon on the left */

    /* search icon */
    background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21 21l-4.3-4.3M10.5 18a7.5 7.5 0 1 1 0-15 7.5 7.5 0 0 1 0 15Z' stroke='%23c9c1b7' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: 14px center;
    background-size: 18px 18px;

    /* animation */
    transition: background-position 0.25s ease, background-size 0.25s ease;
}

.page--reviews input[type="search"]#q:hover,
.page--reviews .ics-filterbar__search:hover {
    background-size: 20px 20px;
    /* gentle pulse on hover */
}

.page--reviews input[type="search"]#q:focus,
.page--reviews .ics-filterbar__search:focus {
    background-position: 16px center;
    /* subtle nudge on focus */
    background-size: 18px 18px;
}

/* SELECTS: chevron + hover/focus glide */
.page--reviews select.ics-filterbar__control,
.page--reviews select#brand,
.page--reviews select#flavor,
.page--reviews select#cat {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;

    padding-right: 42px;

    background-image:
        linear-gradient(to bottom, rgba(255, 255, 255, .06), rgba(255, 255, 255, 0)),
        url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.75 9l5.25 6 5.25-6' stroke='%23c9c1b7' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat, no-repeat;
    background-position: left 0 top 0, right 14px center;
    /* gradient, chevron */
    background-size: auto, 18px 18px;

    transition: background-position 0.25s ease;
}

.page--reviews select.ics-filterbar__control:hover,
.page--reviews select#brand:hover,
.page--reviews select#flavor:hover,
.page--reviews select#cat:hover {
    background-position: left 0 top 0, right 10px center;
    /* chevron glides in */
}

.page--reviews select.ics-filterbar__control:focus,
.page--reviews select#brand:focus,
.page--reviews select#flavor:focus,
.page--reviews select#cat:focus {
    background-position: left 0 top 0, right 8px center;
    /* nudge on focus */
}

/* ---------- Responsive layout for the bar ---------- */
@media (min-width: 540px) {
    .page--reviews .ics-filterbar__inner {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
            "search search"
            "cat brand"
            "flavor flavor";
        gap: .6rem;
    }
}

@media (min-width: 768px) {
    .page--reviews .ics-filterbar__inner {
        grid-template-columns: 1.4fr .9fr .9fr .9fr;
        grid-template-areas: "search cat brand flavor";
        gap: .6rem;
        padding: .75rem .9rem;
    }
}

@media (min-width: 1024px) {
    .page--reviews .ics-filterbar {
        border-radius: 18px;
    }

    .page--reviews .ics-filterbar__control {
        height: 46px;
        font-size: 1rem;
    }
}

/* Micro-interactions + reduced motion */
.page--reviews .ics-filterbar__control:active {
    transform: translateY(1px);
}

@media (prefers-reduced-motion: reduce) {

    .page--reviews .ics-filterbar__control,
    .page--reviews .ics-filterbar,
    .page--reviews .ics-reviews__title {
        transition: none !important;
    }
}

/* ---------- Results meta ---------- */
.page--reviews .ics-results__meta {
    color: var(--ics-muted);
    font-size: .92rem;
    margin: .35rem .25rem 1rem;
    letter-spacing: .2px;
}

.page--reviews .ics-results__meta strong {
    color: var(--ics-accent);
    font-weight: 700;
}

/* ---------- Listing grid ---------- */
.page--reviews .ics-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .page--reviews .ics-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .page--reviews .ics-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ---------- Page-specific card refinements ---------- */
.page--reviews .ics-card {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    overflow: hidden;
    transition: transform .2s ease, box-shadow .25s ease, border-color .25s ease;
}

.page--reviews .ics-card:hover {
    transform: translateY(-3px);
    border-color: rgba(225, 178, 107, .3);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .25);
}

.page--reviews .ics-card__img {
    width: 100%;
    height: 300px;
    object-fit: cover;
    border-radius: 10px 10px 0 0;
    display: block;
}

.page--reviews .ics-card__body {
    padding: 1rem 1.1rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: .7rem;
}

.page--reviews .ics-card__title {
    font-size: 1.1rem;
    color: var(--ics-ink);
    font-weight: 600;
    letter-spacing: .2px;
}

.page--reviews .ics-card__excerpt {
    color: var(--ics-muted);
    line-height: 1.55;
    font-size: .9rem;
    margin-bottom: auto;
}

.page--reviews .ics-card__eyebrow {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--ics-accent);
    background: rgba(225, 178, 107, .10);
    border: 1px solid rgba(225, 178, 107, .25);
    padding: 4px 8px;
    border-radius: 6px;
    align-self: flex-start;
    font-weight: 500;
}

.page--reviews .ics-card__cta {
    margin-top: 1rem;
}

.page--reviews .ics-card__cta .ics-btn {
    display: inline-block;
    width: 100%;
    text-align: center;
    padding: 10px 14px;
    background: var(--ics-accent);
    color: var(--ics-accent-ink, #1d130c);
    border: none;
    border-radius: 8px;
    font-weight: 600;
    letter-spacing: .3px;
    transition: background-color .2s ease, transform .1s ease;
    box-shadow: 0 4px 10px rgba(225, 178, 107, .2);
}

.page--reviews .ics-card__cta .ics-btn:hover {
    background: #f2c87a;
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(225, 178, 107, .3);
}

.page--reviews .ics-card__cta .ics-btn:active {
    transform: translateY(0);
    box-shadow: 0 3px 8px rgba(225, 178, 107, .2);
}

/* Stars/meta row */
.page--reviews .ics-card__meta-row {
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: space-between;
    margin-top: 12px;
    padding-top: 10px;
}

.page--reviews .ics-card__author {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.page--reviews .ics-avatar {
    width: 24px;
    height: 24px;
    border-radius: 6px;
    object-fit: cover;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .12);
}

.page--reviews .ics-author__name {
    font-size: .85rem;
    color: var(--ics-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.page--reviews .ics-card__rating {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
}

.page--reviews .ics-stars {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    line-height: 0;
}

.page--reviews .star--full path {
    fill: var(--ics-accent);
}

.page--reviews .star--half .star__stroke {
    fill: none;
    stroke: var(--ics-accent);
    stroke-width: 1.2;
}

.page--reviews .star--empty path {
    fill: none;
    stroke: rgba(255, 255, 255, .4);
    stroke-width: 1.2;
}

.page--reviews .ics-rating__value {
    font-size: .85rem;
    color: var(--ics-muted);
}

/* Mobile tweaks */
@media (max-width: 640px) {

    .page--reviews .ics-card__title {
        font-size: 1rem;
    }

    .page--reviews .ics-card__cta .ics-btn {
        font-size: .9rem;
        padding: 9px 12px;
    }
}
