/* ============================================
   JAC Model Archive Styles (Optimised)
   Target: /models/ (archive-models.php)

   HERO SYSTEM V1 MIGRATION (Bundle P3):
   - Archive Models page now uses .jac-hero--utility from jac-components.css
   - Old .models-archive-hero styles removed
   - Canonical hero system provides all hero styling
   - Search form integrated within hero using .jac-hero__inner container
   ============================================ */

/* --- Wrapper for the archive page --- */
.jac-archive-models-wrap {
    position: relative;
    background-color: var(--jac-surface-soft);
}


/* ============================================
   SEARCH / FILTER FORM
   ============================================ */

/* --- Search Form Grid --- */
.models-archive-search-form {
    background: var(--jac-white);
    border: 1px solid var(--jac-border);
    border-radius: var(--space-12);
    padding: var(--space-16) var(--space-24);
    box-shadow:
        0 18px 30px var(--jac-ink-a08),
        0 1px var(--space-2) var(--jac-ink-a08);
    max-width: 880px;
}

.search-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 2fr;
    gap: var(--space-16);
    align-items: center;
}

.search-form-field--search .search-form-input-wrap {
    display: flex;
    align-items: stretch;
}

.search-form-field--search .search-form-input {
    border-radius: var(--space-8) 0 0 var(--space-8);
    border-right: none;
}

.search-form-field--search .search-form-submit {
    min-width: var(--btn-height);
    border-radius: 0 var(--btn-radius) var(--btn-radius) 0;
}

/* --- Form Inputs --- */
.search-form-select,
.search-form-input {
    width: 100%;
    height: var(--btn-height);
    padding: 0 var(--space-16);
    font-size: var(--space-16);
    color: var(--jac-graphite);
    background: var(--jac-surface-muted);
    border: 1px solid var(--jac-border);
    border-radius: var(--space-8);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E\");
    background-repeat: no-repeat;
    background-position: right var(--space-12) center;
    background-size: var(--space-16) var(--space-16);
}

.search-form-select:focus,
.search-form-input:focus {
    outline: none;
    border-color: var(--jac-red-a88);
    box-shadow: 0 0 0 1px var(--jac-red-a40);
}

/* Remove arrow for text input */
.search-form-input {
    background-image: none;
}

/* --- Search submit button --- */
.search-form-submit {
    width: 100%;
    min-width: var(--btn-height);
}

.search-form-submit .search-form-submit-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.search-form-submit .search-form-submit-icon svg {
    width: 20px;
    height: 20px;
}

/* ============================================
   MODELS GRID SECTION
   ============================================ */

.jac-models-grid-section {
    padding: var(--section-padding-y) 0; /* 4rem / 64px */
}

/* Inner constraint */
.jac-models-grid-inner {
    max-width: var(--page-max-width);
    margin: 0 auto;
    padding: 0 var(--section-padding-x);
}

/* Section heading */
.jac-models-grid-header {
    margin-bottom: var(--space-24);
}

.jac-models-grid-title {
    font-size: var(--font-size-h2); /* 2rem / 32px */
    font-weight: 700;
    margin: 0;
    color: var(--jac-black);
}

/* Models grid */
.jac-models-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-24);
}

/* ============================================
   MODEL CARD STYLES
   ============================================ */

.jac-model-card-v3 {
    background-color: var(--jac-white);
    border-radius: var(--space-12);
    overflow: hidden;
    border: 1px solid var(--jac-border);
    box-shadow: 0 10px 25px var(--jac-ink-a05);
    display: flex;
    flex-direction: column;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.jac-model-card-v3:hover {
    transform: translateY(-2px);
    border-color: var(--jac-red-a88);
    box-shadow: var(--shadow-card-hover);
}

/* Image - Support both naming conventions */
.jac-card-image-link,
.jac-card__image-wrap a {
    display: block;
}

.jac-card-image-wrap,
.jac-card__image-wrap {
    position: relative;
    padding-top: 56.25%; /* 16:9 aspect ratio - standardized for all cards */
    overflow: hidden;
    background-color: var(--jac-ink);
}

.jac-card-image-wrap img,
.jac-card-image,
.jac-card__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.jac-model-card-v3:hover .jac-card-image,
.jac-model-card-v3:hover .jac-card__image {
    transform: scale(1.03);
}

/* Image placeholder */
.jac-card__image--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--jac-surface-muted);
    color: var(--jac-grey-600);
    font-size: 14px;
}

