/* ============================================================
   JRZ Cars – Public Styles
   Compatible with any WordPress theme
   ============================================================ */

:root {
    --jrz-primary:   #1a1a2e;
    --jrz-secondary: #16213e;
    --jrz-accent:    #C8A96E;
    --jrz-accent-light: rgba(200,169,110,.12);
    --jrz-text:      #333;
    --jrz-text-muted:#666;
    --jrz-bg:        #fff;
    --jrz-bg-alt:    #f8f8f8;
    --jrz-border:    #e0e0e0;
    --jrz-radius:    8px;
    --jrz-shadow:    0 2px 12px rgba(0,0,0,.08);
    --jrz-shadow-hover: 0 6px 24px rgba(0,0,0,.14);
    --jrz-font:      inherit;
    --jrz-green:     #22c55e;
    --jrz-yellow:    #f59e0b;
    --jrz-red:       #ef4444;
    --jrz-blue:      #3b82f6;
}

/* ── Reset scoped ── */
.jrz-catalog-wrap *,
.jrz-single-wrap  *,
.jrz-card         * {
    box-sizing: border-box;
}

/* ============================================================
   CARD
   ============================================================ */
.jrz-card {
    background: var(--jrz-bg);
    border: 1px solid var(--jrz-border);
    border-radius: var(--jrz-radius);
    overflow: hidden;
    transition: box-shadow .2s, transform .2s;
    display: flex;
    flex-direction: column;
}
.jrz-card:hover {
    box-shadow: var(--jrz-shadow-hover);
    transform: translateY(-3px);
}

/* Card image */
.jrz-card-img-wrap {
    display: block;
    position: relative;
    overflow: hidden;
    aspect-ratio: 16/10;
    background: #f0f0f0;
}
.jrz-card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s;
}
.jrz-card:hover .jrz-card-img { transform: scale(1.04); }

