91³Ô¹ÏÍø

Watch CBS News

Miami Marlins opened the season with a 2-1 win over the Colorado Rockies

Javier Sanoja had three hits, Sandy Alcantara allowed one run over seven innings and the Miami Marlins opened the season with a 2-1 win over the Colorado Rockies on Friday night.

Alcantara (1-0) made his franchise-leading sixth start on opening day and struck out five, allowed four hits and walked two. It was a promising beginning to the season for the 2022 NL Cy Young award winner after a rollercoaster 2025 during which he went 11-13 with a 5.36 ERA while facing trade rumors.

Sanoja went 3-for-3 with a run-scoring single in the second.

The Marlins improved to 14-20 on opening day, while the Rockies fell to 17-17.

Alcantara allowed just one baserunner until the fourth inning, when Jake McCarthy hit a leadoff bunt single and stole second before being thrown out at home by right fielder Austin Slater on Hunter Goodman's single. Jordan Beck hit an RBI single later in the inning.

Miami opened the scoring in the second when designated hitter Owen Caissie hit a run-scoring double in his first at-bat with the Marlins, allowing Xavier Edwards to score from first. Caissie was a late addition to Friday's lineup after first baseman Chris Morel was scratched because of a strained oblique.

Pete Fairbanks pitched a scoreless ninth for the save in his Marlins debut. TJ Rumfield hit a one-out single to give the Rockies life before Fairbanks retired Beck on a popout and Brenton Doyle on a lineout.

In his fifth career opening day start — also a franchise-best — Rockies left-hander Kyle Freeland (0-1) gave up five hits and two runs while striking out two in 4 1/3 innings.

It was the third meeting on opening day for the teams, who were both expansion franchises in 1993. The Marlins and Rockies began the 2014 and 2019 seasons against each other in Miami.

Colorado RHP Michael Lorenzen (7-11, 4.64 ERA in 2025) will face Miami RHP Eury Pérez (7-6, 4.25 ERA in 2025) on Saturday.

View CBS News In
CBS News App Open
Chrome Safari Continue
const link = doc.createElement('link'); link.rel = 'stylesheet'; link.href = '/fly/fly/bundles/cbsnewscontent/css/cmp-banner.min.css?v=50747257b890e014813016b79ece0fb2'; doc.head.appendChild(link); doc.body.innerHTML = CONSENT_MESSAGE; } else { el.insertAdjacentHTML('afterend', CONSENT_MESSAGE); } }); } function hidePrivacyMessage() { // Remove from the main document document.querySelectorAll(`.${CONSENT_MESSAGE_CLASS}`).forEach(el => el.remove()); // Remove from inside any iframes document.querySelectorAll('iframe').forEach(iframe => { const doc = iframe.contentDocument || iframe.contentWindow.document; doc.querySelectorAll(`.${CONSENT_MESSAGE_CLASS}`).forEach(el => el.remove()); }); } function activateGatedScripts() { // Handle both new format (cmp-gated-script) and old OneTrust/Ketch format (optanon-category-4) const gatedScripts = Array.from(document.querySelectorAll('script.cmp-gated-script, script.optanon-category-4')); // Activate scripts sequentially with a small delay to avoid timing issues let delay = 0; gatedScripts.forEach(function(placeholder, index) { setTimeout(function() { // Skip if already processed if (placeholder.hasAttribute('data-cmp-processed')) { return; } placeholder.setAttribute('data-cmp-processed', 'true'); const newScript = document.createElement('script'); newScript.type = 'text/javascript'; // Try new format first (data-cmp-src), then fall back to old format (data-src) const src = placeholder.getAttribute('data-cmp-src') || placeholder.getAttribute('data-src'); if (src) { newScript.src = src; } else if (placeholder.textContent) { // Inline script - just copy the content newScript.textContent = placeholder.textContent; } // Handle new format attributes (data-cmp-attrs) - for both inline and external scripts const attrs = placeholder.getAttribute('data-cmp-attrs'); if (attrs) { const tempDiv = document.createElement('div'); tempDiv.innerHTML = '
<\/div>'; const tempAttrs = tempDiv.firstChild.attributes; for (let i = 0; i < tempAttrs.length; i++) { // For external scripts, allow defer/async. For inline scripts, skip them (not valid) if (src || (tempAttrs[i].name !== 'async' && tempAttrs[i].name !== 'defer')) { newScript.setAttribute(tempAttrs[i].name, tempAttrs[i].value); } } } // Copy other attributes from old OneTrust format for (let i = 0; i < placeholder.attributes.length; i++) { const attr = placeholder.attributes[i]; // Skip attributes we've already handled or don't want to copy if (!['class', 'data-src', 'data-type', 'data-cmp-src', 'data-cmp-attrs', 'data-cmp-processed', 'type', 'async', 'defer', 'src'].includes(attr.name)) { newScript.setAttribute(attr.name, attr.value); } } placeholder.parentNode.replaceChild(newScript, placeholder); // If external script, manually trigger window.onload handlers after it loads // This handles widgets that use window.onload for initialization if (src) { newScript.addEventListener('load', function() { // If page already loaded and script set a new onload handler, trigger it if (document.readyState === 'complete' && window.onload) { const originalOnload = window.onload; window.onload = null; // Clear temporarily to prevent loops originalOnload(); // Execute the handler } }); } }, delay); delay += 500; // 500ms delay between each script to allow full loading }); } cbsoptanon.onScriptsReady(function(cmp) { cmp.ot.targetingAllowed(function(allowed) { if (!allowed) { showPrivacyMessage(); } else { activateGatedScripts(); } }); cmp.ot.awaitInitialConsent(function(consent_model) { cmp.ot.addOnConsentChangedHandler(function() { cmp.ot.targetingAllowed(function(allowed) { if (allowed) { hidePrivacyMessage(); activateGatedScripts(); } else { showPrivacyMessage(); } }); }); }); });