/* Card Body - Support both naming conventions */
.jac-card-body,
.jac-card__body {
    padding: var(--space-24); /* 1.5rem / 24px - compact for archive cards */
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

/* Card Header */
.jac-card__header {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/* Model title - Support both naming conventions */
.jac-card-title,
.jac-card__title {
    font-size: 18px;
    font-weight: 700;
    margin: 0;
    color: var(--jac-ink);
}

.jac-card-title a,
.jac-card__title a {
    color: inherit;
    text-decoration: none;
}

.jac-card-title a:hover,
.jac-card__title a:hover {
    color: var(--jac-red-a88);
}

/* Tagline */
.jac-card__tagline {
    font-size: 14px;
    color: var(--jac-grey-600);
    margin: 0;
    line-height: 1.4;
}

/* Price - Support both naming conventions */
.jac-card-price,
.jac-card__price {
    font-size: 14px;
    color: var(--jac-grey-600);
    margin: var(--space-2) 0 var(--space-12);
}

/* Card actions - Support both naming conventions */
.jac-card-actions,
.jac-card__actions {
    margin-top: auto;
}

/* CTA Button */
.jac-card__cta {
    width: 100%;
}

/* COMPONENT PURITY FIX:
   Local .jac-btn override removed (lines 340-379).
   Now relying on canonical .jac-btn system from jac-components.css.
   Templates should use .jac-btn--primary, .jac-btn--ghost, .jac-btn--block as defined in canonical component layer.
*/

/* ============================================
   NO RESULTS STATE
   ============================================ */

.jac-models-no-results {
    background: var(--jac-white);
    border-radius: var(--space-12);
    padding: var(--space-32);
    border: 1px solid var(--jac-border);
    text-align: left;
    max-width: 520px;
}

.jac-models-no-results h2 {
    margin-top: 0;
    margin-bottom: var(--space-8);
    font-size: 22px;
    font-weight: 700;
    color: var(--jac-ink);
}

.jac-models-no-results p {
    margin: 0 0 var(--space-16);
    font-size: 15px;
    color: var(--jac-grey-600);
}

/* ============================================
   PAGINATION
   ============================================ */

.navigation.pagination {
    margin-top: var(--space-32);
    display: flex;
    justify-content: center;
}

.navigation.pagination .nav-links {
    display: inline-flex;
    gap: var(--space-4);
    align-items: center;
}

.navigation.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    font-size: 14px;
    border-radius: 999px;
    border: 1px solid transparent;
    text-decoration: none;
    padding: 0 var(--space-12);
    color: var(--jac-grey-600);
    background-color: var(--jac-surface-muted);
}

.navigation.pagination .page-numbers.current {
    background-color: var(--jac-red-a88);
    color: var(--jac-white);
    border-color: var(--jac-red-a88);
}

.navigation.pagination .page-numbers:hover:not(.current) {
    border-color: var(--jac-border-strong);
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 1024px) {
    .models-archive-search-form {
        max-width: 100%;
    }

    .search-form-grid {
        grid-template-columns: 1fr;
    }

    .jac-models-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .jac-models-grid {
        grid-template-columns: 1fr;
    }

    .jac-models-grid-section {
        padding-bottom: var(--space-64);
    }
}

/* Smallest screens / tightening */
@media (max-width: 480px) {
    .models-archive-search-form {
        padding: var(--space-12) var(--space-16);
    }

    .jac-card-body,
    .jac-card__body {
        padding: var(--space-16); /* 1rem / 16px - tighter on small screens */
    }

    .jac-card-title,
    .jac-card__title {
        font-size: var(--space-16);
    }

    .jac-card-price,
    .jac-card__price {
        font-size: 13px;
    }
}

/* ============================================
   MISC UTILITIES / OVERRIDES
   ============================================ */

/* Ensure archive header doesn’t render twice if theme prints title */
.archive .entry-header {
    display: none;
}

/* Basic reset for any default list styling inside cards */
.jac-model-card-v3 ul {
    margin: 0;
    padding-left: var(--space-24);
}

/* Hide any default Kadence card buttons if needed */
.kadence-blocks-pro-card-link-wrap .jac-model-card-v3 .jac-card-buttons {
    display: none;
}

@media (max-width: 640px) {
    .kadence-blocks-pro-card-link-wrap .jac-model-card-v3 .jac-card-buttons {
        display: none;
    }
}
