/* ====== SooWidget – Frontend Styles ====== */

:root {
    --soo-gap:       1.5rem;
    --soo-radius:    8px;
    --soo-shadow:    0 2px 8px rgba(0, 0, 0, .1);
    --soo-card-bg:   #fff;
    --soo-text:      #1d1d1d;
    --soo-muted:     #5c5c5c;
    --soo-price:     #1a6b38;
    --soo-accent:    #0073aa;
    --soo-border:    #dde1e7;
}

/* ---- Grid ---- */

.soo-grid {
    display: grid;
    gap: var(--soo-gap);
    list-style: none;
    margin: 0;
    padding: 0;
}
.soo-cols-1 { grid-template-columns: repeat(1, 1fr); }
.soo-cols-2 { grid-template-columns: repeat(2, 1fr); }
.soo-cols-3 { grid-template-columns: repeat(3, 1fr); }
.soo-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
    .soo-cols-4,
    .soo-cols-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
    .soo-cols-4,
    .soo-cols-3,
    .soo-cols-2 { grid-template-columns: 1fr; }
}

/* ---- Full Menu ---- */

.soo-menu { margin: 0; }

.soo-category { margin-bottom: 3rem; }
.soo-category:last-child { margin-bottom: 0; }

.soo-category__name {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 .75rem;
    color: var(--soo-text);
    border-bottom: 2px solid var(--soo-accent);
    padding-bottom: .4rem;
}

.soo-category__image {
    width: 100%;
    max-height: 220px;
    object-fit: cover;
    border-radius: var(--soo-radius);
    margin-bottom: 1rem;
    display: block;
}

.soo-category__desc {
    color: var(--soo-muted);
    margin: 0 0 1rem;
    font-size: .95rem;
    line-height: 1.6;
}

/* ---- Item Cards ---- */

.soo-item {
    background: var(--soo-card-bg);
    border-radius: var(--soo-radius);
    box-shadow: var(--soo-shadow);
    border: 1px solid var(--soo-border);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform .2s ease, box-shadow .2s ease;
}

.soo-item:hover,
.soo-item:focus-within {
    transform: translateY(-3px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, .14);
}

.soo-item__img-wrap {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    flex-shrink: 0;
}

.soo-item__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}

.soo-item:hover .soo-item__image { transform: scale(1.04); }

