.cp-wrapper {
    max-width: 960px;
    margin: 24px auto;
    font-family: inherit;
}

/* ── Buscador ── */
.cp-search-box {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
}

.cp-input {
    flex: 1;
    padding: 10px 16px;
    font-size: 1rem;
    border: 2px solid #e5e7eb;
    border-radius: 8px;
    outline: none;
    transition: border-color .2s;
}

.cp-input:focus {
    border-color: #c0392b;
}

.cp-btn {
    background: #c0392b;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 10px 24px;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s;
    white-space: nowrap;
}

.cp-btn:hover { background: #a93226; }
.cp-btn:disabled { opacity: .6; cursor: default; }

/* ── Status ── */
.cp-status {
    padding: 10px 14px;
    border-radius: 6px;
    margin-bottom: 16px;
    font-size: .9rem;
}

.cp-status.loading {
    background: #fef9c3;
    color: #854d0e;
    border: 1px solid #fde047;
}

.cp-status.error {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}

.cp-status.empty {
    background: #f3f4f6;
    color: #374151;
    border: 1px solid #d1d5db;
}

/* ── Tabla ── */
.cp-table-wrap {
    overflow-x: auto;
    border-radius: 10px;
    border: 1px solid #e5e7eb;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

.cp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
}

.cp-table thead tr {
    background: #c0392b;
    color: #fff;
}

.cp-table th {
    padding: 12px 14px;
    text-align: left;
    font-weight: 600;
    white-space: nowrap;
}

.cp-table td {
    padding: 10px 14px;
    border-bottom: 1px solid #f3f4f6;
    vertical-align: top;
}

.cp-table tbody tr:last-child td {
    border-bottom: none;
}

.cp-table tbody tr:hover {
    background: #fef2f2;
}

.cp-table tbody tr td[style*="color"] {
    color: #c0392b !important;
}

.cp-precio {
    font-weight: 800;
    color: #c0392b !important;
    white-space: nowrap;
}

.cp-oferta-badge {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    color: #1a1a2e;
    background: #f5c518;
    padding: 2px 7px;
    border-radius: 20px;
    white-space: nowrap;
    vertical-align: middle;
}

/* ── Badges sucursales ── */
.cp-sucursales {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.cp-badge {
    background: #d1fae5;
    color: #065f46;
    font-size: .75rem;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 20px;
    white-space: nowrap;
}

.cp-no-stock {
    color: #9ca3af;
    font-size: .85rem;
    font-style: italic;
}

/* ── Responsive ── */
@media (max-width: 600px) {
    .cp-search-box {
        flex-direction: column;
    }

    .cp-btn {
        width: 100%;
    }

    .cp-table th,
    .cp-table td {
        padding: 8px 10px;
        font-size: .8rem;
    }
}
