/* AutoParts Showcase 2.1.4 – premium black catalog */

:root {
    --aps-color-bg: #050505;
    --aps-color-card-bg: #101010;
    --aps-color-image-bg: #181818;
    --aps-color-secondary: #f4bd3f;
    --aps-color-border: #292929;
    --aps-color-badge-text: #f4bd3f;
    --aps-color-title: #fff;
    --aps-color-body-text: #c8c8c8;
    --aps-color-icon: #f4bd3f;
    --aps-color-price: #fff;
    --aps-color-spec-label: #8d8d8d;
    --aps-color-spec-value: #f5f5f5;
    --aps-color-btn-bg: #f4bd3f;
    --aps-color-btn-text: #050505;
    --aps-color-btn-border: #f4bd3f;
    --aps-color-btn-hover-bg: #fff;
    --aps-color-btn-hover-text: #050505;
    --aps-color-detail-btn-bg: #151515;
    --aps-color-detail-btn-text: #fff;
    --aps-color-detail-btn-border: #3a3a3a;
    --aps-color-detail-hover-bg: #252525;
    --aps-color-detail-hover-text: #fff;
    --aps-color-whatsapp-bg: #25d366;
    --aps-color-whatsapp-text: #ffffff;
    --aps-color-whatsapp-border: #25d366;
    --aps-color-whatsapp-hover-bg: #1ebe5d;
    --aps-color-whatsapp-hover-text: #ffffff;
    --aps-card-border-width: 1px;
    --aps-card-border-style: solid;
    --aps-card-radius: 16px;
}

.aps-showcase,
.aps-showcase * { box-sizing: border-box; }

.aps-showcase {
    --aps-cols-desktop: 4;
    --aps-cols-tablet: 2;
    --aps-cols-mobile: 1;
    --aps-card-min: 245px;
    --aps-card-max: 290px;
    --aps-grid-max-desktop: 1232px;
    --aps-grid-max-tablet: 604px;
    --aps-grid-max-mobile: 290px;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 42px 16px;
    background: var(--aps-color-bg);
    color: var(--aps-color-body-text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.aps-no-parts {
    margin: 0;
    padding: 32px;
    color: var(--aps-color-body-text);
    background: var(--aps-color-bg);
    text-align: center;
}

.aps-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: 24px;
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
}

.aps-card {
    position: relative;
    display: flex;
    flex: 0 1 var(--aps-card-max);
    flex-direction: column;
    width: min(100%, var(--aps-card-max));
    max-width: var(--aps-card-max);
    min-width: 0;
    overflow: hidden;
    background: var(--aps-color-card-bg);
    border: var(--aps-card-border-width) var(--aps-card-border-style) var(--aps-color-border);
    border-radius: var(--aps-card-radius);
    box-shadow: 0 14px 34px rgba(0,0,0,.28);
    isolation: isolate;
    transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.aps-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 2px;
    z-index: 2;
    background: linear-gradient(90deg, transparent, var(--aps-color-secondary), transparent);
    opacity: 0;
    transition: opacity .24s ease;
}

.aps-card:hover {
    transform: translateY(-5px);
    border-color: var(--aps-color-secondary);
    box-shadow: 0 22px 48px rgba(0,0,0,.48);
}

.aps-card:hover::before { opacity: 1; }

.aps-card-image {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--aps-color-image-bg);
}

.aps-product-image,
.aps-modal-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.aps-product-image { transition: transform .45s ease; }
.aps-card:hover .aps-product-image { transform: scale(1.045); }

.aps-no-image {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    width: 100%;
    height: 100%;
    padding: 24px;
    color: color-mix(in srgb, var(--aps-color-body-text) 45%, transparent);
    text-align: center;
    font-size: 12px;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.aps-no-image svg { width: 52px; height: 52px; }

.aps-card-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    padding: 20px;
}

.aps-part-title {
    margin: 0;
    color: var(--aps-color-title);
    font-size: clamp(18px, 1.6vw, 22px);
    font-weight: 750;
    letter-spacing: -.025em;
    line-height: 1.22;
}

.aps-part-price,
.aps-modal-price {
    margin-top: 10px;
    color: var(--aps-color-price);
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -.02em;
}

.aps-card-features {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
    margin: 16px 0 18px;
}

.aps-card-feature {
    min-width: 0;
    min-height: 58px;
    padding: 9px 10px;
    border: 1px solid var(--aps-color-border);
    border-radius: 9px;
    background: color-mix(in srgb, var(--aps-color-image-bg) 74%, transparent);
}

.aps-card-feature span,
.aps-card-feature strong {
    display: block;
}