.soo-item__body {
    padding: 1rem 1.1rem 1.1rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.soo-item__name {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.4;
    margin: 0 0 .4rem;
    color: var(--soo-text);
}

.soo-item__desc {
    font-size: .875rem;
    color: var(--soo-muted);
    line-height: 1.55;
    margin: 0 0 .75rem;
    flex: 1;
}

.soo-item__price {
    font-size: 1rem;
    font-weight: 700;
    color: var(--soo-price);
    margin-top: auto;
}

/* ---- Category Cards ---- */

.soo-categories { margin: 0; }
.soo-categories ul {
    margin: 0;
    padding: 0;
}

.soo-category-card {
    border-radius: var(--soo-radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* Inner wrapper is the link or a plain div */
.soo-category-card__inner {
    display: flex;
    flex-direction: column;
    flex: 1;
    background: var(--soo-card-bg);
    box-shadow: var(--soo-shadow);
    border: 1px solid var(--soo-border);
    border-radius: var(--soo-radius);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform .2s ease, box-shadow .2s ease;
}

.soo-category-card__inner:hover,
.soo-category-card__inner:focus-visible {
    transform: translateY(-3px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, .14);
    text-decoration: none;
}

/* Linked card gets a subtle arrow indicator */
.soo-category-card--linked .soo-category-card__inner {
    cursor: pointer;
}

.soo-category-card__img-wrap {
    height: 180px;
    overflow: hidden;
    background: #f3f3f3;
    position: relative;
}

.soo-category-card__img-wrap--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    color: #ccc;
}

.soo-category-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}

.soo-category-card__inner:hover .soo-category-card__image { transform: scale(1.04); }

.soo-category-card__body {
    padding: 1rem 1.1rem 1.1rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.soo-category-card__name {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0 0 .4rem;
    color: var(--soo-text);
    line-height: 1.35;
}

.soo-category-card__desc {
    font-size: .875rem;
    color: var(--soo-muted);
    margin: 0 0 .5rem;
    flex: 1;
    line-height: 1.5;
}

.soo-category-card__count {
    font-size: .8rem;
    color: var(--soo-accent);
    font-weight: 500;
    margin-top: auto;
}

.soo-category-card__cta {
    display: block;
    font-size: .8rem;
    font-weight: 600;
    color: var(--soo-accent);
    margin-top: .5rem;
}

/* ---- Slider layout ---- */

.soo-slider-wrap {
    display: flex;
    align-items: stretch;
    gap: .5rem;
}

.soo-slider-viewport {
    overflow: hidden;
    flex: 1;
    min-width: 0;
}

.soo-slider-track {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--soo-gap);
    overflow-x: scroll;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -ms-overflow-style: none;
    list-style: none;
    margin: 0;
    padding: 0 2px 4px; /* subtle room for card shadows */
}

.soo-slider-track::-webkit-scrollbar { display: none; }

.soo-slider-track > li {
    flex: 0 0 calc(
        (100% - (var(--soo-slider-cols, 3) - 1) * var(--soo-gap)) / var(--soo-slider-cols, 3)
    );
    scroll-snap-align: start;
    min-width: 0;
}

.soo-slider-btn {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    background: var(--soo-card-bg);
    border: 1px solid var(--soo-border);
    border-radius: var(--soo-radius);
    color: var(--soo-accent);
    font-size: 1.6rem;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    transition: background .15s, color .15s, border-color .15s;
    align-self: center;
    min-height: 3rem;
}

.soo-slider-btn:hover,
.soo-slider-btn:focus-visible {
    background: var(--soo-accent);
    border-color: var(--soo-accent);
    color: #fff;
    outline: none;
}

.soo-slider-btn:disabled {
    opacity: .3;
    cursor: default;
    pointer-events: none;
}

@media (max-width: 560px) {
    .soo-slider-btn { width: 2rem; font-size: 1.25rem; }

    .soo-slider-track > li {
        flex-basis: calc(
            (100% - (var(--soo-slider-cols, 3) - 1) * var(--soo-gap)) /
            max(1, min(var(--soo-slider-cols, 3), 2))
        );
    }
}

/* ---- Back button ---- */

.soo-back-link {
    margin: 0 0 1.25rem;
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}

.soo-back-btn {
    display: inline-block;
    padding: .4rem .9rem;
    background: var(--soo-card-bg);
    border: 1px solid var(--soo-border);
    border-radius: var(--soo-radius);
    color: var(--soo-accent);
    font-size: .875rem;
    font-weight: 500;
    text-decoration: none;
    transition: background .15s, border-color .15s;
}

.soo-back-btn:hover,
.soo-back-btn:focus-visible {
    background: var(--soo-accent);
    border-color: var(--soo-accent);
    color: #fff;
    text-decoration: none;
}

.soo-active-cat {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--soo-text);
}

/* ---- States ---- */

.soo-error {
    color: #b00;
    background: #fff0f0;
    border: 1px solid #f5c6c6;
    padding: .875rem 1rem;
    border-radius: var(--soo-radius);
    font-size: .9rem;
}

.soo-empty {
    color: var(--soo-muted);
    font-style: italic;
    font-size: .95rem;
}

/* ---- Accessibility: focus rings ---- */

.soo-item:focus-within .soo-item__name,
.soo-category-card:focus-within .soo-category-card__name {
    text-decoration: underline;
}

@media (prefers-reduced-motion: reduce) {
    .soo-item,
    .soo-category-card,
    .soo-item__image,
    .soo-category-card__image {
        transition: none;
    }
}