/* Flags */
.jrz-card-flags { position:absolute; top:8px; left:8px; display:flex; flex-wrap:wrap; gap:4px; }
.jrz-flag {
    display: inline-block;
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.jrz-flag-destacado  { background: var(--jrz-accent); color: #fff; }
.jrz-flag-oferta     { background: #ef4444; color: #fff; }
.jrz-flag-nuevo      { background: #22c55e; color: #fff; }
.jrz-flag-exclusivo  { background: var(--jrz-primary); color: var(--jrz-accent); }

/* Status badge */
.jrz-card-status { position:absolute; top:8px; right:8px; }
.jrz-badge {
    display: inline-block;
    padding: 3px 8px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}
.jrz-badge-vendido      { background:#ef4444; color:#fff; }
.jrz-badge-reservado    { background:#f59e0b; color:#fff; }
.jrz-badge-transito     { background:#3b82f6; color:#fff; }
.jrz-badge-preparacion  { background:#8b5cf6; color:#fff; }
.jrz-badge-no-disponible{ background:#6b7280; color:#fff; }

/* DGT badge */
.jrz-card-dgt  { position:absolute; bottom:8px; right:8px; }
.jrz-dgt-badge {
    display: inline-block;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    font-size: 10px;
    font-weight: 800;
    text-align: center;
    line-height: 28px;
    border: 2px solid rgba(255,255,255,.8);
}

/* Card body */
.jrz-card-body {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 8px;
}
.jrz-card-title {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
    line-height: 1.3;
    color: var(--jrz-primary);
}
.jrz-card-title a { color: inherit; text-decoration: none; }
.jrz-card-title a:hover { color: var(--jrz-accent); }
.jrz-card-version {
    font-size: 12px;
    color: var(--jrz-text-muted);
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Specs row */
.jrz-card-specs {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px 10px;
}
.jrz-spec {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 12px;
    color: var(--jrz-text-muted);
}
.jrz-spec-icon { font-size: 13px; }

/* Card footer */
.jrz-card-footer {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 8px;
    margin-top: auto;
    padding-top: 10px;
    border-top: 1px solid var(--jrz-border);
}
.jrz-card-price { display: flex; flex-direction: column; }
.jrz-price-old  { font-size: 12px; color: #999; text-decoration: line-through; }
.jrz-price-main { font-size: 20px; font-weight: 800; color: var(--jrz-primary); line-height: 1.1; }
.jrz-price-desde { font-size: 12px; color: var(--jrz-accent); font-weight: 600; }
.jrz-price-iva   { font-size: 10px; color: #999; }
.jrz-price-consultar { font-size: 14px; font-weight: 600; color: var(--jrz-text-muted); }

/* ============================================================
   GRID
   ============================================================ */
.jrz-vehicles-grid {
    display: grid;
    gap: 20px;
}
.jrz-cols-2 { grid-template-columns: repeat(2, 1fr); }
.jrz-cols-3 { grid-template-columns: repeat(3, 1fr); }
.jrz-cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ============================================================
   FILTERS BAR
   ============================================================ */
.jrz-filters-bar {
    background: var(--jrz-bg-alt);
    border: 1px solid var(--jrz-border);
    border-radius: var(--jrz-radius);
    padding: 16px;
    margin-bottom: 24px;
}
.jrz-filters-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-end;
}
.jrz-filter-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 140px;
}
.jrz-filter-group label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--jrz-text-muted);
}
.jrz-filter-group select,
.jrz-filter-group input {
    border: 1px solid var(--jrz-border);
    border-radius: 5px;
    padding: 8px 10px;
    font-size: 13px;
    background: #fff;
    color: var(--jrz-text);
    width: 100%;
    transition: border-color .2s;
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23666' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 28px;
}
.jrz-filter-group input[type=number] {
    background-image: none;
    padding-right: 10px;
}
.jrz-filter-group select:focus,
.jrz-filter-group input:focus {
    outline: none;
    border-color: var(--jrz-accent);
    box-shadow: 0 0 0 3px var(--jrz-accent-light);
}
.jrz-filters-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--jrz-border);
}
.jrz-sort-wrap { display:flex; align-items:center; gap:8px; font-size:13px; }
.jrz-sort-wrap select { width:auto; min-width:180px; }
.jrz-results-count { font-size:13px; color:var(--jrz-text-muted); }
.jrz-count-num { font-weight:700; color:var(--jrz-primary); font-size:16px; }
.jrz-btn-reset {
    background: none;
    border: 1px solid var(--jrz-border);
    border-radius: 5px;
    padding: 6px 12px;
    font-size: 12px;
    color: var(--jrz-text-muted);
    cursor: pointer;
    transition: all .2s;
}
.jrz-btn-reset:hover { border-color: #ef4444; color: #ef4444; }

/* ============================================================
   BUTTONS
   ============================================================ */
.jrz-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 9px 18px;
    border-radius: 5px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: all .2s;
    border: none;
    white-space: nowrap;
}
.jrz-btn-primary {
    background: var(--jrz-accent);
    color: #fff;
}
.jrz-btn-primary:hover {
    background: var(--jrz-primary);
    color: var(--jrz-accent);
    text-decoration: none;
}
.jrz-btn-secondary {
    background: var(--jrz-primary);
    color: #fff;
}
.jrz-btn-secondary:hover {
    background: var(--jrz-secondary);
    color: var(--jrz-accent);
}
.jrz-btn-whatsapp {
    background: #25d366;
    color: #fff;
    font-size: 15px;
    padding: 12px 22px;
}
.jrz-btn-whatsapp:hover { background: #128c7e; color: #fff; text-decoration: none; }

/* ============================================================
   LOADING / SPINNER
   ============================================================ */
.jrz-grid-wrap    { position: relative; min-height: 100px; }
.jrz-loading-overlay {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.8);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    font-size: 14px;
    color: var(--jrz-text-muted);
    border-radius: var(--jrz-radius);
    z-index: 10;
}
.jrz-spinner {
    width: 36px; height: 36px;
    border: 3px solid var(--jrz-border);
    border-top-color: var(--jrz-accent);
    border-radius: 50%;
    animation: jrzSpin .7s linear infinite;
}
@keyframes jrzSpin { to { transform: rotate(360deg); } }

/* Load more */
.jrz-load-more-wrap { text-align: center; padding: 24px 0 0; }
.jrz-btn-load-more  { padding: 12px 32px; font-size: 14px; }
.jrz-no-results     { grid-column: 1/-1; text-align: center; padding: 48px; color: var(--jrz-text-muted); font-size: 16px; }

/* Pagination */
.jrz-pagination { display:flex; justify-content:center; margin-top:32px; }
.jrz-pagination .page-numbers { display:flex; list-style:none; margin:0; padding:0; gap:6px; }
.jrz-pagination .page-numbers li a,
.jrz-pagination .page-numbers li span {
    display: flex; align-items: center; justify-content: center;
    min-width: 36px; height: 36px; padding: 0 10px;
    border: 1px solid var(--jrz-border); border-radius: 5px;
    font-size: 13px; color: var(--jrz-text); text-decoration: none; transition: all .2s;
}
.jrz-pagination .page-numbers li .current,
.jrz-pagination .page-numbers li a:hover {
    background: var(--jrz-accent); border-color: var(--jrz-accent); color: #fff;
}

/* ============================================================
   SINGLE VEHICLE
   ============================================================ */
.jrz-single-wrap { max-width: 1200px; margin: 0 auto; padding: 24px 20px 48px; }

/* Breadcrumb */
.jrz-breadcrumb { font-size: 13px; color: #999; margin-bottom: 20px; }
.jrz-breadcrumb a { color: #999; text-decoration: none; }
.jrz-breadcrumb a:hover { color: var(--jrz-accent); }

/* Two-column layout */
.jrz-single-layout {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: 32px;
    align-items: start;
    margin-bottom: 48px;
}

/* Gallery */
.jrz-gallery-main {
    position: relative;
    border-radius: var(--jrz-radius);
    overflow: hidden;
    background: #f0f0f0;
    aspect-ratio: 16/10;
}
.jrz-gallery-hero { width:100%; height:100%; object-fit:cover; display:block; }
.jrz-gallery-badges { position:absolute; top:12px; left:12px; display:flex; flex-wrap:wrap; gap:6px; z-index:2; }
.jrz-gallery-dgt { position:absolute; bottom:12px; right:12px; z-index:2; }
.jrz-gallery-arrow {
    position: absolute; top:50%; transform:translateY(-50%);
    background: rgba(0,0,0,.45); color:#fff; border:none; border-radius:50%;
    width: 38px; height:38px; font-size:16px; cursor:pointer;
    display: flex; align-items:center; justify-content:center;
    transition: background .2s; z-index:3;
}
.jrz-gallery-prev { left:10px; }
.jrz-gallery-next { right:10px; }
.jrz-gallery-arrow:hover { background:var(--jrz-accent); }
.jrz-gallery-counter {
    position: absolute; bottom:10px; left:50%; transform:translateX(-50%);
    background: rgba(0,0,0,.5); color:#fff; padding:2px 10px;
    border-radius:12px; font-size:12px; z-index:3;
}
.jrz-gallery-thumbs {
    display: flex; gap:6px; margin-top:8px; overflow-x:auto;
    scrollbar-width:thin; padding-bottom:4px;
}
.jrz-thumb-btn {
    flex-shrink: 0; width:72px; height:54px; border-radius:4px; overflow:hidden;
    border: 2px solid transparent; cursor:pointer; padding:0; background:none;
    transition: border-color .2s;
}
.jrz-thumb-btn.active { border-color: var(--jrz-accent); }
.jrz-thumb-btn img   { width:100%; height:100%; object-fit:cover; display:block; }

/* Video */
.jrz-video-wrap, .jrz-tour-wrap { margin-top:16px; }
.jrz-section-h { font-size:14px; font-weight:700; color:var(--jrz-primary); margin:0 0 8px; }
.jrz-video-responsive { position:relative; padding-bottom:56.25%; height:0; }
.jrz-video-responsive iframe { position:absolute; inset:0; width:100%; height:100%; border-radius:6px; }

/* Right column */
.jrz-single-header { margin-bottom:16px; }
.jrz-single-make  { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--jrz-accent); }
.jrz-single-title { font-size:22px; font-weight:800; color:var(--jrz-primary); margin:4px 0 6px; line-height:1.3; }
.jrz-single-ref   { font-size:12px; color:#999; margin:0; }

/* Quick specs */
.jrz-quick-specs {
    list-style: none; margin:0 0 16px; padding:0;
    display: grid; grid-template-columns:1fr 1fr; gap:0;
    border: 1px solid var(--jrz-border); border-radius:var(--jrz-radius); overflow:hidden;
}
.jrz-qs-item {
    display: grid; grid-template-columns:24px 1fr 1fr;
    align-items: center; gap:6px; padding:8px 12px;
    font-size: 13px; border-bottom:1px solid var(--jrz-border);
    background: var(--jrz-bg);
}
.jrz-qs-item:nth-child(even) { background: var(--jrz-bg-alt); }
.jrz-qs-icon  { font-size:16px; text-align:center; }
.jrz-qs-label { color:var(--jrz-text-muted); font-size:12px; }
.jrz-qs-val   { font-weight:600; text-align:right; }

/* Price box */
.jrz-price-box {
    background: var(--jrz-bg-alt);
    border: 1px solid var(--jrz-border);
    border-radius: var(--jrz-radius);
    padding: 16px;
    margin-bottom: 16px;
}
.jrz-price-savings    { display:inline-block; background:#dcfce7; color:#166534; padding:2px 10px; border-radius:12px; font-size:12px; font-weight:600; margin-bottom:4px; }
.jrz-price-old-big    { font-size:16px; color:#999; text-decoration:line-through; }
.jrz-price-main-big   { font-size:32px; font-weight:800; color:var(--jrz-primary); line-height:1.1; }
.jrz-price-iva-note   { font-size:11px; color:#999; margin-top:2px; }
.jrz-price-consultar-big { font-size:20px; font-weight:700; color:var(--jrz-text-muted); }
.jrz-fin-teaser       { font-size:13px; color:var(--jrz-accent); margin-top:8px; border-top:1px solid var(--jrz-border); padding-top:8px; }
.jrz-fin-legal        { font-size:10px; color:#bbb; margin-top:4px; }

/* Contact buttons */
.jrz-contact-btns { display:flex; flex-direction:column; gap:10px; margin-bottom:12px; }
.jrz-contact-btns .jrz-btn { width:100%; }
.jrz-tel-note { text-align:center; font-size:14px; color:var(--jrz-text-muted); }
.jrz-tel-note a { color:var(--jrz-primary); text-decoration:none; font-weight:600; }

/* Contact form */
.jrz-contact-form {
    background: var(--jrz-bg-alt);
    border: 1px solid var(--jrz-border);
    border-radius: var(--jrz-radius);
    padding: 20px;
    margin-top: 12px;
}
.jrz-contact-form h4 { margin:0 0 14px; font-size:15px; color:var(--jrz-primary); }
.jrz-form-row    { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:10px; }
.jrz-input {
    width: 100%; padding: 9px 12px; border: 1px solid var(--jrz-border);
    border-radius: 5px; font-size: 13px; font-family: inherit;
    transition: border-color .2s; background: #fff;
}
.jrz-input:focus { outline:none; border-color:var(--jrz-accent); }
.jrz-textarea    { resize: vertical; }
.jrz-privacy-check { font-size: 12px; color: #777; display: flex; align-items: flex-start; gap: 6px; margin: 10px 0; cursor: pointer; }
.jrz-privacy-check input { margin-top: 2px; flex-shrink: 0; }
.jrz-privacy-check a { color: var(--jrz-accent); }
.jrz-submit-btn  { width: 100%; }
.jrz-form-msg    { padding: 10px 14px; border-radius: 5px; font-size: 13px; margin-top: 10px; }
.jrz-msg-ok  { background: #dcfce7; color: #166534; }
.jrz-msg-err { background: #fee2e2; color: #991b1b; }

/* ============================================================
   FULL SPECS & EQUIPMENT
   ============================================================ */
.jrz-full-specs-wrap,
.jrz-equipment-wrap,
.jrz-description-wrap,
.jrz-related-wrap { margin-top: 48px; }

.jrz-section-title {
    font-size: 22px; font-weight: 800; color: var(--jrz-primary);
    margin: 0 0 24px; padding-bottom: 12px;
    border-bottom: 2px solid var(--jrz-accent);
}
.jrz-specs-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}
.jrz-specs-group { background: var(--jrz-bg-alt); border-radius: var(--jrz-radius); overflow: hidden; }
.jrz-specs-group-title {
    background: var(--jrz-primary); color: var(--jrz-accent);
    font-size: 13px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .5px; padding: 10px 16px; margin: 0;
}
.jrz-specs-table { width: 100%; border-collapse: collapse; }
.jrz-specs-table tr:nth-child(even) td,
.jrz-specs-table tr:nth-child(even) th { background: rgba(0,0,0,.02); }
.jrz-specs-table th,
.jrz-specs-table td { padding: 8px 16px; font-size: 13px; text-align: left; border-bottom: 1px solid var(--jrz-border); }
.jrz-specs-table th { color: var(--jrz-text-muted); font-weight: 400; width: 50%; }
.jrz-specs-table td { font-weight: 600; color: var(--jrz-primary); }

/* Equipment list */
.jrz-equipment-list { display: flex; flex-wrap: wrap; gap: 8px; }
.jrz-equip-item {
    padding: 5px 12px; background: var(--jrz-bg-alt);
    border: 1px solid var(--jrz-border); border-radius: 20px;
    font-size: 13px; color: var(--jrz-text);
}
.jrz-equip-custom { font-size: 13px; color: var(--jrz-text-muted); margin-top: 12px; }

/* Archive */
.jrz-archive-wrap { max-width: 1200px; margin: 0 auto; padding: 24px 20px 48px; }
.jrz-archive-header { margin-bottom: 32px; }
.jrz-archive-title  { font-size: 28px; font-weight: 800; color: var(--jrz-primary); margin: 0; }

/* Catalog title */
.jrz-catalog-title { font-size: 22px; font-weight: 800; color: var(--jrz-primary); margin: 0 0 24px; }

/* Search form */
.jrz-search-form { background: var(--jrz-bg-alt); border-radius: var(--jrz-radius); padding: 20px; }
.jrz-sf-grid { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; margin-bottom: 12px; }
.jrz-sf-field { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 160px; }
.jrz-sf-field label { font-size: 11px; font-weight: 700; text-transform: uppercase; color: #666; }
.jrz-sf-field select, .jrz-sf-field input { padding: 9px 10px; border: 1px solid var(--jrz-border); border-radius: 5px; font-size: 13px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
    .jrz-cols-4 { grid-template-columns: repeat(3, 1fr); }
    .jrz-single-layout { grid-template-columns: 1fr 360px; }
}
@media (max-width: 900px) {
    .jrz-single-layout { grid-template-columns: 1fr; }
    .jrz-specs-grid { grid-template-columns: 1fr; }
    .jrz-cols-3, .jrz-cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .jrz-cols-2, .jrz-cols-3, .jrz-cols-4 { grid-template-columns: 1fr; }
    .jrz-filters-row { flex-direction: column; }
    .jrz-filter-group { min-width: 100%; }
    .jrz-quick-specs { grid-template-columns: 1fr; }
    .jrz-form-row { grid-template-columns: 1fr; }
    .jrz-filters-footer { flex-direction: column; align-items: stretch; }
    .jrz-single-wrap { padding: 16px 12px 32px; }
}