.aps-card-feature span {
    margin-bottom: 4px;
    color: var(--aps-color-spec-label);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: .08em;
    line-height: 1.2;
    text-transform: uppercase;
}

.aps-card-feature strong {
    display: -webkit-box;
    overflow: hidden;
    color: var(--aps-color-spec-value);
    font-size: 11px;
    font-weight: 700;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

/* Generic specification styling is retained for the View Details modal. */
.aps-spec-icon {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    color: var(--aps-color-icon);
}

.aps-spec-icon svg {
    width: 100%;
    height: 100%;
    stroke: currentColor;
}

.aps-card-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: auto;
    padding-top: 2px;
}

.aps-card-actions > :only-child { grid-column: 1 / -1; }

.aps-btn-details,
.aps-btn-purchase {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 13px;
    border-radius: 9px;
    font-family: inherit;
    font-size: 12px;
    font-weight: 750;
    line-height: 1.2;
    text-align: center;
    text-decoration: none !important;
    cursor: pointer;
    transition: transform .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}

.aps-btn-details {
    border: 1px solid var(--aps-color-detail-btn-border);
    background: var(--aps-color-detail-btn-bg);
    color: var(--aps-color-detail-btn-text);
}

.aps-btn-details:hover,
.aps-btn-details:focus-visible {
    border-color: var(--aps-color-secondary);
    background: var(--aps-color-detail-hover-bg);
    color: var(--aps-color-detail-hover-text);
}

.aps-btn-purchase {
    border: 1px solid var(--aps-color-btn-border);
    background: var(--aps-color-btn-bg);
    color: var(--aps-color-btn-text);
}

.aps-btn-purchase:hover,
.aps-btn-purchase:focus-visible {
    border-color: var(--aps-color-btn-hover-bg);
    background: var(--aps-color-btn-hover-bg);
    color: var(--aps-color-btn-hover-text);
}

.aps-btn-details:hover,
.aps-btn-purchase:hover { transform: translateY(-1px); }

.aps-btn-details:focus-visible,
.aps-btn-purchase:focus-visible,
.aps-modal-close:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--aps-color-secondary) 45%, transparent);
    outline-offset: 2px;
}

/* Details modal */
body.aps-modal-open { overflow: hidden; }

.aps-modal[hidden] { display: none !important; }

.aps-modal {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: grid;
    place-items: center;
    padding: 22px;
}

.aps-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.82);
    backdrop-filter: blur(7px);
}

.aps-modal-panel {
    position: relative;
    z-index: 1;
    width: min(1040px, 100%);
    max-height: calc(100vh - 44px);
    overflow: auto;
    color: var(--aps-color-body-text);
    background: var(--aps-color-card-bg);
    border: var(--aps-card-border-width) var(--aps-card-border-style) var(--aps-color-border);
    border-radius: var(--aps-card-radius);
    box-shadow: 0 34px 100px rgba(0,0,0,.72);
    animation: aps-modal-in .2s ease both;
}

@keyframes aps-modal-in {
    from { opacity: 0; transform: translateY(10px) scale(.985); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

.aps-modal-close {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 4;
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    padding: 0;
    border: 1px solid var(--aps-color-detail-btn-border);
    border-radius: 50%;
    color: var(--aps-color-title);
    background: rgba(10,10,10,.82);
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
}

.aps-modal-layout {
    display: grid;
    grid-template-columns: minmax(300px, .9fr) minmax(0, 1.1fr);
}

.aps-modal-media {
    min-height: 100%;
    aspect-ratio: 1 / 1;
    background: var(--aps-color-image-bg);
}

.aps-modal-no-image { min-height: 420px; }

.aps-modal-content { padding: 42px 38px 38px; }

.aps-modal-content h2 {
    margin: 8px 0 0;
    color: var(--aps-color-title);
    font-size: clamp(25px, 3vw, 38px);
    letter-spacing: -.035em;
    line-height: 1.12;
}

.aps-modal-price { font-size: 25px; }

.aps-detail-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 24px 0 0;
}

.aps-detail-list > div {
    padding: 12px 14px;
    border: 1px solid var(--aps-color-border);
    border-radius: 10px;
    background: color-mix(in srgb, var(--aps-color-image-bg) 72%, transparent);
}

.aps-detail-list dt {
    margin-bottom: 4px;
    color: var(--aps-color-spec-label);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.aps-detail-list dd {
    margin: 0;
    color: var(--aps-color-spec-value);
    font-size: 13px;
    font-weight: 650;
    word-break: break-word;
}

.aps-modal-description {
    margin-top: 24px;
    color: var(--aps-color-body-text);
    font-size: 14px;
    line-height: 1.75;
}

.aps-modal-description > :first-child { margin-top: 0; }
.aps-modal-description > :last-child { margin-bottom: 0; }

.aps-modal-specs { margin-top: 26px; }

.aps-modal-specs h3 {
    margin: 0 0 12px;
    color: var(--aps-color-title);
    font-size: 15px;
    letter-spacing: .01em;
}

.aps-modal-spec-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.aps-modal-spec {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--aps-color-border);
    border-radius: 10px;
}

.aps-modal-spec .aps-spec-icon { width: 19px; height: 19px; }
.aps-modal-spec span:last-child { min-width: 0; }
.aps-modal-spec small,
.aps-modal-spec strong { display: block; }
.aps-modal-spec small { color: var(--aps-color-spec-label); font-size: 10px; }
.aps-modal-spec strong { overflow: hidden; color: var(--aps-color-spec-value); font-size: 13px; text-overflow: ellipsis; }

.aps-modal-purchase {
    width: 100%;
    min-height: 50px;
    margin-top: 28px;
    font-size: 14px;
}

/* Automatic category archives */
.aps-taxonomy-page {
    min-height: 60vh;
    background: var(--aps-color-bg);
}

.aps-taxonomy-header {
    max-width: 100%;
    margin: 0 auto;
    padding: 64px 24px 6px;
    color: var(--aps-color-body-text);
}

.aps-taxonomy-kicker {
    color: var(--aps-color-secondary);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.aps-taxonomy-header h1 {
    margin: 8px 0 0;
    color: var(--aps-color-title);
    font-size: clamp(34px, 6vw, 62px);
    letter-spacing: -.045em;
    line-height: 1.05;
}

.aps-taxonomy-description { max-width: 720px; margin-top: 16px; line-height: 1.7; }

@media (max-width: 1024px) {
    .aps-grid { max-width: 100%; }
    .aps-modal-layout { grid-template-columns: 1fr 1fr; }
    .aps-modal-content { padding: 36px 30px 32px; }
}

@media (max-width: 720px) {
    .aps-showcase { padding: 24px 6px; }
    .aps-grid {
        gap: 14px;
        max-width: 100%;
        padding: 0;
    }
    .aps-card {
        flex: 0 0 100%;
        width: 100%;
        max-width: 520px;
        justify-self: center;
    }
    .aps-modal { padding: 10px; }
    .aps-modal-panel { max-height: calc(100vh - 20px); }
    .aps-modal-layout { display: block; }
    .aps-modal-media { min-height: 0; }
    .aps-modal-no-image { min-height: 300px; }
    .aps-modal-content { padding: 28px 20px 24px; }
    .aps-detail-list,
    .aps-modal-spec-grid { grid-template-columns: 1fr; }
    .aps-taxonomy-header { padding: 44px 16px 2px; }
}

@media (max-width: 440px) {
    .aps-card-actions { grid-template-columns: 1fr; }
    .aps-card-actions > * { grid-column: 1 / -1; }
    .aps-card-features { grid-template-columns: 1fr; }
}

/* Frontend catalog filters */
.aps-filter-panel {
    width: 100%;
    max-width: 100%;
    margin: 0 auto 26px;
    padding: 18px;
    background: color-mix(in srgb, var(--aps-color-card-bg) 92%, #fff 2%);
    border: var(--aps-card-border-width) var(--aps-card-border-style) var(--aps-color-border);
    border-radius: var(--aps-card-radius);
    box-shadow: 0 14px 36px rgba(0,0,0,.22);
}

.aps-filter-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 15px;
}

.aps-filter-kicker {
    display: block;
    margin-bottom: 3px;
    color: var(--aps-color-secondary);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.aps-filter-heading h2 {
    margin: 0;
    color: var(--aps-color-title);
    font-size: 20px;
    line-height: 1.2;
}

.aps-results-count {
    flex: 0 0 auto;
    color: var(--aps-color-spec-label);
    font-size: 12px;
    font-weight: 650;
}

.aps-filter-grid {
    display: grid;
    grid-template-columns: minmax(220px, 1.35fr) repeat(3, minmax(150px, .8fr)) auto;
    gap: 11px;
    align-items: end;
}

.aps-filter-field {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.aps-filter-field > span {
    color: var(--aps-color-spec-label);
    font-size: 10px;
    font-weight: 750;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.aps-filter-field input,
.aps-filter-field select {
    width: 100%;
    min-height: 44px;
    margin: 0;
    padding: 10px 12px;
    border: 1px solid var(--aps-color-border);
    border-radius: 9px;
    outline: none;
    color: var(--aps-color-title);
    background: var(--aps-color-image-bg);
    font-family: inherit;
    font-size: 13px;
    box-shadow: none;
}

.aps-filter-field select {
    cursor: pointer;
    color-scheme: dark;
}

/* Native select menus may open on a light system panel. Explicit colors prevent
   brand, part type, and condition labels from appearing blank/invisible. */
.aps-filter-field select option,
.aps-filter-field select optgroup {
    color: #111111;
    background: #ffffff;
}

.aps-filter-field input::placeholder {
    color: color-mix(in srgb, var(--aps-color-body-text) 55%, transparent);
}

.aps-filter-field input:focus,
.aps-filter-field select:focus {
    border-color: var(--aps-color-secondary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--aps-color-secondary) 16%, transparent);
}

.aps-filter-reset {
    min-height: 44px;
    padding: 10px 17px;
    border: 1px solid var(--aps-color-secondary);
    border-radius: 9px;
    color: var(--aps-color-secondary);
    background: color-mix(in srgb, var(--aps-color-secondary) 8%, transparent);
    font-family: inherit;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
    transition: background-color .18s ease, color .18s ease, transform .18s ease;
}

.aps-filter-reset:hover,
.aps-filter-reset:focus-visible {
    color: var(--aps-color-btn-text);
    background: var(--aps-color-secondary);
    transform: translateY(-1px);
}

.aps-condition-badge {
    position: absolute;
    top: 13px;
    left: 13px;
    z-index: 2;
    max-width: calc(100% - 26px);
    overflow: hidden;
    padding: 6px 9px;
    border: 1px solid color-mix(in srgb, var(--aps-color-secondary) 45%, transparent);
    border-radius: 999px;
    color: var(--aps-color-secondary);
    background: rgba(0,0,0,.72);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: .06em;
    line-height: 1.2;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
    backdrop-filter: blur(6px);
}

.aps-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 13px;
}

.aps-card-tags:empty { display: none; }

.aps-card-tags span {
    max-width: 100%;
    overflow: hidden;
    padding: 6px 8px;
    border: 1px solid var(--aps-color-border);
    border-radius: 7px;
    color: var(--aps-color-body-text);
    background: color-mix(in srgb, var(--aps-color-image-bg) 82%, transparent);
    font-size: 10px;
    font-weight: 650;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* View Details first, WhatsApp directly underneath */
.aps-card-actions {
    grid-template-columns: 1fr;
    gap: 9px;
}

.aps-card-actions > * {
    grid-column: 1 / -1;
    width: 100%;
}

.aps-btn-whatsapp {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 10px 13px;
    border: 1px solid var(--aps-color-whatsapp-border);
    border-radius: 9px;
    color: var(--aps-color-whatsapp-text);
    background: var(--aps-color-whatsapp-bg);
    font-family: inherit;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
    text-decoration: none !important;
    cursor: pointer;
    transition: transform .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}

.aps-btn-whatsapp:hover,
.aps-btn-whatsapp:focus-visible {
    border-color: var(--aps-color-whatsapp-hover-bg);
    color: var(--aps-color-whatsapp-hover-text);
    background: var(--aps-color-whatsapp-hover-bg);
    transform: translateY(-1px);
}

.aps-btn-whatsapp:focus-visible,
.aps-filter-reset:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--aps-color-whatsapp-bg) 28%, transparent);
    outline-offset: 2px;
}

.aps-whatsapp-icon {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
}

.aps-modal-actions {
    display: grid;
    gap: 10px;
    margin-top: 28px;
}

.aps-modal-whatsapp,
.aps-modal-purchase {
    width: 100%;
    min-height: 50px;
    margin-top: 0;
    font-size: 14px;
}

.aps-card[hidden] { display: none !important; }

.aps-filter-empty {
    flex: 0 0 100%;
    grid-column: 1 / -1;
    width: min(680px, 100%);
    margin: 10px auto 0;
    padding: 42px 24px;
    border: 1px dashed var(--aps-color-border);
    border-radius: var(--aps-card-radius);
    color: var(--aps-color-body-text);
    background: var(--aps-color-card-bg);
    text-align: center;
}

.aps-filter-empty[hidden] { display: none !important; }
.aps-filter-empty strong,
.aps-filter-empty span { display: block; }
.aps-filter-empty strong { color: var(--aps-color-title); font-size: 18px; }
.aps-filter-empty span { margin-top: 6px; color: var(--aps-color-spec-label); font-size: 13px; }

@media (max-width: 1100px) {
    .aps-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .aps-filter-search { grid-column: 1 / -1; }
    .aps-filter-reset { width: 100%; }
}

@media (max-width: 640px) {
    .aps-filter-panel { padding: 15px; }
    .aps-filter-heading { align-items: flex-start; flex-direction: column; gap: 7px; }
    .aps-filter-grid { grid-template-columns: 1fr; }
    .aps-filter-search { grid-column: auto; }
}
